Compare commits
55 Commits
system76-4
...
kudu6
Author | SHA1 | Date | |
---|---|---|---|
|
45fcc5bb6c | ||
|
ceb6908a78 | ||
|
1bcce6f204 | ||
|
b3563572f2 | ||
|
cd0254dfc4 | ||
|
86033d34b3 | ||
|
7dd9a8837e | ||
|
ee392ba10b | ||
|
6a26d0da0a | ||
|
1165fa9e03 | ||
|
83424ce3c8 | ||
|
1cfef49b64 | ||
|
3502c82019 | ||
|
19e85a3a21 | ||
|
b734f0fed0 | ||
|
d33dcc7a45 | ||
|
67a59cb124 | ||
|
bfa4225fdf | ||
|
137b12aee4 | ||
|
1957255f5e | ||
|
7e0a708cf9 | ||
|
fbd1e7305b | ||
|
334f6f944e | ||
|
63367e4b13 | ||
|
f0b04c0874 | ||
|
880501405b | ||
|
8482a83d1d | ||
|
cf0a4fcc67 | ||
|
4d2a48330e | ||
|
7e4221e335 | ||
|
c419da8394 | ||
|
90ac4fe952 | ||
|
2479c7c784 | ||
|
dfbcfaa533 | ||
|
6e9ec53576 | ||
|
c24f2ed615 | ||
|
b5cdcb1094 | ||
|
19e658a279 | ||
|
f1a67f8924 | ||
|
85b2e0d8f1 | ||
|
149f6cb1c2 | ||
|
4b657deaa1 | ||
|
afcfa1c1a9 | ||
|
872c49bc5e | ||
|
36c44fb448 | ||
|
7bcc106226 | ||
|
4cb1593c16 | ||
|
0d96fb33b9 | ||
|
f14f41e814 | ||
|
0e0b593e2a | ||
|
98513ad676 | ||
|
c111e46659 | ||
|
98b27e93ff | ||
|
fd7e5f888b | ||
|
9c1f72a500 |
@@ -22,7 +22,6 @@
|
|||||||
--ignore PRINTK_WITHOUT_KERN_LEVEL
|
--ignore PRINTK_WITHOUT_KERN_LEVEL
|
||||||
--ignore ASSIGN_IN_IF
|
--ignore ASSIGN_IN_IF
|
||||||
--ignore UNNECESSARY_ELSE
|
--ignore UNNECESSARY_ELSE
|
||||||
--ignore GERRIT_CHANGE_ID
|
|
||||||
|
|
||||||
# FILE_PATH_CHANGES seems to not be working correctly. It will
|
# FILE_PATH_CHANGES seems to not be working correctly. It will
|
||||||
# choke on added / deleted files even if the MAINTAINERS file
|
# choke on added / deleted files even if the MAINTAINERS file
|
||||||
|
1
.gitmodules
vendored
1
.gitmodules
vendored
@@ -48,7 +48,6 @@
|
|||||||
path = 3rdparty/cmocka
|
path = 3rdparty/cmocka
|
||||||
url = https://review.coreboot.org/cmocka.git
|
url = https://review.coreboot.org/cmocka.git
|
||||||
update = none
|
update = none
|
||||||
branch = stable-1.1
|
|
||||||
[submodule "3rdparty/qc_blobs"]
|
[submodule "3rdparty/qc_blobs"]
|
||||||
path = 3rdparty/qc_blobs
|
path = 3rdparty/qc_blobs
|
||||||
url = https://review.coreboot.org/qc_blobs.git
|
url = https://review.coreboot.org/qc_blobs.git
|
||||||
|
425
.mailmap
425
.mailmap
@@ -1,425 +0,0 @@
|
|||||||
# Map author and committer names and email addresses to canonical real names and
|
|
||||||
# email addresses. https://git-scm.com/docs/gitmailmap
|
|
||||||
#
|
|
||||||
# Note that this is only needed in the case where someone has contributed
|
|
||||||
# with multiple different email addresses or Names.
|
|
||||||
#
|
|
||||||
# Forms: Proper Name <commit@email.xx>
|
|
||||||
# Proper Name <proper@email.xx> <commit@email.xx>
|
|
||||||
# Proper Name <proper@email.xx> Commit Name <commit@email.xx>
|
|
||||||
|
|
||||||
|
|
||||||
Aamir Bohra <aamirbohra@gmail.com> <aamir.bohra@intel.com>
|
|
||||||
Aaron Durbin <adurbin@chromium.org>
|
|
||||||
Aaron Durbin <adurbin@chromium.org> <adurbin@adurbin.bld.corp.google.com>
|
|
||||||
Aaron Durbin <adurbin@chromium.org> <adurbin@google.com>
|
|
||||||
Abhay Kumar <abhay.kumar@intel.com>
|
|
||||||
Abhinav Hardikar <realdevmaster64@gmail.com> devmaster64 <devmaster64@gmail.com>
|
|
||||||
Alex Levin <levinale@google.com> <levinale@chromium.org>
|
|
||||||
Alex Miao <alex.miao@mediatek.corp-partner.google.com>
|
|
||||||
Alexandru Gagniuc <mr.nuke.me@gmail.com> <alexandrux.gagniuc@intel.com>
|
|
||||||
Alexandru Gagniuc <mr.nuke.me@gmail.com> mrnuke <mrnuke@nukelap.gtech>
|
|
||||||
Amanda Huang <amanda_hwang@compal.corp-partner.google.com>
|
|
||||||
Amol N Sukerkar <amol.n.sukerkar@intel.com>
|
|
||||||
Andrea Barberio <barberio@fb.com> <insomniac@slackware.it>
|
|
||||||
Andrey Petrov <anpetrov@fb.com> <andrey.petrov@intel.com>
|
|
||||||
Andrey Pronin <apronin@chromium.org> <apronin@google.com>
|
|
||||||
Andriy Gapon <avg@FreeBSD.org> <avg@icyb.net.ua>
|
|
||||||
Anil Kumar <anil.kumar.k@intel.com> <anil.kumar.k@intel.corp-partner.google.com>
|
|
||||||
Anish K. Patel <anishp@win-ent.com>
|
|
||||||
Anton Kochkov <anton.kochkov@gmail.com> <a.kochkov@securitycode.ru>
|
|
||||||
Antonello Dettori <dev@dettori.io> <dettori.an@gmail.com>
|
|
||||||
Ariel Fang <ariel_fang@wistron.corp-partner.google.com>
|
|
||||||
Arne Georg Gleditsch <arne.gleditsch@numascale.com> <arne.gleditsch@numscale.com>
|
|
||||||
Asami Doi <d0iasm.pub@gmail.com> <doiasami1219@gmail.com>
|
|
||||||
Ashwin Kumar <ashk@codeaurora.org>
|
|
||||||
Axel Holewa <mono@posteo.de> Mono <mono-for-coreboot@donderklumpen.de>
|
|
||||||
Axel Holewa <mono@posteo.de> Mono <mono@posteo.de>
|
|
||||||
Bao Zheng <fishbaozi@gmail.com>
|
|
||||||
Bao Zheng <fishbaozi@gmail.com> <Zheng Bao zheng.bao@amd.com>
|
|
||||||
Bao Zheng <fishbaozi@gmail.com> <zheng.bao@amd.com>
|
|
||||||
Bayi Cheng <bayi.cheng@mediatek.com>
|
|
||||||
Ben Zhang <benzh@google.com> <benzh@chromium.org>
|
|
||||||
Bernhard M. Wiedermann <corebootbmw@lsmod.de>
|
|
||||||
Bill Xie <persmule@hardenedlinux.org> <persmule@gmail.com>
|
|
||||||
Bill Xie <persmule@hardenedlinux.org> Bill XIE <persmule@hardenedlinux.org>
|
|
||||||
Bingxun Shi <bingxunshi@gmail.com>
|
|
||||||
Bingxun Shi <bingxunshi@gmail.com> <bxshi@msik.com.cn>
|
|
||||||
Brandon Breitenstein <brandon.breitenstein@intel.com> <brandon.breitenstein@intel.corp-partner.google.com>
|
|
||||||
Bruce Griffith <bruce.griffith@se-eng.com> <Bruce.Griffith@se-eng.com>
|
|
||||||
Bryant Ou <Bryant.Ou.Q@gmail.com>
|
|
||||||
Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net> <Carl-Daniel Hailfinger>
|
|
||||||
Casper Chang<casper_chang@wistron.corp-partner.google.com> <casper.chang@bitland.corp-partner.google.com>
|
|
||||||
Caveh Jalali <caveh@chromium.org> <caveh@google.com>
|
|
||||||
Caveh Jalali <caveh@chromium.org> caveh jalali <caveh@chromium.org>
|
|
||||||
Charles Marslett <charles@scarlettechnologies.com> <charles.marslett@silverbackltd.com>
|
|
||||||
Chee Soon Lew <chee.soon.lew@intel.com>
|
|
||||||
Cheng-Yi Chiang <cychiang@chromium.org> <cychiang@google.com>
|
|
||||||
Chris Ching <chris@ching.codes> <chingcodes@chromium.org>
|
|
||||||
Chris Ching <chris@ching.codes> <chingcodes@google.com>
|
|
||||||
Chris Wang <chris.wang@amd-corp-partner.google.com> <chriswang@ami.corp-partner.google.com>
|
|
||||||
Chris Wang <chris.wang@amd-corp-partner.google.com> Chris Wang <chris.wang@amd-corp-partner.google.com>
|
|
||||||
Chris Wang <chris.wang@amd-corp-partner.google.com> chris wang <chris.wang@amd.corp-partner.google.com>
|
|
||||||
Chris Wang <chris.wang@amd-corp-partner.google.com> Chris.Wang <chris.wang@amd.corp-partner.google.com>
|
|
||||||
Chris Zhou <chris_zhou@compal.corp-partner.google.com>
|
|
||||||
Christian Ruppert <idl0r@qasl.de> <idl0r@gentoo.org>
|
|
||||||
Chun-Jie Chen <chun-jie.chen@mediatek.corp-partner.google.com>
|
|
||||||
Clay Daniels Jr <clay.daniels.jr@gmail.com>
|
|
||||||
Cole Nelson<colex.nelson@intel.com>
|
|
||||||
Corey Osgood <corey.osgod@gmail.com> <corey_osgood@verizon.net>
|
|
||||||
Corey Osgood <corey.osgod@gmail.com> <corey.osgood@gmail.com>
|
|
||||||
Cristian Măgherușan-Stanciu <cristi.magherusan@gmail.com>
|
|
||||||
Cristian Măgherușan-Stanciu <cristi.magherusan@gmail.com> Cristi Magherusan <cristi.magherusan@net.utcluj.ro>
|
|
||||||
Da Lao <dalao@tutanota.com> dalao <dalao@tutanota.com>
|
|
||||||
Daisuke Nojiri <dnojiri@chromium.org> dnojiri <dnojiri@chromium.org>
|
|
||||||
Dan Elkouby <streetwalkermc@gmail.com> <streetwalrus@codewalr.us>
|
|
||||||
Daphne Jansen <dcjansen@chromium.org> Justin TerAvest <teravest@chromium.org>
|
|
||||||
Daphne Jansen <dcjansen@chromium.org> Justin TerAvest <teravest@google.com>
|
|
||||||
Dave Parker <dparker@chromium.org>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> <david.hendricks@gmail.com>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> <dhendricks@fb.com>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> <dhendrix@chromium.org>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> <dhendrix@fb.com>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> <dhendrix@google.com>
|
|
||||||
David Hendricks <davidhendricks@gmail.com> David W. Hendricks <dwh@lanl.gov>
|
|
||||||
David Wu <david_wu@quantatw.com> <david_wu@quanta.corp-partner.google.com>
|
|
||||||
David Wu <david_wu@quantatw.com> david <david_wu@quantatw.com>
|
|
||||||
Dawei Chien <dawei.chien@mediatek.com>
|
|
||||||
Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org> <GNUtoo@no-log.org>
|
|
||||||
Derek Huang <derek.huang@intel.com> <derek.huang@intel.corp-partner.google.com>
|
|
||||||
Dmitry Ponamorev <dponamorev@gmail.com>
|
|
||||||
Douglas Anderson <dianders@chromium.org>
|
|
||||||
Duncan Laurie <dlaurie@chromium.org> <dlaurie@google.com>
|
|
||||||
Ed Swierk <eswierk@aristanetworks.com> <eswierk@arastra.com>
|
|
||||||
Edward O'Callaghan <quasisec@google.com> <edward.ocallaghan@koparo.com>
|
|
||||||
Edward O'Callaghan <quasisec@google.com> <eocallaghan@alterapraxis.com>
|
|
||||||
Edward O'Callaghan <quasisec@google.com> <funfunctor@folklore1984.net>
|
|
||||||
Edward O'Callaghan <quasisec@google.com> <quasisec@chromium.org>
|
|
||||||
Eric Biederman <ebiederm@xmission.com> <ebiederman@lnxi.com>
|
|
||||||
Eric Biederman <ebiederm@xmission.com> Eric W. Biederman <ebiederm@xmission.com>
|
|
||||||
Eugene Myers <edmyers@tycho.nsa.gov> <cedarhouse@comcast.net>
|
|
||||||
Evgeny Zinoviev <me@ch1p.io> <me@ch1p.com>
|
|
||||||
Felix Durairaj <felixx.durairaj@intel.com>
|
|
||||||
Felix Held <felix-coreboot@felixheld.de> <felix-github@felixheld.de>
|
|
||||||
Felix Held <felix-coreboot@felixheld.de> <felix.held@amd.corp-partner.google.com>
|
|
||||||
Felix Singer <felixsinger@posteo.net> <felix.singer@9elements.com>
|
|
||||||
Felix Singer <felixsinger@posteo.net> <felix.singer@secunet.com>
|
|
||||||
Felix Singer <felixsinger@posteo.net> <migy@darmstadt.ccc.de>
|
|
||||||
Francois Toguo Fotso <francois.toguo.fotso@intel.com> Francois Toguo <francois.toguo.fotso@intel.com>
|
|
||||||
Frank Chu <frank_chu@pegatron.corp-partner.google.com>
|
|
||||||
Frank Chu <frank_chu@pegatron.corp-partner.google.com> Frank Chu <Frank_Chu@pegatron.corp-partner.google.com>
|
|
||||||
Frank Chu <frank_chu@pegatron.corp-partner.google.com> FrankChu <Frank_Chu@pegatron.corp-partner.google.com>
|
|
||||||
Frank Vibrans <efdesign98@gmail.com> efdesign98 <efdesign98@gmail.com>
|
|
||||||
Frank Vibrans <efdesign98@gmail.com> Frank Vibrans <frank.vibrans@amd.com>
|
|
||||||
Frank Vibrans <efdesign98@gmail.com> frank vibrans <frank.vibrans@scarletltd.com>
|
|
||||||
Frank Vibrans <efdesign98@gmail.com> Frank Vibrans <frank.vibrans@se-eng.com>
|
|
||||||
Frank Vibrans <efdesign98@gmail.com> Frank.Vibrans <frank.vibrans@amd.com>
|
|
||||||
Furquan Shaikh <furquan@chromium.org> <furquan@google.com>
|
|
||||||
G. Pangao <gtk_pangao@mediatek.com> <gtk_pangao@mediatek.corp-partner.google.com>
|
|
||||||
Gabe Black <gabeblack@chromium.org> <gabeblack@chromium.com>
|
|
||||||
Gabe Black <gabeblack@chromium.org> <gabeblack@google.com>
|
|
||||||
Gaggery Tsai <gaggery.tsai@intel.com>
|
|
||||||
Georg Wicherski <gwicherski@gmail.com> <gw@oxff.net>
|
|
||||||
Gomathi Kumar <gomathi.kumar@intel.com>
|
|
||||||
Greg V <greg@unrelenting.technology>
|
|
||||||
Greg Watson <gwatson@lanl.gov> <jarrah@users.sourceforge.net>
|
|
||||||
Hannah Williams <hannah.williams@dell.com> <hannah.williams@intel.com>
|
|
||||||
Hao Chou <hao_chou@pegatron.corp-partner.google.com>
|
|
||||||
Haridhar Kalvala <haridhar.kalvala@intel.com> haridhar <haridhar.kalvala@intel.com>
|
|
||||||
Harsha Priya <harshapriya.n@intel.com>
|
|
||||||
Harsha Priya <harshapriya.n@intel.com> <harhapriya.n@intel.com>
|
|
||||||
Harshit Sharma <harshitsharmajs@gmail.com> harshit <harshitsharmajs@gmail.com>
|
|
||||||
Henry C Chen <henryc.chen@mediatek.com> henryc.chen <henryc.chen@mediatek.com>
|
|
||||||
Himanshu Sahdev <sahdev.himan@gmail.com> <himanshusah@hcl.com>
|
|
||||||
Himanshu Sahdev <sahdev.himan@gmail.com> Himanshu Sahdev aka CunningLearner <sahdev.himan@gmail.com>
|
|
||||||
Hsuan Ting Chen <roccochen@chromium.org> Hsuan-ting Chen <roccochen@google.com>
|
|
||||||
Huang Lin <hl@rock-chips.com>
|
|
||||||
Huayang Duan <huayang.duan@mediatek.com>
|
|
||||||
Huki Huang <huki.huang@intel.com>
|
|
||||||
Idwer Vollering <vidwer@gmail.com> <idwer_v@hotmail.com>
|
|
||||||
Igor Bagnucki <bagnucki02@gmail.com> <igor.bagnucki@3mdeb.com>
|
|
||||||
Indrek Kruusa <indrek.kruusa@artecdesign.ee> <Indrek Kruusa>
|
|
||||||
Ivy Jian <ivy_jian@compal.com> <ivy_jian@compal.corp-partner.google.com>
|
|
||||||
Jacob Laska <jlaska91@gmail.com> <jlaska@xes-inc.com>
|
|
||||||
Jakub Czapiga <jacz@semihalf.com>
|
|
||||||
Jason Wang <Qingpei.Wang@amd.com> Jason WangQingpei.wang <Jason WangQingpei.wang@amd.com>
|
|
||||||
JasonX Z Chen <jasonx.z.chen@intel.com>
|
|
||||||
Jens Kühnel <coreboot@jens.kuehnel.org> Jens Kuehnel <coreboot@jens.kuehnel.org>
|
|
||||||
Jens Rottmann <JRottmann@LiPPERTembedded.de> <JRottmann@LiPPERTEmbedded.de>
|
|
||||||
Jeremy Compostella <jeremy.compostella@intel.com> <jeremy.compostella@gmail.com>
|
|
||||||
Jeremy Soller <jackpot51@gmail.com> <jeremy@system76.com>
|
|
||||||
Jiaxin Yu <jiaxin.yu@mediatek.com>
|
|
||||||
Jiazi Yang <Tomato_Yang@asus.com>
|
|
||||||
Jim Lai <jim.lai@intel.com>
|
|
||||||
Jingle Hsu <jingle_hsu@wiwynn.com>
|
|
||||||
Jinkun Hong <jinkun.hong@rock-chips.com>
|
|
||||||
Joe Moore <awokd@danwin1210.me>
|
|
||||||
Joe Pillow <joseph.a.pillow@gmail.com>
|
|
||||||
Johanna Schander <coreboot@mimoja.de>
|
|
||||||
John Zhao <john.zhao@intel.com>
|
|
||||||
Jonathan Kollasch <jakllsch@kollasch.net>
|
|
||||||
Jordan Crouse <jordan@cosmicpenguin.net> <Jordan Crouse>
|
|
||||||
Jordan Crouse <jordan@cosmicpenguin.net> <jordan.crouse@amd.com>
|
|
||||||
Josef Kellermann <Joseph.Kellermann@heitec.de> <seppk@arcor.de>
|
|
||||||
Josef Kellermann <Joseph.Kellermann@heitec.de> Josef Kellermannseppk <Josef Kellermannseppk@arcor.de>
|
|
||||||
Joseph Smith <joe@settoplinux.org> <joe@settoplinux.org Acked-by: Joseph Smith joe@settoplinux.org>
|
|
||||||
Joseph Smith <joe@settoplinux.org> <joe@smittys.pointclark.net>
|
|
||||||
Juergen Beisert <juergen@kreuzholzen.de> <juergen127@kreuzholzen.de>
|
|
||||||
Julian Schroeder <julianmarcusschroeder@gmail.com> <julian.schroeder@amd.com>
|
|
||||||
Julien Viard de Galbert <julien@vdg.name> <jviarddegalbert@online.net>
|
|
||||||
Justin Wu <amersel@runbox.me>
|
|
||||||
Kaiyen Chang <kaiyen.chang@intel.com> <kaiyen.chang@intel.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> <kane_chen@pegatron.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> <kane.chen@intel.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> Kane Chenffd <kane_chen@pegatron.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> kane_chen <kane_chen@pegatron.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> YanRu Chen <kane_chen@pegatron.corp-partner.google.com>
|
|
||||||
Kane Chen <kane.chen@intel.com> YenLu Chen <kane_chen@pegatron.corp-partner.google.com>
|
|
||||||
Karthikeyan Ramasubramanian <kramasub@google.com> <kramasub@chromium.org>
|
|
||||||
Katie Roberts-Hoffman <katierh@chromium.org> <katierh@google.com>
|
|
||||||
Kerry She <kerry.she@amd.com> <Kerry.she@amd.com>
|
|
||||||
Kerry Sheh <shekairui@gmail.com>
|
|
||||||
Kevin Chang <kevin.chang@lcfc.corp-partner.google.com>
|
|
||||||
Kevin Chiu <kevin.chiu.17802@gmail.com> <kevin.chiu@quanta.corp-partner.google.com>
|
|
||||||
Kevin Chiu <kevin.chiu.17802@gmail.com> <kevin.chiu@quantatw.com>
|
|
||||||
Kevin Chiu <kevin.chiu.17802@gmail.com> <Kevin.Chiu@quantatw.com>
|
|
||||||
Kevin Paul Herbert <kph@platinasystems.com> <kevin@trippers.org>
|
|
||||||
Kevin Paul Herbert <kph@platinasystems.com> <kph@meraki.net>
|
|
||||||
Kirk Wang <kirk_wang@pegatron.corp-partner.google.com> kirk_wang <kirk_wang@pegatron.corp-partner.google.com>
|
|
||||||
Konstantin Aladyshev <aladyshev22@gmail.com> <aladyshev@nicevt.ru>
|
|
||||||
Kyösti Mälkki <kyosti.malkki@gmail.com>
|
|
||||||
Kyösti Mälkki <kyosti.malkki@gmail.com> <kyosti.malkki@3mdeb.com>
|
|
||||||
Lean Sheng Tan <sheng.tan@9elements.com> <lean.sheng.tan@intel.com>
|
|
||||||
Lee Leahy <lpleahyjr@gmail.com> <leroy.p.leahy@intel.com>
|
|
||||||
Li Cheng Sooi <li.cheng.sooi@intel.com>
|
|
||||||
Lijian Zhao <lijian.zhao@intel.com>
|
|
||||||
Lin Huang <hl@rock-chips.com>
|
|
||||||
Maciej Matuszczyk <maccraft123mc@gmail.com>
|
|
||||||
Maggie Li <maggie.li@amd.com> <Maggie.li@amd.com>
|
|
||||||
Manideep Kurumella <mkurumel@qualcomm.corp-partner.google.com> <mkurumel@codeaurora.org>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marc.jones@amd.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marc.jones@gmail.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marc.jones@scarletltd.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marc.jones@se-eng.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marcj.jones@amd.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marcj303@gmail.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marcj303@yahoo.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> <marcjones@sysproconsulting.com>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> Marc Jones (marc.jones <Marc Jones (marc.jones@amd.com)>
|
|
||||||
Marc Jones <marc@marcjonesconsulting.com> Marc Jones(marc.jones <Marc Jones(marc.jones@amd.com)>
|
|
||||||
Marcello Sylvester Bauer <sylv@sylv.io>
|
|
||||||
Marcello Sylvester Bauer <sylv@sylv.io> <info@marcellobauer.com>
|
|
||||||
Marcello Sylvester Bauer <sylv@sylv.io> <sylvblck@sylv.io>
|
|
||||||
Marco Chen <marcochen@google.com> <marcochen@chromium.org>
|
|
||||||
Mariusz Szafrański <mariuszx.szafranski@intel.com> Mariusz Szafranski <mariuszx.szafranski@intel.com>
|
|
||||||
Marshall Dawson <marshalldawson3rd@gmail.com> <marshall.dawson@amd.corp-partner.google.com>
|
|
||||||
Marshall Dawson <marshalldawson3rd@gmail.com> <marshall.dawson@scarletltd.com>
|
|
||||||
Mart Raudsepp <leio@gentoo.org> <mart.raudsepp@artecdesign.ee>
|
|
||||||
Martin Kepplinger <martink@posteo.de> <martin.kepplinger@puri.sm>
|
|
||||||
Martin Roth <gaumless@gmail.com> <martin.roth@se-eng.com>
|
|
||||||
Martin Roth <gaumless@gmail.com> <martin@coreboot.org>
|
|
||||||
Martin Roth <gaumless@gmail.com> <martinr@coreboot.org>
|
|
||||||
Martin Roth <gaumless@gmail.com> <martinroth@chromium.org>
|
|
||||||
Martin Roth <gaumless@gmail.com> <martinroth@google.com>
|
|
||||||
Martin Roth <gaumless@gmail.com> Martin Roth <martin@se-eng.com>
|
|
||||||
Marx Wang <marx.wang@intel.com>
|
|
||||||
Mathias Krause <minipli@googlemail.com> <mathias.krause@secunet.com>
|
|
||||||
Mathias Krause <minipli@googlemail.com> <Mathias.Krause@secunet.com>
|
|
||||||
Mats Erik Andersson <mats.andersson@gisladisker.org> <mats.andersson@gisladisker.se>
|
|
||||||
Matt DeVillier <matt.devillier@gmail.com> <matt.devillier@puri.sm>
|
|
||||||
Matt Papageorge <matthewpapa07@gmail.com> <matt.papageorge@amd.corp-partner.google.com>
|
|
||||||
Matt Ziegelbaum <ziegs@google.com> <ziegs@chromium.org>
|
|
||||||
Maulik V Vaghela <maulik.v.vaghela@intel.com>
|
|
||||||
Maulik V Vaghela <maulik.v.vaghela@intel.com> <maulik.v.vaghela@intel.corp-partner.google.com>
|
|
||||||
Max Blau <tripleshiftone@gmail.com> Bluemax <1403092+BlueMax@users.noreply.github.com>
|
|
||||||
Maxim Polyakov <max.senia.poliak@gmail.com> <m.poliakov@yahoo.com>
|
|
||||||
Mengqi Zhang <Mengqi.Zhang@mediatek.com> mengqi.zhang <mengqi.zhang@mediatek.com>
|
|
||||||
Michael Niewöhner <foss@mniewoehner.de> <michael.niewoehner@8com.de>
|
|
||||||
Michael Xie <Michael.Xie@amd.com> <Michael Xie Michael.Xie@amd.com>
|
|
||||||
Michele Guerini Rocco <rnhmjoj@inventati.org>
|
|
||||||
Mike Banon <mikebdp2@gmail.com> <mike.banon@3mdeb.com>
|
|
||||||
Mike Hsieh <Mike_Hsieh@wistron.com> <mike_hsieh@wistron.corp-partner.google.com>
|
|
||||||
Mike Loptien <loptienm@gmail.com> <mike.loptien@se-eng.com>
|
|
||||||
Mondrian Nuessle <nuessle@uni-hd.de>
|
|
||||||
Mondrian Nuessle <nuessle@uni-hd.de> <nuessle@uni-mannheim.de>
|
|
||||||
Motiejus Jakštys <desired.mta@gmail.com>
|
|
||||||
Myles Watson <mylesgw@gmail.com> <myles@pel.cs.byu.edu>
|
|
||||||
Nancy Lin <nancy.lin@mediatek.com>
|
|
||||||
Naresh Solanki <naresh.solanki@intel.com>
|
|
||||||
Naresh Solanki <naresh.solanki@intel.com> <Naresh.Solanki@intel.com>
|
|
||||||
Naveen Manohar <naveen.m@intel.com>
|
|
||||||
Naveen Manohar <naveen.m@intel.com>
|
|
||||||
Neil Chen <neilc@nvidia.com> <neilc%nvidia.com@gtempaccount.com>
|
|
||||||
Nick Chen <nick_xr_chen@wistron.corp-partner.google.com>
|
|
||||||
Nick Vaccaro <nvaccaro@google.com> <nvaccaro@chromium.org>
|
|
||||||
Nicky Sielicki <nlsielicki@wisc.edu>
|
|
||||||
Nico Huber <nico.h@gmx.de> <nico.huber@secunet.com>
|
|
||||||
Nicolas Boichat <drinkcat@chromium.org> <drinkcat@google.com>
|
|
||||||
Nicolas Reinecke <nr@das-labor.org>
|
|
||||||
Nils Jacobs <njacobs8@adsltotaal.nl> <njacobs8@hetnet.nl>
|
|
||||||
Nina Wu <nina-cm.wu@mediatek.com> <nina-cm.wu@mediatek.corp-partner.google.com>
|
|
||||||
Oskar Enoksson <enok@lysator.liu.se>
|
|
||||||
Oskar Enoksson <enok@lysator.liu.se> <oskeno@foi.se>
|
|
||||||
Pablo Moyano <42.pablo.ms@gmail.com> p4block <p4block@users.noreply.github.com>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <Patrick Georgi patrick.georgi@coresystems.de>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <Patrick Georgi patrick@georgi-clan.de>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <patrick.georgi@coresystems.de>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <patrick.georgi@secunet.com>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <Patrick.Georgi@secunet.com>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <patrick@georgi-clan.de>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> <patrick@georgi.software>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> Patrick Georgi <pgeorgi@chromium.org>
|
|
||||||
Patrick Georgi <patrick@coreboot.org> Patrick Georgi <pgeorgi@google.com>
|
|
||||||
Patrick Rudolph <siro@das-labor.org> <patrick.rudolph@9elements.com>
|
|
||||||
Paul Fagerburg <pfagerburg@chromium.org> <pfagerburg@google.com>
|
|
||||||
Paul Kocialkowski <contact@paulk.fr>
|
|
||||||
Paul Ma <magf@bitland.com.cn> <magf@bitland.corp-partner.google.com>
|
|
||||||
Paul Ma <magf@bitland.com.cn> Magf - <magf@bitland.corp-partner.google.com>
|
|
||||||
Paul Menzel <pmenzel@molgen.mpg.de> <paulepanter@mailbox.org>
|
|
||||||
Paul Menzel <pmenzel@molgen.mpg.de> <paulepanter@users.sourceforge.net>
|
|
||||||
Peichao Wang <peichao.wang@bitland.corp-partner.google.com>
|
|
||||||
Peichao Wang <peichao.wang@bitland.corp-partner.google.com>
|
|
||||||
Philip Chen <philipchen@google.com>
|
|
||||||
Philip Chen <philipchen@google.com> <philipchen@chromium.org>
|
|
||||||
Philipp Deppenwiese <zaolin.daisuki@gmail.com>
|
|
||||||
Philipp Deppenwiese <zaolin.daisuki@gmail.com> <philipp.deppenwiese@9elements.com>
|
|
||||||
Philipp Deppenwiese <zaolin.daisuki@gmail.com> <zaolin@das-labor.org>
|
|
||||||
Ping-chung Chen <ping-chung.chen@intel.com>
|
|
||||||
Ping-chung Chen <ping-chung.chen@intel.com>
|
|
||||||
Piotr Kleinschmidt <piotr.kleinschmidt@3mdeb.com> <piotr.kleins@gmail.com>
|
|
||||||
Piotr Szymaniak <szarpaj@grubelek.pl>
|
|
||||||
Po Xu <jg_poxu@mediatek.com>
|
|
||||||
Po Xu <jg_poxu@mediatek.com> <jg_poxu@mediatek.corp-partner.google.com>
|
|
||||||
Praveen Hodagatta Pranesh <praveenx.hodagatta.pranesh@intel.com>
|
|
||||||
Preetham Chandrian <preetham.chandrian@intel.com>
|
|
||||||
Puthikorn Voravootivat <puthik@chromium.org> <puthik@google.com>
|
|
||||||
QingPei Wang <wangqingpei@gmail.com>
|
|
||||||
Quan Tran <qeed.quan@gmail.com>
|
|
||||||
Rasheed Hsueh <rasheed.hsueh@lcfc.corp-partner.google.com>
|
|
||||||
Raul Rangel <rrangel@chromium.org>
|
|
||||||
Ravi Kumar Bokka <rbokka@codeaurora.org>
|
|
||||||
Ravindra <ravindra@intel.com>
|
|
||||||
Ravindra <ravindra@intel.com> Ravindra N <ravindra@intel.corp-partner.google.com>
|
|
||||||
Ravishankar Sarawadi <ravishankar.sarawadi@intel.com>
|
|
||||||
Raymond Chung <raymondchung@ami.corp-partner.google.com>
|
|
||||||
Raymond Danks <raymonddanks@gmail.com> <ray.danks@se-eng.com>
|
|
||||||
Reka Norman <rekanorman@google.com> <rekanorman@chromium.org>
|
|
||||||
Ren Kuo <ren.kuo@quantatw.com>
|
|
||||||
Ren Kuo <ren.kuo@quantatw.com> <ren.kuo@quanta.corp-partner.google.com>
|
|
||||||
Rex-BC Chen <rex-bc.chen@mediatek.com> <rex-bc.chen@mediatek.corp-partner.google.com>
|
|
||||||
Ricardo Ribalda <ribalda@chromium.org> <ricardo.ribalda@gmail.com>
|
|
||||||
Richard Spiegel <richard.spiegel@silverbackltd.com> <richard.spiegel@amd.corp-partner.google.com>
|
|
||||||
Rishavnath Satapathy <rishavnath.satapathy@intel.com>
|
|
||||||
Ritul Guru <ritul.bits@gmail.com>
|
|
||||||
Rizwan Qureshi <rizwan.qureshi@intel.com> <rizwan.qureshi@intel.corp-partner.google.com>
|
|
||||||
Robbie Zhang <robbie.zhang@intel.com>
|
|
||||||
Robert Chen <robert.chen@quanta.corp-partner.google.com>
|
|
||||||
Robert Chen <robert.chen@quanta.corp-partner.google.com> = <robert.chen@quanta.corp-partner.google.com>
|
|
||||||
Roger Pau Monne <roger.pau@citrix.com>
|
|
||||||
Roman Kononov <kononov@dls.net> <kononov195-lbl@yahoo.com>
|
|
||||||
Ron Minnich <rminnich@gmail.com>
|
|
||||||
Ron Minnich <rminnich@gmail.com> <Ron Minnich>
|
|
||||||
Ron Minnich <rminnich@gmail.com> <Ronald G. Minnich rminnich@gmail.com>
|
|
||||||
Ron Minnich <rminnich@gmail.com> Ronald G. Minnich <minnich@google.com>
|
|
||||||
Ron Minnich <rminnich@gmail.com> Ronald G. Minnich <rminnich@chromium.org>
|
|
||||||
Ron Minnich <rminnich@gmail.com> Ronald G. Minnich <rminnich@google.com>
|
|
||||||
Ron Minnich <rminnich@gmail.com> Ronald G. Minnich <rminnich@lanl.gov>
|
|
||||||
Ron Minnich <rminnich@gmail.com> ronald g. minnich <ronald g. minnich>
|
|
||||||
Ron Minnich <rminnich@gmail.com> Ronald G. Minnich <Ronald G. Minnich>
|
|
||||||
Ronak Kanabar <ronak.kanabar@intel.com>
|
|
||||||
Rudolf Marek <r.marek@assembler.cz> <r.marek@asssembler.cz>
|
|
||||||
Ryan Chuang <ryan.chuang@mediatek.com> <ryan.chuang@mediatek.corp-partner.google.com>
|
|
||||||
Santhosh Janardhana Hassan <sahassan@google.com>
|
|
||||||
Scott Chao <scott_chao@wistron.corp-partner.google.com> <scott.chao@bitland.corp-partner.google.com>
|
|
||||||
Scott Duplichan <scott@notabs.org> <sc...@notabs.org>
|
|
||||||
Scott Tsai <AT>
|
|
||||||
Sebastian "Swift Geek" Grzywna <swiftgeek@gmail.com>
|
|
||||||
Selma Bensaid <selma.bensaid@intel.com>
|
|
||||||
Seunghwan Kim <sh_.kim@samsung.com>
|
|
||||||
Seunghwan Kim <sh_.kim@samsung.com> <sh_.kim@samsung.corp-partner.google.com>
|
|
||||||
Seunghwan Kim <sh_.kim@samsung.com> sh.kim <sh_.kim@samsung.corp-partner.google.com>
|
|
||||||
Shawn Chang <citypw@gmail.com>
|
|
||||||
Shawn Nematbakhsh <shawnn@google.com> <shawnn@chromium.org>
|
|
||||||
Shelley Chen <shchen@google.com> <shchen@chromium.org>
|
|
||||||
Sheng-Liang Pan <Sheng-Liang.Pan@quantatw.com> <sheng-liang.pan@quanta.corp-partner.google.com>
|
|
||||||
Shreesh Chhabbi <shreesh.chhabbi@intel.com> <shreesh.chhabbi@intel.corp-partner.google.com>
|
|
||||||
Shunqian Zheng <zhengsq@rock-chips.com>
|
|
||||||
Siyuan Wang <wangsiyuanbuaa@gmail.com>
|
|
||||||
Sowmya <v.sowmya@intel.com>
|
|
||||||
Sridhar Siricilla <sridhar.siricilla@intel.com>
|
|
||||||
Sridhar Siricilla <sridhar.siricilla@intel.com> <sridhar.siricilla@intel.corp-partner.google.com>
|
|
||||||
Srinidhi Kaushik <srinidhi.n.kaushik@intel.com>
|
|
||||||
Stanley Wu <stanley1.wu@lcfc.corp-partner.google.com>
|
|
||||||
Stefan Ott <stefan@ott.net> <coreboot@desire.ch>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <reinauer@chromium.org>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <reinauer@google.com>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <Stefan Reinauerstepan@coresystems.de>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <stefan.reinauer@coreboot.org>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <stepan@coresystems.de>
|
|
||||||
Stefan Reinauer <stepan@coreboot.org> <stepan@openbios.org>
|
|
||||||
Stephan Guilloux <stephan.guilloux@free.fr> <mailto:stephan.guilloux@free.fr>
|
|
||||||
Subrata Banik <subratabanik@google.com> <subi.banik@gmail.com>
|
|
||||||
Subrata Banik <subratabanik@google.com> <subrata.banik@intel.com>
|
|
||||||
Subrata Banik <subratabanik@google.com> <subrata.banik@intel.com>
|
|
||||||
Sudheer Kumar Amrabadi <samrab@codeaurora.org>
|
|
||||||
Sumeet Pawnikar <sumeet.r.pawnikar@intel.com>
|
|
||||||
Sunwei Li <lisunwei@huaqin.corp-partner.google.com>
|
|
||||||
Susendra Selvaraj <susendra.selvaraj@intel.com>
|
|
||||||
Sylvain "ythier" Hitier <sylvain.hitier@gmail.com>
|
|
||||||
T Michael Turney <mturney@codeaurora.org> mturney mturney <quic_mturney@quicinc.com>
|
|
||||||
T Michael Turney <mturney@codeaurora.org> T Michael Turney <quic_mturney@quicinc.com>
|
|
||||||
T.H. Lin <T.H_Lin@quantatw.com> <t.h_lin@quanta.corp-partner.google.com>
|
|
||||||
T.H. Lin <T.H_Lin@quantatw.com> T.H.Lin <T.H_Lin@quantatw.com>
|
|
||||||
Taniya Das <quic_tdas@quicinc.com> <tdas@codeaurora.org>
|
|
||||||
Tao Xia <xiatao5@huaqin.corp-partner.google.com>
|
|
||||||
Thejaswani Putta <thejaswani.putta@intel.com> <thejaswani.putta@intel.corp-partner.google.com>
|
|
||||||
Thejaswani Putta <thejaswani.putta@intel.com>
|
|
||||||
Thejaswani Putta <thejaswani.putta@intel.com> Thejaswani Puta thejaswani.putta@intel.com <thejaswani.putta@intel.com>
|
|
||||||
Thomas Heijligen <thomas.heijligen@secunet.com> <src@posteo.de>
|
|
||||||
Tim Chen <Tim-Chen@quantatw.com> <tim-chen@quanta.corp-partner.google.com>
|
|
||||||
Tim Chu <Tim.Chu@quantatw.com>
|
|
||||||
Tim Wawrzynczak <twawrzynczak@chromium.org> <twawrzynczak@google.com>
|
|
||||||
Timothy Pearson <tpearson@raptorengineering.com> <tpearson@raptorengineeringinc.com>
|
|
||||||
Tinghan Shen <tinghan.shen@mediatek.com>
|
|
||||||
Tobias Diedrich <ranma+coreboot@tdiedrich.de> <ranma+openocd@tdiedrich.de>
|
|
||||||
Tracy Wu <tracy.wu@intel.com> <tracy.wu@intel.corp-partner.google.com>
|
|
||||||
Tristan Corrick <tristan@corrick.kiwi> <tristancorrick86@gmail.com>
|
|
||||||
Tyler Wang <tyler.wang@quanta.corp-partner.google.com> <Tyler.Wang@quanta.corp-partner.google.com>
|
|
||||||
Usha P <usha.p@intel.com> <usha.p@intel.corp-partner.google.com>
|
|
||||||
V Sujith Kumar Reddy <vsujithk@codeaurora.org>
|
|
||||||
Vadim Bendebury <vbendeb@chromium.org> <vbendeb@google.com>
|
|
||||||
Vaibhav Shankar <vaibhav.shankar@intel.com>
|
|
||||||
Van Chen <van_chen@compal.corp-partner.google.com>
|
|
||||||
Varshit Pandya <varshit.b.pandya@intel.com>
|
|
||||||
Varshit Pandya <varshit.b.pandya@intel.com> Varshit B Pandya <varshit.b.pandya@intel.com>
|
|
||||||
Varun Joshi <varun.joshi@intel.com> <varun.joshi@intel.corp-partner.google.com>
|
|
||||||
Vincent Lim <vincent.lim@amd.com> <Vincent Lim vincent.lim@amd.com>
|
|
||||||
Vladimir Serbinenko <phcoder@gmail.com>
|
|
||||||
Wayne3 Wang <wayne3_wang@pegatron.corp-partner.google.com> <Wayne3_Wang@pegatron.corp-partner.google.com>
|
|
||||||
William Wu <wulf@rock-chips.com>
|
|
||||||
Wim Vervoorn <wvervoorn@eltan.com>
|
|
||||||
Wisley Chen <wisley.chen@quantatw.com>
|
|
||||||
Wisley Chen <wisley.chen@quantatw.com> <wisley.chen@quanta.corp-partner.google.com>
|
|
||||||
Xi Chen <xixi.chen@mediatek.com> <xixi.chen@mediatek.corp-partner.google.com>
|
|
||||||
Xiang Wang <merle@hardenedlinux.org> <wxjstz@126.com>
|
|
||||||
Xingyu Wu <wuxy@bitland.corp-partner.google.com>
|
|
||||||
Xuxin Xiong <xuxinxiong@huaqin.corp-partner.google.com>
|
|
||||||
Yang A Fang <yang.a.fang@intel.com>
|
|
||||||
Yinghai Lu <yinghailu@gmail.com> <yinghai.lu at amd.com>
|
|
||||||
Yinghai Lu <yinghailu@gmail.com> <yinghai.lu@amd.com>
|
|
||||||
Yinghai Lu <yinghailu@gmail.com> <yinghai@kernel.org>
|
|
||||||
Yongkun Yu <yuyongkun@huaqin.corp-partner.google.com>
|
|
||||||
Yongqiang Niu <yongqiang.niu@mediatek.com>
|
|
||||||
Youness Alaoui <snifikino@gmail.com> <kakaroto@kakaroto.homelinux.net>
|
|
||||||
Youness Alaoui <snifikino@gmail.com> <youness.alaoui@puri.sm>
|
|
||||||
Yu-Hsuan Hsu <yuhsuan@google.com>
|
|
||||||
Yu-Hsuan Hsu <yuhsuan@google.com> <yuhsuan@chromium.org>
|
|
||||||
Yu-Ping Wu <yupingso@google.com> <yupingso@chromium.org>
|
|
||||||
Yuanlidingm <yuanliding@huaqin.corp-partner.google.com>
|
|
||||||
Yuchen Huang <yuchen.huang@mediatek.com> <yuchen.huang@mediatek.corp-partner.google.com>
|
|
||||||
Yuji Sasaki <sasakiy@chromium.org> <sasakiy@google.com>
|
|
||||||
Zanxi Chen <chenzanxi@huaqin.corp-partner.google.com>
|
|
||||||
Zhi Li <lizhi7@huaqin.corp-partner.google.com>
|
|
||||||
Zhongze Hu <frankhu@chromium.org> <frankhu@google.com>
|
|
||||||
Zhuo-Hao Lee <zhuo-hao.lee@intel.com>
|
|
||||||
Zhuohao Lee <zhuohao@chromium.org> <zhuohao@google.com>
|
|
2
3rdparty/amd_blobs
vendored
2
3rdparty/amd_blobs
vendored
Submodule 3rdparty/amd_blobs updated: a0693217d2...9e8f457edc
2
3rdparty/blobs
vendored
2
3rdparty/blobs
vendored
Submodule 3rdparty/blobs updated: 8c580e55da...f14575cb99
2
3rdparty/cmocka
vendored
2
3rdparty/cmocka
vendored
Submodule 3rdparty/cmocka updated: 8931845c35...672c5cee79
2
3rdparty/fsp
vendored
2
3rdparty/fsp
vendored
Submodule 3rdparty/fsp updated: f4bbf5ab89...10eae55b8e
@@ -26,7 +26,9 @@ In order to add support for x86_64 the following assumptions were made:
|
|||||||
* A stage can install new page tables in RAM
|
* A stage can install new page tables in RAM
|
||||||
|
|
||||||
## Page tables
|
## Page tables
|
||||||
A `pagetables` cbfs file is generated based on an assembly file.
|
Page tables are generated by a tool in `util/pgtblgen/pgtblgen`. It writes
|
||||||
|
the page tables to a file which is then included into the CBFS as file called
|
||||||
|
`pagetables`.
|
||||||
|
|
||||||
To generate the static page tables it must know the physical address where to
|
To generate the static page tables it must know the physical address where to
|
||||||
place the file.
|
place the file.
|
||||||
|
@@ -115,4 +115,4 @@ Our arbitration team consists of the following people
|
|||||||
This Code of Conduct is distributed under
|
This Code of Conduct is distributed under
|
||||||
a [Creative Commons Attribution-ShareAlike
|
a [Creative Commons Attribution-ShareAlike
|
||||||
license](http://creativecommons.org/licenses/by-sa/3.0/). It is based
|
license](http://creativecommons.org/licenses/by-sa/3.0/). It is based
|
||||||
on the [Citizen Code of Conduct](https://web.archive.org/web/20200330154000/http://citizencodeofconduct.org/)
|
on the [Citizen Code of Conduct](http://citizencodeofconduct.org/)
|
||||||
|
@@ -14,7 +14,7 @@ their development kit with them and conduct development sessions.
|
|||||||
|
|
||||||
[Open Source Firmware at Facebook](https://fosdem.org/2019/schedule/event/open_source_firmware_at_facebook/) by [David Hendricks](https://github.com/dhendrix) and [Andrea Barberio](https://github.com/insomniacslk) at [FOSDEM 2019](https://fosdem.org/2019/) ([video](https://video.fosdem.org/2019/K.4.401/open_source_firmware_at_facebook.mp4)) ([slides](https://insomniac.slackware.it/static/2019_fosdem_linuxboot_at_facebook.pdf)) (2019-02-03)
|
[Open Source Firmware at Facebook](https://fosdem.org/2019/schedule/event/open_source_firmware_at_facebook/) by [David Hendricks](https://github.com/dhendrix) and [Andrea Barberio](https://github.com/insomniacslk) at [FOSDEM 2019](https://fosdem.org/2019/) ([video](https://video.fosdem.org/2019/K.4.401/open_source_firmware_at_facebook.mp4)) ([slides](https://insomniac.slackware.it/static/2019_fosdem_linuxboot_at_facebook.pdf)) (2019-02-03)
|
||||||
|
|
||||||
[Open Source Firmware - A love story](https://www.youtube.com/watch?v=xfqKm190dbU) by [Philipp Deppenwiese](https://cybersecurity.9elements.com) at [35c3](https://web.archive.org/web/20211027210118/https://events.ccc.de/congress/2018/wiki/index.php/Main_Page)
|
[Open Source Firmware - A love story](https://www.youtube.com/watch?v=xfqKm190dbU) by [Philipp Deppenwiese](https://cybersecurity.9elements.com) at [35c3](https://events.ccc.de/congress/2018)
|
||||||
([slides](https://cdn.media.ccc.de/congress/2018/slides-h264-hd/35c3-9778-deu-eng-Open_Source_Firmware_hd-slides.mp4)) (2018-12-27)
|
([slides](https://cdn.media.ccc.de/congress/2018/slides-h264-hd/35c3-9778-deu-eng-Open_Source_Firmware_hd-slides.mp4)) (2018-12-27)
|
||||||
|
|
||||||
[coreboot mainboard porting with Intel FSP 2.0](https://www.youtube.com/watch?v=qUgo-AVsSCI) by Subrata Banik at OSFC 2018
|
[coreboot mainboard porting with Intel FSP 2.0](https://www.youtube.com/watch?v=qUgo-AVsSCI) by Subrata Banik at OSFC 2018
|
||||||
|
@@ -1,6 +0,0 @@
|
|||||||
# Community
|
|
||||||
|
|
||||||
* [Code of Conduct](code_of_conduct.md)
|
|
||||||
* [Language style](language_style.md)
|
|
||||||
* [Community forums](forums.md)
|
|
||||||
* [coreboot at conferences](conferences.md)
|
|
@@ -1,6 +1,6 @@
|
|||||||
# Accounts on coreboot.org
|
# Accounts on coreboot.org
|
||||||
|
|
||||||
There are a number of places where you can benefit from creating an account
|
There are a number of places where you can benefit from creaating an account
|
||||||
in our community. Since there is no single sign-on system in place (at this
|
in our community. Since there is no single sign-on system in place (at this
|
||||||
time), they come with their own setup routines.
|
time), they come with their own setup routines.
|
||||||
|
|
@@ -960,55 +960,17 @@ asm ("magic %reg1, #42nt"
|
|||||||
: /* outputs */ : /* inputs */ : /* clobbers */);
|
: /* outputs */ : /* inputs */ : /* clobbers */);
|
||||||
```
|
```
|
||||||
|
|
||||||
GCC extensions
|
|
||||||
--------------
|
|
||||||
|
|
||||||
GCC is the only officially-supported compiler for coreboot, and a
|
|
||||||
variety of its C language extensions are heavily used throughout the
|
|
||||||
code base. There have been occasional attempts to add clang as a second
|
|
||||||
compiler option, which is generally compatible to the same language
|
|
||||||
extensions that have been long-established by GCC.
|
|
||||||
|
|
||||||
Some GCC extensions (e.g. inline assembly) are basically required for
|
|
||||||
proper firmware development. Others enable more safe or flexible
|
|
||||||
coding patterns than can be expressed with standard C (e.g. statement
|
|
||||||
expressions and `typeof()` to avoid double evaluation in macros like
|
|
||||||
`MAX()`). Yet others just add some simple convenience and reduce
|
|
||||||
boilerplate (e.g. `void *` arithmetic).
|
|
||||||
|
|
||||||
Since some GCC extensions are necessary either way, there is no gain
|
|
||||||
from avoiding other GCC extensions elsewhere. The use of all official
|
|
||||||
GCC extensions is expressly allowed within coreboot. In cases where an
|
|
||||||
extension can be replaced by a 100% equivalent C standard feature with
|
|
||||||
no extra boilerplate or loss of readability, the C standard feature
|
|
||||||
should be preferred (this usually only happens when GCC retains an
|
|
||||||
older pre-standardization extension for backwards compatibility, e.g.
|
|
||||||
the old pre-C99 syntax for designated initializers). But if there is
|
|
||||||
any advantage offered by the GCC extension (e.g. using GCC zero-length
|
|
||||||
arrays instead of C99 variable-length arrays because they don't inhibit
|
|
||||||
`sizeof()`), there is no reason to deprive ourselves of that, and "this
|
|
||||||
is not C standard compliant" should not be a reason to argue against
|
|
||||||
its use in reviews.
|
|
||||||
|
|
||||||
This rule only applies to explicit GCC extensions listed in the
|
|
||||||
"Extensions to the C Language Family" section of the GCC manual. Code
|
|
||||||
should never rely on incidental GCC translation behavior that is not
|
|
||||||
explicitly documented as a feature and could change at any moment.
|
|
||||||
|
|
||||||
References
|
References
|
||||||
----------
|
----------
|
||||||
|
|
||||||
The C Programming Language, Second Edition by Brian W. Kernighan and
|
The C Programming Language, Second Edition by Brian W. Kernighan and
|
||||||
Dennis M. Ritchie. Prentice Hall, Inc., 1988. ISBN 0-13-110362-8
|
Dennis M. Ritchie. Prentice Hall, Inc., 1988. ISBN 0-13-110362-8
|
||||||
(paperback), 0-13-110370-9 (hardback). URL:
|
(paperback), 0-13-110370-9 (hardback). URL:
|
||||||
<https://duckduckgo.com/?q=isbn+0-13-110362-8> or
|
<http://cm.bell-labs.com/cm/cs/cbook/>
|
||||||
<https://www.google.com/search?q=isbn+0-13-110362-8.
|
|
||||||
|
|
||||||
|
|
||||||
The Practice of Programming by Brian W. Kernighan and Rob Pike.
|
The Practice of Programming by Brian W. Kernighan and Rob Pike.
|
||||||
Addison-Wesley, Inc., 1999. ISBN 0-201-61586-X. URL:
|
Addison-Wesley, Inc., 1999. ISBN 0-201-61586-X. URL:
|
||||||
<https://duckduckgo.com/?q=ISBN+0-201-61586-X> or
|
<http://cm.bell-labs.com/cm/cs/tpop/>
|
||||||
<https://www.google.com/search?q=ISBN+0-201-61586-X>
|
|
||||||
|
|
||||||
GNU manuals - where in compliance with K&R and this text - for cpp, gcc,
|
GNU manuals - where in compliance with K&R and this text - for cpp, gcc,
|
||||||
gcc internals and indent, all available from
|
gcc internals and indent, all available from
|
||||||
|
@@ -1,275 +0,0 @@
|
|||||||
# Google Summer of Code
|
|
||||||
|
|
||||||
|
|
||||||
## Contacts
|
|
||||||
|
|
||||||
If you are interested in participating in GSoC as a contributor or mentor,
|
|
||||||
please have a look at our [community forums] and reach out to us. Working closely
|
|
||||||
with the community is highly encouraged, as we've seen that our most successful
|
|
||||||
contributors are generally very involved.
|
|
||||||
|
|
||||||
Felix Singer, David Hendricks and Martin Roth are the coreboot GSoC admins for
|
|
||||||
2022. Please feel free to reach out to them directly if you have any questions.
|
|
||||||
|
|
||||||
|
|
||||||
## Why work on coreboot for GSoC?
|
|
||||||
|
|
||||||
* coreboot offers you the opportunity to work with various architectures
|
|
||||||
right on the iron. coreboot supports both current and older silicon for a
|
|
||||||
wide variety of chips and technologies.
|
|
||||||
|
|
||||||
* coreboot has a worldwide developer and user base.
|
|
||||||
|
|
||||||
* We are a very passionate team, so you will interact directly with the
|
|
||||||
project initiators and project leaders.
|
|
||||||
|
|
||||||
* We have a large, helpful community. coreboot has some extremely talented
|
|
||||||
and helpful experts in firmware involved in the project. They are ready to
|
|
||||||
assist and mentor contributors participating in GSoC.
|
|
||||||
|
|
||||||
* One of the last areas where open source software is not common is firmware.
|
|
||||||
Running proprietary firmware can have severe effects on user's freedom and
|
|
||||||
security. coreboot has a mission to change that by providing a common
|
|
||||||
framework for initial hardware initialization and you can help us succeed.
|
|
||||||
|
|
||||||
|
|
||||||
## Collection of official GSoC guides & documents
|
|
||||||
|
|
||||||
* [Timeline][GSoC Timeline]
|
|
||||||
|
|
||||||
* [Roles and Responsibilities][GSoC Roles and Responsibilities]
|
|
||||||
|
|
||||||
* [Contributor Guide][GSoC Contributor Guide]
|
|
||||||
|
|
||||||
* [Contributor Advice][GSoC Contributor Advice]
|
|
||||||
|
|
||||||
* [Mentor Guide][GSoC Mentor Guide]
|
|
||||||
|
|
||||||
* [FAQ][GSoC FAQ]
|
|
||||||
|
|
||||||
* [Rules][GSoC Rules]
|
|
||||||
|
|
||||||
* [Glossary][GSoC Glossary]
|
|
||||||
|
|
||||||
|
|
||||||
## Contributor requirements & commitments
|
|
||||||
|
|
||||||
Google Summer of Code is a significant time commitment for you. Medium-sized
|
|
||||||
projects are estimated to take 175 hours, while large-sized projects are
|
|
||||||
estimated to take 350 hours. Depending on the project size, this means we
|
|
||||||
expect you to work roughly half-time or full-time on your project during the
|
|
||||||
three months of coding. We expect to be able to see this level of effort in the
|
|
||||||
results.
|
|
||||||
|
|
||||||
The standard program duration is 12 weeks and in consultation with the mentor
|
|
||||||
it can be extended up to 22 weeks. Please keep in mind that the actual number
|
|
||||||
of hours you spend on the project highly depends on your skills and previous
|
|
||||||
experience.
|
|
||||||
|
|
||||||
Make sure that your schedule (exams, courses, day job) gives you a sufficient
|
|
||||||
amount of spare time. If this is not the case, then you should not apply.
|
|
||||||
|
|
||||||
|
|
||||||
### Before applying
|
|
||||||
|
|
||||||
* Join the [mailing list] and our other [community forums]. Introduce yourself
|
|
||||||
and mention that you are a prospective GSoC contributor. Ask questions and
|
|
||||||
discuss the project that you are considering. Community involvement is a
|
|
||||||
key component of coreboot development.
|
|
||||||
|
|
||||||
* You accept our [Code of Conduct] and [Language style].
|
|
||||||
|
|
||||||
* Demonstrate that you can work with the coreboot codebase.
|
|
||||||
|
|
||||||
* Look over some of the development processes guidelines: [Getting started],
|
|
||||||
[Tutorial], [Flashing firmware tutorial] and [Coding style].
|
|
||||||
|
|
||||||
* Download, build and boot coreboot in QEMU or on real hardware. Please email
|
|
||||||
your serial output results to the [mailing list].
|
|
||||||
|
|
||||||
* Look through some patches on Gerrit to get an understanding of the review
|
|
||||||
process and common issues.
|
|
||||||
|
|
||||||
* Get signed up for Gerrit and push at least one patch to Gerrit for review.
|
|
||||||
Check the [easy project list][Project ideas] or ask for simple tasks on
|
|
||||||
the [mailing list] or on our other [community forums] if you need ideas.
|
|
||||||
|
|
||||||
|
|
||||||
### During the program
|
|
||||||
|
|
||||||
* To pass and to be paid by Google requires that you meet certain milestones.
|
|
||||||
|
|
||||||
* First, you must be in good standing with the community before the official
|
|
||||||
start of the program. We expect you to post some design emails to the
|
|
||||||
[mailing list], and get feedback on them, both before applying, and during
|
|
||||||
the "community bonding period" between acceptance and official start.
|
|
||||||
|
|
||||||
* You must have made progress and committed significant code before the
|
|
||||||
mid-term point and by the final.
|
|
||||||
|
|
||||||
* We require that accepted contributors to maintain a blog, where you are
|
|
||||||
expected to write about your project *WEEKLY*. This is a way to measure
|
|
||||||
progress and for the community at large to be able to help you. GSoC is
|
|
||||||
*NOT* a private contract between your mentor and you.
|
|
||||||
|
|
||||||
* You must be active in the community on IRC and the [mailing list].
|
|
||||||
|
|
||||||
* You are expected to work on development publicly, and to push commits to the
|
|
||||||
project on a regular basis. Depending on the project and what your mentor
|
|
||||||
agrees to, these can be published directly to the project or to a public
|
|
||||||
repository such as Gitlab or Github. If you are not publishing directly to
|
|
||||||
the project codebase, be aware that we do not want large dumps of code that
|
|
||||||
need to be rushed to meet the mid-term and final goals.
|
|
||||||
|
|
||||||
We don't expect our contributors to be experts in our problem domain, but we
|
|
||||||
don't want you to fail because some basic misunderstanding was in your way of
|
|
||||||
completing the task.
|
|
||||||
|
|
||||||
|
|
||||||
## Projects
|
|
||||||
|
|
||||||
There are many development tasks available in coreboot. We prepared some ideas
|
|
||||||
for Summer of Code projects. These are projects that we think can be managed in
|
|
||||||
the timeline of GSoC, and they cover areas where coreboot is trying to reach
|
|
||||||
new users and new use cases.
|
|
||||||
|
|
||||||
Of course your application does not have to be based on any of the ideas listed.
|
|
||||||
It is entirely possible that you have a great idea that we just didn't think of
|
|
||||||
yet. Please let us know!
|
|
||||||
|
|
||||||
The blog posts related to previous GSoC projects might give some insights to
|
|
||||||
what it is like to be a coreboot GSoC contributor.
|
|
||||||
|
|
||||||
|
|
||||||
## coreboot Summer of Code Application
|
|
||||||
|
|
||||||
coreboot welcomes contributors from all backgrounds and levels of experience.
|
|
||||||
|
|
||||||
Your application should include a complete project proposal. You should
|
|
||||||
document that you have the knowledge and the ability to complete your proposed
|
|
||||||
project. This may require a little research and understanding of coreboot prior
|
|
||||||
to sending your application. The community and coreboot project mentors are your
|
|
||||||
best resource in fleshing out your project ideas and helping with a project
|
|
||||||
timeline. We recommend that you get feedback and recommendations on your
|
|
||||||
proposal before the application deadline.
|
|
||||||
|
|
||||||
Please complete the standard GSoC application and project proposal. Provide the
|
|
||||||
following information as part of your application. Make sure to provide multiple
|
|
||||||
ways of communicating in case your equipment (such as a laptop) is lost,
|
|
||||||
damaged, or stolen, or in case of a natural disaster that disrupts internet
|
|
||||||
service. You risk automatically failing if your mentor cannot contact you and if
|
|
||||||
you cannot provide updates according to GSoC deadlines.
|
|
||||||
|
|
||||||
**Personal Information**
|
|
||||||
|
|
||||||
* Name
|
|
||||||
|
|
||||||
* Email and contact options (IRC, Matrix, …)
|
|
||||||
|
|
||||||
* Phone number (optional, but recommended)
|
|
||||||
|
|
||||||
* Timezone, Usual working hours (UTC)
|
|
||||||
|
|
||||||
* School / University, Degree Program, expected graduation date
|
|
||||||
|
|
||||||
* Short bio / Overview of your background
|
|
||||||
|
|
||||||
* What are your other time commitments? Do you have a job, classes, vacations?
|
|
||||||
When and how long?
|
|
||||||
|
|
||||||
**Software experience**
|
|
||||||
|
|
||||||
If applicable, please provide the following information:
|
|
||||||
|
|
||||||
* Portfolio, Website, blog, microblog, Github, Gitlab, ...
|
|
||||||
|
|
||||||
* Links to one or more patches submitted
|
|
||||||
|
|
||||||
* Links to posts on the [mailing list] with the serial output of your build.
|
|
||||||
|
|
||||||
* Please comment on your software and firmware experience.
|
|
||||||
|
|
||||||
* Have you contributed to an open source project? Which one? What was your
|
|
||||||
experience?
|
|
||||||
|
|
||||||
* What was your experience while building and running coreboot? Did you have
|
|
||||||
problems?
|
|
||||||
|
|
||||||
**Your project**
|
|
||||||
|
|
||||||
* Provide an overview of your project (in your own words).
|
|
||||||
|
|
||||||
* Provide a breakdown of your project in small specific weekly goals. Think
|
|
||||||
about the potential timeline.
|
|
||||||
|
|
||||||
* How will you accomplish this goal? What is your working style?
|
|
||||||
|
|
||||||
* Explain what risks or potential problems your project might experience.
|
|
||||||
|
|
||||||
* What would you expect as a minimum level of success?
|
|
||||||
|
|
||||||
* Do you have a stretch goal?
|
|
||||||
|
|
||||||
**Other**
|
|
||||||
|
|
||||||
* Resume (optional)
|
|
||||||
|
|
||||||
|
|
||||||
### Advice on how to apply
|
|
||||||
|
|
||||||
* [GSoC Contributor Guide]
|
|
||||||
|
|
||||||
* The Drupal project has a great page on how to write an GSoC application.
|
|
||||||
|
|
||||||
* Secrets for GSoC success: [2]
|
|
||||||
|
|
||||||
|
|
||||||
## Mentors
|
|
||||||
|
|
||||||
Each accepted project will have at least one mentor. We will match mentors and
|
|
||||||
contributors based on the project and experience level. If possible, we also
|
|
||||||
will try to match their time zones.
|
|
||||||
|
|
||||||
Mentors are expected to stay in frequent contact with the contributor and
|
|
||||||
provide guidance such as code reviews, pointers to useful documentation, etc.
|
|
||||||
This should generally be a time commitment of several hours per week.
|
|
||||||
|
|
||||||
Some projects might have more than one mentor, who can serve as a backup. They
|
|
||||||
are expected to coordinate with each other and a contributor on a regular basis,
|
|
||||||
and keep track of the contributor process. They should be able to take over
|
|
||||||
mentoring duty if one of the mentors is unavailable (vacations, sickness,
|
|
||||||
emergencies).
|
|
||||||
|
|
||||||
|
|
||||||
### Volunteering to be a mentor
|
|
||||||
|
|
||||||
If you'd like to volunteer to be a mentor, please read the [GSoC Mentor Guide].
|
|
||||||
This will give you a better idea of expectations, and where to go for help.
|
|
||||||
After that, contact Org Admins (see coreboot contacts section above).
|
|
||||||
|
|
||||||
The following coreboot developers have volunteered to be GSoC 2022 mentors.
|
|
||||||
Please stop by in our community forums and say hi to them and ask them
|
|
||||||
questions.
|
|
||||||
|
|
||||||
* Tim Wawrzynczak
|
|
||||||
* Raul Rangel
|
|
||||||
* Ron Minnich
|
|
||||||
|
|
||||||
|
|
||||||
[community forums]: ../community/forums.md
|
|
||||||
[mailing list]: https://mail.coreboot.org/postorius/lists/coreboot.coreboot.org
|
|
||||||
[Getting started]: ../getting_started/index.md
|
|
||||||
[Tutorial]: ../tutorial/index.md
|
|
||||||
[Flashing firmware tutorial]: ../tutorial/flashing_firmware/index.md
|
|
||||||
[Coding style]: coding_style.md
|
|
||||||
[Code of Conduct]: ../community/code_of_conduct.md
|
|
||||||
[Language style]: ../community/language_style.md
|
|
||||||
[Project ideas]: project_ideas.md
|
|
||||||
[GSoC Timeline]: https://developers.google.com/open-source/gsoc/timeline
|
|
||||||
[GSoC Roles and Responsibilities]: https://developers.google.com/open-source/gsoc/help/responsibilities
|
|
||||||
[GSoC Contributor Guide]: https://google.github.io/gsocguides/student
|
|
||||||
[GSoC Contributor Advice]: https://developers.google.com/open-source/gsoc/help/student-advice
|
|
||||||
[GSoC Mentor Guide]: https://google.github.io/gsocguides/mentor
|
|
||||||
[GSoC FAQ]: https://developers.google.com/open-source/gsoc/faq
|
|
||||||
[GSoC Rules]: https://summerofcode.withgoogle.com/rules
|
|
||||||
[GSoC Glossary]: https://developers.google.com/open-source/gsoc/resources/glossary
|
|
@@ -1,7 +0,0 @@
|
|||||||
# Contributing
|
|
||||||
|
|
||||||
* [Coding Style](coding_style.md)
|
|
||||||
* [Gerrit Guidelines](gerrit_guidelines.md)
|
|
||||||
* [Project Ideas](project_ideas.md)
|
|
||||||
* [Documentation Ideas](documentation_ideas.md)
|
|
||||||
* [Google Summer of Code](gsoc.md)
|
|
@@ -20,24 +20,6 @@ doubt if you can bring yourself up to speed in a required time frame
|
|||||||
with the projects. We can then try together to figure out if you're a
|
with the projects. We can then try together to figure out if you're a
|
||||||
good match for a project, even when requirements might not all be met.
|
good match for a project, even when requirements might not all be met.
|
||||||
|
|
||||||
## Easy projects
|
|
||||||
|
|
||||||
This is a collection of tasks which don't require deep knowledge on
|
|
||||||
coreboot itself. If you are a beginner and want to get familiar with the
|
|
||||||
the project and the code base, or if you just want to get your hands
|
|
||||||
dirty with some easy tasks, then these are for you.
|
|
||||||
|
|
||||||
* Resolve static analysis issues reported by [scan-build] and
|
|
||||||
[Coverity scan]. More details on the page for
|
|
||||||
[Coverity scan integration].
|
|
||||||
|
|
||||||
* Resolve issues reported by the [linter][Linter issues]
|
|
||||||
|
|
||||||
[scan-build]: https://coreboot.org/scan-build/
|
|
||||||
[Coverity scan]: https://scan.coverity.com/projects/coreboot
|
|
||||||
[Coverity scan integration]: ../infrastructure/coverity.md
|
|
||||||
[Linter issues]: https://qa.coreboot.org/job/untested-coreboot-files/lastSuccessfulBuild/artifact/lint.txt
|
|
||||||
|
|
||||||
## Provide toolchain binaries
|
## Provide toolchain binaries
|
||||||
Our crossgcc subproject provides a uniform compiler environment for
|
Our crossgcc subproject provides a uniform compiler environment for
|
||||||
working on coreboot and related projects. Sadly, building it takes hours,
|
working on coreboot and related projects. Sadly, building it takes hours,
|
||||||
|
Before Width: | Height: | Size: 5.0 KiB After Width: | Height: | Size: 5.0 KiB |
Before Width: | Height: | Size: 4.5 KiB After Width: | Height: | Size: 4.5 KiB |
@@ -167,61 +167,32 @@ could cause catastrophic failures, up to and including your mainboard!
|
|||||||
As per Intel Platform Controller Hub (PCH) EDS since Skylake, a GPIO PAD register
|
As per Intel Platform Controller Hub (PCH) EDS since Skylake, a GPIO PAD register
|
||||||
supports four different types of GPIO reset as:
|
supports four different types of GPIO reset as:
|
||||||
|
|
||||||
```eval_rst
|
| PAD Reset Config | Platform Reset | GPP | GPD |
|
||||||
+------------------------+----------------+-------------+-------------+
|
|-------------------------------------------------|----------------|-----|-----|
|
||||||
| | | PAD Reset ? |
|
| 00 - Power Good (GPP: RSMRST, GPD: DSW_PWROK) | Warm Reset | N | N |
|
||||||
+ PAD Reset Config + Platform Reset +-------------+-------------+
|
| | Cold Reset | N | N |
|
||||||
| | | GPP | GPD |
|
| | S3/S4/S5 | N | N |
|
||||||
+========================+================+=============+=============+
|
| | Global Reset | N | N |
|
||||||
| | 00 - Power Good | Warm Reset | N | N |
|
| | Deep Sx | Y | N |
|
||||||
| | (GPP: RSMRST, +----------------+-------------+-------------+
|
| | G3 | Y | N |
|
||||||
| | GPD: DSW_PWROK) | Cold Reset | N | N |
|
| 01 - Deep | Warm Reset | Y | Y |
|
||||||
| +----------------+-------------+-------------+
|
| | Cold Reset | Y | Y |
|
||||||
| | S3/S4/S5 | N | N |
|
| | S3/S4/S5 | N | N |
|
||||||
| +----------------+-------------+-------------+
|
| | Global Reset | Y | Y |
|
||||||
| | Global Reset | N | N |
|
| | Deep Sx | Y | Y |
|
||||||
| +----------------+-------------+-------------+
|
| | G3 | Y | Y |
|
||||||
| | Deep Sx | Y | N |
|
| 10 - Host Reset/PLTRST | Warm Reset | Y | Y |
|
||||||
| +----------------+-------------+-------------+
|
| | Cold Reset | Y | Y |
|
||||||
| | G3 | Y | Y |
|
| | S3/S4/S5 | Y | Y |
|
||||||
+------------------------+----------------+-------------+-------------+
|
| | Global Reset | Y | Y |
|
||||||
| 01 - Deep | Warm Reset | Y | Y |
|
| | Deep Sx | Y | Y |
|
||||||
| +----------------+-------------+-------------+
|
| | G3 | Y | Y |
|
||||||
| | Cold Reset | Y | Y |
|
| 11 - Resume Reset (GPP: Reserved, GPD: RSMRST) | Warm Reset | - | N |
|
||||||
| +----------------+-------------+-------------+
|
| | Cold Reset | - | N |
|
||||||
| | S3/S4/S5 | N | N |
|
| | S3/S4/S5 | - | N |
|
||||||
| +----------------+-------------+-------------+
|
| | Global Reset | - | N |
|
||||||
| | Global Reset | Y | Y |
|
| | Deep Sx | - | Y |
|
||||||
| +----------------+-------------+-------------+
|
| | G3 | - | Y |
|
||||||
| | Deep Sx | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | G3 | Y | Y |
|
|
||||||
+------------------------+----------------+-------------+-------------+
|
|
||||||
| 10 - Host Reset/PLTRST | Warm Reset | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | Cold Reset | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | S3/S4/S5 | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | Global Reset | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | Deep Sx | Y | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | G3 | Y | Y |
|
|
||||||
+------------------------+----------------+-------------+-------------+
|
|
||||||
| | 11 - Resume Reset | Warm Reset | n/a | N |
|
|
||||||
| | (GPP: Reserved, +----------------+-------------+-------------+
|
|
||||||
| | GPD: RSMRST) | Cold Reset | n/a | N |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | S3/S4/S5 | n/a | N |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | Global Reset | n/a | N |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | Deep Sx | n/a | Y |
|
|
||||||
| +----------------+-------------+-------------+
|
|
||||||
| | G3 | n/a | Y |
|
|
||||||
+------------------------+----------------+-------------+-------------+
|
|
||||||
```
|
|
||||||
|
|
||||||
Each GPIO Community has a Pad Configuration Lock register for a GPP allowing locking
|
Each GPIO Community has a Pad Configuration Lock register for a GPP allowing locking
|
||||||
specific register fields in the PAD configuration register.
|
specific register fields in the PAD configuration register.
|
||||||
|
@@ -4,5 +4,7 @@
|
|||||||
* [Build System](build_system.md)
|
* [Build System](build_system.md)
|
||||||
* [Submodules](submodules.md)
|
* [Submodules](submodules.md)
|
||||||
* [Kconfig](kconfig.md)
|
* [Kconfig](kconfig.md)
|
||||||
|
* [Gerrit Guidelines](gerrit_guidelines.md)
|
||||||
|
* [Documentation License](license.md)
|
||||||
* [Writing Documentation](writing_documentation.md)
|
* [Writing Documentation](writing_documentation.md)
|
||||||
* [Setting up GPIOs](gpio.md)
|
* [Setting up GPIOs](gpio.md)
|
||||||
|
@@ -786,7 +786,7 @@ select <symbol> \[if <expr>\]
|
|||||||
config TPM
|
config TPM
|
||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
select MEMORY_MAPPED_TPM if ARCH_X86
|
select LPC_TPM if ARCH_X86
|
||||||
select I2C_TPM if ARCH_ARM
|
select I2C_TPM if ARCH_ARM
|
||||||
select I2C_TPM if ARCH_ARM64
|
select I2C_TPM if ARCH_ARM64
|
||||||
help
|
help
|
||||||
|
@@ -159,5 +159,5 @@ TOC tree.
|
|||||||
[guide]: http://www.sphinx-doc.org/en/stable/install.html
|
[guide]: http://www.sphinx-doc.org/en/stable/install.html
|
||||||
[Sphinx]: http://www.sphinx-doc.org/en/master/
|
[Sphinx]: http://www.sphinx-doc.org/en/master/
|
||||||
[Markdown Guide]: https://www.markdownguide.org/
|
[Markdown Guide]: https://www.markdownguide.org/
|
||||||
[Gerrit Guidelines]: ../contributing/gerrit_guidelines.md
|
[Gerrit Guidelines]: gerrit_guidelines.md
|
||||||
[review.coreboot.org]: https://review.coreboot.org
|
[review.coreboot.org]: https://review.coreboot.org
|
||||||
|
@@ -168,8 +168,14 @@ Contents:
|
|||||||
|
|
||||||
* [Getting Started](getting_started/index.md)
|
* [Getting Started](getting_started/index.md)
|
||||||
* [Tutorial](tutorial/index.md)
|
* [Tutorial](tutorial/index.md)
|
||||||
* [Contributing](contributing/index.md)
|
* [Coding Style](contributing/coding_style.md)
|
||||||
* [Community](community/index.md)
|
* [Project Ideas](contributing/project_ideas.md)
|
||||||
|
* [Documentation Ideas](contributing/documentation_ideas.md)
|
||||||
|
* [Code of Conduct](community/code_of_conduct.md)
|
||||||
|
* [Language style](community/language_style.md)
|
||||||
|
* [Community forums](community/forums.md)
|
||||||
|
* [Project services](community/services.md)
|
||||||
|
* [coreboot at conferences](community/conferences.md)
|
||||||
* [Payloads](payloads.md)
|
* [Payloads](payloads.md)
|
||||||
* [Distributions](distributions.md)
|
* [Distributions](distributions.md)
|
||||||
* [Technotes](technotes/index.md)
|
* [Technotes](technotes/index.md)
|
||||||
@@ -188,6 +194,6 @@ Contents:
|
|||||||
* [SuperIO](superio/index.md)
|
* [SuperIO](superio/index.md)
|
||||||
* [Vendorcode](vendorcode/index.md)
|
* [Vendorcode](vendorcode/index.md)
|
||||||
* [Utilities](util.md)
|
* [Utilities](util.md)
|
||||||
* [Project infrastructure & services](infrastructure/index.md)
|
* [coreboot infrastructure](infrastructure/index.md)
|
||||||
* [Release notes](releases/index.md)
|
* [Release notes for past releases](releases/index.md)
|
||||||
* [Documentation License](documentation_license.md)
|
* [Flashing firmware tutorial](flash_tutorial/index.md)
|
||||||
|
@@ -8,8 +8,8 @@ Let a jenkins admin know that you’re interested in setting up a jenkins
|
|||||||
build system.
|
build system.
|
||||||
|
|
||||||
For a permanent build system, this should generally be a dedicated
|
For a permanent build system, this should generally be a dedicated
|
||||||
machine workstation or server class machine that is not generally being
|
machine that is not generally being used for other purposes. The
|
||||||
used for other purposes. The coreboot builds are very intensive.
|
coreboot builds are very intensive.
|
||||||
|
|
||||||
It's also best to be aware that although we don't know of any security
|
It's also best to be aware that although we don't know of any security
|
||||||
issues, the jenkins-node image is run with the privileged flag which
|
issues, the jenkins-node image is run with the privileged flag which
|
||||||
@@ -26,40 +26,34 @@ Currently active Jenkins admins:
|
|||||||
* Patrick Georgi:
|
* Patrick Georgi:
|
||||||
* Email: [patrick@georgi-clan.de](mailto:patrick@georgi-clan.de)
|
* Email: [patrick@georgi-clan.de](mailto:patrick@georgi-clan.de)
|
||||||
* IRC: pgeorgi
|
* IRC: pgeorgi
|
||||||
* Martin Roth:
|
|
||||||
* Email: [gaumless@gmail.com](mailto:gaumless@gmail.com)
|
|
||||||
* IRC: martinr
|
|
||||||
|
|
||||||
### Build Machine requirements
|
### Build Machine requirements
|
||||||
|
|
||||||
For a builder, we need a very fast system with lots of threads and
|
For a builder, we need a fast system with lots of threads and plenty of
|
||||||
plenty of RAM. The builder builds and stores the git repos and output
|
RAM. The builder builds and stores the git repos and output in tmpfs
|
||||||
in tmpfs along with the ccache save area, so if there isn't enough
|
along with the ccache save area, so if there isn't enough memory, the
|
||||||
memory, the builds will slow down because of smaller ccache areas and
|
builds will slow down because of smaller ccache areas and can run into
|
||||||
can run into "out of storage space" errors.
|
"out of storage space" errors.
|
||||||
|
|
||||||
#### Current Build Machines
|
#### Current Build Machines
|
||||||
|
|
||||||
To give an idea of what a suitable build machine might be, currently the
|
To give an idea of what a suitable build machine might be, currently the
|
||||||
coreboot project has 4 active jenkins build machines.
|
coreboot project has 3 active jenkins build machines.
|
||||||
|
|
||||||
These times are taken from the week of Feb 21 - Feb 28, 2022
|
|
||||||
|
|
||||||
* Congenialbuilder - 128 threads, 256GiB RAM
|
* Congenialbuilder - 128 threads, 256GiB RAM
|
||||||
* Fastest Passing coreboot gerrit build: 6 min, 47 sec
|
* Fastest Passing coreboot gerrit build: 4 min, 30 sec
|
||||||
* Slowest Passing coreboot gerrit build: 14 min
|
* Slowest Passing coreboot gerrit build: 9 min, 56 sec
|
||||||
|
|
||||||
* Gleefulbuilder - 64 thread, 64GiB RAM
|
|
||||||
* Fastest Passing coreboot gerrit build: 10 min
|
|
||||||
* Slowest Passing coreboot gerrit build: 46 min
|
|
||||||
|
|
||||||
* Fabulousbuilder - 64 threads, 64GiB RAM
|
* Gleeful builder - 64 thread, 64GiB RAM
|
||||||
* Fastest Passing coreboot gerrit build: 7 min, 56 sec
|
* Fastest Passing coreboot gerrit build: 6 min, 6 sec
|
||||||
* Slowest Passing coreboot gerrit build: 56 min (No ccache)
|
* Slowest Passing coreboot gerrit build, 34 min
|
||||||
|
|
||||||
|
|
||||||
* Ultron (9elements) - 48 threads, 128GiB RAM
|
* Ultron (9elements) - 48 threads, 128GiB RAM
|
||||||
* Fastest Passing coreboot gerrit build: 12
|
* Fastest Passing coreboot gerrit build: 6 min, 32 sec
|
||||||
* Slowest Passing coreboot gerrit build: 58 min
|
* Slowest Passing coreboot gerrit build: 44 min
|
||||||
|
|
||||||
|
|
||||||
### Jenkins Builds
|
### Jenkins Builds
|
||||||
@@ -67,13 +61,13 @@ These times are taken from the week of Feb 21 - Feb 28, 2022
|
|||||||
There are a number of builds handled by the coreboot jenkins builders,
|
There are a number of builds handled by the coreboot jenkins builders,
|
||||||
for a number of different projects - coreboot, flashrom, memtest86+,
|
for a number of different projects - coreboot, flashrom, memtest86+,
|
||||||
em100, etc. Many of these have builders for their current master branch
|
em100, etc. Many of these have builders for their current master branch
|
||||||
as well as Gerrit and [Coverity](coverity.md) builds.
|
as well as gerrit and coverity builds.
|
||||||
|
|
||||||
You can see all the builds here:
|
You can see all the builds here:
|
||||||
[https://qa.coreboot.org/](https://qa.coreboot.org/)
|
[https://qa.coreboot.org/](https://qa.coreboot.org/)
|
||||||
|
|
||||||
Most of the time on the builders is taken up by the coreboot master and
|
Most of the time on the builders is taken up by the coreboot master and
|
||||||
coreboot gerrit builds.
|
gerrit builds.
|
||||||
|
|
||||||
* [coreboot gerrit build](https://qa.coreboot.org/job/coreboot-gerrit/)
|
* [coreboot gerrit build](https://qa.coreboot.org/job/coreboot-gerrit/)
|
||||||
([Time trend](https://qa.coreboot.org/job/coreboot-gerrit/buildTimeTrend))
|
([Time trend](https://qa.coreboot.org/job/coreboot-gerrit/buildTimeTrend))
|
||||||
@@ -133,23 +127,10 @@ the machine remotely (if you allow them).
|
|||||||
|
|
||||||
### Install and set up docker
|
### Install and set up docker
|
||||||
|
|
||||||
Install docker by following [the
|
Install docker by following the
|
||||||
directions](https://docs.docker.com/engine/install/) on the docker site.
|
[directions](https://docs.docker.com/engine/install/) on the docker
|
||||||
These instructions keep changing, so just check the latest information.
|
site. These instructions keep changing, so just check the latest
|
||||||
|
information.
|
||||||
|
|
||||||
### Set up the system for the jenkins builder
|
|
||||||
|
|
||||||
As a regular user - *Not root*, run:
|
|
||||||
|
|
||||||
```
|
|
||||||
sudo mkdir -p ${COREBOOT_JENKINS_CACHE_DIR}
|
|
||||||
sudo mkdir -p ${COREBOOT_JENKINS_CCACHE_DIR}
|
|
||||||
sudo chown $(whoami):$(whoami) ${COREBOOT_JENKINS_CCACHE_DIR}
|
|
||||||
sudo chown $(whoami):$(whoami) ${COREBOOT_JENKINS_CACHE_DIR}
|
|
||||||
wget http://www.dediprog.com/save/78.rar/to/EM100Pro.rar
|
|
||||||
mv EM100Pro.rar ${COREBOOT_JENKINS_CACHE_DIR}
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
#### Set up environment variables
|
#### Set up environment variables
|
||||||
@@ -162,8 +143,8 @@ using something other than the default.
|
|||||||
# Set the port used on your machine to connect to jenkins.
|
# Set the port used on your machine to connect to jenkins.
|
||||||
export COREBOOT_JENKINS_PORT=49151
|
export COREBOOT_JENKINS_PORT=49151
|
||||||
|
|
||||||
# Set the revision of the container from [docker hub](https://hub.docker.com/repository/docker/coreboot/coreboot-sdk)
|
# Set the revision of the container from docker hub
|
||||||
export DOCKER_COMMIT=2021-09-23_b0d87f753c
|
export DOCKER_COMMIT=65718760fa
|
||||||
|
|
||||||
# Set the location of where the jenkins cache directory will be.
|
# Set the location of where the jenkins cache directory will be.
|
||||||
export COREBOOT_JENKINS_CACHE_DIR="/srv/docker/coreboot-builder/cache"
|
export COREBOOT_JENKINS_CACHE_DIR="/srv/docker/coreboot-builder/cache"
|
||||||
@@ -218,6 +199,18 @@ Variables:
|
|||||||
DOCKER_COMMIT=65718760fa
|
DOCKER_COMMIT=65718760fa
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Set up the system for the jenkins builder
|
||||||
|
|
||||||
|
As a regular user - *Not root*, run:
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo mkdir -p ${COREBOOT_JENKINS_CACHE_DIR}
|
||||||
|
sudo mkdir -p ${COREBOOT_JENKINS_CCACHE_DIR}
|
||||||
|
sudo chown $(whoami):$(whoami) ${COREBOOT_JENKINS_CCACHE_DIR}
|
||||||
|
sudo chown $(whoami):$(whoami) ${COREBOOT_JENKINS_CACHE_DIR}
|
||||||
|
wget http://www.dediprog.com/save/78.rar/to/EM100Pro.rar
|
||||||
|
mv EM100Pro.rar ${COREBOOT_JENKINS_CACHE_DIR}
|
||||||
|
```
|
||||||
|
|
||||||
### Install the coreboot jenkins builder
|
### Install the coreboot jenkins builder
|
||||||
|
|
||||||
@@ -233,17 +226,17 @@ machine profile on qa.coreboot.org.
|
|||||||
|
|
||||||
They need to know:
|
They need to know:
|
||||||
* Your external IP address or domain name. If you don’t have a static
|
* Your external IP address or domain name. If you don’t have a static
|
||||||
IP, make sure you have a dynamic dns hostname configured.
|
IP, make sure you have a dynamic dns hostname configured.
|
||||||
* The port on your machine and firewall that’s exposed for jenkins:
|
* The port on your machine and firewall that’s exposed for jenkins:
|
||||||
`$COREBOOT_JENKINS_PORT`
|
`$COREBOOT_JENKINS_PORT`
|
||||||
* The core count of the machine.
|
* The core count of the machine.
|
||||||
* How much memory is available on the machine. This helps determine
|
* How much memory is available on the machine. This helps determine
|
||||||
the amount of memory used for ccache.
|
the amount of memory used for ccache.
|
||||||
|
|
||||||
|
|
||||||
### First build
|
### First build
|
||||||
On the first build after a machine is reset, it will frequently take
|
On the first build after a machine is reset, it will frequently take
|
||||||
an hour to do the entire what-jenkins-does build while the ccache
|
20-25 minutes to do the entire what-jenkins-does build while the ccache
|
||||||
is getting filled up and the entire coreboot repo gets downloaded. As
|
is getting filled up and the entire coreboot repo gets downloaded. As
|
||||||
the ccache gets populated, the build time will drop.
|
the ccache gets populated, the build time will drop.
|
||||||
|
|
||||||
@@ -261,12 +254,12 @@ the ccache gets populated, the build time will drop.
|
|||||||
|
|
||||||
|
|
||||||
WARNING: This should not be used to make changes to the build system,
|
WARNING: This should not be used to make changes to the build system,
|
||||||
but just to debug issues. Changes to the build system image are highly
|
but just to debug issues. Changes to the build system are highly
|
||||||
discouraged as it leads to situations where patches can pass the build
|
discouraged as it leads to situations where patches can pass the build
|
||||||
testing on one builder and fail on another builder. Any changes that are
|
testing on one builder and fail on another builder. Any changes that are
|
||||||
made in the image will be lost on the next update, so if you
|
made in the image will be lost on the next update, so if you
|
||||||
accidentally change something, you can remove the containers and images,
|
accidentally change something, you can remove the containers and images
|
||||||
then update to get a fresh installation.
|
and update to get a fresh installation.
|
||||||
|
|
||||||
|
|
||||||
### How to download containers/images for a fresh installation and remove old containers
|
### How to download containers/images for a fresh installation and remove old containers
|
||||||
@@ -383,7 +376,6 @@ to be marked as a coverity builder.
|
|||||||
|
|
||||||
Download the Linux-64 coverity build tool and decompress it into your
|
Download the Linux-64 coverity build tool and decompress it into your
|
||||||
cache directory as defined by the `$COREBOOT_JENKINS_CACHE_DIR` variable
|
cache directory as defined by the `$COREBOOT_JENKINS_CACHE_DIR` variable
|
||||||
on the jenkins server.
|
|
||||||
|
|
||||||
[https://scan.coverity.com/download](https://scan.coverity.com/download)
|
[https://scan.coverity.com/download](https://scan.coverity.com/download)
|
||||||
|
|
||||||
|
@@ -1,103 +0,0 @@
|
|||||||
# Coverity Scan for open source firmware
|
|
||||||
|
|
||||||
## What’s Coverity and Coverity Scan?
|
|
||||||
|
|
||||||
Coverity is a static analysis tool. It hooks into the build process
|
|
||||||
and in addition to the compiler creating object files, Coverity collects
|
|
||||||
information about the code. That data is then processed in a separate pass
|
|
||||||
to identify common programming errors, like out of bounds accesses in C.
|
|
||||||
|
|
||||||
Coverity Scan is an online service for Open Source projects providing this
|
|
||||||
analysis for free. The analysis pass is done on their servers and issues
|
|
||||||
can be handled in their [web UI](https://scan.coverity.com/).
|
|
||||||
|
|
||||||
The Scan service has some quotas based on code size to avoid overloading
|
|
||||||
the system, but even at one build per week, that’s usually good enough
|
|
||||||
because the identified issues still need to be triaged and fixed or they
|
|
||||||
will simply be re-identified next week.
|
|
||||||
|
|
||||||
### Triage?
|
|
||||||
|
|
||||||
The Web UI looks a bit like an issue tracker, even if it’s not a very
|
|
||||||
good one. It’s possible to mark identified issues as valid or invalid,
|
|
||||||
and annotate them with metadata which CLs fix them. The latter isn’t
|
|
||||||
strictly necessary because Coverity Scan simply marks issues it can’t
|
|
||||||
find anymore as fixed, but at times it helped identify issues that made
|
|
||||||
a comeback.
|
|
||||||
|
|
||||||
### Alternatives
|
|
||||||
|
|
||||||
There’s also clang’s scan-build, which is fully open-source, and
|
|
||||||
finds different issues. As such, it’s less of an alternative and more
|
|
||||||
of a complement.
|
|
||||||
|
|
||||||
There’s a regular run of that for coreboot but not for the other projects
|
|
||||||
hosted at coreboot.org.
|
|
||||||
|
|
||||||
One downside is that it emits a bunch of HTML to report on issues,
|
|
||||||
but there’s no interactivity (e.g. marking issues solved), no way
|
|
||||||
to merge multiple builds (e.g. multiple board builds of a single tree)
|
|
||||||
or a simple way to extract burndown charts and the like from that.
|
|
||||||
|
|
||||||
#### Looking for a project?
|
|
||||||
|
|
||||||
On the upside, it can emit the data in a machine readable format, so if
|
|
||||||
anybody needs a project, a scan-build web-frontend like Coverity Scan would
|
|
||||||
be feasible without having to go through scan-build’s guts, just by parsing
|
|
||||||
text files - plus all the stateful and web parts to build on top.
|
|
||||||
|
|
||||||
## Logging into Coverity Scan
|
|
||||||
|
|
||||||
Coverity Scan needs an account. It supports its own accounts and GitHub
|
|
||||||
OAuth.
|
|
||||||
|
|
||||||
Access to the dashboards needs approval: Request and you shall receive.
|
|
||||||
|
|
||||||
## coreboot & friends and Coverity Scan
|
|
||||||
|
|
||||||
coreboot, flashrom, Chromium EC and other projects of that family have
|
|
||||||
been made Coverity aware, that is, their build systems support building
|
|
||||||
with a custom compiler configuration passed in “just right” to enable
|
|
||||||
Coverity to add its hooks.
|
|
||||||
|
|
||||||
The public coreboot CI system at
|
|
||||||
[https://qa.coreboot.org/](https://qa.coreboot.org/) regularly does
|
|
||||||
builds with Coverity and sends them off to Coverity Scan.
|
|
||||||
|
|
||||||
Specifically, it covers:
|
|
||||||
|
|
||||||
* Chromium EC: [Coverity Scan site][crECCoverity] ([build job][crECBuildJob])
|
|
||||||
* coreboot: [Coverity Scan site][corebootCoverity] ([build job][corebootBuildJob]), [scan-build output][corebootScanBuild] ([build job][corebootScanBuildJob])
|
|
||||||
* em100: [Coverity Scan site][em100Coverity] ([build job][em100BuildJob])
|
|
||||||
* fcode-utils: [Coverity Scan site][fcodeUtilsCoverity] ([build job][fcodeUtilsBuildJob])
|
|
||||||
* flashrom: [Coverity Scan site][flashromCoverity] ([build job][flashromBuildJob])
|
|
||||||
* memtest86+: [Coverity Scan site][memtestCoverity] ([build job][memtestBuildJob])
|
|
||||||
* vboot: [Coverity Scan site][vbootCoverity] ([build job][vbootBuildJob])
|
|
||||||
|
|
||||||
[crECCoverity]: https://scan.coverity.com/projects/chromium-ec
|
|
||||||
[corebootCoverity]: https://scan.coverity.com/projects/coreboot
|
|
||||||
[em100Coverity]: https://scan.coverity.com/projects/em100
|
|
||||||
[fcodeUtilsCoverity]: https://scan.coverity.com/projects/fcode-utils
|
|
||||||
[flashromCoverity]: https://scan.coverity.com/projects/flashrom
|
|
||||||
[memtestCoverity]: https://scan.coverity.com/projects/memtest86
|
|
||||||
[vbootCoverity]: https://scan.coverity.com/projects/vboot
|
|
||||||
|
|
||||||
[corebootScanBuild]: https://www.coreboot.org/scan-build/
|
|
||||||
|
|
||||||
[crECBuildJob]: https://qa.coreboot.org/view/coverity/job/ChromeEC-Coverity/
|
|
||||||
[corebootBuildJob]: https://qa.coreboot.org/view/coverity/job/coreboot-coverity/
|
|
||||||
[corebootScanBuildJob]: https://qa.coreboot.org/view/coverity/job/coreboot_scanbuild/
|
|
||||||
[em100BuildJob]: https://qa.coreboot.org/view/coverity/job/em100-coverity/
|
|
||||||
[fcodeUtilsBuildJob]: https://qa.coreboot.org/view/coverity/job/fcode-utils-coverity/
|
|
||||||
[flashromBuildJob]: https://qa.coreboot.org/view/coverity/job/flashrom-coverity/
|
|
||||||
[memtestBuildJob]: https://qa.coreboot.org/view/coverity/job/memtest86plus-coverity/
|
|
||||||
[vbootBuildJob]: https://qa.coreboot.org/view/coverity/job/vboot-coverity/
|
|
||||||
|
|
||||||
Some projects (e.g. Chromium EC) build a different subset of boards on
|
|
||||||
each run, ensuring that everything is analyzed eventually. The downside
|
|
||||||
is that coverity issues pop up and disappear somewhat randomly as they
|
|
||||||
are discovered and go unnoticed in a later build.
|
|
||||||
|
|
||||||
More projects that are hosted on review.coreboot.org (potentially as a
|
|
||||||
mirror, like vboot and EC) could be served through that pipeline. Reach
|
|
||||||
out to {stepan,patrick,martin}@coreboot.org.
|
|
@@ -1,12 +1,6 @@
|
|||||||
# Project infrastructure & services
|
# coreboot infrastructure
|
||||||
|
|
||||||
This section contains documentation about our infrastructure
|
|
||||||
|
|
||||||
## Services
|
|
||||||
|
|
||||||
* [Project services](services.md)
|
|
||||||
|
|
||||||
|
This section contains documentation about coreboot infrastructure
|
||||||
|
|
||||||
## Jenkins builders and builds
|
## Jenkins builders and builds
|
||||||
* [Setting up Jenkins build machines](builders.md)
|
* [Setting up Jenkins build machines](builders.md)
|
||||||
* [Coverity Scan integration](coverity.md)
|
|
||||||
|
@@ -124,7 +124,7 @@ $ sudo flashrom \
|
|||||||
|
|
||||||
```eval_rst
|
```eval_rst
|
||||||
In addition to the information here, please see the
|
In addition to the information here, please see the
|
||||||
:doc:`../../tutorial/flashing_firmware/index`.
|
:doc:`../../flash_tutorial/index`.
|
||||||
```
|
```
|
||||||
|
|
||||||
### External flashing
|
### External flashing
|
||||||
|
@@ -58,7 +58,7 @@ The main SPI flash can be accessed using [flashrom]. By default, only
|
|||||||
the BIOS region of the flash is writable. If you wish to change any
|
the BIOS region of the flash is writable. If you wish to change any
|
||||||
other region, such as the Management Engine or firmware descriptor, then
|
other region, such as the Management Engine or firmware descriptor, then
|
||||||
an external programmer is required (unless you find a clever way around
|
an external programmer is required (unless you find a clever way around
|
||||||
the flash protection). More information about this [here](../../tutorial/flashing_firmware/index.md).
|
the flash protection). More information about this [here](../../flash_tutorial/index.md).
|
||||||
|
|
||||||
### External programming
|
### External programming
|
||||||
|
|
||||||
@@ -131,4 +131,4 @@ facing towards the bottom of the board.
|
|||||||
[ASRock H110M-DVS]: https://www.asrock.com/mb/Intel/H110M-DVS%20R2.0/
|
[ASRock H110M-DVS]: https://www.asrock.com/mb/Intel/H110M-DVS%20R2.0/
|
||||||
[MX25L6473E]: http://www.macronix.com/Lists/Datasheet/Attachments/7380/MX25L6473E,%203V,%2064Mb,%20v1.4.pdf
|
[MX25L6473E]: http://www.macronix.com/Lists/Datasheet/Attachments/7380/MX25L6473E,%203V,%2064Mb,%20v1.4.pdf
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[H110M-DVS manual]: https://web.archive.org/web/20191023230631/http://asrock.pc.cdn.bitgravity.com/Manual/H110M-DVS%20R2.0.pdf
|
[H110M-DVS manual]: http://asrock.pc.cdn.bitgravity.com/Manual/H110M-DVS%20R2.0.pdf
|
||||||
|
@@ -115,7 +115,7 @@ region is not readable even by the host.
|
|||||||
|
|
||||||
```eval_rst
|
```eval_rst
|
||||||
In addition to the information here, please see the
|
In addition to the information here, please see the
|
||||||
:doc:`../../tutorial/flashing_firmware/index`.
|
:doc:`../../flash_tutorial/index`.
|
||||||
```
|
```
|
||||||
|
|
||||||
## Hardware monitoring and fan control
|
## Hardware monitoring and fan control
|
||||||
|
@@ -130,4 +130,4 @@ Please also see :doc:`../../northbridge/intel/haswell/known-issues`.
|
|||||||
[ASRock H81M-HDS]: https://www.asrock.com/mb/Intel/H81M-HDS/
|
[ASRock H81M-HDS]: https://www.asrock.com/mb/Intel/H81M-HDS/
|
||||||
[W25Q32FV]: https://www.winbond.com/resource-files/w25q32fv%20revi%2010202015.pdf
|
[W25Q32FV]: https://www.winbond.com/resource-files/w25q32fv%20revi%2010202015.pdf
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[Board manual]: https://web.archive.org/web/20191231093418/http://asrock.pc.cdn.bitgravity.com/Manual/H81M-HDS.pdf
|
[Board manual]: http://asrock.pc.cdn.bitgravity.com/Manual/H81M-HDS.pdf
|
||||||
|
@@ -190,9 +190,9 @@ This version is usable for all the GPUs.
|
|||||||
- [Board manual]
|
- [Board manual]
|
||||||
- Flash chip datasheet [W25Q64FV]
|
- Flash chip datasheet [W25Q64FV]
|
||||||
|
|
||||||
[ASUS F2A85-M]: https://web.archive.org/web/20160320065008/http://www.asus.com/Motherboards/F2A85M/
|
[ASUS F2A85-M]: https://www.asus.com/Motherboards/F2A85M/
|
||||||
[Board manual]: https://web.archive.org/web/20211028063105/https://dlcdnets.asus.com/pub/ASUS/mb/SocketFM2/F2A85-M/E8005_F2A85-M.pdf
|
[Board manual]: https://dlcdnets.asus.com/pub/ASUS/mb/SocketFM2/F2A85-M/E8005_F2A85-M.pdf
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[Piledriver]: https://en.wikipedia.org/wiki/Piledriver_%28microarchitecture%29#APU_lines
|
[Piledriver]: https://en.wikipedia.org/wiki/Piledriver_%28microarchitecture%29#APU_lines
|
||||||
[TeraScale 3]: https://en.wikipedia.org/wiki/TeraScale_%28microarchitecture%29#TeraScale_3
|
[TeraScale 3]: https://en.wikipedia.org/wiki/TeraScale_%28microarchitecture%29#TeraScale_3
|
||||||
[W25Q64FV]: https://web.archive.org/web/20220127184640/https://www.winbond.com/resource-files/w25q64fv%20revs%2007182017.pdf
|
[W25Q64FV]: https://www.winbond.com/resource-files/w25q64fv%20revs%2007182017.pdf
|
||||||
|
@@ -130,5 +130,5 @@ You can also control the CPU fan with similar rules:
|
|||||||
echo 2000 >/sys/class/hwmon/hwmon2/pwm1_tolerance
|
echo 2000 >/sys/class/hwmon/hwmon2/pwm1_tolerance
|
||||||
|
|
||||||
[ASUS P5Q]: https://www.asus.com/Motherboards/P5Q
|
[ASUS P5Q]: https://www.asus.com/Motherboards/P5Q
|
||||||
[this guide]: ../../tutorial/flashing_firmware/int_flashrom.md
|
[this guide]: https://doc.coreboot.org/flash_tutorial/int_flashrom.html
|
||||||
[kernel docs]: https://www.kernel.org/doc/Documentation/hwmon/w83627ehf.rst
|
[kernel docs]: https://www.kernel.org/doc/Documentation/hwmon/w83627ehf.rst
|
||||||
|
@@ -106,6 +106,6 @@ region is not readable even by the host.
|
|||||||
- [Flash chip datasheet][W25Q32BV]
|
- [Flash chip datasheet][W25Q32BV]
|
||||||
|
|
||||||
[ASUS P8H61-M LX]: https://www.asus.com/Motherboards/P8H61M_LX/
|
[ASUS P8H61-M LX]: https://www.asus.com/Motherboards/P8H61M_LX/
|
||||||
[W25Q32BV]: https://web.archive.org/web/20211002141814/https://www.winbond.com/resource-files/w25q32bv_revi_100413_wo_automotive.pdf
|
[W25Q32BV]: https://www.winbond.com/resource-files/w25q32bv_revi_100413_wo_automotive.pdf
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[Board manual]: http://dlcdnet.asus.com/pub/ASUS/mb/LGA1155/P8H61_M_LX/E6803_P8H61-M_LX.zip
|
[Board manual]: http://dlcdnet.asus.com/pub/ASUS/mb/LGA1155/P8H61_M_LX/E6803_P8H61-M_LX.zip
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
# QEMU RISC-V emulator
|
# Qemu RISC-V emulator
|
||||||
|
|
||||||
## Building coreboot and running it in QEMU
|
## Building coreboot and running it in Qemu
|
||||||
|
|
||||||
- Configure coreboot and run `make` as usual
|
- Configure coreboot and run `make` as usual
|
||||||
- Run `util/riscv/make-spike-elf.sh build/coreboot.rom build/coreboot.elf` to
|
- Run `util/riscv/make-spike-elf.sh build/coreboot.rom build/coreboot.elf` to
|
||||||
convert coreboot to an ELF that QEMU can load
|
convert coreboot to an ELF that Qemu can load
|
||||||
- Run `qemu-system-riscv64 -M virt -m 1024M -nographic -kernel build/coreboot.elf`
|
- Run `qemu-system-riscv64 -M virt -m 1024M -nographic -kernel build/coreboot.elf`
|
||||||
|
@@ -142,7 +142,7 @@ Built gigabyte/ga-g41m-es2l (GA-G41M-ES2L)
|
|||||||
|
|
||||||
```eval_rst
|
```eval_rst
|
||||||
In addition to the information here, please see the
|
In addition to the information here, please see the
|
||||||
:doc:`../../tutorial/flashing_firmware/index`.
|
:doc:`../../flash_tutorial/index`.
|
||||||
```
|
```
|
||||||
|
|
||||||
### Do backup
|
### Do backup
|
||||||
|
@@ -94,6 +94,6 @@ Schematic of this laptop can be found on [Lab One].
|
|||||||
|
|
||||||
[HP EliteBook 2560p]: https://support.hp.com/us-en/product/hp-elitebook-2560p-notebook-pc/5071201
|
[HP EliteBook 2560p]: https://support.hp.com/us-en/product/hp-elitebook-2560p-notebook-pc/5071201
|
||||||
[Maintenance and Service Guide]: http://h10032.www1.hp.com/ctg/Manual/c03011618
|
[Maintenance and Service Guide]: http://h10032.www1.hp.com/ctg/Manual/c03011618
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
[Lab One]: https://www.laboneinside.com/hp-elitebook-2560p-schematic-diagram/
|
[Lab One]: https://www.laboneinside.com/hp-elitebook-2560p-schematic-diagram/
|
||||||
[bug #141]: https://ticket.coreboot.org/issues/141
|
[bug #141]: https://ticket.coreboot.org/issues/141
|
||||||
|
@@ -48,11 +48,10 @@ This section contains documentation about coreboot on specific mainboards.
|
|||||||
The boards in this section are not real mainboards, but emulators.
|
The boards in this section are not real mainboards, but emulators.
|
||||||
|
|
||||||
- [Spike RISC-V emulator](emulation/spike-riscv.md)
|
- [Spike RISC-V emulator](emulation/spike-riscv.md)
|
||||||
- [QEMU RISC-V emulator](emulation/qemu-riscv.md)
|
- [Qemu RISC-V emulator](emulation/qemu-riscv.md)
|
||||||
- [QEMU AArch64 emulator](emulation/qemu-aarch64.md)
|
- [Qemu AArch64 emulator](emulation/qemu-aarch64.md)
|
||||||
- [QEMU x86 Q35](emulation/qemu-q35.md)
|
- [Qemu x86 Q35](emulation/qemu-q35.md)
|
||||||
- [QEMU x86 PC](emulation/qemu-i440fx.md)
|
- [Qemu x86 PC](emulation/qemu-i440fx.md)
|
||||||
- [QEMU POWER9](emulation/qemu-power9.md)
|
|
||||||
|
|
||||||
## Facebook
|
## Facebook
|
||||||
|
|
||||||
@@ -180,14 +179,10 @@ The boards in this section are not real mainboards, but emulators.
|
|||||||
|
|
||||||
## Star Labs Systems
|
## Star Labs Systems
|
||||||
|
|
||||||
- [LabTop Mk IV](starlabs/labtop_cml.md)
|
|
||||||
- [StarLite Mk III](starlabs/lite_glk.md)
|
|
||||||
- [StarLite Mk IV](starlabs/lite_glkr.md)
|
|
||||||
- [StarBook Mk V](starlabs/starbook_tgl.md)
|
- [StarBook Mk V](starlabs/starbook_tgl.md)
|
||||||
|
|
||||||
## Supermicro
|
## Supermicro
|
||||||
|
|
||||||
- [X9SAE](supermicro/x9sae.md)
|
|
||||||
- [X10SLM+-F](supermicro/x10slm-f.md)
|
- [X10SLM+-F](supermicro/x10slm-f.md)
|
||||||
- [X11 LGA1151 series](supermicro/x11-lga1151-series/x11-lga1151-series.md)
|
- [X11 LGA1151 series](supermicro/x11-lga1151-series/x11-lga1151-series.md)
|
||||||
- [Flashing using the BMC](supermicro/flashing_on_vendorbmc.md)
|
- [Flashing using the BMC](supermicro/flashing_on_vendorbmc.md)
|
||||||
|
@@ -38,7 +38,7 @@ This information is valid for all supported models, except T430s, [T431s](t431s.
|
|||||||
* ROM chip size should be set to 12MiB.
|
* ROM chip size should be set to 12MiB.
|
||||||
|
|
||||||
```eval_rst
|
```eval_rst
|
||||||
Please also have a look at :doc:`../../tutorial/flashing_firmware/index`.
|
Please also have a look at :doc:`../../flash_tutorial/index`.
|
||||||
```
|
```
|
||||||
|
|
||||||
## Splitting the coreboot.rom
|
## Splitting the coreboot.rom
|
||||||
@@ -90,4 +90,4 @@ Tests on Lenovo W530 showed no issues with a stripped and shrunken ME firmware.
|
|||||||
|
|
||||||
|
|
||||||
[me_cleaner]: ../../northbridge/intel/sandybridge/me_cleaner.md
|
[me_cleaner]: ../../northbridge/intel/sandybridge/me_cleaner.md
|
||||||
[external programmer]: ../../tutorial/flashing_firmware/index.md
|
[external programmer]: ../../flash_tutorial/index.md
|
||||||
|
@@ -70,5 +70,5 @@ the remaining space for the `bios` partition.
|
|||||||
|
|
||||||
|
|
||||||
[me_cleaner]: ../../northbridge/intel/sandybridge/me_cleaner.md
|
[me_cleaner]: ../../northbridge/intel/sandybridge/me_cleaner.md
|
||||||
[external programmer]: ../../tutorial/flashing_firmware/index.md
|
[external programmer]: ../../flash_tutorial/index.md
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/index.md
|
[flashing tutorial]: ../../flash_tutorial/index.md
|
||||||
|
@@ -353,12 +353,9 @@ Verify that it worked:
|
|||||||
|
|
||||||
Bingo!
|
Bingo!
|
||||||
|
|
||||||
Now you can [flash internally]. Remember to flash only the `bios` region
|
Now you can [flash internally](/flash_tutorial/int_flashrom.md).
|
||||||
(use `--ifd -i bios -N` flashrom arguments). `fd` and `me` are still
|
Remember to flash only the `bios` region (use `--ifd -i bios -N`
|
||||||
locked.
|
flashrom arguments). `fd` and `me` are still locked.
|
||||||
|
|
||||||
Note that you should have an external SPI programmer as a backup method.
|
Note that you should have an external SPI programmer as a backup method.
|
||||||
It will help you recover if you flash non-working ROM by mistake.
|
It will help you recover if you flash non-working ROM by mistake.
|
||||||
|
|
||||||
|
|
||||||
[flash internally]: ../../tutorial/flashing_firmware/int_flashrom.md
|
|
||||||
|
@@ -37,7 +37,7 @@ The chip will either be a Macronix MX25L6405D or a Winbond W25Q64CVSIG.
|
|||||||
Do not rely on dots painted in the corner of the chip (such as the blue dot
|
Do not rely on dots painted in the corner of the chip (such as the blue dot
|
||||||
pictured) to orient the pins!
|
pictured) to orient the pins!
|
||||||
|
|
||||||
[Flashing tutorial](../../tutorial/flashing_firmware/no_ext_power.md)
|
[Flashing tutorial](../../flash_tutorial/no_ext_power.md)
|
||||||
|
|
||||||
Steps to access the flash IC are described here [T4xx series].
|
Steps to access the flash IC are described here [T4xx series].
|
||||||
|
|
||||||
|
@@ -53,5 +53,5 @@ Steps to access the flash IC are described here [T4xx series].
|
|||||||
* Suspend (Windows 10)
|
* Suspend (Windows 10)
|
||||||
|
|
||||||
[T4xx series]: t4xx_series.md
|
[T4xx series]: t4xx_series.md
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
[T420 / T520 / X220 / T420s / W520 common]: Sandy_Bridge_series.md
|
[T420 / T520 / X220 / T420s / W520 common]: Sandy_Bridge_series.md
|
||||||
|
@@ -9,6 +9,6 @@ the general [flashing tutorial].
|
|||||||
|
|
||||||
Steps to access the flash IC are described here [T4xx series].
|
Steps to access the flash IC are described here [T4xx series].
|
||||||
|
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
[T4xx series]: t4xx_series.md
|
[T4xx series]: t4xx_series.md
|
||||||
[T430 / T530 / X230 / T430s / W530 common]: Ivy_Bridge_series.md
|
[T430 / T530 / X230 / T430s / W530 common]: Ivy_Bridge_series.md
|
||||||
|
@@ -22,5 +22,5 @@ the general [flashing tutorial].
|
|||||||
|
|
||||||
[w530-2]: w530-2.jpg
|
[w530-2]: w530-2.jpg
|
||||||
|
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
[T430 / T530 / X230 / T430s / W530 common]: Ivy_Bridge_series.md
|
[T430 / T530 / X230 / T430s / W530 common]: Ivy_Bridge_series.md
|
||||||
|
@@ -18,5 +18,5 @@ the general [flashing tutorial].
|
|||||||
Steps to access the flash IC are described here [X2xx series].
|
Steps to access the flash IC are described here [X2xx series].
|
||||||
|
|
||||||
[X2xx series]: x2xx_series.md
|
[X2xx series]: x2xx_series.md
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
[T420 / T520 / X220 / T420s / W520 common]: Sandy_Bridge_series.md
|
[T420 / T520 / X220 / T420s / W520 common]: Sandy_Bridge_series.md
|
||||||
|
@@ -16,4 +16,4 @@ is located at the circled place.
|
|||||||
|
|
||||||
Unlike [most Ivy Bridge ThinkPads](Ivy_Bridge_series.md), X230s has a single 16MiB SPI flash chip.
|
Unlike [most Ivy Bridge ThinkPads](Ivy_Bridge_series.md), X230s has a single 16MiB SPI flash chip.
|
||||||
|
|
||||||
The general [flashing tutorial](../../tutorial/flashing_firmware/index.md) has more details.
|
The general [flashing tutorial](../../flash_tutorial/index.md) has more details.
|
||||||
|
@@ -43,5 +43,5 @@ Tested:
|
|||||||
Linux payload (Heads) and SeaBIOS.
|
Linux payload (Heads) and SeaBIOS.
|
||||||
|
|
||||||
|
|
||||||
[flashing tutorial]: ../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../flash_tutorial/ext_power.md
|
||||||
|
|
||||||
|
@@ -74,7 +74,7 @@ seconds. Setting the jumper alone is not enough (the Fintek is VBAT backed).
|
|||||||
Put all back in place and restart the board. It might need 1-2 AC power cycles
|
Put all back in place and restart the board. It might need 1-2 AC power cycles
|
||||||
to reinitialize (running at full fan speed - don't panic).
|
to reinitialize (running at full fan speed - don't panic).
|
||||||
* External flashing has been tested with RPi2 without main power connected.
|
* External flashing has been tested with RPi2 without main power connected.
|
||||||
3.3V provided by RPi2. Read more about [flashing methods].
|
3.3V provided by RPi2. Read more about flashing methods [here](https://doc.coreboot.org/flash_tutorial/index.html).
|
||||||
* In case of going back to proprietary BIOS create/save CMOS settings as early
|
* In case of going back to proprietary BIOS create/save CMOS settings as early
|
||||||
as possible (do not leave BIOS on first start without saving settings).
|
as possible (do not leave BIOS on first start without saving settings).
|
||||||
The BIOS might corrupt nvram (not cmos!) and leave the system in a dead state
|
The BIOS might corrupt nvram (not cmos!) and leave the system in a dead state
|
||||||
@@ -110,4 +110,3 @@ needed (internally re-routed already).
|
|||||||
[Winbond 25Q32BV datasheet]: https://www.winbond.com/resource-files/w25q32bv_revi_100413_wo_automotive.pdf
|
[Winbond 25Q32BV datasheet]: https://www.winbond.com/resource-files/w25q32bv_revi_100413_wo_automotive.pdf
|
||||||
[Fintek F71808A datasheet]: https://www.alldatasheet.com/datasheet-pdf/pdf/459069/FINTEK/F71808A.html
|
[Fintek F71808A datasheet]: https://www.alldatasheet.com/datasheet-pdf/pdf/459069/FINTEK/F71808A.html
|
||||||
[flashlayout]: flashlayout.svg
|
[flashlayout]: flashlayout.svg
|
||||||
[flashing methods]: ../../../tutorial/flashing_firmware/index.md
|
|
||||||
|
@@ -49,6 +49,6 @@ The board features:
|
|||||||
## Extra links
|
## Extra links
|
||||||
|
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[flashing tutorial]: ../../../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../../../flash_tutorial/ext_power.md
|
||||||
[Intel FSP2.0]: ../../../../soc/intel/fsp/index.md
|
[Intel FSP2.0]: ../../../../soc/intel/fsp/index.md
|
||||||
[AST2500]: https://www.aspeedtech.com/products.php?fPath=20&rId=440
|
[AST2500]: https://www.aspeedtech.com/products.php?fPath=20&rId=440
|
||||||
|
@@ -1,71 +0,0 @@
|
|||||||
# Flashing with fwupd
|
|
||||||
|
|
||||||
#### **Requirements:**
|
|
||||||
|
|
||||||
* fwupd version 1.5.6 or later
|
|
||||||
* The battery must be charged to at least 30%
|
|
||||||
* The charger must be connected (either USB-C or DC Jack)
|
|
||||||
* BIOS Lock must be disabled
|
|
||||||
* Supported Linux distribution (Ubuntu 20.04 +, Linux Mint 20.1 + elementaryOS 6 +, Manjaro 21+)
|
|
||||||
|
|
||||||
**fwupd 1.5.6 or later**
|
|
||||||
To check the version of **fwupd** you have installed, open a terminal window and enter the below command:
|
|
||||||
|
|
||||||
```
|
|
||||||
fwupdmgr --version
|
|
||||||
```
|
|
||||||
|
|
||||||
This will show the version number. **1.5.6** or greater will work.
|
|
||||||

|
|
||||||
On Ubuntu 20.04, Ubuntu 20.10, Linux Mint 20.1 and elementaryOS 6, fwupd 1.5.6 can be installed from our PPA with the below terminal commands:
|
|
||||||
|
|
||||||
```
|
|
||||||
sudo add-apt-repository ppa:starlabs/ppa
|
|
||||||
sudo apt update
|
|
||||||
sudo apt install fwupd
|
|
||||||
```
|
|
||||||
|
|
||||||
On Manjaro:
|
|
||||||
|
|
||||||
```
|
|
||||||
sudo pacman -Sy fwupd-git flashrom-starlabs
|
|
||||||
```
|
|
||||||
|
|
||||||
Instructions for other distributions will be added once fwupd 1.5.6 is available. If you are not using one of the distributions listed above, it is possible to install coreboot using a Live USB.
|
|
||||||
|
|
||||||
**Disable BIOS Lock**
|
|
||||||
BIOS Lock must be disabled when switching from the standard AMI (American Megatrends Inc.) firmware to coreboot. To disable BIOS Lock:
|
|
||||||
|
|
||||||
1\. Start with your LabTop turned off\. Turn it on whilst holding the **F2** key to access the BIOS settings.
|
|
||||||
2\. When the BIOS settings load, use the arrow keys to navigate to the **Advanced** tab\. Here you will see **BIOS Lock**\.
|
|
||||||
3\. Press `Enter` to change this setting from **Enabled** to **Disabled**
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
4\. Next, press the `F10` key to **Save & Exit** and then `Enter` to confirm.
|
|
||||||
|
|
||||||
#### **Switching Branch**
|
|
||||||
|
|
||||||
Switching branch refers to changing from AMI firmware to coreboot, or vice versa.
|
|
||||||
|
|
||||||
First, check for new firmware files with the below terminal command:
|
|
||||||
|
|
||||||
```
|
|
||||||
fwupdmgr refresh --force
|
|
||||||
```
|
|
||||||
|
|
||||||
Then, to change branch, enter the below terminal command:
|
|
||||||
|
|
||||||
```
|
|
||||||
fwupdmgr switch-branch
|
|
||||||
```
|
|
||||||
|
|
||||||
You can then select which branch you would like to use, by typing in the corresponding number:
|
|
||||||

|
|
||||||
You will be prompted to confirm, press `y` to continue or `n` to cancel.
|
|
||||||
|
|
||||||
Once the switch has been completed, you will be prompted to restart.
|
|
||||||
|
|
||||||
The next reboot can take up to **5 minutes,** do not interrupt this process or disconnect the charger. Once the reboot is complete, that's it - you'll continue to receive updates for whichever branch you are using.
|
|
||||||
|
|
||||||
You can switch branch at any time.
|
|
@@ -1,87 +0,0 @@
|
|||||||
# Star LabTop Mk IV
|
|
||||||
|
|
||||||
## Specs
|
|
||||||
|
|
||||||
- CPU (full processor specs available at https://ark.intel.com)
|
|
||||||
- Intel i7-10710U (Comet Lake)
|
|
||||||
- Intel i3-10110U (Comet Lake)
|
|
||||||
- EC
|
|
||||||
- ITE IT8987E
|
|
||||||
- Backlit Keyboard, with standard PS/2 keycodes and SCI hotkeys
|
|
||||||
- Battery
|
|
||||||
- Charger, using AC adapter or USB-C PD
|
|
||||||
- Suspend / resume
|
|
||||||
- GPU
|
|
||||||
- Intel UHD Graphics 620
|
|
||||||
- GOP driver is recommended, VBT is provided
|
|
||||||
- eDP 13-inch 1920x1080 LCD
|
|
||||||
- HDMI video
|
|
||||||
- USB-C DisplayPort video
|
|
||||||
- Memory
|
|
||||||
- 16GB on-board *1
|
|
||||||
- Networking
|
|
||||||
- AX201 CNVi WiFi / Bluetooth soldered to PCBA
|
|
||||||
- Sound
|
|
||||||
- Realtek ALC256
|
|
||||||
- Internal speakers
|
|
||||||
- Internal microphone
|
|
||||||
- Combined headphone / microphone 3.5-mm jack
|
|
||||||
- HDMI audio
|
|
||||||
- USB-C DisplayPort audio
|
|
||||||
- Storage
|
|
||||||
- M.2 PCIe SSD
|
|
||||||
- RTS5129 MicroSD card reader
|
|
||||||
- USB
|
|
||||||
- 1280x720 CCD camera
|
|
||||||
- USB 3.1 Gen 2 Type-C (left)
|
|
||||||
- USB 3.1 Gen 2 Type-A (left)
|
|
||||||
- USB 3.1 Gen 1 Type-A (right)
|
|
||||||
|
|
||||||
[^1] The Comet Lake PCB supports multiple memory variations that are based on hardware configuration resistors see `src/mainboard/starlabs/labtop/variants/cml/romstage.c`
|
|
||||||
|
|
||||||
## Building coreboot
|
|
||||||
|
|
||||||
### Preliminaries
|
|
||||||
|
|
||||||
Prior to building coreboot the following files are required:
|
|
||||||
* Intel Flash Descriptor file (descriptor.bin)
|
|
||||||
* Intel Management Engine firmware (me.bin)
|
|
||||||
* ITE Embedded Controller firmware (ec.bin)
|
|
||||||
|
|
||||||
The files listed below are optional:
|
|
||||||
- Splash screen image in Windows 3.1 BMP format (Logo.bmp)
|
|
||||||
|
|
||||||
These files exist in the correct location in the StarLabsLtd/blobs repo on GitHub which is used in place of the standard 3rdparty/blobs repo.
|
|
||||||
|
|
||||||
### Build
|
|
||||||
|
|
||||||
The following commands will build a working image:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
make distclean
|
|
||||||
make defconfig KBUILD_DEFCONFIG=configs/config.starlabs_labtop_cml
|
|
||||||
make
|
|
||||||
```
|
|
||||||
|
|
||||||
## Flashing coreboot
|
|
||||||
|
|
||||||
```eval_rst
|
|
||||||
+---------------------+------------+
|
|
||||||
| Type | Value |
|
|
||||||
+=====================+============+
|
|
||||||
| Socketed flash | no |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Vendor | Winbond |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Model | 25Q128JVSQ |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Size | 16 MiB |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Package | SOIC-8 |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Internal flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
| External flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
|
|
||||||
Please see [here](../common/flashing.md) for instructions on how to flash with fwupd.
|
|
@@ -1,83 +0,0 @@
|
|||||||
# StarLite Mk III
|
|
||||||
|
|
||||||
## Specs
|
|
||||||
- CPU (full processor specs available at https://ark.intel.com)
|
|
||||||
- Intel N5000 (Gemini Lake)
|
|
||||||
- EC
|
|
||||||
- ITE IT8987E
|
|
||||||
- Backlit Keyboard, with standard PS/2 keycodes and SCI hotkeys
|
|
||||||
- Battery
|
|
||||||
- Charger, using AC adapter or USB-C PD
|
|
||||||
- Suspend / resume
|
|
||||||
- GPU
|
|
||||||
- Intel UHD Graphics 605
|
|
||||||
- GOP driver is recommended, VBT is provided
|
|
||||||
- eDP 11.6-inch 1920x1080 LCD
|
|
||||||
- HDMI video
|
|
||||||
- USB-C DisplayPort video
|
|
||||||
- Memory
|
|
||||||
- 8GB on-board
|
|
||||||
- Networking
|
|
||||||
- 9462 CNVi WiFi / Bluetooth soldered to PCBA
|
|
||||||
- Sound
|
|
||||||
- Realtek ALC269
|
|
||||||
- Internal speakers
|
|
||||||
- Internal microphone
|
|
||||||
- Combined headphone / microphone 3.5-mm jack
|
|
||||||
- HDMI audio
|
|
||||||
- USB-C DisplayPort audio
|
|
||||||
- Storage
|
|
||||||
- M.2 SATA SSD
|
|
||||||
- RTS5129 MicroSD card reader
|
|
||||||
- USB
|
|
||||||
- 640x480 CCD camera
|
|
||||||
- USB 3.1 Gen 1 Type-C (left)
|
|
||||||
- USB 3.1 Gen 1 Type-A (left)
|
|
||||||
- USB 3.1 Gen 1 Type-A (right)
|
|
||||||
|
|
||||||
## Building coreboot
|
|
||||||
|
|
||||||
### Preliminaries
|
|
||||||
|
|
||||||
Prior to building coreboot the following files are required:
|
|
||||||
* Intel Flash Descriptor file (descriptor.bin)
|
|
||||||
* Intel Management Engine firmware (me.bin)
|
|
||||||
* ITE Embedded Controller firmware (ec.bin)
|
|
||||||
|
|
||||||
The files listed below are optional:
|
|
||||||
- Splash screen image in Windows 3.1 BMP format (Logo.bmp)
|
|
||||||
|
|
||||||
These files exist in the correct location in the StarLabsLtd/blobs repo on GitHub which is used in place of the standard 3rdparty/blobs repo.
|
|
||||||
|
|
||||||
### Build
|
|
||||||
|
|
||||||
The following commands will build a working image:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
make distclean
|
|
||||||
make defconfig KBUILD_DEFCONFIG=configs/config.starlabs_lite_glk
|
|
||||||
make
|
|
||||||
```
|
|
||||||
|
|
||||||
## Flashing coreboot
|
|
||||||
|
|
||||||
```eval_rst
|
|
||||||
+---------------------+------------+
|
|
||||||
| Type | Value |
|
|
||||||
+=====================+============+
|
|
||||||
| Socketed flash | no |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Vendor | Gigadevice |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Model | GD25LQ64(B)|
|
|
||||||
+---------------------+------------+
|
|
||||||
| Size | 8 MiB |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Package | SOIC-8 |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Internal flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
| External flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
|
|
||||||
Please see [here](../common/flashing.md) for instructions on how to flash with fwupd.
|
|
@@ -1,82 +0,0 @@
|
|||||||
# StarLite Mk III
|
|
||||||
|
|
||||||
## Specs
|
|
||||||
- CPU (full processor specs available at https://ark.intel.com)
|
|
||||||
- Intel N5030 (Gemini Lake Refresh)
|
|
||||||
- EC
|
|
||||||
- Nuvoton NPCE985P/G
|
|
||||||
- Backlit Keyboard, with standard PS/2 keycodes and SCI hotkeys
|
|
||||||
- Battery
|
|
||||||
- Charger, using AC adapter or USB-C PD
|
|
||||||
- Suspend / resume
|
|
||||||
- GPU
|
|
||||||
- Intel UHD Graphics 605
|
|
||||||
- GOP driver is recommended, VBT is provided
|
|
||||||
- eDP 11.6-inch 1920x1080 LCD
|
|
||||||
- HDMI video
|
|
||||||
- USB-C DisplayPort video
|
|
||||||
- Memory
|
|
||||||
- 8GB on-board
|
|
||||||
- Networking
|
|
||||||
- 9461 CNVi WiFi / Bluetooth soldered to PCBA
|
|
||||||
- Sound
|
|
||||||
- Realtek ALC269
|
|
||||||
- Internal speakers
|
|
||||||
- Internal microphone
|
|
||||||
- Combined headphone / microphone 3.5-mm jack
|
|
||||||
- HDMI audio
|
|
||||||
- USB-C DisplayPort audio
|
|
||||||
- Storage
|
|
||||||
- M.2 SATA SSD
|
|
||||||
- RTS5129 MicroSD card reader
|
|
||||||
- USB
|
|
||||||
- 1200x1600 CCD camera
|
|
||||||
- USB 3.1 Gen 1 Type-C (left)
|
|
||||||
- USB 3.1 Gen 1 Type-A (left)
|
|
||||||
- USB 3.1 Gen 1 Type-A (right)
|
|
||||||
|
|
||||||
## Building coreboot
|
|
||||||
|
|
||||||
### Preliminaries
|
|
||||||
|
|
||||||
Prior to building coreboot the following files are required:
|
|
||||||
* Intel Flash Descriptor file (descriptor.bin)
|
|
||||||
* IFWI Image (ifwi.rom)
|
|
||||||
|
|
||||||
The files listed below are optional:
|
|
||||||
- Splash screen image in Windows 3.1 BMP format (Logo.bmp)
|
|
||||||
|
|
||||||
These files exist in the correct location in the StarLabsLtd/blobs repo on GitHub which is used in place of the standard 3rdparty/blobs repo.
|
|
||||||
|
|
||||||
### Build
|
|
||||||
|
|
||||||
The following commands will build a working image:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
make distclean
|
|
||||||
make defconfig KBUILD_DEFCONFIG=configs/config.starlabs_lite_glkr
|
|
||||||
make
|
|
||||||
```
|
|
||||||
|
|
||||||
## Flashing coreboot
|
|
||||||
|
|
||||||
```eval_rst
|
|
||||||
+---------------------+------------+
|
|
||||||
| Type | Value |
|
|
||||||
+=====================+============+
|
|
||||||
| Socketed flash | no |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Vendor | Gigadevice |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Model | GD25LQ64(B)|
|
|
||||||
+---------------------+------------+
|
|
||||||
| Size | 8 MiB |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Package | SOIC-8 |
|
|
||||||
+---------------------+------------+
|
|
||||||
| Internal flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
| External flashing | yes |
|
|
||||||
+---------------------+------------+
|
|
||||||
|
|
||||||
Please see [here](../common/flashing.md) for instructions on how to flash with fwupd.
|
|
@@ -83,4 +83,72 @@ make
|
|||||||
| External flashing | yes |
|
| External flashing | yes |
|
||||||
+---------------------+------------+
|
+---------------------+------------+
|
||||||
|
|
||||||
Please see [here](../common/flashing.md) for instructions on how to flash with fwupd.
|
#### **Requirements:**
|
||||||
|
|
||||||
|
* fwupd version 1.5.6 or later
|
||||||
|
* The battery must be charged to at least 30%
|
||||||
|
* The charger must be connected (either USB-C or DC Jack)
|
||||||
|
* BIOS Lock must be disabled
|
||||||
|
* Supported Linux distribution (Ubuntu 20.04 +, Linux Mint 20.1 + elementaryOS 6 +, Manjaro 21+)
|
||||||
|
|
||||||
|
**fwupd 1.5.6 or later**
|
||||||
|
To check the version of **fwupd** you have installed, open a terminal window and enter the below command:
|
||||||
|
|
||||||
|
```
|
||||||
|
fwupdmgr --version
|
||||||
|
```
|
||||||
|
|
||||||
|
This will show the version number. **1.5.6** or greater will work.
|
||||||
|

|
||||||
|
On Ubuntu 20.04, Ubuntu 20.10, Linux Mint 20.1 and elementaryOS 6, fwupd 1.5.6 can be installed from our PPA with the below terminal commands:
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo add-apt-repository ppa:starlabs/ppa
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install fwupd
|
||||||
|
```
|
||||||
|
|
||||||
|
On Manjaro:
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo pacman -Sy fwupd-git flashrom-starlabs
|
||||||
|
```
|
||||||
|
|
||||||
|
Instructions for other distributions will be added once fwupd 1.5.6 is available. If you are not using one of the distributions listed above, it is possible to install coreboot using a Live USB.
|
||||||
|
|
||||||
|
**Disable BIOS Lock**
|
||||||
|
BIOS Lock must be disabled when switching from the standard AMI (American Megatrends Inc.) firmware to coreboot. To disable BIOS Lock:
|
||||||
|
|
||||||
|
1\. Start with your LabTop turned off\. Turn it on whilst holding the **F2** key to access the BIOS settings.
|
||||||
|
2\. When the BIOS settings load, use the arrow keys to navigate to the **Advanced** tab\. Here you will see **BIOS Lock**\.
|
||||||
|
3\. Press `Enter` to change this setting from **Enabled** to **Disabled**
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
4\. Next, press the `F10` key to **Save & Exit** and then `Enter` to confirm.
|
||||||
|
|
||||||
|
#### **Switching Branch**
|
||||||
|
|
||||||
|
Switching branch refers to changing from AMI firmware to coreboot, or vice versa.
|
||||||
|
|
||||||
|
First, check for new firmware files with the below terminal command:
|
||||||
|
|
||||||
|
```
|
||||||
|
fwupdmgr refresh --force
|
||||||
|
```
|
||||||
|
|
||||||
|
Then, to change branch, enter the below terminal command:
|
||||||
|
|
||||||
|
```
|
||||||
|
fwupdmgr switch-branch
|
||||||
|
```
|
||||||
|
|
||||||
|
You can then select which branch you would like to use, by typing in the corresponding number:
|
||||||
|

|
||||||
|
You will be prompted to confirm, press `y` to continue or `n` to cancel.
|
||||||
|
|
||||||
|
Once the switch has been completed, you will be prompted to restart.
|
||||||
|
|
||||||
|
The next reboot can take up to **5 minutes,** do not interrupt this process or disconnect the charger. Once the reboot is complete, that's it - you'll continue to receive updates for whichever branch you are using.
|
||||||
|
|
||||||
|
You can switch branch at any time.
|
||||||
|
@@ -42,7 +42,7 @@ Now, run `make` to build the coreboot image.
|
|||||||
|
|
||||||
```eval_rst
|
```eval_rst
|
||||||
In addition to the information here, please see the
|
In addition to the information here, please see the
|
||||||
:doc:`../../tutorial/flashing_firmware/index`.
|
:doc:`../../flash_tutorial/index`.
|
||||||
```
|
```
|
||||||
|
|
||||||
### Internal programming
|
### Internal programming
|
||||||
|
@@ -56,6 +56,6 @@ These issues apply to all boards. Have a look at the board-specific issues, too.
|
|||||||
[Supermicro X11 LGA1151 series]: https://www.supermicro.com/products/motherboard/Xeon3000/#1151
|
[Supermicro X11 LGA1151 series]: https://www.supermicro.com/products/motherboard/Xeon3000/#1151
|
||||||
[OpenBMC]: https://www.openbmc.org/
|
[OpenBMC]: https://www.openbmc.org/
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[flashing tutorial]: ../../../../tutorial/flashing_firmware/ext_power.md
|
[flashing tutorial]: ../../../../flash_tutorial/ext_power.md
|
||||||
[Intel FSP2.0]: ../../../../soc/intel/fsp/index.md
|
[Intel FSP2.0]: ../../../../soc/intel/fsp/index.md
|
||||||
[AST2400]: https://www.aspeedtech.com/products.php?fPath=20&rId=376
|
[AST2400]: https://www.aspeedtech.com/products.php?fPath=20&rId=376
|
||||||
|
@@ -41,9 +41,10 @@ first, otherwise ME may write something back and break the firmware you write.
|
|||||||
The following command may be used to flash coreboot. (To do so, linux kernel
|
The following command may be used to flash coreboot. (To do so, linux kernel
|
||||||
could be started with `iomem=relaxed` or unload the `lpc_ich` kernel module)
|
could be started with `iomem=relaxed` or unload the `lpc_ich` kernel module)
|
||||||
|
|
||||||
Now you can [flash internally]. It is recommended to flash only the `bios`
|
Now you can [flash internally](/flash_tutorial/int_flashrom.md). It is
|
||||||
region (use `--ifd -i bios -N` flashrom arguments), in order to minimize the
|
recommended to flash only the `bios` region (use `--ifd -i bios -N` flashrom
|
||||||
chances of messing something up in the beginning.
|
arguments), in order to minimize the chances of messing something up in the
|
||||||
|
beginning.
|
||||||
|
|
||||||
The flash chip is a SOIC-8 SPI flash, and may be socketed, so it's also easy
|
The flash chip is a SOIC-8 SPI flash, and may be socketed, so it's also easy
|
||||||
to do in-system programming, or remove and flash externally if it is socketed.
|
to do in-system programming, or remove and flash externally if it is socketed.
|
||||||
@@ -105,4 +106,3 @@ seems that it shall not appear on X9SAE even if it is defined.
|
|||||||
[X9SAE-V]: https://www.supermicro.com/products/motherboard/xeon/c216/x9sae-v.cfm
|
[X9SAE-V]: https://www.supermicro.com/products/motherboard/xeon/c216/x9sae-v.cfm
|
||||||
[W25Q128FVSG]: https://static.chipdip.ru/lib/093/DOC001093213.pdf
|
[W25Q128FVSG]: https://static.chipdip.ru/lib/093/DOC001093213.pdf
|
||||||
[flashrom]: https://flashrom.org/Flashrom
|
[flashrom]: https://flashrom.org/Flashrom
|
||||||
[flash internally]: ../../tutorial/flashing_firmware/int_flashrom.md
|
|
||||||
|
@@ -127,5 +127,5 @@ ROM.
|
|||||||
hang on a bad SD card or when the SD card is removed during boot.
|
hang on a bad SD card or when the SD card is removed during boot.
|
||||||
|
|
||||||
|
|
||||||
[Beaglebone Black]: https://beagleboard.org/black
|
[Beaglebone Black]: https://beagleboard.org/black [U-Boot Falcon mode]:
|
||||||
[U-Boot Falcon mode]: https://elixir.bootlin.com/u-boot/v2020.07/source/doc/README.falcon
|
https://elixir.bootlin.com/u-boot/v2020.07/source/doc/README.falcon
|
@@ -81,4 +81,4 @@ Make sure to include all partitions into the ROM:
|
|||||||
* ME
|
* ME
|
||||||
* BIOS
|
* BIOS
|
||||||
|
|
||||||
[external programmer]: ../../../tutorial/flashing_firmware/index.md
|
[external programmer]: ../../../flash_tutorial/index.md
|
||||||
|
@@ -1,7 +1,3 @@
|
|||||||
```eval_rst
|
|
||||||
:orphan:
|
|
||||||
```
|
|
||||||
|
|
||||||
# coreboot Release Process
|
# coreboot Release Process
|
||||||
|
|
||||||
This document describes our release process and all prerequisites to implement
|
This document describes our release process and all prerequisites to implement
|
||||||
|
@@ -25,7 +25,7 @@ New mainboards
|
|||||||
* Google nipperkin
|
* Google nipperkin
|
||||||
* Lenovo w541
|
* Lenovo w541
|
||||||
* Siemens mc_ehl
|
* Siemens mc_ehl
|
||||||
* Supermicro x9sae
|
* SuperMicro x9sae
|
||||||
* System76 addw1
|
* System76 addw1
|
||||||
* System76 addw2
|
* System76 addw2
|
||||||
* System76 bonw14
|
* System76 bonw14
|
||||||
|
@@ -1,340 +1,27 @@
|
|||||||
coreboot 4.16
|
Upcoming release - coreboot 4.16
|
||||||
========================================================================
|
================================
|
||||||
|
|
||||||
The 4.16 release was done on February 25th, 2022.
|
The 4.16 release is planned for February, 2022.
|
||||||
|
|
||||||
Since 4.15 there have been more than 1770 new commits by more than 170
|
We are increasing the frequency of releases in order to enable others to release quarterly on
|
||||||
developers. Of these, more than 35 contributed to coreboot for the
|
a fresher version of coreboot.
|
||||||
first time.
|
|
||||||
|
|
||||||
Welcome to the project!
|
Update this document with changes that should be in the release notes.
|
||||||
|
|
||||||
Thank you to all the developers who continue to make coreboot the
|
* Please use Markdown.
|
||||||
great open source firmware project that it is.
|
* See the past few release notes for the general format.
|
||||||
|
* The chip and board additions and removals will be updated right
|
||||||
New mainboards:
|
before the release, so those do not need to be added.
|
||||||
---------------
|
|
||||||
* Acer Aspire VN7-572G
|
|
||||||
* AMD Chausie
|
|
||||||
* ASROCK H77 Pro4-M
|
|
||||||
* ASUS P8Z77-M
|
|
||||||
* Emulation QEMU power9
|
|
||||||
* Google Agah
|
|
||||||
* Google Anahera4ES
|
|
||||||
* Google Banshee
|
|
||||||
* Google Beadrix
|
|
||||||
* Google Brya4ES
|
|
||||||
* Google Crota
|
|
||||||
* Google Dojo
|
|
||||||
* Google Gimble4ES
|
|
||||||
* Google Herobrine_Rev0
|
|
||||||
* Google Kingler
|
|
||||||
* Google Kinox
|
|
||||||
* Google Krabby
|
|
||||||
* Google Moli
|
|
||||||
* Google Nereid
|
|
||||||
* Google Nivviks
|
|
||||||
* Google Primus4ES
|
|
||||||
* Google Redrix4ES
|
|
||||||
* Google Skyrim
|
|
||||||
* Google Taeko4ES
|
|
||||||
* Google Taniks
|
|
||||||
* Google Vell
|
|
||||||
* Google Volmar
|
|
||||||
* Intel Alderlake-N RVP
|
|
||||||
* Prodrive Atlas
|
|
||||||
* Star Labs Star Labs StarBook Mk V (i3-1115G4 and i7-1165G7)
|
|
||||||
* System76 gaze16 3050
|
|
||||||
* System76 gaze16 3060
|
|
||||||
* System76 gaze16 3060-b
|
|
||||||
|
|
||||||
Removed mainboards:
|
|
||||||
-------------------
|
|
||||||
* Google -> Corsola
|
|
||||||
* Google -> Nasher
|
|
||||||
* Google -> Stryke
|
|
||||||
|
|
||||||
Added processors:
|
|
||||||
-----------------
|
|
||||||
* src/cpu/power9
|
|
||||||
* src/soc/amd/sabrina
|
|
||||||
|
|
||||||
Submodule Updates
|
|
||||||
-----------------
|
|
||||||
* /3rdparty/amd_blobs (6 commits)
|
|
||||||
* /3rdparty/arm-trusted-firmware (965 commits)
|
|
||||||
* /3rdparty/blobs (30 commits)
|
|
||||||
* /3rdparty/chromeec (2212 commits)
|
|
||||||
* /3rdparty/intel-microcode (1 commits)
|
|
||||||
* /3rdparty/qc_blobs (13 commits)
|
|
||||||
* /3rdparty/vboot (44 commits)
|
|
||||||
|
|
||||||
Plans to move platform support to a branch:
|
|
||||||
-------------------------------------------
|
|
||||||
After the 4.18 release in November 2022, we plan to move support for any
|
|
||||||
boards still requiring RESOURCE_ALLOCATOR_V3 to the 4.18 branch. V4 was
|
|
||||||
introduced more than a year ago and with minor changes most platforms
|
|
||||||
were able to work just fine with it. A major difference is that V3 uses
|
|
||||||
just one continuous region below 4G to allocate all PCI memory BAR's. V4
|
|
||||||
uses all available space below 4G and if asked to, also above 4G too.
|
|
||||||
This makes it important that SoC code properly reports all fixed
|
|
||||||
resources.
|
|
||||||
|
|
||||||
Currently only AGESA platforms have issues with it. On Gerrit both
|
|
||||||
attempts to fix AMD AGESA codebases to use V4 and compatibility modes
|
|
||||||
inside the V4 allocator have been proposed, but both efforts seem
|
|
||||||
stalled. See the (not yet merged) documentation
|
|
||||||
[CR:43603](https://review.coreboot.org/c/coreboot/+/43603) on it's
|
|
||||||
details. It looks like properly reporting all fixed resources is the
|
|
||||||
issue.
|
|
||||||
|
|
||||||
At this point, we are not specifying which platforms this will include
|
|
||||||
as there are a number of patches to fix these issues in flight.
|
|
||||||
Hopefully, all platforms will end up being migrated to the v4 resource
|
|
||||||
allocator so that none of the platforms need to be supported on the
|
|
||||||
branch.
|
|
||||||
|
|
||||||
Additionally, even if the support for the platform is moved to a branch,
|
|
||||||
it can be brought back to ToT if they're fixed to support the v4
|
|
||||||
allocator.
|
|
||||||
|
|
||||||
Plans for Code Deprecation
|
|
||||||
--------------------------
|
|
||||||
As of release 4.18 (November 2022) we plan to deprecate LEGACY_SMP_INIT.
|
|
||||||
This also includes the codepath for SMM_ASEG. This code is used to start
|
|
||||||
APs and do some feature programming on each AP, but also set up SMM.
|
|
||||||
This has largely been superseded by PARALLEL_MP, which should be able to
|
|
||||||
cover all use cases of LEGACY_SMP_INIT, with little code changes. The
|
|
||||||
reason for deprecation is that having 2 codepaths to do the virtually
|
|
||||||
the same increases maintenance burden on the community a lot, while also
|
|
||||||
being rather confusing.
|
|
||||||
|
|
||||||
A few things are lacking in PARALLEL_MP init:
|
|
||||||
- Support for !CONFIG_SMP on single core systems. It's likely easy to
|
|
||||||
extend PARALLEL_MP or write some code that just does CPU detection on
|
|
||||||
the BSP CPU.
|
|
||||||
- Support SMM in the legacy ASEG (0xa0000 - 0xb0000) region. A POC
|
|
||||||
showed that it's not that hard to do with PARALLEL_MP
|
|
||||||
https://review.coreboot.org/c/coreboot/+/58700
|
|
||||||
|
|
||||||
No platforms in the tree have any hardware limitations that would block
|
|
||||||
migrating to PARALLEL_MP / a simple !CONFIG_SMP codebase.
|
|
||||||
|
|
||||||
Significant changes
|
Significant changes
|
||||||
-------------------
|
-------------------
|
||||||
This is, of course, not a complete list of all changes in the 4.16
|
|
||||||
coreboot release, but a sampling of some of the more interesting and
|
### Add significant changes here
|
||||||
significant changes.
|
|
||||||
|
|
||||||
### Option to disable Intel Management Engine
|
### Option to disable Intel Management Engine
|
||||||
Disable the Intel (Converged Security) Management Engine ((CS)ME) via
|
Disable the Intel (Converged Security) Management Engine ((CS)ME) via HECI based
|
||||||
HECI based on Intel Core processors from Skylake to Alder Lake. State is
|
on Intel Core processors from Skylake to Alder Lake. State is set based on a
|
||||||
set based on a CMOS value of `me_state`. A value of `0` will result in a
|
CMOS value of `me_state`. A value of `0` will result in a (CS)ME state of `0`
|
||||||
(CS)ME state of `0` (working) and value of `1` will result in a (CS)ME
|
(working) and value of `1` will result in a (CS)ME state of `3` (disabled). For
|
||||||
state of `3` (disabled). For an example CMOS layout and more info, see
|
an example CMOS layout and more info, see
|
||||||
[cse.c](../../src/soc/intel/common/block/cse/cse.c).
|
[cse.c](../../src/soc/intel/common/block/cse/cse.c).
|
||||||
|
|
||||||
|
|
||||||
### Add [AMD] apcb_v3_edit tool
|
|
||||||
apcb_v3_edit.py tool edits APCB V3 binaries. Specifically it will inject
|
|
||||||
up to 16 SPDs into an existing APCB. The APCB must have a magic number
|
|
||||||
at the top of each SPD slot.
|
|
||||||
|
|
||||||
|
|
||||||
### Allow enable/disable ME via CMOS
|
|
||||||
Add .enable method that will set the CSME state. The state is based on
|
|
||||||
the new CMOS option me_state, with values of 0 and 1. The method is very
|
|
||||||
stable when switching between different firmware platforms.
|
|
||||||
|
|
||||||
This method should not be used in combination with USE_ME_CLEANER.
|
|
||||||
|
|
||||||
State 1 will result in:
|
|
||||||
ME: Current Working State : 4
|
|
||||||
ME: Current Operation State : 1
|
|
||||||
ME: Current Operation Mode : 3
|
|
||||||
ME: Error Code : 2
|
|
||||||
|
|
||||||
State 0 will result in:
|
|
||||||
ME: Current Working State : 5
|
|
||||||
ME: Current Operation State : 1
|
|
||||||
ME: Current Operation Mode : 0
|
|
||||||
ME: Error Code : 0
|
|
||||||
|
|
||||||
|
|
||||||
### Move LAPIC configuration to MP init
|
|
||||||
Implementation for setup_lapic() did two things -- call enable_lapic()
|
|
||||||
and virtual_wire_mode_init().
|
|
||||||
|
|
||||||
In PARALLEL_MP case enable_lapic() was redundant as it was already
|
|
||||||
executed prior to initialize_cpu() call. For the !PARALLEL_MP case
|
|
||||||
enable_lapic() is added to AP CPUs.
|
|
||||||
|
|
||||||
|
|
||||||
### Add ANSI escape sequences for highlighting
|
|
||||||
Add ANSI escape sequences to highlight a log line based on its loglevel
|
|
||||||
to the output of "interactive" consoles that are meant to be displayed
|
|
||||||
on a terminal (e.g. UART). This should help make errors and warnings
|
|
||||||
stand out better among the usual spew of debug messages. For users whose
|
|
||||||
terminal or use case doesn't support these sequences for some reason (or
|
|
||||||
who simply don't like them), they can be disabled with a Kconfig.
|
|
||||||
|
|
||||||
While ANSI escape sequences can be used to add color, minicom (the
|
|
||||||
presumably most common terminal emulator for UART endpoints?) doesn't
|
|
||||||
support color output unless explicitly enabled (via -c command line
|
|
||||||
flag), and other terminal emulators may have similar restrictions, so in
|
|
||||||
an effort to make this as widely useful by default as possible I have
|
|
||||||
chosen not to use color codes and implement this highlighting via
|
|
||||||
bolding, underlining and inverting alone (which seem to go through in
|
|
||||||
all cases). If desired, support for separate color highlighting could be
|
|
||||||
added via Kconfig later.
|
|
||||||
|
|
||||||
|
|
||||||
### Add cbmem_dump_console
|
|
||||||
This function is similar to cbmem_dump_console_to_uart except it uses
|
|
||||||
the normally configured consoles. A console_paused flag was added to
|
|
||||||
prevent the cbmem console from writing to itself.
|
|
||||||
|
|
||||||
|
|
||||||
### Add coreboot-configurator
|
|
||||||
A simple GUI to change CMOS settings in coreboot's CBFS, via the
|
|
||||||
nvramtool utility. Testing on Debian, Ubuntu and Manjaro with coreboot
|
|
||||||
4.14+, but should work with any distribution or coreboot release that
|
|
||||||
has an option table. For more info, please check the
|
|
||||||
[README](https://web.archive.org/web/20220225194308/https://review.coreboot.org/plugins/gitiles/coreboot/+/refs/heads/master/util/coreboot-configurator/README.md).
|
|
||||||
|
|
||||||
|
|
||||||
### Update live ISO configs to NixOS 21.11
|
|
||||||
Update configs so that they work with NixOS 21.11. Drop `iasl` package
|
|
||||||
since it was replaced with `acpica-tools`.
|
|
||||||
|
|
||||||
|
|
||||||
### Move to U-Boot v2021.10
|
|
||||||
Move to building the latest U-Boot.
|
|
||||||
|
|
||||||
|
|
||||||
### Support systems with >128 cores
|
|
||||||
Each time the spinlock is acquired a byte is decreased and then the
|
|
||||||
sign of the byte is checked. If there are more than 128 cores the sign
|
|
||||||
check will overflow. An easy fix is to increase the word size of the
|
|
||||||
spinlock acquiring and releasing.
|
|
||||||
|
|
||||||
|
|
||||||
### Add [samsung] sx9360 [proximity sensor] driver
|
|
||||||
Add driver for setting up Semtech sx9360 SAR sensor.
|
|
||||||
The driver is based on sx9310.c. The core of the driver is the same, but
|
|
||||||
the bindings are slightly different.
|
|
||||||
|
|
||||||
Registers are documented [in the kernel tree:](https://web.archive.org/web/20220225182803/https://patchwork.kernel.org/project/linux-iio/patch/20211213024057.3824985-4-gwendal@chromium.org/)
|
|
||||||
Documentation/devicetree/bindings/iio/proximity/semtech,sx9360.yaml
|
|
||||||
|
|
||||||
|
|
||||||
### Add driver for Genesys Logic [SD Controller] GL9750
|
|
||||||
The device is a PCIe Gen1 to SD 3.0 card reader controller to be
|
|
||||||
used in the Chromebook. The datasheet name is GL9750S and the revision
|
|
||||||
is 01.
|
|
||||||
|
|
||||||
The patch disables ASPM L0s.
|
|
||||||
|
|
||||||
|
|
||||||
### Add support for Realtek RT8125
|
|
||||||
The Realtek RT8168 and RT8125 have a similar programming interface,
|
|
||||||
therefore add the PCI device ID for the RT8125 into driver for support.
|
|
||||||
|
|
||||||
|
|
||||||
### Add Fibocom 5G WWAN ACPI support
|
|
||||||
Support PXSX._RST and PXSX.MRST._RST for warm and cold reset.
|
|
||||||
PXSX._RST is invoked on driver removal.
|
|
||||||
|
|
||||||
build dependency:
|
|
||||||
soc/intel/common/block/pcie/rtd3
|
|
||||||
|
|
||||||
This driver will use the rtd3 methods for the same parent in the device
|
|
||||||
tree. The rtd3 chip needs to be added on the same root port in the
|
|
||||||
devicetree separately.
|
|
||||||
|
|
||||||
|
|
||||||
### Fix bug in vr_config
|
|
||||||
The `cpu_get_power_max()` function returns the TDP in milliwatts, but
|
|
||||||
the vr_config code interprets the value in watts. Divide the value by
|
|
||||||
1000 to fix this.
|
|
||||||
|
|
||||||
This also fixes an integer overflow when `cpu_get_power_max()` returns
|
|
||||||
a value greater than 65535 (UINT16_MAX).
|
|
||||||
|
|
||||||
|
|
||||||
### Make mixed topology work
|
|
||||||
When using a mixed memory topology with DDR4, it's not possible to boot
|
|
||||||
when no DIMMs are installed, even though memory-down is available. This
|
|
||||||
happens because the DIMM SPD length defaults to 256 when no DIMM SPD is
|
|
||||||
available. Relax the length check when no DIMMs are present to overcome
|
|
||||||
this problem.
|
|
||||||
|
|
||||||
|
|
||||||
### Add FSP 2.3 support
|
|
||||||
FSP 2.3 specification introduces following changes:
|
|
||||||
|
|
||||||
1. FSP_INFO_HEADER changes
|
|
||||||
Updated SpecVersion from 0x22 to 0x23
|
|
||||||
Updated HeaderRevision from 5 to 6
|
|
||||||
Added ExtendedImageRevision
|
|
||||||
FSP_INFO_HEADER length changed to 0x50
|
|
||||||
|
|
||||||
2. Added FSP_NON_VOLATILE_STORAGE_HOB2
|
|
||||||
|
|
||||||
Following changes are implemented in the patch to support FSP 2.3:
|
|
||||||
|
|
||||||
- Add Kconfig option
|
|
||||||
- Update FSP build binary version info based on ExtendedImageRevision
|
|
||||||
field in header
|
|
||||||
- New NV HOB related changes will be pushed as part of another patch
|
|
||||||
|
|
||||||
|
|
||||||
### Join hash calculation for verification and measurement
|
|
||||||
This patch moves the CBFS file measurement when CONFIG_TPM_MEASURED_BOOT
|
|
||||||
is enabled from the lookup step into the code where a file is actually
|
|
||||||
loaded or mapped from flash. This has the advantage that CBFS routines
|
|
||||||
which just look up a file to inspect its metadata (e.g. cbfs_get_size())
|
|
||||||
do not cause the file to be measured twice. It also removes the existing
|
|
||||||
inefficiency that files are loaded twice when measurement is enabled
|
|
||||||
(once to measure and then again when they are used). When CBFS
|
|
||||||
verification is enabled and uses the same hash algorithm as the TPM, we
|
|
||||||
are even able to only hash the file a single time and use the result for
|
|
||||||
both purposes.
|
|
||||||
|
|
||||||
|
|
||||||
### Skip FSP Notify APIs
|
|
||||||
Alder Lake SoC deselects Kconfigs as below:
|
|
||||||
- USE_FSP_NOTIFY_PHASE_READY_TO_BOOT
|
|
||||||
- USE_FSP_NOTIFY_PHASE_END_OF_FIRMWARE
|
|
||||||
to skip FSP notify APIs (Ready to boot and End of Firmware) and make
|
|
||||||
use of native coreboot driver to perform SoC recommended operations
|
|
||||||
prior booting to payload/OS.
|
|
||||||
|
|
||||||
Additionally, created a helper function `heci_finalize()` to keep HECI
|
|
||||||
related operations separated for easy guarding again config.
|
|
||||||
|
|
||||||
TODO: coreboot native implementation to skip FSP notify phase API (post
|
|
||||||
pci enumeration) is still WIP.
|
|
||||||
|
|
||||||
|
|
||||||
### Add support for PCIe Resizable BARs
|
|
||||||
Section 7.8.6 of the PCIe spec (rev 4) indicates that some devices can
|
|
||||||
indicates support for "Resizable BARs" via a PCIe extended capability.
|
|
||||||
|
|
||||||
When support this capability is indicated by the device, the size of
|
|
||||||
each BAR is determined in a different way than the normal "moving
|
|
||||||
bits" method. Instead, a pair of capability and control registers is
|
|
||||||
allocated in config space for each BAR, which can be used to both
|
|
||||||
indicate the different sizes the device is capable of supporting for
|
|
||||||
the BAR (powers-of-2 number of bits from 20 [1 MiB] to 63 [8 EiB]), and
|
|
||||||
to also inform the device of the size that the allocator actually
|
|
||||||
reserved for the MMIO range.
|
|
||||||
|
|
||||||
This patch adds a Kconfig for a mainboard to select if it knows that it
|
|
||||||
will have a device that requires this support during PCI enumeration.
|
|
||||||
If so, there is a corresponding Kconfig to indicate the maximum number
|
|
||||||
of bits of address space to hand out to devices this way (again, limited
|
|
||||||
by what devices can support and each individual system may want to
|
|
||||||
support, but just like above, this number can range from 20 to 63) If
|
|
||||||
the device can support more bits than this Kconfig, the resource request
|
|
||||||
is truncated to the number indicated by this Kconfig.
|
|
||||||
|
@@ -1,37 +1,35 @@
|
|||||||
# Release notes
|
Release notes for previous releases
|
||||||
|
===================================
|
||||||
|
|
||||||
## Upcoming release
|
* [4.1 - July 2015](coreboot-4.1-relnotes.md)
|
||||||
|
* [4.2 - October 2015](coreboot-4.2-relnotes.md)
|
||||||
|
* [4.3 - January 2016](coreboot-4.3-relnotes.md)
|
||||||
|
* [4.4 - May 2016](coreboot-4.4-relnotes.md)
|
||||||
|
* [4.5 - October 2016](coreboot-4.5-relnotes.md)
|
||||||
|
* [4.6 - April 2017](coreboot-4.6-relnotes.md)
|
||||||
|
* [4.7 - January 2018](coreboot-4.7-relnotes.md)
|
||||||
|
* [4.8 - May 2018](coreboot-4.8.1-relnotes.md)
|
||||||
|
* [4.9 - December 2018](coreboot-4.9-relnotes.md)
|
||||||
|
* [4.10 - July 2019](coreboot-4.10-relnotes.md)
|
||||||
|
* [4.11 - November 2019](coreboot-4.11-relnotes.md)
|
||||||
|
* [4.12 - May 2020](coreboot-4.12-relnotes.md)
|
||||||
|
* [4.13 - November 2020](coreboot-4.13-relnotes.md)
|
||||||
|
* [4.14 - May 2021](coreboot-4.14-relnotes.md)
|
||||||
|
* [4.15 - November 2021](coreboot-4.15-relnotes.md)
|
||||||
|
|
||||||
Please add to the release notes as changes are added:
|
The checklist contains instructions to ensure that a release covers all
|
||||||
* [4.17 - May 2022](coreboot-4.17-relnotes.md)
|
|
||||||
|
|
||||||
The [checklist] contains instructions to ensure that a release covers all
|
|
||||||
important things and provides a reliable format for tarballs, branch
|
important things and provides a reliable format for tarballs, branch
|
||||||
names etc.
|
names etc.
|
||||||
|
|
||||||
For release related communications consider using a [template] so everything
|
* [checklist](checklist.md)
|
||||||
|
|
||||||
|
For release related communications consider using a template so everything
|
||||||
important is taken care of.
|
important is taken care of.
|
||||||
|
|
||||||
|
* [templates](templates.md)
|
||||||
|
|
||||||
## Previous releases
|
Upcoming release
|
||||||
|
----------------
|
||||||
|
|
||||||
|
Please add to the release notes as changes are added:
|
||||||
* [4.16 - Feb 2022](coreboot-4.16-relnotes.md)
|
* [4.16 - Feb 2022](coreboot-4.16-relnotes.md)
|
||||||
* [4.15 - November 2021](coreboot-4.15-relnotes.md)
|
|
||||||
* [4.14 - May 2021](coreboot-4.14-relnotes.md)
|
|
||||||
* [4.13 - November 2020](coreboot-4.13-relnotes.md)
|
|
||||||
* [4.12 - May 2020](coreboot-4.12-relnotes.md)
|
|
||||||
* [4.11 - November 2019](coreboot-4.11-relnotes.md)
|
|
||||||
* [4.10 - July 2019](coreboot-4.10-relnotes.md)
|
|
||||||
* [4.9 - December 2018](coreboot-4.9-relnotes.md)
|
|
||||||
* [4.8 - May 2018](coreboot-4.8.1-relnotes.md)
|
|
||||||
* [4.7 - January 2018](coreboot-4.7-relnotes.md)
|
|
||||||
* [4.6 - April 2017](coreboot-4.6-relnotes.md)
|
|
||||||
* [4.5 - October 2016](coreboot-4.5-relnotes.md)
|
|
||||||
* [4.4 - May 2016](coreboot-4.4-relnotes.md)
|
|
||||||
* [4.3 - January 2016](coreboot-4.3-relnotes.md)
|
|
||||||
* [4.2 - October 2015](coreboot-4.2-relnotes.md)
|
|
||||||
* [4.1 - July 2015](coreboot-4.1-relnotes.md)
|
|
||||||
|
|
||||||
|
|
||||||
[checklist]: checklist.md
|
|
||||||
[template]: templates.md
|
|
||||||
|
@@ -1,7 +1,3 @@
|
|||||||
```eval_rst
|
|
||||||
:orphan:
|
|
||||||
```
|
|
||||||
|
|
||||||
# Communication templates related to release management
|
# Communication templates related to release management
|
||||||
|
|
||||||
## Deprecation notices
|
## Deprecation notices
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
# vboot-enabled devices
|
# vboot-enabled devices
|
||||||
|
|
||||||
## AMD
|
## AMD
|
||||||
- Chausie
|
|
||||||
- Majolica
|
- Majolica
|
||||||
|
|
||||||
## Clevo
|
## Clevo
|
||||||
@@ -30,37 +29,9 @@
|
|||||||
- Panther (ASUS Chromebox CN60)
|
- Panther (ASUS Chromebox CN60)
|
||||||
- Tricky (Dell Chromebox 3010)
|
- Tricky (Dell Chromebox 3010)
|
||||||
- Zako (HP Chromebox G1)
|
- Zako (HP Chromebox G1)
|
||||||
- Agah
|
|
||||||
- Anahera
|
|
||||||
- Anahera4ES
|
|
||||||
- Brask
|
|
||||||
- Brya 0
|
|
||||||
- Brya4ES
|
|
||||||
- Felwinter
|
|
||||||
- Gimble
|
|
||||||
- Gimble4ES
|
|
||||||
- Kano
|
|
||||||
- Nivviks
|
|
||||||
- Nereid
|
|
||||||
- Primus
|
|
||||||
- Primus4ES
|
|
||||||
- Redrix
|
|
||||||
- Redrix4ES
|
|
||||||
- Taeko
|
|
||||||
- Taeko4ES
|
|
||||||
- Taniks
|
|
||||||
- Vell
|
|
||||||
- Volmar
|
|
||||||
- Banshee
|
|
||||||
- Crota
|
|
||||||
- Moli
|
|
||||||
- Kinox
|
|
||||||
- Butterfly (HP Pavilion Chromebook 14)
|
- Butterfly (HP Pavilion Chromebook 14)
|
||||||
- Cherry
|
- Cherry
|
||||||
- Dojo
|
|
||||||
- Tomato
|
- Tomato
|
||||||
- Kingler
|
|
||||||
- Krabby
|
|
||||||
- Banon (Acer Chromebook 15 (CB3-532))
|
- Banon (Acer Chromebook 15 (CB3-532))
|
||||||
- Celes (Samsung Chromebook 3)
|
- Celes (Samsung Chromebook 3)
|
||||||
- Cyan (Acer Chromebook R11 (C738T))
|
- Cyan (Acer Chromebook R11 (C738T))
|
||||||
@@ -99,31 +70,31 @@
|
|||||||
- Nipperkin
|
- Nipperkin
|
||||||
- Dewatt
|
- Dewatt
|
||||||
- Akemi (IdeaPad Flex 5/5i Chromebook)
|
- Akemi (IdeaPad Flex 5/5i Chromebook)
|
||||||
- Ambassador
|
|
||||||
- Dooly
|
|
||||||
- Dratini (HP Pro c640 Chromebook)
|
- Dratini (HP Pro c640 Chromebook)
|
||||||
- Duffy Legacy (32MB)
|
- Duffy Legacy (32MB)
|
||||||
- Duffy (ASUS Chromebox 4)
|
- Duffy (ASUS Chromebox 4)
|
||||||
- Faffy (ASUS Fanless Chromebox)
|
- Faffy (ASUS Fanless Chromebox)
|
||||||
- Genesis
|
|
||||||
- Hatch
|
- Hatch
|
||||||
- Helios (ASUS Chromebook Flip C436FA)
|
|
||||||
- Helios_Diskswap
|
|
||||||
- Jinlon (HP Elite c1030 Chromebook)
|
- Jinlon (HP Elite c1030 Chromebook)
|
||||||
- Kaisa Legacy (32MB)
|
- Kaisa Legacy (32MB)
|
||||||
- Kaisa (Acer Chromebox CXI4)
|
- Kaisa (Acer Chromebox CXI4)
|
||||||
- Kindred (Acer Chromebook 712)
|
|
||||||
- Kohaku (Samsung Galaxy Chromebook)
|
- Kohaku (Samsung Galaxy Chromebook)
|
||||||
- Moonbuggy
|
- Kindred (Acer Chromebook 712)
|
||||||
|
- Helios (ASUS Chromebook Flip C436FA)
|
||||||
- Mushu
|
- Mushu
|
||||||
|
- Palkia
|
||||||
- Nightfury (Samsung Galaxy Chromebook 2)
|
- Nightfury (Samsung Galaxy Chromebook 2)
|
||||||
- Noibat (HP Chromebox G3)
|
- Noibat (HP Chromebox G3)
|
||||||
- Palkia
|
|
||||||
- Puff
|
- Puff
|
||||||
- Scout
|
- Helios_Diskswap
|
||||||
|
- Stryke
|
||||||
- Wyvern (CTL Chromebox CBx2)
|
- Wyvern (CTL Chromebox CBx2)
|
||||||
|
- Dooly
|
||||||
|
- Ambassador
|
||||||
|
- Genesis
|
||||||
|
- Scout
|
||||||
|
- Moonbuggy
|
||||||
- Herobrine
|
- Herobrine
|
||||||
- Herobrine_Rev0
|
|
||||||
- Senor
|
- Senor
|
||||||
- Piglin
|
- Piglin
|
||||||
- Hoglin
|
- Hoglin
|
||||||
@@ -194,6 +165,7 @@
|
|||||||
- Pyro (Lenovo Thinkpad (Yoga) 11e Chromebook)
|
- Pyro (Lenovo Thinkpad (Yoga) 11e Chromebook)
|
||||||
- Sand (Acer Chromebook 15 CB515-1HT/1H)
|
- Sand (Acer Chromebook 15 CB515-1HT/1H)
|
||||||
- Snappy (HP Chromebook x360 11 G1 EE)
|
- Snappy (HP Chromebook x360 11 G1 EE)
|
||||||
|
- Nasher
|
||||||
- Coral
|
- Coral
|
||||||
- Arcada (Latitude 5300 2-in-1 Chromebook Enterprise)
|
- Arcada (Latitude 5300 2-in-1 Chromebook Enterprise)
|
||||||
- Sarien (Dell Latitude 5400 Chromebook Enterprise)
|
- Sarien (Dell Latitude 5400 Chromebook Enterprise)
|
||||||
@@ -206,7 +178,6 @@
|
|||||||
- Stout (Lenovo Thinkpad X131e Chromebook)
|
- Stout (Lenovo Thinkpad X131e Chromebook)
|
||||||
- Bubs
|
- Bubs
|
||||||
- Coachz
|
- Coachz
|
||||||
- Gelarshie
|
|
||||||
- Homestar
|
- Homestar
|
||||||
- Kingoftown
|
- Kingoftown
|
||||||
- Lazor
|
- Lazor
|
||||||
@@ -244,8 +215,6 @@
|
|||||||
- Alderlake-P RVP with Microchip EC
|
- Alderlake-P RVP with Microchip EC
|
||||||
- Alderlake-M RVP
|
- Alderlake-M RVP
|
||||||
- Alderlake-M RVP with Chrome EC
|
- Alderlake-M RVP with Chrome EC
|
||||||
- Alderlake-N RVP
|
|
||||||
- Alderlake-N RVP with Chrome EC
|
|
||||||
- Basking Ridge CRB
|
- Basking Ridge CRB
|
||||||
- Coffeelake U SO-DIMM DDR4 RVP
|
- Coffeelake U SO-DIMM DDR4 RVP
|
||||||
- Coffeelake H SO-DIMM DDR4 RVP11
|
- Coffeelake H SO-DIMM DDR4 RVP11
|
||||||
|
@@ -4,4 +4,3 @@
|
|||||||
* [Part 2: Submitting a patch to coreboot.org](part2.md)
|
* [Part 2: Submitting a patch to coreboot.org](part2.md)
|
||||||
* [Part 3: Writing unit tests](part3.md)
|
* [Part 3: Writing unit tests](part3.md)
|
||||||
* [Managing local additions](managing_local_additions.md)
|
* [Managing local additions](managing_local_additions.md)
|
||||||
* [Flashing firmware](flashing_firmware/index.md)
|
|
||||||
|
@@ -12,7 +12,7 @@ Download, configure, and build coreboot
|
|||||||
### Step 1 - Install tools and libraries needed for coreboot
|
### Step 1 - Install tools and libraries needed for coreboot
|
||||||
$ sudo apt-get install -y bison build-essential curl flex git gnat libncurses5-dev m4 zlib1g-dev
|
$ sudo apt-get install -y bison build-essential curl flex git gnat libncurses5-dev m4 zlib1g-dev
|
||||||
$ sudo pacman -S base-devel curl git gcc-ada ncurses zlib
|
$ sudo pacman -S base-devel curl git gcc-ada ncurses zlib
|
||||||
$ sudo dnf install git make gcc-gnat flex bison xz bzip2 gcc g++ ncurses-devel wget zlib-devel patch
|
$ sudo dnf install git make gcc-gnat flex bison xz bzip2 gcc g++ ncurses-devel wget zlib-devel
|
||||||
|
|
||||||
### Step 2 - Download coreboot source tree
|
### Step 2 - Download coreboot source tree
|
||||||
$ git clone https://review.coreboot.org/coreboot
|
$ git clone https://review.coreboot.org/coreboot
|
||||||
|
35
MAINTAINERS
35
MAINTAINERS
@@ -141,7 +141,6 @@ AMD family 17h and 19h reference boards
|
|||||||
M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
M: Jason Glenesk <jason.glenesk@gmail.com>
|
M: Jason Glenesk <jason.glenesk@gmail.com>
|
||||||
M: Fred Reitberger <reitbergerfred@gmail.com>
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/mainboard/amd/chausie/
|
F: src/mainboard/amd/chausie/
|
||||||
F: src/mainboard/amd/majolica/
|
F: src/mainboard/amd/majolica/
|
||||||
@@ -298,14 +297,6 @@ M: Damien Zammit <damien@zamaudio.com>
|
|||||||
S: Odd Fixes
|
S: Odd Fixes
|
||||||
F: src/mainboard/intel/d510mo/
|
F: src/mainboard/intel/d510mo/
|
||||||
|
|
||||||
INTEL HARCUVAR_CRB MAINBOARD
|
|
||||||
M: Jeff Daly <jeffd@silicom-usa.com>
|
|
||||||
M: Vanessa Eusebio <vanessa.f.eusebio@intel.com>
|
|
||||||
M: Suresh Bellampalli <suresh.bellampalli@intel.com>
|
|
||||||
M: Mariusz Szafranski <mariuszx.szafranski@intel.com>
|
|
||||||
S: Maintained
|
|
||||||
F: src/mainboard/intel/harcuvar/
|
|
||||||
|
|
||||||
INTEL STRAGO MAINBOARD
|
INTEL STRAGO MAINBOARD
|
||||||
M: Hannah Williams <hannah.williams@intel.com>
|
M: Hannah Williams <hannah.williams@intel.com>
|
||||||
S: Supported
|
S: Supported
|
||||||
@@ -330,6 +321,7 @@ F: src/mainboard/kontron/mal10/
|
|||||||
|
|
||||||
LENOVO MAINBOARDS
|
LENOVO MAINBOARDS
|
||||||
M: Alexander Couzens <lynxis@fe80.eu>
|
M: Alexander Couzens <lynxis@fe80.eu>
|
||||||
|
M: Patrick Rudolph <siro@das-labor.org>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/mainboard/lenovo/
|
F: src/mainboard/lenovo/
|
||||||
|
|
||||||
@@ -450,7 +442,6 @@ SIEMENS MC_xxxx MAINBOARDS
|
|||||||
M: Werner Zeh <werner.zeh@siemens.com>
|
M: Werner Zeh <werner.zeh@siemens.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/mainboard/siemens/mc_apl1/
|
F: src/mainboard/siemens/mc_apl1/
|
||||||
F: src/mainboard/siemens/mc_ehl/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -582,6 +573,7 @@ F: src/southbridge/amd/
|
|||||||
F: src/include/cpu/amd/
|
F: src/include/cpu/amd/
|
||||||
|
|
||||||
INTEL SUPPORT
|
INTEL SUPPORT
|
||||||
|
M: Patrick Rudolph <siro@das-labor.org>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/vendorcode/intel/
|
F: src/vendorcode/intel/
|
||||||
F: src/cpu/intel/
|
F: src/cpu/intel/
|
||||||
@@ -591,6 +583,15 @@ F: src/soc/intel/
|
|||||||
F: src/drivers/intel/
|
F: src/drivers/intel/
|
||||||
F: src/include/cpu/intel/
|
F: src/include/cpu/intel/
|
||||||
|
|
||||||
|
INTEL FSP DENVERTON-NS SOC & HARCUVAR CRB
|
||||||
|
M: Suresh Bellampalli <suresh.bellampalli@intel.com>
|
||||||
|
M: Vanessa Eusebio <vanessa.f.eusebio@intel.com>
|
||||||
|
M: Michal Motyl <michalx.motyl@intel.com>
|
||||||
|
M: Mariusz Szafranski <mariuszx.szafranski@intel.com>
|
||||||
|
S: Maintained
|
||||||
|
F: src/mainboard/intel/harcuvar/
|
||||||
|
F: src/soc/intel/denverton_ns/
|
||||||
|
|
||||||
INTEL FSP 1.1
|
INTEL FSP 1.1
|
||||||
M: Lee Leahy <leroy.p.leahy@intel.com>
|
M: Lee Leahy <leroy.p.leahy@intel.com>
|
||||||
M: Huang Jin <huang.jin@intel.com>
|
M: Huang Jin <huang.jin@intel.com>
|
||||||
@@ -612,7 +613,6 @@ M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
|||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
M: Jason Glenesk <jason.glenesk@gmail.com>
|
M: Jason Glenesk <jason.glenesk@gmail.com>
|
||||||
M: Raul E Rangel <rrangel@chromium.org>
|
M: Raul E Rangel <rrangel@chromium.org>
|
||||||
M: Fred Reitberger <reitbergerfred@gmail.com>
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/soc/amd/cezanne/
|
F: src/soc/amd/cezanne/
|
||||||
F: src/vendorcode/amd/fsp/cezanne/
|
F: src/vendorcode/amd/fsp/cezanne/
|
||||||
@@ -622,7 +622,6 @@ M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
|||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
M: Jason Glenesk <jason.glenesk@gmail.com>
|
M: Jason Glenesk <jason.glenesk@gmail.com>
|
||||||
M: Raul E Rangel <rrangel@chromium.org>
|
M: Raul E Rangel <rrangel@chromium.org>
|
||||||
M: Fred Reitberger <reitbergerfred@gmail.com>
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/soc/amd/common/
|
F: src/soc/amd/common/
|
||||||
|
|
||||||
@@ -631,7 +630,6 @@ M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
|||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
M: Jason Glenesk <jason.glenesk@gmail.com>
|
M: Jason Glenesk <jason.glenesk@gmail.com>
|
||||||
M: Raul E Rangel <rrangel@chromium.org>
|
M: Raul E Rangel <rrangel@chromium.org>
|
||||||
M: Fred Reitberger <reitbergerfred@gmail.com>
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/soc/amd/picasso/
|
F: src/soc/amd/picasso/
|
||||||
F: src/vendorcode/amd/fsp/picasso/
|
F: src/vendorcode/amd/fsp/picasso/
|
||||||
@@ -641,7 +639,6 @@ M: Marshall Dawson <marshalldawson3rd@gmail.com>
|
|||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
M: Jason Glenesk <jason.glenesk@gmail.com>
|
M: Jason Glenesk <jason.glenesk@gmail.com>
|
||||||
M: Raul E Rangel <rrangel@chromium.org>
|
M: Raul E Rangel <rrangel@chromium.org>
|
||||||
M: Fred Reitberger <reitbergerfred@gmail.com>
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: src/soc/amd/sabrina/
|
F: src/soc/amd/sabrina/
|
||||||
F: src/vendorcode/amd/fsp/sabrina/
|
F: src/vendorcode/amd/fsp/sabrina/
|
||||||
@@ -670,14 +667,6 @@ S: Maintained
|
|||||||
F: /src/soc/intel/braswell/
|
F: /src/soc/intel/braswell/
|
||||||
F: /src/vendorcode/intel/fsp/fsp1_1/braswell/
|
F: /src/vendorcode/intel/fsp/fsp1_1/braswell/
|
||||||
|
|
||||||
INTEL DENVERTON-NS SOC
|
|
||||||
M: Jeff Daly <jeffd@silicom-usa.com>
|
|
||||||
M: Vanessa Eusebio <vanessa.f.eusebio@intel.com>
|
|
||||||
M: Suresh Bellampalli <suresh.bellampalli@intel.com>
|
|
||||||
M: Mariusz Szafranski <mariuszx.szafranski@intel.com>
|
|
||||||
S: Maintained
|
|
||||||
F: src/soc/intel/denverton_ns/
|
|
||||||
|
|
||||||
INTEL TIGERLAKE SOC
|
INTEL TIGERLAKE SOC
|
||||||
M: Tim Wawrzynczak <twawrzynczak@chromium.org>
|
M: Tim Wawrzynczak <twawrzynczak@chromium.org>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
@@ -881,7 +870,7 @@ F: src/security/tpm/
|
|||||||
|
|
||||||
SUPERIOS & SUPERIOTOOL
|
SUPERIOS & SUPERIOTOOL
|
||||||
M: Felix Held <felix-coreboot@felixheld.de>
|
M: Felix Held <felix-coreboot@felixheld.de>
|
||||||
S: Odd Fixes
|
S: Maintained
|
||||||
F: src/superio/
|
F: src/superio/
|
||||||
F: util/superiotool/
|
F: util/superiotool/
|
||||||
|
|
||||||
|
5
Makefile
5
Makefile
@@ -193,7 +193,6 @@ strip_quotes = $(strip $(subst ",,$(subst \",,$(1))))
|
|||||||
real-all: real-target
|
real-all: real-target
|
||||||
|
|
||||||
# must come rather early
|
# must come rather early
|
||||||
.SECONDARY:
|
|
||||||
.SECONDEXPANSION:
|
.SECONDEXPANSION:
|
||||||
.DELETE_ON_ERROR:
|
.DELETE_ON_ERROR:
|
||||||
|
|
||||||
@@ -470,10 +469,10 @@ doxyclean: doxygen-clean
|
|||||||
doxygen-clean:
|
doxygen-clean:
|
||||||
rm -rf $(DOXYGEN_OUTPUT_DIR)
|
rm -rf $(DOXYGEN_OUTPUT_DIR)
|
||||||
|
|
||||||
clean-for-update: doxygen-clean
|
clean-for-update: doxygen-clean clean-for-update-target
|
||||||
rm -rf $(obj) .xcompile
|
rm -rf $(obj) .xcompile
|
||||||
|
|
||||||
clean: clean-for-update clean-utils clean-payloads
|
clean: clean-for-update clean-target clean-utils
|
||||||
rm -f .ccwrap
|
rm -f .ccwrap
|
||||||
|
|
||||||
clean-cscope:
|
clean-cscope:
|
||||||
|
38
Makefile.inc
38
Makefile.inc
@@ -81,9 +81,8 @@ PHONY+= clean-abuild coreboot check-style build_complete
|
|||||||
# root source directories of coreboot
|
# root source directories of coreboot
|
||||||
subdirs-y := src/lib src/commonlib/ src/console src/device src/acpi src/superio/common
|
subdirs-y := src/lib src/commonlib/ src/console src/device src/acpi src/superio/common
|
||||||
subdirs-y += src/ec/acpi $(wildcard src/ec/*/*) $(wildcard src/southbridge/*/*)
|
subdirs-y += src/ec/acpi $(wildcard src/ec/*/*) $(wildcard src/southbridge/*/*)
|
||||||
subdirs-y += $(wildcard src/soc/*) $(wildcard src/soc/*/common) $(filter-out $(wildcard src/soc/*/common),$(wildcard src/soc/*/*))
|
subdirs-y += $(wildcard src/soc/*) $(wildcard src/soc/*/*) $(wildcard src/northbridge/*/*)
|
||||||
subdirs-y += $(wildcard src/northbridge/*/*)
|
subdirs-y += $(wildcard src/superio/*) $(wildcard src/superio/*/*)
|
||||||
subdirs-y += $(filter-out src/superio/common,$(wildcard src/superio/*)) $(wildcard src/superio/*/*)
|
|
||||||
subdirs-y += $(wildcard src/drivers/*) $(wildcard src/drivers/*/*) $(wildcard src/drivers/*/*/*)
|
subdirs-y += $(wildcard src/drivers/*) $(wildcard src/drivers/*/*) $(wildcard src/drivers/*/*/*)
|
||||||
subdirs-y += src/cpu src/vendorcode
|
subdirs-y += src/cpu src/vendorcode
|
||||||
subdirs-y += util/cbfstool util/sconfig util/nvramtool util/pgtblgen util/amdfwtool
|
subdirs-y += util/cbfstool util/sconfig util/nvramtool util/pgtblgen util/amdfwtool
|
||||||
@@ -261,6 +260,9 @@ endef
|
|||||||
# ResourceTemplate is the correct code.
|
# ResourceTemplate is the correct code.
|
||||||
# As it's valid ASL, disable the warning.
|
# As it's valid ASL, disable the warning.
|
||||||
EMPTY_RESOURCE_TEMPLATE_WARNING = 3150
|
EMPTY_RESOURCE_TEMPLATE_WARNING = 3150
|
||||||
|
# Redundant offset remarks are not useful in any way and are masking useful
|
||||||
|
# ones that might indicate an issue so it is better to hide them.
|
||||||
|
REDUNDANT_OFFSET_REMARK = 2158
|
||||||
# IASL compiler check for usage of _CRS, _DIS, _PRS, and _SRS objects:
|
# IASL compiler check for usage of _CRS, _DIS, _PRS, and _SRS objects:
|
||||||
# 1) If _PRS is present, must have _CRS and _SRS
|
# 1) If _PRS is present, must have _CRS and _SRS
|
||||||
# 2) If _SRS is present, must have _PRS (_PRS requires _CRS and _SRS)
|
# 2) If _SRS is present, must have _PRS (_PRS requires _CRS and _SRS)
|
||||||
@@ -277,8 +279,8 @@ ifeq ($(CONFIG_IGNORE_IASL_MISSING_DEPENDENCY),y)
|
|||||||
build_complete::
|
build_complete::
|
||||||
printf "*** WARNING: The ASL code for this platform is incomplete. Please fix it. ***\n"
|
printf "*** WARNING: The ASL code for this platform is incomplete. Please fix it. ***\n"
|
||||||
printf "*** If _PRS is present, must have _CRS and _SRS ***\n"
|
printf "*** If _PRS is present, must have _CRS and _SRS ***\n"
|
||||||
printf "*** If _SRS is present, must have _PRS and _CRS ***\n"
|
printf "*** If _SRS is present, must have _PRS, _CRS, and _SRS ***\n"
|
||||||
printf "*** If _DIS is present, must have _SRS, _PRS and _CRS ***\n"
|
printf "*** If _DIS is present, must have _SRS, _PRS, _CRS, and _SRS ***\n"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
IGNORED_IASL_WARNINGS = $(addprefix -vw , $(IASL_WARNINGS_LIST))
|
IGNORED_IASL_WARNINGS = $(addprefix -vw , $(IASL_WARNINGS_LIST))
|
||||||
@@ -337,7 +339,7 @@ endef
|
|||||||
# arg1: C source file
|
# arg1: C source file
|
||||||
# arg2: binary file
|
# arg2: binary file
|
||||||
cbfs-files-processor-struct= \
|
cbfs-files-processor-struct= \
|
||||||
$(eval $(2): $(1) $(obj)/build.h $(obj)/fmap_config.h $(KCONFIG_AUTOHEADER); \
|
$(eval $(2): $(1) $(obj)/build.h $(KCONFIG_AUTOHEADER); \
|
||||||
printf " CC+STRIP $(1)\n"; \
|
printf " CC+STRIP $(1)\n"; \
|
||||||
$(CC_ramstage) -MMD $(CPPFLAGS_ramstage) $(CFLAGS_ramstage) --param asan-globals=0 $$(ramstage-c-ccopts) -include $(KCONFIG_AUTOHEADER) -MT $(2) -o $(2).tmp -c $(1) && \
|
$(CC_ramstage) -MMD $(CPPFLAGS_ramstage) $(CFLAGS_ramstage) --param asan-globals=0 $$(ramstage-c-ccopts) -include $(KCONFIG_AUTOHEADER) -MT $(2) -o $(2).tmp -c $(1) && \
|
||||||
$(OBJCOPY_ramstage) -O binary --set-section-flags .bss*=alloc,contents,load $(2).tmp $(2); \
|
$(OBJCOPY_ramstage) -O binary --set-section-flags .bss*=alloc,contents,load $(2).tmp $(2); \
|
||||||
@@ -673,6 +675,19 @@ decompressor-y += $(CONFIG_MEMLAYOUT_LD_FILE)
|
|||||||
clean-abuild:
|
clean-abuild:
|
||||||
rm -rf coreboot-builds
|
rm -rf coreboot-builds
|
||||||
|
|
||||||
|
clean-for-update-target: clean-payloads
|
||||||
|
rm -f $(obj)/ramstage?* $(obj)/coreboot.romstage $(obj)/coreboot.pre* $(obj)/coreboot.bootblock $(obj)/coreboot.a
|
||||||
|
rm -rf $(obj)/bootblock?* $(obj)/romstage?* $(obj)/location.*
|
||||||
|
rm -f $(obj)/option_table.* $(obj)/crt0.S $(obj)/ldscript
|
||||||
|
rm -f $(obj)/mainboard/$(MAINBOARDDIR)/static.c $(obj)/mainboard/$(MAINBOARDDIR)/config.py $(obj)/mainboard/$(MAINBOARDDIR)/static.dot
|
||||||
|
rm -f $(obj)/mainboard/$(MAINBOARDDIR)/crt0.s $(obj)/mainboard/$(MAINBOARDDIR)/crt0.disasm
|
||||||
|
rm -f $(obj)/mainboard/$(MAINBOARDDIR)/romstage.inc
|
||||||
|
rm -f $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.* $(obj)/dsdt.*
|
||||||
|
rm -f $(obj)/cpu/x86/smm/smm_bin.c $(obj)/cpu/x86/smm/smm.* $(obj)/cpu/x86/smm/smm
|
||||||
|
|
||||||
|
clean-target:
|
||||||
|
rm -f $(obj)/coreboot*
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
# Development utilities
|
# Development utilities
|
||||||
printcrt0s:
|
printcrt0s:
|
||||||
@@ -776,14 +791,11 @@ endif
|
|||||||
$(objcbfs)/%.bin: $(objcbfs)/%.raw.bin
|
$(objcbfs)/%.bin: $(objcbfs)/%.raw.bin
|
||||||
cp $< $@
|
cp $< $@
|
||||||
|
|
||||||
$(objcbfs)/%.map: $(objcbfs)/%.debug
|
$(objcbfs)/%.elf: $(objcbfs)/%.debug
|
||||||
$(eval class := $(call find-class,$(@F)))
|
|
||||||
$(NM_$(class)) -n $< | sort > $(basename $@).map
|
|
||||||
|
|
||||||
$(objcbfs)/%.elf: $(objcbfs)/%.debug $(objcbfs)/%.map
|
|
||||||
$(eval class := $(call find-class,$(@F)))
|
$(eval class := $(call find-class,$(@F)))
|
||||||
@printf " OBJCOPY $(subst $(obj)/,,$(@))\n"
|
@printf " OBJCOPY $(subst $(obj)/,,$(@))\n"
|
||||||
cp $< $@.tmp
|
cp $< $@.tmp
|
||||||
|
$(NM_$(class)) -n $@.tmp | sort > $(basename $@).map
|
||||||
$(OBJCOPY_$(class)) --strip-debug $@.tmp
|
$(OBJCOPY_$(class)) --strip-debug $@.tmp
|
||||||
$(OBJCOPY_$(class)) --add-gnu-debuglink=$< $@.tmp
|
$(OBJCOPY_$(class)) --add-gnu-debuglink=$< $@.tmp
|
||||||
mv $@.tmp $@
|
mv $@.tmp $@
|
||||||
@@ -1100,10 +1112,6 @@ ifeq ($(CONFIG_INTEL_ADD_TOP_SWAP_BOOTBLOCK),y)
|
|||||||
TS_OPTIONS := -j $(CONFIG_INTEL_TOP_SWAP_BOOTBLOCK_SIZE)
|
TS_OPTIONS := -j $(CONFIG_INTEL_TOP_SWAP_BOOTBLOCK_SIZE)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# coreboot.pre doesn't follow the standard Make conventions. It gets modified
|
|
||||||
# by multiple rules, and thus we can't compute the dependencies correctly.
|
|
||||||
$(shell rm -f $(obj)/coreboot.pre)
|
|
||||||
|
|
||||||
ifneq ($(CONFIG_UPDATE_IMAGE),y)
|
ifneq ($(CONFIG_UPDATE_IMAGE),y)
|
||||||
$(obj)/coreboot.pre: $(objcbfs)/bootblock.bin $$(prebuilt-files) $(CBFSTOOL) $(obj)/fmap.fmap $(obj)/fmap.desc
|
$(obj)/coreboot.pre: $(objcbfs)/bootblock.bin $$(prebuilt-files) $(CBFSTOOL) $(obj)/fmap.fmap $(obj)/fmap.desc
|
||||||
$(CBFSTOOL) $@.tmp create -M $(obj)/fmap.fmap -r $(shell cat $(obj)/fmap.desc)
|
$(CBFSTOOL) $@.tmp create -M $(obj)/fmap.fmap -r $(shell cat $(obj)/fmap.desc)
|
||||||
|
@@ -94,8 +94,10 @@ static int coreboot_module_redraw(WINDOW *win)
|
|||||||
mvwprintw(win, row++, 3, " Table: ");
|
mvwprintw(win, row++, 3, " Table: ");
|
||||||
}
|
}
|
||||||
|
|
||||||
wprintw(win, "%16.16llx - %16.16llx", cb_info.range[i].start,
|
wprintw(win, "%16.16llx - %16.16llx",
|
||||||
cb_info.range[i].start + cb_info.range[i].size - 1);
|
cb_unpack64(cb_info.range[i].start),
|
||||||
|
cb_unpack64(cb_info.range[i].start) +
|
||||||
|
cb_unpack64(cb_info.range[i].size) - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
8
payloads/external/LinuxBoot/Kconfig
vendored
8
payloads/external/LinuxBoot/Kconfig
vendored
@@ -177,15 +177,15 @@ if LINUXBOOT_UROOT
|
|||||||
|
|
||||||
choice
|
choice
|
||||||
prompt "U-root version"
|
prompt "U-root version"
|
||||||
default LINUXBOOT_UROOT_MAIN
|
default LINUXBOOT_UROOT_MASTER
|
||||||
|
|
||||||
config LINUXBOOT_UROOT_CUSTOM
|
config LINUXBOOT_UROOT_CUSTOM
|
||||||
bool "custom"
|
bool "custom"
|
||||||
help
|
help
|
||||||
choose a custom u-root branch
|
choose a custom u-root branch
|
||||||
|
|
||||||
config LINUXBOOT_UROOT_MAIN
|
config LINUXBOOT_UROOT_MASTER
|
||||||
bool "main"
|
bool "master"
|
||||||
help
|
help
|
||||||
Latest u-root version
|
Latest u-root version
|
||||||
|
|
||||||
@@ -207,7 +207,7 @@ config LINUXBOOT_UROOT_CHECKOUT
|
|||||||
config LINUXBOOT_UROOT_VERSION
|
config LINUXBOOT_UROOT_VERSION
|
||||||
string
|
string
|
||||||
default LINUXBOOT_UROOT_CHECKOUT if LINUXBOOT_UROOT_CUSTOM
|
default LINUXBOOT_UROOT_CHECKOUT if LINUXBOOT_UROOT_CUSTOM
|
||||||
default "main" if LINUXBOOT_UROOT_MAIN
|
default "master" if LINUXBOOT_UROOT_MASTER
|
||||||
default "v3.0.0" if LINUXBOOT_UROOT_V3_0_0
|
default "v3.0.0" if LINUXBOOT_UROOT_V3_0_0
|
||||||
default "v2.0.0" if LINUXBOOT_UROOT_V2_0_0
|
default "v2.0.0" if LINUXBOOT_UROOT_V2_0_0
|
||||||
default "v1.0.0" if LINUXBOOT_UROOT_V1_0_0
|
default "v1.0.0" if LINUXBOOT_UROOT_V1_0_0
|
||||||
|
@@ -39,7 +39,7 @@ endif
|
|||||||
|
|
||||||
get: version
|
get: version
|
||||||
if [ -d "$(go_path_dir)/src/$(uroot_package)" ]; then \
|
if [ -d "$(go_path_dir)/src/$(uroot_package)" ]; then \
|
||||||
git -C $(go_path_dir)/src/$(uroot_package) checkout --quiet main; \
|
git -C $(go_path_dir)/src/$(uroot_package) checkout --quiet master; \
|
||||||
GOPATH=$(go_path_dir) go get -d -u -v $(uroot_package) || \
|
GOPATH=$(go_path_dir) go get -d -u -v $(uroot_package) || \
|
||||||
echo -e "\n<<u-root package update failed>>\n"; \
|
echo -e "\n<<u-root package update failed>>\n"; \
|
||||||
else \
|
else \
|
||||||
|
22
payloads/external/Makefile.inc
vendored
22
payloads/external/Makefile.inc
vendored
@@ -136,29 +136,22 @@ payloads/external/depthcharge/depthcharge/build/depthcharge.elf depthcharge: $(D
|
|||||||
|
|
||||||
# Tianocore
|
# Tianocore
|
||||||
|
|
||||||
$(obj)/UEFIPAYLOAD.fd tianocore: $(DOTCONFIG)
|
payloads/external/tianocore/tianocore/Build/UEFIPAYLOAD.fd tianocore: $(DOTCONFIG)
|
||||||
$(MAKE) -C payloads/external/tianocore all \
|
$(MAKE) -C payloads/external/tianocore all \
|
||||||
HOSTCC="$(HOSTCC)" \
|
HOSTCC="$(HOSTCC)" \
|
||||||
CC="$(HOSTCC)" \
|
CC="$(HOSTCC)" \
|
||||||
CONFIG_TIANOCORE_REPOSITORY=$(CONFIG_TIANOCORE_REPOSITORY) \
|
CONFIG_TIANOCORE_REVISION_ID=$(CONFIG_TIANOCORE_REVISION_ID) \
|
||||||
CONFIG_TIANOCORE_TAG_OR_REV=$(CONFIG_TIANOCORE_TAG_OR_REV) \
|
CONFIG_TIANOCORE_DEBUG=$(CONFIG_TIANOCORE_DEBUG) \
|
||||||
|
CONFIG_TIANOCORE_TARGET_IA32=$(CONFIG_TIANOCORE_TARGET_IA32) \
|
||||||
|
CONFIG_TIANOCORE_BOOTSPLASH_FILE=$(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
||||||
CONFIG_TIANOCORE_UEFIPAYLOAD=$(CONFIG_TIANOCORE_UEFIPAYLOAD) \
|
CONFIG_TIANOCORE_UEFIPAYLOAD=$(CONFIG_TIANOCORE_UEFIPAYLOAD) \
|
||||||
CONFIG_TIANOCORE_UPSTREAM=$(CONFIG_TIANOCORE_UPSTREAM) \
|
CONFIG_TIANOCORE_UPSTREAM=$(CONFIG_TIANOCORE_UPSTREAM) \
|
||||||
CONFIG_TIANOCORE_COREBOOTPAYLOAD=$(CONFIG_TIANOCORE_COREBOOTPAYLOAD) \
|
CONFIG_ECAM_MMCONF_BASE_ADDRESS=$(CONFIG_ECAM_MMCONF_BASE_ADDRESS) \
|
||||||
CONFIG_TIANOCORE_DEBUG=$(CONFIG_TIANOCORE_DEBUG) \
|
|
||||||
CONFIG_TIANOCORE_RELEASE=$(CONFIG_TIANOCORE_RELEASE) \
|
|
||||||
CONFIG_TIANOCORE_ABOVE_4G_MEMORY=$(CONFIG_TIANOCORE_ABOVE_4G_MEMORY) \
|
CONFIG_TIANOCORE_ABOVE_4G_MEMORY=$(CONFIG_TIANOCORE_ABOVE_4G_MEMORY) \
|
||||||
CONFIG_TIANOCORE_BOOTSPLASH_FILE=$(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
|
||||||
CONFIG_TIANOCORE_BOOT_MANAGER_ESCAPE=$(CONFIG_TIANOCORE_BOOT_MANAGER_ESCAPE) \
|
|
||||||
CONFIG_TIANOCORE_BOOT_TIMEOUT=$(CONFIG_TIANOCORE_BOOT_TIMEOUT) \
|
CONFIG_TIANOCORE_BOOT_TIMEOUT=$(CONFIG_TIANOCORE_BOOT_TIMEOUT) \
|
||||||
CONFIG_TIANOCORE_CBMEM_LOGGING=$(CONFIG_TIANOCORE_CBMEM_LOGGING) \
|
CONFIG_TIANOCORE_CBMEM_LOGGING=$(CONFIG_TIANOCORE_CBMEM_LOGGING) \
|
||||||
CONFIG_TIANOCORE_FOLLOW_BGRT_SPEC=$(CONFIG_TIANOCORE_FOLLOW_BGRT_SPEC) \
|
CONFIG_TIANOCORE_COREBOOTPAYLOAD=$(CONFIG_TIANOCORE_COREBOOTPAYLOAD) \
|
||||||
CONFIG_TIANOCORE_HAVE_EFI_SHELL=$(CONFIG_TIANOCORE_HAVE_EFI_SHELL) \
|
|
||||||
CONFIG_TIANOCORE_PRIORITIZE_INTERNAL=$(CONFIG_TIANOCORE_PRIORITIZE_INTERNAL) \
|
|
||||||
CONFIG_TIANOCORE_PS2_SUPPORT=$(CONFIG_TIANOCORE_PS2_SUPPORT) \
|
|
||||||
CONFIG_TIANOCORE_SD_MMC_TIMEOUT=$(CONFIG_TIANOCORE_SD_MMC_TIMEOUT) \
|
|
||||||
CONFIG_TIANOCORE_USE_8254_TIMER=$(CONFIG_TIANOCORE_USE_8254_TIMER) \
|
CONFIG_TIANOCORE_USE_8254_TIMER=$(CONFIG_TIANOCORE_USE_8254_TIMER) \
|
||||||
CONFIG_ECAM_MMCONF_BASE_ADDRESS=$(CONFIG_ECAM_MMCONF_BASE_ADDRESS) \
|
|
||||||
GCC_CC_x86_32=$(GCC_CC_x86_32) \
|
GCC_CC_x86_32=$(GCC_CC_x86_32) \
|
||||||
GCC_CC_x86_64=$(GCC_CC_x86_64) \
|
GCC_CC_x86_64=$(GCC_CC_x86_64) \
|
||||||
GCC_CC_arm=$(GCC_CC_arm) \
|
GCC_CC_arm=$(GCC_CC_arm) \
|
||||||
@@ -168,7 +161,6 @@ $(obj)/UEFIPAYLOAD.fd tianocore: $(DOTCONFIG)
|
|||||||
OBJCOPY_arm=$(OBJCOPY_arm) \
|
OBJCOPY_arm=$(OBJCOPY_arm) \
|
||||||
OBJCOPY_arm64=$(OBJCOPY_arm64) \
|
OBJCOPY_arm64=$(OBJCOPY_arm64) \
|
||||||
MFLAGS= MAKEFLAGS=
|
MFLAGS= MAKEFLAGS=
|
||||||
mv payloads/external/tianocore/output/UEFIPAYLOAD.fd $@
|
|
||||||
|
|
||||||
# FILO
|
# FILO
|
||||||
|
|
||||||
|
2
payloads/external/SeaBIOS/Kconfig
vendored
2
payloads/external/SeaBIOS/Kconfig
vendored
@@ -5,7 +5,7 @@ choice
|
|||||||
default SEABIOS_STABLE
|
default SEABIOS_STABLE
|
||||||
|
|
||||||
config SEABIOS_STABLE
|
config SEABIOS_STABLE
|
||||||
bool "1.16.0"
|
bool "1.14.0"
|
||||||
help
|
help
|
||||||
Stable SeaBIOS version
|
Stable SeaBIOS version
|
||||||
config SEABIOS_MASTER
|
config SEABIOS_MASTER
|
||||||
|
2
payloads/external/SeaBIOS/Makefile
vendored
2
payloads/external/SeaBIOS/Makefile
vendored
@@ -1,5 +1,5 @@
|
|||||||
TAG-$(CONFIG_SEABIOS_MASTER)=origin/master
|
TAG-$(CONFIG_SEABIOS_MASTER)=origin/master
|
||||||
TAG-$(CONFIG_SEABIOS_STABLE)=d239552ce7220e448ae81f41515138f7b9e3c4db
|
TAG-$(CONFIG_SEABIOS_STABLE)=155821a1990b6de78dde5f98fa5ab90e802021e0
|
||||||
TAG-$(CONFIG_SEABIOS_REVISION)=$(CONFIG_SEABIOS_REVISION_ID)
|
TAG-$(CONFIG_SEABIOS_REVISION)=$(CONFIG_SEABIOS_REVISION_ID)
|
||||||
|
|
||||||
project_git_repo=https://review.coreboot.org/seabios.git
|
project_git_repo=https://review.coreboot.org/seabios.git
|
||||||
|
2
payloads/external/depthcharge/Makefile
vendored
2
payloads/external/depthcharge/Makefile
vendored
@@ -68,8 +68,6 @@ $(libpayload_install_dir): $(project_dir)
|
|||||||
false)
|
false)
|
||||||
echo $(DEPTHCHARGE_LIBPAYLOAD_MSG)
|
echo $(DEPTHCHARGE_LIBPAYLOAD_MSG)
|
||||||
cp $(libpayload_config) $(libpayload_dir)/.config
|
cp $(libpayload_config) $(libpayload_dir)/.config
|
||||||
(grep -q '^\s*CONFIG_LP_CHROMEOS=' $(libpayload_dir)/.config) || \
|
|
||||||
(echo "CONFIG_LP_CHROMEOS=y" >> $(libpayload_dir)/.config)
|
|
||||||
$(MAKE) -C $(libpayload_dir) olddefconfig
|
$(MAKE) -C $(libpayload_dir) olddefconfig
|
||||||
$(MAKE) -C $(libpayload_dir)
|
$(MAKE) -C $(libpayload_dir)
|
||||||
$(MAKE) -C $(libpayload_dir) install DESTDIR=$(libpayload_install_dir)
|
$(MAKE) -C $(libpayload_dir) install DESTDIR=$(libpayload_install_dir)
|
||||||
|
4
payloads/external/iPXE/Kconfig
vendored
4
payloads/external/iPXE/Kconfig
vendored
@@ -31,12 +31,12 @@ choice
|
|||||||
depends on BUILD_IPXE
|
depends on BUILD_IPXE
|
||||||
|
|
||||||
config IPXE_STABLE
|
config IPXE_STABLE
|
||||||
bool "2022.1"
|
bool "2019.3"
|
||||||
help
|
help
|
||||||
iPXE uses a rolling release with no stable version, for
|
iPXE uses a rolling release with no stable version, for
|
||||||
reproducibility, use the last commit of a given month as the
|
reproducibility, use the last commit of a given month as the
|
||||||
'stable' version.
|
'stable' version.
|
||||||
This is iPXE from the end of January, 2022.
|
This is iPXE from the end of March, 2019.
|
||||||
|
|
||||||
config IPXE_MASTER
|
config IPXE_MASTER
|
||||||
bool "master"
|
bool "master"
|
||||||
|
4
payloads/external/iPXE/Makefile
vendored
4
payloads/external/iPXE/Makefile
vendored
@@ -1,8 +1,8 @@
|
|||||||
## SPDX-License-Identifier: GPL-2.0-only
|
## SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
|
||||||
# 2022.1 - Last commit of January 2022
|
# 2019.3 - Last commit of March 2019
|
||||||
# When updating, change the name both here and in payloads/external/iPXE/Kconfig
|
# When updating, change the name both here and in payloads/external/iPXE/Kconfig
|
||||||
STABLE_COMMIT_ID=6ba671acd922ee046b257c5119b8a0f64d275473
|
STABLE_COMMIT_ID=ebf2eaf515e46abd43bc798e7e4ba77bfe529218
|
||||||
|
|
||||||
TAG-$(CONFIG_IPXE_MASTER)=origin/master
|
TAG-$(CONFIG_IPXE_MASTER)=origin/master
|
||||||
TAG-$(CONFIG_IPXE_STABLE)=$(STABLE_COMMIT_ID)
|
TAG-$(CONFIG_IPXE_STABLE)=$(STABLE_COMMIT_ID)
|
||||||
|
125
payloads/external/tianocore/Kconfig
vendored
125
payloads/external/tianocore/Kconfig
vendored
@@ -2,7 +2,7 @@ if PAYLOAD_TIANOCORE
|
|||||||
|
|
||||||
config PAYLOAD_FILE
|
config PAYLOAD_FILE
|
||||||
string "Tianocore binary"
|
string "Tianocore binary"
|
||||||
default "$(obj)/UEFIPAYLOAD.fd"
|
default "payloads/external/tianocore/tianocore/Build/UEFIPAYLOAD.fd"
|
||||||
help
|
help
|
||||||
The result of a UefiPayloadPkg build
|
The result of a UefiPayloadPkg build
|
||||||
|
|
||||||
@@ -35,30 +35,13 @@ config TIANOCORE_COREBOOTPAYLOAD
|
|||||||
Select this option to build using MrChromebox's older (now deprecated)
|
Select this option to build using MrChromebox's older (now deprecated)
|
||||||
CorebootPayloadPkg-based Tianocore branch
|
CorebootPayloadPkg-based Tianocore branch
|
||||||
|
|
||||||
config TIANOCORE_CUSTOM
|
|
||||||
bool "Custom"
|
|
||||||
help
|
|
||||||
Specify your own edk2 repository and branch to use.
|
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
config TIANOCORE_REPOSITORY
|
config TIANOCORE_REVISION_ID
|
||||||
string "URL to git repository for edk2"
|
|
||||||
default "https://github.com/tianocore/edk2" if TIANOCORE_UPSTREAM
|
|
||||||
default "https://github.com/mrchromebox/edk2" if TIANOCORE_UEFIPAYLOAD || TIANOCORE_COREBOOTPAYLOAD
|
|
||||||
help
|
|
||||||
coreboot supports an array of build options which can be found below. These options
|
|
||||||
will only have an effect if the relevant options exist in the target repository.
|
|
||||||
|
|
||||||
config TIANOCORE_TAG_OR_REV
|
|
||||||
string "Insert a commit's SHA-1 or a branch name"
|
string "Insert a commit's SHA-1 or a branch name"
|
||||||
default "origin/uefipayload_202107" if TIANOCORE_UEFIPAYLOAD
|
|
||||||
default "origin/master" if TIANOCORE_UPSTREAM
|
|
||||||
default "origin/coreboot_fb" if TIANOCORE_COREBOOTPAYLOAD
|
|
||||||
help
|
help
|
||||||
The commit's SHA-1 or branch name of the revision to use. This must exist in
|
The commit's SHA-1 or branch name of the revision to use. Choose "upstream/master"
|
||||||
TIANOCORE_REPOSITORY, and in the case of a branch name, prefixed with origin i.e.
|
for master branch of Tianocore release on github.
|
||||||
"origin/uefipayload_202202"
|
|
||||||
|
|
||||||
choice
|
choice
|
||||||
prompt "Tianocore build"
|
prompt "Tianocore build"
|
||||||
@@ -81,33 +64,32 @@ endchoice
|
|||||||
|
|
||||||
if TIANOCORE_UEFIPAYLOAD
|
if TIANOCORE_UEFIPAYLOAD
|
||||||
|
|
||||||
config TIANOCORE_ABOVE_4G_MEMORY
|
config TIANOCORE_CBMEM_LOGGING
|
||||||
bool "Enable above 4G memory"
|
bool "Enable Tianocore logging to CBMEM"
|
||||||
default n
|
|
||||||
help
|
help
|
||||||
Select this option to enable Above 4G Decode. This will allow the
|
Select this option if you want to enable Tianocore logging to CBMEM.
|
||||||
payload to use all of the memory, rather than an maximum of 4G.
|
You may want to increase the default cbmem buffer size when selecting
|
||||||
|
this option, especially if using a debug (vs release) build.
|
||||||
|
Selecting this option will increase the payload size in CBFS by ~220KB.
|
||||||
|
|
||||||
Disabling memory above 4G is useful for bootloaders that are not
|
config TIANOCORE_BOOTSPLASH_IMAGE
|
||||||
fully 64-bit aware such as Qubes R4.0.4 bootloader.
|
bool "Use a custom bootsplash image"
|
||||||
|
|
||||||
|
|
||||||
config TIANOCORE_BOOTSPLASH_FILE
|
|
||||||
string "Tianocore Bootsplash path and filename"
|
|
||||||
default "bootsplash.bmp"
|
|
||||||
help
|
help
|
||||||
Select this option if you have a bootsplash image that you would
|
Select this option if you have a bootsplash image that you would
|
||||||
like to be used. If this option is not selected, the default
|
like to be used. If this option is not selected, the default
|
||||||
coreboot logo (European Brown Hare) will used.
|
coreboot logo (European Brown Hare) will used.
|
||||||
|
|
||||||
|
config TIANOCORE_BOOTSPLASH_FILE
|
||||||
|
string "Tianocore Bootsplash path and filename"
|
||||||
|
depends on TIANOCORE_BOOTSPLASH_IMAGE
|
||||||
|
default "bootsplash.bmp"
|
||||||
|
help
|
||||||
The path and filename of the file to use as graphical bootsplash
|
The path and filename of the file to use as graphical bootsplash
|
||||||
image. The file must be an uncompressed BMP, in BMP 3 format.
|
image. The file must be an uncompressed BMP.
|
||||||
|
|
||||||
Linux can create these with the below command:
|
|
||||||
`convert splosh.bmp BMP3:splash.bmp`
|
|
||||||
|
|
||||||
This image will also be used as the BGRT boot image, which may
|
This image will also be used as the BGRT boot image, which may
|
||||||
persist through your OS boot process.
|
persist through your OS boot process, and will be displayed
|
||||||
|
vertically centered 38.2% from the top of the display.
|
||||||
|
|
||||||
See ACPI spec 6.3, 5.2.22 Boot Graphics Resource Table (BGRT), and
|
See ACPI spec 6.3, 5.2.22 Boot Graphics Resource Table (BGRT), and
|
||||||
Microsoft's documentation on BGRT positioning:
|
Microsoft's documentation on BGRT positioning:
|
||||||
@@ -119,61 +101,16 @@ config TIANOCORE_BOOTSPLASH_FILE
|
|||||||
If an absolute path is not given, the path will assumed to be
|
If an absolute path is not given, the path will assumed to be
|
||||||
relative to the coreboot root directory.
|
relative to the coreboot root directory.
|
||||||
|
|
||||||
config TIANOCORE_BOOT_MANAGER_ESCAPE
|
config TIANOCORE_ABOVE_4G_MEMORY
|
||||||
bool "Use Escape key for Boot Manager"
|
bool "Enable above 4G memory"
|
||||||
default n
|
default n
|
||||||
help
|
help
|
||||||
Use Escape as the hot-key to access the Boot Manager. This replaces
|
Select this option to enable Above 4G Decode. This will allow the
|
||||||
the default key of F2.
|
payload to use all of the memory, rather than an maximum of 4G.
|
||||||
|
|
||||||
config TIANOCORE_BOOT_TIMEOUT
|
Disabling this option, which will reserve memory above 4G, is
|
||||||
int "Set the timeout for boot menu prompt"
|
useful for bootloaders that are not fully 64-bit aware such as
|
||||||
default 2
|
Qubes R4.0.4 bootloader.
|
||||||
help
|
|
||||||
The length of time in seconds for which the boot splash/menu prompt will be displayed.
|
|
||||||
For boards with an internal display, the default value of 2s is generally sufficient.
|
|
||||||
For boards with an external display, a value of 5s is generally sufficient.
|
|
||||||
|
|
||||||
config TIANOCORE_CBMEM_LOGGING
|
|
||||||
bool "Enable Tianocore logging to CBMEM"
|
|
||||||
help
|
|
||||||
Select this option if you want to enable Tianocore logging to CBMEM.
|
|
||||||
You may want to increase the default cbmem buffer size when selecting
|
|
||||||
this option, especially if using a debug (vs release) build.
|
|
||||||
Selecting this option will increase the payload size in CBFS by 0x10000.
|
|
||||||
|
|
||||||
config TIANOCORE_FOLLOW_BGRT_SPEC
|
|
||||||
bool "Center logo 38.2% from the top of screen"
|
|
||||||
default n
|
|
||||||
help
|
|
||||||
Follow the BGRT Specification implemented by Microsoft and
|
|
||||||
the Boot Logo 38.2% will be vertically centered 38.2% from
|
|
||||||
the top of the display.
|
|
||||||
|
|
||||||
config TIANOCORE_HAVE_EFI_SHELL
|
|
||||||
bool "Include EFI Shell"
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
Include the EFI shell Binary
|
|
||||||
|
|
||||||
config TIANOCORE_PRIORITIZE_INTERNAL
|
|
||||||
bool "Prioritize internal boot devices"
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
Prioritize internal boot devices over external devices
|
|
||||||
|
|
||||||
config TIANOCORE_PS2_SUPPORT
|
|
||||||
bool "Support PS/2 Keyboards"
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
Include support for PS/2 keyboards
|
|
||||||
|
|
||||||
config TIANOCORE_SD_MMC_TIMEOUT
|
|
||||||
int "Timeout in μs for initializing SD Card reader"
|
|
||||||
default 1000
|
|
||||||
help
|
|
||||||
The amount of time allowed to initialize the SD Card reader and/or eMMC drive.
|
|
||||||
Most only require 1000μs, but certain readers can take 1000000μs.
|
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@@ -186,4 +123,12 @@ config TIANOCORE_USE_8254_TIMER
|
|||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
config TIANOCORE_BOOT_TIMEOUT
|
||||||
|
int
|
||||||
|
default 2
|
||||||
|
help
|
||||||
|
The length of time in seconds for which the boot splash/menu prompt will be displayed.
|
||||||
|
For boards with an internal display, the default value of 2s is generally sufficient.
|
||||||
|
For boards without an internal display, a value of 5s is generally sufficient.
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
151
payloads/external/tianocore/Makefile
vendored
151
payloads/external/tianocore/Makefile
vendored
@@ -3,110 +3,84 @@
|
|||||||
# force the shell to bash - the edksetup.sh script doesn't work with dash
|
# force the shell to bash - the edksetup.sh script doesn't work with dash
|
||||||
export SHELL := env bash
|
export SHELL := env bash
|
||||||
|
|
||||||
project_name = Tianocore
|
project_name=Tianocore
|
||||||
project_dir = $(CURDIR)/$(word 3,$(subst /, ,$(CONFIG_TIANOCORE_REPOSITORY)))
|
project_dir=$(CURDIR)/tianocore
|
||||||
|
project_git_repo=https://github.com/mrchromebox/edk2
|
||||||
|
project_git_branch=uefipayload_202107
|
||||||
|
upstream_git_repo=https://github.com/tianocore/edk2
|
||||||
|
|
||||||
|
build_flavor=-D BOOTLOADER=COREBOOT -D PCIE_BASE=$(CONFIG_ECAM_MMCONF_BASE_ADDRESS) -DPS2_KEYBOARD_ENABLE
|
||||||
|
|
||||||
BUILD_STR = -a IA32 -a X64 -t COREBOOT
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_COREBOOTPAYLOAD),y)
|
ifeq ($(CONFIG_TIANOCORE_COREBOOTPAYLOAD),y)
|
||||||
BUILD_STR += -p CorebootPayloadPkg/CorebootPayloadPkgIa32X64.dsc
|
project_git_branch=coreboot_fb
|
||||||
|
bootloader=CorebootPayloadPkg
|
||||||
else
|
else
|
||||||
BUILD_STR += -p UefiPayloadPkg/UefiPayloadPkg.dsc
|
bootloader=UefiPayloadPkg
|
||||||
endif
|
endif
|
||||||
BUILD_STR += -D BOOTLOADER=COREBOOT -q
|
|
||||||
|
|
||||||
#
|
ifeq ($(CONFIG_TIANOCORE_UPSTREAM),y)
|
||||||
# EDK II has the following build options relevant to coreboot:
|
TAG=upstream/master
|
||||||
#
|
else
|
||||||
#
|
TAG=origin/$(project_git_branch)
|
||||||
# OPTION = DEFAULT_VALUE
|
|
||||||
#
|
|
||||||
# ABOVE_4G_MEMORY = TRUE
|
|
||||||
ifneq ($(CONFIG_TIANOCORE_ABOVE_4G_MEMORY),y)
|
|
||||||
BUILD_STR += -D ABOVE_4G_MEMORY=FALSE
|
|
||||||
endif
|
endif
|
||||||
# BOOTSPLASH_IMAGE = FALSE
|
|
||||||
ifneq ($(CONFIG_TIANOCORE_BOOTSPLASH_FILE),)
|
ifneq ($(CONFIG_TIANOCORE_REVISION_ID),)
|
||||||
BUILD_STR += -D BOOTSPLASH_IMAGE=TRUE
|
TAG=$(CONFIG_TIANOCORE_REVISION_ID)
|
||||||
endif
|
endif
|
||||||
# BOOT_MANAGER_ESCAPE = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_BOOT_MANAGER_ESCAPE),y)
|
export EDK_TOOLS_PATH=$(project_dir)/BaseTools
|
||||||
BUILD_STR += -D BOOT_MANAGER_ESCAPE=TRUE
|
|
||||||
|
ifeq ($(CONFIG_TIANOCORE_DEBUG),y)
|
||||||
|
BUILD_TYPE=DEBUG
|
||||||
|
else
|
||||||
|
BUILD_TYPE=RELEASE
|
||||||
endif
|
endif
|
||||||
# BUILD_TARGETS = DEBUG
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_RELEASE),y)
|
|
||||||
BUILD_STR += -b RELEASE
|
|
||||||
endif
|
|
||||||
# FOLLOW_BGRT_SPEC = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_FOLLOW_BGRT_SPEC),y)
|
|
||||||
BUILD_STR += -D FOLLOW_BGRT_SPEC=TRUE
|
|
||||||
endif
|
|
||||||
# PRIORITIZE_INTERNAL = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_PRIORITIZE_INTERNAL),y)
|
|
||||||
BUILD_STR += -D PRIORITIZE_INTERNAL=TRUE
|
|
||||||
endif
|
|
||||||
# PS2_KEYBOARD_ENABLE = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_PS2_SUPPORT),y)
|
|
||||||
BUILD_STR += -D PS2_KEYBOARD_ENABLE=TRUE
|
|
||||||
endif
|
|
||||||
# PLATFORM_BOOT_TIMEOUT = 3
|
|
||||||
ifneq ($(CONFIG_TIANOCORE_BOOT_TIMEOUT),)
|
|
||||||
BUILD_STR += -D PLATFORM_BOOT_TIMEOUT=$(CONFIG_TIANOCORE_BOOT_TIMEOUT)
|
|
||||||
endif
|
|
||||||
# SIO_BUS_ENABLE = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_PS2_SUPPORT),y)
|
|
||||||
BUILD_STR += -D SIO_BUS_ENABLE=TRUE
|
|
||||||
endif
|
|
||||||
# SHELL_TYPE = BUILD_SHELL
|
|
||||||
ifneq ($(CONFIG_TIANOCORE_HAVE_EFI_SHELL),y)
|
|
||||||
BUILD_STR += -D SHELL_TYPE=NONE
|
|
||||||
endif
|
|
||||||
# USE_CBMEM_FOR_CONSOLE = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_CBMEM_LOGGING),y)
|
ifeq ($(CONFIG_TIANOCORE_CBMEM_LOGGING),y)
|
||||||
BUILD_STR += -D USE_CBMEM_FOR_CONSOLE=TRUE
|
CBMEM=-D USE_CBMEM_FOR_CONSOLE=TRUE
|
||||||
endif
|
|
||||||
# SD_MMC_TIMEOUT = 1000000
|
|
||||||
ifneq ($(CONFIG_TIANOCORE_SD_MMC_TIMEOUT),)
|
|
||||||
BUILD_STR += -D SD_MMC_TIMEOUT=$(CONFIG_TIANOCORE_SD_MMC_TIMEOUT)
|
|
||||||
endif
|
|
||||||
#
|
|
||||||
# The below are legacy options only available in CorebootPayloadPkg:
|
|
||||||
#
|
|
||||||
# PCIE_BASE = 0
|
|
||||||
ifneq ($(CONFIG_ECAM_MMCONF_BASE_ADDRESS),)
|
|
||||||
BUILD_STR += -D PCIE_BASE=$(CONFIG_ECAM_MMCONF_BASE_ADDRESS)
|
|
||||||
endif
|
|
||||||
# USE_HPET_TIMER = FALSE
|
|
||||||
ifeq ($(CONFIG_TIANOCORE_USE_8254_TIMER),y)
|
|
||||||
BUILD_STR += -D USE_HPET_TIMER=TRUE
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
bootloader = $(word 8,$(subst /, ,$(BUILD_STR)))
|
ifeq ($(CONFIG_TIANOCORE_ABOVE_4G_MEMORY),y)
|
||||||
|
4G=-D ABOVE_4G_MEMORY=TRUE
|
||||||
|
else
|
||||||
|
4G=-D ABOVE_4G_MEMORY=FALSE
|
||||||
|
endif
|
||||||
|
|
||||||
|
TIMEOUT=-D PLATFORM_BOOT_TIMEOUT=$(CONFIG_TIANOCORE_BOOT_TIMEOUT)
|
||||||
|
|
||||||
|
ifneq ($(CONFIG_TIANOCORE_USE_8254_TIMER), y)
|
||||||
|
TIMER=-DUSE_HPET_TIMER
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_TIANOCORE_COREBOOTPAYLOAD),y)
|
||||||
|
BUILD_STR=-q -a IA32 -a X64 -p CorebootPayloadPkg/CorebootPayloadPkgIa32X64.dsc -t COREBOOT -b $(BUILD_TYPE) $(TIMER) -DPS2_KEYBOARD_ENABLE
|
||||||
|
else
|
||||||
|
BUILD_STR=-q -a IA32 -a X64 -p UefiPayloadPkg/UefiPayloadPkg.dsc -t COREBOOT -b $(BUILD_TYPE) $(TIMEOUT) $(build_flavor) $(CBMEM) $(4G)
|
||||||
|
endif
|
||||||
|
|
||||||
all: clean build
|
all: clean build
|
||||||
|
|
||||||
$(project_dir):
|
$(project_dir):
|
||||||
echo " Cloning $(project_name) from $(CONFIG_TIANOCORE_REPOSITORY)"
|
echo " Cloning $(project_name) from Git"
|
||||||
git clone $(CONFIG_TIANOCORE_REPOSITORY) $(project_dir); \
|
git clone --branch $(project_git_branch) $(project_git_repo) $(project_dir); \
|
||||||
cd $(project_dir);
|
cd $(project_dir); \
|
||||||
|
git remote add upstream $(upstream_git_repo)
|
||||||
|
|
||||||
update: $(project_dir)
|
update: $(project_dir)
|
||||||
if [ ! -d "$(project_dir)" ]; then \
|
|
||||||
git clone $(CONFIG_TIANOCORE_REPOSITORY) $(project_dir); \
|
|
||||||
fi
|
|
||||||
cd $(project_dir); \
|
cd $(project_dir); \
|
||||||
echo " Fetching new commits from $(CONFIG_TIANOCORE_REPOSITORY)"; \
|
echo " Fetching new commits from the $(project_name) repo"; \
|
||||||
git fetch origin 2>/dev/null; \
|
git fetch --multiple origin upstream 2>/dev/null; \
|
||||||
if ! git rev-parse --verify -q $(CONFIG_TIANOCORE_TAG_OR_REV) >/dev/null; then \
|
if ! git rev-parse --verify -q $(TAG) >/dev/null; then \
|
||||||
echo " $(CONFIG_TIANOCORE_TAG_OR_REV) is not a valid git reference"; \
|
echo " $(TAG) is not a valid git reference"; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi; \
|
fi; \
|
||||||
if git status --ignore-submodules=dirty | grep -qv clean; then \
|
if git status --ignore-submodules=dirty | grep -qv clean; then \
|
||||||
echo " Checking out $(project_name) revision $(CONFIG_TIANOCORE_TAG_OR_REV)"; \
|
echo " Checking out $(project_name) revision $(TAG)"; \
|
||||||
git checkout --detach $(CONFIG_TIANOCORE_TAG_OR_REV) -f; \
|
git checkout --detach $(TAG); \
|
||||||
else \
|
else \
|
||||||
echo " Working directory not clean; will not overwrite"; \
|
echo " Working directory not clean; will not overwrite"; \
|
||||||
fi; \
|
fi; \
|
||||||
git submodule update --init --checkout
|
git submodule update --init
|
||||||
|
|
||||||
checktools:
|
checktools:
|
||||||
echo "Checking uuid-dev..."
|
echo "Checking uuid-dev..."
|
||||||
@@ -120,15 +94,15 @@ checktools:
|
|||||||
( echo " Not found."; echo "Error: Please install nasm."; exit 1 )
|
( echo " Not found."; echo "Error: Please install nasm."; exit 1 )
|
||||||
|
|
||||||
build: update checktools
|
build: update checktools
|
||||||
unset CC; $(MAKE) -C $(project_dir)/BaseTools 2>&1
|
unset CC; $(MAKE) -C $(project_dir)/BaseTools
|
||||||
echo " build $(project_name) $(CONFIG_TIANOCORE_TAG_OR_REV)"
|
echo " build $(project_name) $(TAG)"
|
||||||
if [ -n "$(CONFIG_TIANOCORE_BOOTSPLASH_FILE)" ]; then \
|
if [ -n "$(CONFIG_TIANOCORE_BOOTSPLASH_FILE)" ]; then \
|
||||||
echo " Copying custom bootsplash image"; \
|
echo " Copying custom bootsplash image"; \
|
||||||
case "$(CONFIG_TIANOCORE_BOOTSPLASH_FILE)" in \
|
case "$(CONFIG_TIANOCORE_BOOTSPLASH_FILE)" in \
|
||||||
/*) convert $(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
/*) cp $(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
||||||
BMP3:$(project_dir)/MdeModulePkg/Logo/Logo.bmp;; \
|
$(project_dir)/MdeModulePkg/Logo/Logo.bmp;; \
|
||||||
*) convert $(top)/$(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
*) cp $(top)/$(CONFIG_TIANOCORE_BOOTSPLASH_FILE) \
|
||||||
BMP3:$(project_dir)/MdeModulePkg/Logo/Logo.bmp;; \
|
$(project_dir)/MdeModulePkg/Logo/Logo.bmp;; \
|
||||||
esac \
|
esac \
|
||||||
fi; \
|
fi; \
|
||||||
cd $(project_dir); \
|
cd $(project_dir); \
|
||||||
@@ -140,14 +114,13 @@ build: update checktools
|
|||||||
cat ../tools_def.txt >> $(project_dir)/Conf/tools_def.txt; \
|
cat ../tools_def.txt >> $(project_dir)/Conf/tools_def.txt; \
|
||||||
fi; \
|
fi; \
|
||||||
build $(BUILD_STR); \
|
build $(BUILD_STR); \
|
||||||
mkdir -p $(project_dir)/../output
|
mv $(project_dir)/Build/$(bootloader)*/*/FV/UEFIPAYLOAD.fd $(project_dir)/Build/UEFIPAYLOAD.fd; \
|
||||||
mv $(project_dir)/Build/$(bootloader)*/*/FV/UEFIPAYLOAD.fd $(project_dir)/../output/UEFIPAYLOAD.fd; \
|
|
||||||
git checkout MdeModulePkg/Logo/Logo.bmp > /dev/null 2>&1 || true
|
git checkout MdeModulePkg/Logo/Logo.bmp > /dev/null 2>&1 || true
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
test -d $(project_dir) && (cd $(project_dir); rm -rf Build; rm -f Conf/tools_def.txt) || exit 0
|
test -d $(project_dir) && (cd $(project_dir); rm -rf Build; rm -f Conf/tools_def.txt) || exit 0
|
||||||
|
|
||||||
distclean:
|
distclean:
|
||||||
rm -rf */
|
rm -rf $(project_dir)
|
||||||
|
|
||||||
.PHONY: all update checktools config build clean distclean
|
.PHONY: all update checktools config build clean distclean
|
||||||
|
@@ -42,7 +42,6 @@ libc-$(CONFIG_LP_GPL) += string.c
|
|||||||
libgdb-y += gdb.c
|
libgdb-y += gdb.c
|
||||||
|
|
||||||
libcbfs-$(CONFIG_LP_CBFS) += rom_media.c
|
libcbfs-$(CONFIG_LP_CBFS) += rom_media.c
|
||||||
libcbfs-$(CONFIG_LP_CBFS) += boot_media.c
|
|
||||||
|
|
||||||
# Multiboot support is configurable
|
# Multiboot support is configurable
|
||||||
libc-$(CONFIG_LP_MULTIBOOT) += multiboot.c
|
libc-$(CONFIG_LP_MULTIBOOT) += multiboot.c
|
||||||
|
@@ -1,6 +1,5 @@
|
|||||||
/* SPDX-License-Identifier: BSD-3-Clause */
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||||
|
|
||||||
#include <arch/virtual.h>
|
|
||||||
#include <boot_device.h>
|
#include <boot_device.h>
|
||||||
#include <commonlib/bsd/cb_err.h>
|
#include <commonlib/bsd/cb_err.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
@@ -12,7 +11,7 @@ __attribute__((weak)) ssize_t boot_device_read(void *buf, size_t offset, size_t
|
|||||||
/* Memory-mapping usually only works for the top 16MB. */
|
/* Memory-mapping usually only works for the top 16MB. */
|
||||||
if (!lib_sysinfo.boot_media_size || lib_sysinfo.boot_media_size - offset > 16 * MiB)
|
if (!lib_sysinfo.boot_media_size || lib_sysinfo.boot_media_size - offset > 16 * MiB)
|
||||||
return CB_ERR_ARG;
|
return CB_ERR_ARG;
|
||||||
const void *const ptr = phys_to_virt(0 - lib_sysinfo.boot_media_size + offset);
|
void *ptr = (void *)(uintptr_t)(0 - lib_sysinfo.boot_media_size + offset);
|
||||||
memcpy(buf, ptr, size);
|
memcpy(buf, ptr, size);
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
@@ -182,15 +182,7 @@ trygccoption -fno-stack-protector
|
|||||||
_CFLAGS="$_CFLAGS -include $BASE/../include/kconfig.h -include $BASE/../include/compiler.h"
|
_CFLAGS="$_CFLAGS -include $BASE/../include/kconfig.h -include $BASE/../include/compiler.h"
|
||||||
_CFLAGS="$_CFLAGS -I`$DEFAULT_CC $_ARCHEXTRA -print-search-dirs | head -n 1 | cut -d' ' -f2`include"
|
_CFLAGS="$_CFLAGS -I`$DEFAULT_CC $_ARCHEXTRA -print-search-dirs | head -n 1 | cut -d' ' -f2`include"
|
||||||
|
|
||||||
if [ "$CONFIG_LP_VBOOT_LIB" = y ]; then
|
_LDFLAGS="-L$_LIBDIR $_LDSCRIPT -static"
|
||||||
if [ "$CONFIG_LP_VBOOT_TPM2_MODE" = y ]; then
|
|
||||||
_CFLAGS="$_CFLAGS -DTPM2_MODE"
|
|
||||||
else
|
|
||||||
_CFLAGS="$_CFLAGS -DTPM1_MODE"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
_LDFLAGS="-L$_LIBDIR $_LDSCRIPT -static -Wl,--gc-sections"
|
|
||||||
|
|
||||||
if [ $DOLINK -eq 0 ]; then
|
if [ $DOLINK -eq 0 ]; then
|
||||||
if [ $DEBUGME -eq 1 ]; then
|
if [ $DEBUGME -eq 1 ]; then
|
||||||
|
@@ -80,28 +80,11 @@ void cbmem_console_write(const void *buffer, size_t count)
|
|||||||
do_write(buffer, count);
|
do_write(buffer, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void snapshot_putc(char *console, uint32_t *cursor, char c)
|
|
||||||
{
|
|
||||||
/* This is BIOS_LOG_IS_MARKER() from coreboot. Due to stupid
|
|
||||||
licensing restrictions, we can't use it directly. */
|
|
||||||
if (c >= 0x10 && c <= 0x18)
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* Slight memory corruption may occur between reboots and give us a few
|
|
||||||
unprintable characters like '\0'. Replace them with '?' on output. */
|
|
||||||
if (!isprint(c) && !isspace(c))
|
|
||||||
console[*cursor] = '?';
|
|
||||||
else
|
|
||||||
console[*cursor] = c;
|
|
||||||
|
|
||||||
*cursor += 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *cbmem_console_snapshot(void)
|
char *cbmem_console_snapshot(void)
|
||||||
{
|
{
|
||||||
const struct cbmem_console *const console_p = phys_to_virt(cbmem_console_p);
|
const struct cbmem_console *const console_p = phys_to_virt(cbmem_console_p);
|
||||||
char *console_c;
|
char *console_c;
|
||||||
uint32_t size, cursor, overflow, newc, oldc;
|
uint32_t size, cursor, overflow;
|
||||||
|
|
||||||
if (!console_p) {
|
if (!console_p) {
|
||||||
printf("ERROR: No cbmem console found in coreboot table\n");
|
printf("ERROR: No cbmem console found in coreboot table\n");
|
||||||
@@ -121,19 +104,24 @@ char *cbmem_console_snapshot(void)
|
|||||||
size);
|
size);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
console_c[size] = '\0';
|
||||||
|
|
||||||
newc = 0;
|
|
||||||
if (overflow) {
|
if (overflow) {
|
||||||
if (cursor >= size) {
|
if (cursor >= size) {
|
||||||
printf("ERROR: CBMEM console struct is corrupted\n");
|
printf("ERROR: CBMEM console struct is corrupted\n");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
for (oldc = cursor; oldc < size; oldc++)
|
memcpy(console_c, console_p->body + cursor, size - cursor);
|
||||||
snapshot_putc(console_c, &newc, console_p->body[oldc]);
|
memcpy(console_c + size - cursor, console_p->body, cursor);
|
||||||
|
} else {
|
||||||
|
memcpy(console_c, console_p->body, size);
|
||||||
}
|
}
|
||||||
for (oldc = 0; oldc < size && oldc < cursor; oldc++)
|
|
||||||
snapshot_putc(console_c, &newc, console_p->body[oldc]);
|
/* Slight memory corruption may occur between reboots and give us a few
|
||||||
console_c[newc] = '\0';
|
unprintable characters like '\0'. Replace them with '?' on output. */
|
||||||
|
for (cursor = 0; cursor < size; cursor++)
|
||||||
|
if (!isprint(console_c[cursor]) && !isspace(console_c[cursor]))
|
||||||
|
console_c[cursor] = '?';
|
||||||
|
|
||||||
return console_c;
|
return console_c;
|
||||||
}
|
}
|
||||||
|
@@ -57,6 +57,7 @@ static const struct cb_framebuffer *fbinfo;
|
|||||||
#define PIVOT_H_MASK (PIVOT_H_LEFT|PIVOT_H_CENTER|PIVOT_H_RIGHT)
|
#define PIVOT_H_MASK (PIVOT_H_LEFT|PIVOT_H_CENTER|PIVOT_H_RIGHT)
|
||||||
#define PIVOT_V_MASK (PIVOT_V_TOP|PIVOT_V_CENTER|PIVOT_V_BOTTOM)
|
#define PIVOT_V_MASK (PIVOT_V_TOP|PIVOT_V_CENTER|PIVOT_V_BOTTOM)
|
||||||
#define ROUNDUP(x, y) ((((x) + ((y) - 1)) / (y)) * (y))
|
#define ROUNDUP(x, y) ((((x) + ((y) - 1)) / (y)) * (y))
|
||||||
|
#define ABS(x) ((x) < 0 ? -(x) : (x))
|
||||||
|
|
||||||
static char initialized = 0;
|
static char initialized = 0;
|
||||||
|
|
||||||
|
@@ -83,7 +83,6 @@ enum {
|
|||||||
CB_TAG_BOARD_CONFIG = 0x0040,
|
CB_TAG_BOARD_CONFIG = 0x0040,
|
||||||
CB_TAG_ACPI_CNVS = 0x0041,
|
CB_TAG_ACPI_CNVS = 0x0041,
|
||||||
CB_TAG_TYPE_C_INFO = 0x0042,
|
CB_TAG_TYPE_C_INFO = 0x0042,
|
||||||
CB_TAG_ACPI_RSDP = 0x0043,
|
|
||||||
CB_TAG_CMOS_OPTION_TABLE = 0x00c8,
|
CB_TAG_CMOS_OPTION_TABLE = 0x00c8,
|
||||||
CB_TAG_OPTION = 0x00c9,
|
CB_TAG_OPTION = 0x00c9,
|
||||||
CB_TAG_OPTION_ENUM = 0x00ca,
|
CB_TAG_OPTION_ENUM = 0x00ca,
|
||||||
@@ -91,7 +90,10 @@ enum {
|
|||||||
CB_TAG_OPTION_CHECKSUM = 0x00cc,
|
CB_TAG_OPTION_CHECKSUM = 0x00cc,
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef __aligned(4) uint64_t cb_uint64_t;
|
struct cbuint64 {
|
||||||
|
u32 lo;
|
||||||
|
u32 hi;
|
||||||
|
};
|
||||||
|
|
||||||
struct cb_header {
|
struct cb_header {
|
||||||
u8 signature[4];
|
u8 signature[4];
|
||||||
@@ -108,8 +110,8 @@ struct cb_record {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct cb_memory_range {
|
struct cb_memory_range {
|
||||||
cb_uint64_t start;
|
struct cbuint64 start;
|
||||||
cb_uint64_t size;
|
struct cbuint64 size;
|
||||||
u32 type;
|
u32 type;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -268,14 +270,14 @@ struct cb_gpios {
|
|||||||
struct lb_range {
|
struct lb_range {
|
||||||
uint32_t tag;
|
uint32_t tag;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
cb_uint64_t range_start;
|
uint64_t range_start;
|
||||||
uint32_t range_size;
|
uint32_t range_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cb_cbmem_tab {
|
struct cb_cbmem_tab {
|
||||||
uint32_t tag;
|
uint32_t tag;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
cb_uint64_t cbmem_tab;
|
uint64_t cbmem_tab;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cb_x86_rom_mtrr {
|
struct cb_x86_rom_mtrr {
|
||||||
@@ -313,10 +315,10 @@ struct cb_boot_media_params {
|
|||||||
uint32_t tag;
|
uint32_t tag;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
/* offsets are relative to start of boot media */
|
/* offsets are relative to start of boot media */
|
||||||
cb_uint64_t fmap_offset;
|
uint64_t fmap_offset;
|
||||||
cb_uint64_t cbfs_offset;
|
uint64_t cbfs_offset;
|
||||||
cb_uint64_t cbfs_size;
|
uint64_t cbfs_size;
|
||||||
cb_uint64_t boot_media_size;
|
uint64_t boot_media_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -324,7 +326,7 @@ struct cb_cbmem_entry {
|
|||||||
uint32_t tag;
|
uint32_t tag;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
|
|
||||||
cb_uint64_t address;
|
uint64_t address;
|
||||||
uint32_t entry_size;
|
uint32_t entry_size;
|
||||||
uint32_t id;
|
uint32_t id;
|
||||||
};
|
};
|
||||||
@@ -366,7 +368,7 @@ struct cb_board_config {
|
|||||||
uint32_t tag;
|
uint32_t tag;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
|
|
||||||
cb_uint64_t fw_config;
|
struct cbuint64 fw_config;
|
||||||
uint32_t board_id;
|
uint32_t board_id;
|
||||||
uint32_t ram_code;
|
uint32_t ram_code;
|
||||||
uint32_t sku_id;
|
uint32_t sku_id;
|
||||||
@@ -420,18 +422,13 @@ struct cb_cmos_checksum {
|
|||||||
u32 type;
|
u32 type;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
|
||||||
* Handoff the ACPI RSDP
|
|
||||||
*/
|
|
||||||
struct cb_acpi_rsdp {
|
|
||||||
uint32_t tag;
|
|
||||||
uint32_t size;
|
|
||||||
cb_uint64_t rsdp_pointer; /* Address of the ACPI RSDP */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/* Helpful inlines */
|
/* Helpful inlines */
|
||||||
|
|
||||||
|
static inline u64 cb_unpack64(struct cbuint64 val)
|
||||||
|
{
|
||||||
|
return (((u64) val.hi) << 32) | val.lo;
|
||||||
|
}
|
||||||
|
|
||||||
static inline u16 cb_checksum(const void *ptr, unsigned len)
|
static inline u16 cb_checksum(const void *ptr, unsigned len)
|
||||||
{
|
{
|
||||||
return ipchksum(ptr, len);
|
return ipchksum(ptr, len);
|
||||||
|
@@ -7,6 +7,6 @@
|
|||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
/* Looks for area with |name| in FlashMap. Requires lib_sysinfo.fmap_cache. */
|
/* Looks for area with |name| in FlashMap. Requires lib_sysinfo.fmap_cache. */
|
||||||
enum cb_err fmap_locate_area(const char *name, size_t *offset, size_t *size);
|
cb_err_t fmap_locate_area(const char *name, size_t *offset, size_t *size);
|
||||||
|
|
||||||
#endif /* _FMAP_H */
|
#endif /* _FMAP_H */
|
||||||
|
@@ -46,8 +46,6 @@
|
|||||||
#include <libpayload-config.h>
|
#include <libpayload-config.h>
|
||||||
#include <cbgfx.h>
|
#include <cbgfx.h>
|
||||||
#include <commonlib/bsd/fmap_serialized.h>
|
#include <commonlib/bsd/fmap_serialized.h>
|
||||||
#include <commonlib/bsd/helpers.h>
|
|
||||||
#include <commonlib/bsd/mem_chip_info.h>
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <die.h>
|
#include <die.h>
|
||||||
#include <endian.h>
|
#include <endian.h>
|
||||||
@@ -68,8 +66,33 @@
|
|||||||
#include <pci.h>
|
#include <pci.h>
|
||||||
#include <archive.h>
|
#include <archive.h>
|
||||||
|
|
||||||
|
/* Double-evaluation unsafe min/max, for bitfields and outside of functions */
|
||||||
|
#define __CMP_UNSAFE(a, b, op) ((a) op (b) ? (a) : (b))
|
||||||
|
#define MIN_UNSAFE(a, b) __CMP_UNSAFE(a, b, <)
|
||||||
|
#define MAX_UNSAFE(a, b) __CMP_UNSAFE(a, b, >)
|
||||||
|
|
||||||
|
#define __CMP_SAFE(a, b, op, var_a, var_b) ({ \
|
||||||
|
__TYPEOF_UNLESS_CONST(a, b) var_a = (a); \
|
||||||
|
__TYPEOF_UNLESS_CONST(b, a) var_b = (b); \
|
||||||
|
var_a op var_b ? var_a : var_b; \
|
||||||
|
})
|
||||||
|
|
||||||
|
#define __CMP(a, b, op) __builtin_choose_expr( \
|
||||||
|
__builtin_constant_p(a) && __builtin_constant_p(b), \
|
||||||
|
__CMP_UNSAFE(a, b, op), __CMP_SAFE(a, b, op, __TMPNAME, __TMPNAME))
|
||||||
|
|
||||||
|
#define MIN(a, b) __CMP(a, b, <)
|
||||||
|
#define MAX(a, b) __CMP(a, b, >)
|
||||||
|
|
||||||
|
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
|
||||||
#define BIT(x) (1ul << (x))
|
#define BIT(x) (1ul << (x))
|
||||||
|
|
||||||
|
#define DIV_ROUND_UP(x, y) ({ \
|
||||||
|
typeof(x) _div_local_x = (x); \
|
||||||
|
typeof(y) _div_local_y = (y); \
|
||||||
|
(_div_local_x + _div_local_y - 1) / _div_local_y; \
|
||||||
|
})
|
||||||
|
|
||||||
static inline u32 div_round_up(u32 n, u32 d) { return (n + d - 1) / d; }
|
static inline u32 div_round_up(u32 n, u32 d) { return (n + d - 1) / d; }
|
||||||
|
|
||||||
#define LITTLE_ENDIAN 1234
|
#define LITTLE_ENDIAN 1234
|
||||||
|
@@ -2,7 +2,6 @@
|
|||||||
#define _STDDEF_H
|
#define _STDDEF_H
|
||||||
|
|
||||||
#include <arch/types.h>
|
#include <arch/types.h>
|
||||||
#include <commonlib/bsd/helpers.h>
|
|
||||||
|
|
||||||
#ifndef __WCHAR_TYPE__
|
#ifndef __WCHAR_TYPE__
|
||||||
#define __WCHAR_TYPE__ int
|
#define __WCHAR_TYPE__ int
|
||||||
@@ -23,6 +22,22 @@ typedef __SIZE_TYPE__ size_t;
|
|||||||
typedef __SIZE_TYPE__ ssize_t;
|
typedef __SIZE_TYPE__ ssize_t;
|
||||||
#undef unsigned
|
#undef unsigned
|
||||||
|
|
||||||
|
#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *) 0)->MEMBER)
|
||||||
|
#define member_size(TYPE, MEMBER) (sizeof(((TYPE *) 0)->MEMBER))
|
||||||
|
|
||||||
|
#define check_member(structure, member, offset) _Static_assert( \
|
||||||
|
offsetof(struct structure, member) == offset, \
|
||||||
|
"`struct " #structure "` offset for `" #member "` is not " #offset)
|
||||||
|
|
||||||
|
/* Standard units. */
|
||||||
|
#define KiB (1 << 10)
|
||||||
|
#define MiB (1 << 20)
|
||||||
|
#define GiB (1 << 30)
|
||||||
|
|
||||||
|
#define KHz (1000)
|
||||||
|
#define MHz (1000*KHz)
|
||||||
|
#define GHz (1000*MHz)
|
||||||
|
|
||||||
#define NSECS_PER_SEC 1000000000
|
#define NSECS_PER_SEC 1000000000
|
||||||
#define USECS_PER_SEC 1000000
|
#define USECS_PER_SEC 1000000
|
||||||
#define MSECS_PER_SEC 1000
|
#define MSECS_PER_SEC 1000
|
||||||
|
@@ -34,6 +34,12 @@
|
|||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#define ALIGN(x,a) __ALIGN_MASK(x,(typeof(x))(a)-1UL)
|
||||||
|
#define __ALIGN_MASK(x,mask) (((x)+(mask))&~(mask))
|
||||||
|
#define ALIGN_UP(x,a) ALIGN((x),(a))
|
||||||
|
#define ALIGN_DOWN(x,a) ((x) & ~((typeof(x))(a)-1UL))
|
||||||
|
#define IS_ALIGNED(x,a) (((x) & ((typeof(x))(a)-1UL)) == 0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @defgroup malloc Memory allocation functions
|
* @defgroup malloc Memory allocation functions
|
||||||
* @{
|
* @{
|
||||||
|
@@ -83,7 +83,6 @@ struct sysinfo_t {
|
|||||||
uintptr_t compiler;
|
uintptr_t compiler;
|
||||||
uintptr_t linker;
|
uintptr_t linker;
|
||||||
uintptr_t assembler;
|
uintptr_t assembler;
|
||||||
uintptr_t mem_chip_base;
|
|
||||||
|
|
||||||
uintptr_t cb_version;
|
uintptr_t cb_version;
|
||||||
|
|
||||||
@@ -111,7 +110,6 @@ struct sysinfo_t {
|
|||||||
uintptr_t mrc_cache;
|
uintptr_t mrc_cache;
|
||||||
uintptr_t acpi_gnvs;
|
uintptr_t acpi_gnvs;
|
||||||
uintptr_t acpi_cnvs;
|
uintptr_t acpi_cnvs;
|
||||||
uintptr_t acpi_rsdp;
|
|
||||||
|
|
||||||
#define UNDEFINED_STRAPPING_ID (~0)
|
#define UNDEFINED_STRAPPING_ID (~0)
|
||||||
#define UNDEFINED_FW_CONFIG ~((uint64_t)0)
|
#define UNDEFINED_FW_CONFIG ~((uint64_t)0)
|
||||||
|
@@ -61,8 +61,12 @@ static void cb_parse_memory(void *ptr, struct sysinfo_t *info)
|
|||||||
continue;
|
continue;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
info->memrange[info->n_memranges].base = range->start;
|
info->memrange[info->n_memranges].base =
|
||||||
info->memrange[info->n_memranges].size = range->size;
|
cb_unpack64(range->start);
|
||||||
|
|
||||||
|
info->memrange[info->n_memranges].size =
|
||||||
|
cb_unpack64(range->size);
|
||||||
|
|
||||||
info->memrange[info->n_memranges].type = range->type;
|
info->memrange[info->n_memranges].type = range->type;
|
||||||
|
|
||||||
info->n_memranges++;
|
info->n_memranges++;
|
||||||
@@ -117,7 +121,7 @@ static void cb_parse_mac_addresses(unsigned char *ptr,
|
|||||||
static void cb_parse_board_config(unsigned char *ptr, struct sysinfo_t *info)
|
static void cb_parse_board_config(unsigned char *ptr, struct sysinfo_t *info)
|
||||||
{
|
{
|
||||||
struct cb_board_config *const config = (struct cb_board_config *)ptr;
|
struct cb_board_config *const config = (struct cb_board_config *)ptr;
|
||||||
info->fw_config = config->fw_config;
|
info->fw_config = cb_unpack64(config->fw_config);
|
||||||
info->board_id = config->board_id;
|
info->board_id = config->board_id;
|
||||||
info->ram_code = config->ram_code;
|
info->ram_code = config->ram_code;
|
||||||
info->sku_id = config->sku_id;
|
info->sku_id = config->sku_id;
|
||||||
@@ -256,20 +260,11 @@ static void cb_parse_cbmem_entry(void *ptr, struct sysinfo_t *info)
|
|||||||
case CBMEM_ID_TYPE_C_INFO:
|
case CBMEM_ID_TYPE_C_INFO:
|
||||||
info->type_c_info = cbmem_entry->address;
|
info->type_c_info = cbmem_entry->address;
|
||||||
break;
|
break;
|
||||||
case CBMEM_ID_MEM_CHIP_INFO:
|
|
||||||
info->mem_chip_base = cbmem_entry->address;
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cb_parse_rsdp(void *ptr, struct sysinfo_t *info)
|
|
||||||
{
|
|
||||||
const struct cb_acpi_rsdp *cb_acpi_rsdp = ptr;
|
|
||||||
info->acpi_rsdp = cb_acpi_rsdp->rsdp_pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
int cb_parse_header(void *addr, int len, struct sysinfo_t *info)
|
int cb_parse_header(void *addr, int len, struct sysinfo_t *info)
|
||||||
{
|
{
|
||||||
struct cb_header *header;
|
struct cb_header *header;
|
||||||
@@ -410,9 +405,6 @@ int cb_parse_header(void *addr, int len, struct sysinfo_t *info)
|
|||||||
cb_parse_tsc_info(ptr, info);
|
cb_parse_tsc_info(ptr, info);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
case CB_TAG_ACPI_RSDP:
|
|
||||||
cb_parse_rsdp(ptr, info);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
cb_parse_arch_specific(rec, info);
|
cb_parse_arch_specific(rec, info);
|
||||||
break;
|
break;
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user