3 List of upstream coreboot maintainers
4 and how to submit coreboot changes
6 This represents the list of maintainers that work on the upstream coreboot
7 code base (on coreboot.org). Maintainers are assigned to topics and when
8 applicable to subtrees of the source tree. You'll find some subtrees that
9 don't have a maintainer. If you are looking for reviewers for such a sub-
10 tree, it's often a good choice to look at the git history to see who worked
13 Please try to follow the guidelines below. This will make things
14 easier on the maintainers. Not all of these guidelines matter for every
15 trivial patch so apply some common sense.
17 1. Always _test_ your changes, however small, on at least 1 or
18 2 people, preferably many more.
20 2. Try to release a few ALPHA test versions to gerrit. Announce
21 them onto the coreboot mailing list and IRC channel and await
22 results. This is especially important on coreboot core changes,
23 but also for device drivers, because often that's the only way
24 you will find things like the fact revision 3 chipset needs
25 a magic fix you didn't know about, or some clown changed the
26 chips on a board and not its name. (Don't laugh!)
28 3. Make sure your changes compile correctly in multiple
29 configurations. In particular check that changes work for all
30 boards in the tree (use abuild!)
32 4. When you are happy with a change make it generally available for
33 testing in gerrit and await feedback.
35 5. Make your patch available through coreboot's gerrit code review
36 system, and add the relevant maintainer from this list as a code
37 reviewer. Be prepared to get your changes sent back with seemingly
38 silly requests about formatting and variable names. These aren't
39 as silly as they seem. One job the maintainers do is to keep
40 things looking the same. Sometimes this means that the clever
41 hack in your mainboard or chipset to get around a problem actually
42 needs to become a generalized coreboot feature ready for next time.
44 PLEASE check your patch with the automated style checker
45 (util/lint/checkpatch.pl) to catch trival style violations.
46 See https://www.coreboot.org/Coding_Style for guidance here.
48 PLEASE add the maintainers that are generated by
49 util/scripts/get_maintainer.pl as reviewers. The results returned
50 by the script will be best if you have git installed and are
51 making your changes in a branch derived from coreboot.org's latest
54 PLEASE try to include any credit lines you want added with the
55 patch. It avoids people being missed off by mistake and makes
56 it easier to know who wants adding and who doesn't.
58 PLEASE document known bugs. If it doesn't work for everything
59 or does something very odd once a month document it.
61 PLEASE remember that submissions must be made under the terms
62 of the OSDL certificate of contribution and should include a
63 Signed-off-by: line. The current version of this "Developer's
64 Certificate of Origin" (DCO) is listed at
65 https://www.coreboot.org/Development_Guidelines#Sign-off_Procedure.
67 6. Make sure you have the right to send any changes you make. If you
68 do changes at work you may find your employer owns the patch
73 Descriptions of section entries:
75 M: Maintainer: FullName <address@domain>
76 Must be registered to Gerrit (https://review.coreboot.org/).
77 Should have experience with upstream coreboot development.
78 R: Designated reviewer: FullName <address@domain>
79 These reviewers should be CCed on patches.
80 L: Mailing list that is relevant to this area
81 W: Web-page with status/info
82 Q: Patchwork web based patch tracking system site
83 T: SCM tree type and location.
84 Type is one of: git, hg, quilt, stgit, topgit
85 S: Status, one of the following:
86 Supported: Someone is continuously paid to look after this and
87 a reaction to review requests can be expected
88 within a few days, a month at most.
89 Maintained: Someone actually looks after it and a reaction to
90 review requests can usually be expected within a
92 Odd Fixes: It has a maintainer but they don't have time to do
93 much other than throw the odd patch in. See below..
94 Orphan: No current maintainer [but maybe you could take the
95 role as you write your new code].
96 Obsolete: Old code. Something tagged obsolete generally means
97 it has been replaced by a better system and you
99 F: Files and directories with wildcard patterns.
100 A trailing slash includes all files and subdirectory files.
101 F: drivers/net/ all files in and below drivers/net
102 F: drivers/net/* all files in drivers/net, but not below
103 F: */net/* all files in "any top level directory"/net
104 One pattern per line. Multiple F: lines acceptable.
105 N: Files and directories with regex patterns.
106 N: [^a-z]tegra all files whose path contains the word tegra
107 One pattern per line. Multiple N: lines acceptable.
108 scripts/get_maintainer.pl has different behavior for files that
109 match F: pattern and matches of N: patterns. By default,
110 get_maintainer will not look at git log history when an F: pattern
111 match occurs. When an N: match occurs, git log history is used
112 to also notify the people that have git commit signatures.
113 X: Files and directories that are NOT maintained, same rules as F:
114 Files exclusions are tested before file matches.
115 Can be useful for excluding a specific subdirectory, for instance:
118 matches all files in and below net excluding net/ipv6/
119 K: Keyword perl extended regex pattern to match content in a
120 patch or file. For instance:
122 matches patches or files that contain "of_get_profile"
123 K: \b(printk|pr_(info|err))\b
124 matches patches or files that contain one or more of the words
125 printk, pr_info or pr_err
126 One regex pattern per line. Multiple K: lines acceptable.
128 Note: For the hard of thinking, this list is meant to remain in alphabetical
129 order. If you could add yourselves to it in alphabetical order that would be
132 Maintainers List (try to look for most precise areas first)
134 -----------------------------------
137 M: Ronald Minnich <rminnich@gmail.com>
138 R: Philipp Hug <philipp@hug.cx>
143 F: src/mainboard/emulation/*-riscv/
144 F: src/mainboard/sifive/
148 M: Ronald Minnich <rminnich@gmail.com>
149 M: Timothy Pearson <tpearson@raptorengineeringinc.com>
152 F: src/cpu/qemu-power8/
153 F: src/mainboard/emulation/qemu-power8/
156 M: Alexander Couzens <lynxis@fe80.eu>
161 M: Alexander Couzens <lynxis@fe80.eu>
162 M: Patrick Rudolph <siro@das-labor.org>
164 F: src/mainboard/lenovo/
167 M: Evgeny Zinoviev <me@ch1p.io>
169 F: src/mainboard/apple/
172 M: Patrick Georgi <patrick@georgi.software>
174 F: src/mainboard/getac/p470
176 INTEL PINEVIEW CHIPSET
177 M: Damien Zammit <damien@zamaudio.com>
179 F: src/northbridge/intel/pineview/
181 INTEL D510MO MAINBOARD
182 M: Damien Zammit <damien@zamaudio.com>
184 F: src/mainboard/intel/d510mo
187 M: Damien Zammit <damien@zamaudio.com>
189 F: src/northbridge/intel/x4x/
191 GIGABYTE GA-G41M-ES2L MAINBOARD
192 M: Damien Zammit <damien@zamaudio.com>
194 F: src/mainboard/gigabyte/ga-g41m-es2l
196 GIGABYTE GA-H61M-S2PV MAINBOARD
197 M: Angel Pons <th3fanbus@gmail.com>
199 F: src/mainboard/gigabyte/ga-h61m-s2pv
201 GOOGLE PANTHER MAINBOARD
202 M: Stefan Reinauer <stefan.reinauer@coreboot.org>
204 F: src/mainboard/google/panther/
206 GOOGLE MAINBOARDS (Intel-based, legacy/inactive)
207 M: Matt DeVillier <MrChromebox@gmail.com>
209 F: src/mainboard/google/auron/
210 F: src/mainboard/google/beltino/
211 F: src/mainboard/google/butterfly/
212 F: src/mainboard/google/cyan/
213 F: src/mainboard/google/glados/
214 F: src/mainboard/google/jecht/
215 F: src/mainboard/google/link/
216 F: src/mainboard/google/parrot/
217 F: src/mainboard/google/slippy/
218 F: src/mainboard/google/stout/
220 OPENCELLULAR MAINBOARDS
221 M: Philipp Deppenwiese <zaolin.daisuki@gmail.com>
222 M: Patrick Rudolph <patrick.rudolph@9elements.com>
224 F: src/mainboard/opencellular/elgon/
227 M: Matt DeVillier <matt.devillier@puri.sm>
229 F: src/mainboard/purism
231 SAMSUNG CHROMEOS MAINBOARDS
232 M: Matt DeVillier <MrChromebox@gmail.com>
234 F: src/mainboard/samsung/lumpy/
235 F: src/mainboard/samsung/stumpy/
237 INTEL FSP DENVERTON-NS SOC & HARCUVAR CRB
238 M: Vanessa Eusebio <vanessa.f.eusebio@intel.com>
239 M: David Guckian <david.guckian@intel.com>
241 F: src/mainboard/intel/harcuvar/
242 F: src/soc/intel/denverton_ns/
243 F: src/vendorcode/intel/fsp/fsp2_0/denverton_ns/
246 M: Lee Leahy <leroy.p.leahy@intel.com>
247 M: Huang Jin <huang.jin@intel.com>
248 M: York Yang <york.yang@intel.com>
250 F: src/drivers/intel/fsp1_1/
253 M: Andrey Petrov <andrey.petrov@gmail.com>
255 F: src/drivers/intel/fsp2_0/
257 INTEL STRAGO MAINBOARD
258 M: Hannah Williams <hannah.williams@intel.com>
260 F: /src/mainboard/intel/strago/
263 M: Piotr Król <piotr.krol@3mdeb.com>
264 M: Michał Żygowski <michal.zygowski@3mdeb.com>
265 M: Frans Hendriks <fhendriks@eltan.com>
267 F: /src/soc/intel/braswell
268 F: /src/vendorcode/intel/fsp/fsp1_1/braswell
271 M: Andrey Petrov <andrey.petrov@gmail.com>
273 F: src/soc/intel/apollolake/
275 ASROCK G41C-GS MAINBOARD & VARIANTS
276 M: Angel Pons <th3fanbus@gmail.com>
278 F: src/mainboard/asrock/g41c-gs/
280 ASROCK H81M-HDS MAINBOARD
281 M: Tristan Corrick <tristan@corrick.kiwi>
283 F: src/mainboard/asrock/h81m-hds/
285 ASUS MAXIMUS IV GENE-Z MAINBOARD
286 M: Tristan Corrick <tristan@corrick.kiwi>
288 F: src/mainboard/asus/maximus_iv_gene-z/
290 ASUS P5QC PRO MAINBOARD & VARIANTS
291 M: Angel Pons <th3fanbus@gmail.com>
293 F: src/mainboard/asus/p5qc/
295 ASUS P8H61-M LX MAINBOARD
296 M: Tristan Corrick <tristan@corrick.kiwi>
298 F: src/mainboard/asus/p8h61-m_lx/
300 ASUS P8H61-M PRO MAINBOARD
301 M: Angel Pons <th3fanbus@gmail.com>
303 F: src/mainboard/asus/p8h61-m_pro/
305 ASUS P8Z77-M PRO MAINBOARD
306 M: Vlado Cibic <vladocb@protonmail.com>
308 F: src/mainboard/asus/p8z77-m_pro/
310 PC ENGINES ALL MAINBOARDS
311 M: Piotr Król <piotr.krol@3mdeb.com>
312 M: Michał Żygowski <michal.zygowski@3mdeb.com>
314 F: src/mainboard/pcengines/
316 SIEMENS MC_xxxx MAINBOARDS
317 M: Werner Zeh <werner.zeh@siemens.com>
319 F: src/mainboard/siemens/mc_apl1/
321 SUPERMICRO X10SLM+-F MAINBOARD
322 M: Tristan Corrick <tristan@corrick.kiwi>
324 F: src/mainboard/supermicro/x10slm-f/
326 SUPERMICRO X11-LGA1151-SERIES
327 M: Michael Niewöhner <foss@mniewoehner.de>
329 F: src/mainboard/supermicro/x11-lga1151-series
331 FACEBOOK FBG1701 MAINBOARD
332 M: Frans Hendriks <fhendriks@eltan.com>
333 M: Wim Vervoorn <wvervoorn@eltan.com>
335 F: src/mainboard/facebook/fbg1701/
337 PORTWELL PQ-M107 MAINBOARD
338 M: Frans Hendriks <fhendriks@eltan.com>
339 M: Wim Vervoorn <wvervoorn@eltan.com>
341 F: src/mainboard/portwell/m107/
343 ASPEED AST2050 DRIVER & COMMON CODE
344 M: Timothy Pearson <tpearson@raptorengineeringinc.com>
346 F: src/drivers/aspeed/common/
347 F: src/drivers/aspeed/ast2050/
351 F: src/drivers/ati/mach64/
354 M: Patrick Georgi <patrick@georgi-clan.de>
355 M: Martin Roth <gaumless@gmail.com>
361 F: src/arch/x86/acpi/
365 M: Julius Werner <jwerner@chromium.org>
367 F: src/commonlib/lz4*
368 F: payloads/libpayload/liblz4/
369 F: util/cbfstool/lz4/
372 M: Julius Werner <jwerner@chromium.org>
384 F: src/cpu/allwinner/
390 F: util/arm_boot_tools/
399 F: src/include/cpu/x86/
402 M: Patrick Rudolph <siro@das-labor.org>
404 F: src/vendorcode/intel/
406 F: src/northbridge/intel/
407 F: src/southbridge/intel/
409 F: src/drivers/intel/
410 F: src/include/cpu/intel/
413 F: src/vendorcode/amd/
415 F: src/northbridge/amd/
416 F: src/southbridge/amd/
417 F: src/include/cpu/amd/
420 M: Patrick Georgi <patrick@georgi-clan.de>
421 M: Martin Roth <gaumless@gmail.com>
426 M: Stefan Reinauer <stefan.reinauer@coreboot.org>
430 M: Philipp Deppenwiese <zaolin.daisuki@gmail.com>
434 M: Nicola Corna <nicola@corna.info>
435 W: https://github.com/corna/me_cleaner
440 M: Stefan Reinauer <stefan.reinauer@coreboot.org>
444 M: Patrick Georgi <patrick@georgi-clan.de>
445 M: Martin Roth <gaumless@gmail.com>
449 F: src/include/kconfig.h
456 F: util/board_status/
463 F: src/vendorcode/google/chromeos/
465 F: src/include/tpm_lite/
469 F: src/include/device/
470 F: src/include/cpu/cpu.h
472 OPTION ROM EXECUTION & X86EMU
476 F: src/include/cbfs.h
477 F: src/include/cbfs_serialized.h
481 F: src/include/cbmem.h
482 F: src/include/cbmem_id.h
487 F: src/include/console/
493 F: payloads/nvramcui/
496 F: payloads/libpayload/
502 F: payloads/coreinfo/
504 EXTERNAL PAYLOADS INTEGRATION
505 M: Stefan Reinauer <stefan.reinauer@coreboot.org>
506 M: Martin Roth <gaumless@gmail.com>
509 LINUXBOOT PAYLOAD INTEGRATION
510 M: Philipp Deppenwiese <zaolin.daisuki@gmail.com>
511 M: Marcello Sylvester Bauer <info@marcellobauer.com>
513 F: payloads/external/LinuxBoot
516 M: Aaron Durbin <adurbin@chromium.org>
517 F: src/security/vboot/
520 M: Philipp Deppenwiese <zaolin.daisuki@gmail.com>
522 F: src/drivers/*/tpm/
523 F: src/security/vboot/vboot_crtm.*
527 M: Martin Roth <gaumless@gmail.com>
538 SUPERIOS & SUPERIOTOOL
539 M: Felix Held <felix-coreboot@felixheld.de>
545 M: Julius Werner <jwerner@chromium.org>
551 M: Frans Hendriks <fhendriks@eltan.com>
552 M: Wim Vervoorn <wvervoorn@eltan.com>
554 F: src/vendorcode/eltan
556 MISSING: TIMERS / DELAYS
566 MISSING: DMP / QEMU-X86
572 # *** Infrastructure Owners***
573 # This is intended to let people know who they should contact for issues with various infrastructure pieces.
575 # Owners: Stefan, Patrick
579 # Owners: Stefan, Patrick
583 # Owners: Martin, Philipp
584 # Backups: Patrick, Stefan
586 # Documentation Website
587 # Owners: Patrick, Philipp
591 M: Stefan Reinauer <stefan.reinauer@coreboot.org>
592 M: Patrick Georgi <patrick@coreboot.org>
593 M: Ronald Minnich <rminnich@coreboot.org>
594 M: Martin Roth <martin@coreboot.org>
596 F: Documentation/community/code_of_conduct.md
599 # Owners: Stefan, Patrick
603 # Owners: Stefan, Patrick
607 # Owners: Patrick, Martin
615 # Owners: Stefan, Patrick
618 # Software Freedom Conservancy
619 # Main contact: Martin
620 # “Official” contact: Stefan