2021-05-18 12:56:12 +00:00
|
|
|
*~
|
2023-04-08 02:14:48 +00:00
|
|
|
*.o
|
2023-06-25 13:17:29 +00:00
|
|
|
/lbmk.err.log
|
|
|
|
/cbutils/
|
2023-05-06 20:21:42 +00:00
|
|
|
/pciroms/
|
2023-05-06 06:23:45 +00:00
|
|
|
/util/e6400-flash-unlock/e6400_flash_unlock
|
2023-04-08 02:14:48 +00:00
|
|
|
/util/ich9utils/*.bin
|
|
|
|
/util/ich9utils/demefactory
|
|
|
|
/util/ich9utils/ich9deblob
|
|
|
|
/util/ich9utils/ich9show
|
|
|
|
/util/ich9utils/ich9gen
|
2021-05-18 12:56:12 +00:00
|
|
|
/TODO
|
2023-05-06 16:15:14 +00:00
|
|
|
/bios_extract/
|
2023-04-02 00:33:33 +00:00
|
|
|
/ec/
|
2021-05-18 12:56:12 +00:00
|
|
|
/tmp/
|
consolidate u-boot/seabios/coreboot build scripts
See file:
resources/scripts/build/defconfig/for
It is based on:
resources/scripts/build/payload/u-boot
The u-boot payload script has been deleted, as has the
seabios payload script; the build/boot/roms logic has
been heavily simplified too, by removing the logic for
building of elf files based on defconfig.
SeaBIOS, U-Boot and coreboot all use defconfig-type
infrastructure for their build systems, and they are
fundamentally the *same* in how to compile each codebase,
at least in an lbmk context, regardless of actual (and
very huge) differences in these codebases.
Several hundred sources-lines of code have been eliminated
by this change, drastically simplifying everything; U-Boot
payload compiling also now errors out when a single build
fails, instead of continuing. Also: build/boot/roms no longer
re-compiles a coreboot target that was already compiled,
which is the same behaviour observed for payloads.
(this means you must now manually delete a target, when you
wish to re-build it; the build/boot/roms logic now more or
less just runs cbfstool; blobutil is handled from
build/defconfig/for)
ALSO: Since crossgcc is now handled by build/defconfig/for, not
build/boot/roms, standalone compiling of u-boot is now possible.
This has been tested. You compile it like so:
./build defconfig for u-boot
or specific trees, e.g.
./build defconfig for u-boot default
One other consequence of this patch is that re-building the same
ROM image is now much faster, because the same builds are re-used
unless deleted. This could be useful when testing grub.cfg changes,
for example, if that's all you change. With things like ccache used
(not yet used robustly in lbmk), this could speed things up more,
depending on the codebase.
This patch demonstrates the raw power of lbmk; it is a very
simple and highly efficient build system, and now much more so!
Signed-off-by: Leah Rowe <leah@libreboot.org>
2023-08-17 22:27:30 +00:00
|
|
|
/elf/
|
2021-05-18 12:56:12 +00:00
|
|
|
/payload/
|
|
|
|
/me_cleaner/
|
|
|
|
*.s[a-w]?
|
|
|
|
*.vim
|
|
|
|
/*.elf
|
|
|
|
/*.bin
|
|
|
|
/*.rom
|
|
|
|
/build_error
|
|
|
|
/TODO/
|
|
|
|
/docs/version
|
|
|
|
/bucts/
|
|
|
|
/coreboot/
|
|
|
|
/crossgcc/
|
|
|
|
/depthcharge/
|
|
|
|
/flashrom/
|
2023-08-22 18:58:41 +00:00
|
|
|
/resources/*/*/seen
|
2021-05-18 12:56:12 +00:00
|
|
|
/grub/
|
2021-11-01 02:51:10 +00:00
|
|
|
/memtest86plus/
|
2021-05-18 12:56:12 +00:00
|
|
|
/seabios/
|
2022-08-26 16:32:08 +00:00
|
|
|
/u-boot/
|
2021-05-18 12:56:12 +00:00
|
|
|
/bin/
|
|
|
|
/release/
|
|
|
|
/descriptors/
|
|
|
|
/*.bin
|
|
|
|
/push
|
|
|
|
/version
|
|
|
|
/versiondate
|
move ifd/gbe configs into config/ifd/
it doesn't really make sense for them to be under
blobs/ - nominally, they are blobs, but they are
well-understood data files containing config data,
that is easily parsed by tools like ich9show or
ifdtool (and tools like bincfg or nvmutil)
blobs/ has been re-purposed: this directory no longer
exists in lbmk, but it is created (and on .gitignore)
when needed, by blobutil
thus, the blobs/ directory shall only contain vendor
files, and only those files that libreboot scrubs from
releases. therefore, build/release/src can (and has
been) simplified; it currently copies just the ifd and
gbe files from blobs/, selectively, and this logic is
quite error prone, requiring maintenance. now, the
build/release/src script simply copies config/ (which
only ever contains distributable files) and entirely
ignores the blobs/ directory
the blob download script already creates the required
directory, except for the sch5545 download; this is
now fixed
lbmk code size is slightly smaller, due to this patch
Signed-off-by: Leah Rowe <leah@libreboot.org>
2023-09-04 00:17:23 +00:00
|
|
|
/blobs/
|
2023-04-01 16:14:07 +00:00
|
|
|
*me.bin
|
NEW BOARD: Dell Precision T1650
Very nice ivybridge board that supports ECC RAM.
NOTE: I couldn't get onboard graphics working yet, but
this was confirmed working with a graphics card (in my
case nvidia quadra k420) booted in text mode on the SeaBIOS
payload. The GRUB payload also works, when loaded from SeaBIOS.
Therefore, this is a SeaBIOS-only board (as far as first payload
is concerned), but you can pick GRUB from the menu.
You could make it "GRUB-only" in practise by setting SeaBIOS
boot order to only load GRUB, and disable the SeaBIOS menu.
We refer to this as "SeaGRUB".
I've made lbmk use biosutilities and uefiextract, to
get at the SMSC SCH5545 Environmental Control (EC) firmware.
This firmware is needed for fan control. This is automatically
downloaded and extracted, from Dell UEFI firmware updates.
As with other blobs such as Intel ME, this firmware is then
scrubbed by the release build scripts. The blobutil "inject"
script can be used to re-insert it.
Of note: there is no fixed offset, but no other blobs to
be inserted in CBFS either, so the offset when re-inserting
on release ROMs should still be the same, and thus the ROM
checksums should match, when running blobutil inject.
Signed-off-by: Leah Rowe <leah@libreboot.org>
2023-08-11 13:50:17 +00:00
|
|
|
*sch5545ec.bin
|
2022-11-17 12:08:06 +00:00
|
|
|
/mrc/
|
2022-11-19 03:49:24 +00:00
|
|
|
/util/nvmutil/nvm
|
NEW BOARD: Dell Precision T1650
Very nice ivybridge board that supports ECC RAM.
NOTE: I couldn't get onboard graphics working yet, but
this was confirmed working with a graphics card (in my
case nvidia quadra k420) booted in text mode on the SeaBIOS
payload. The GRUB payload also works, when loaded from SeaBIOS.
Therefore, this is a SeaBIOS-only board (as far as first payload
is concerned), but you can pick GRUB from the menu.
You could make it "GRUB-only" in practise by setting SeaBIOS
boot order to only load GRUB, and disable the SeaBIOS menu.
We refer to this as "SeaGRUB".
I've made lbmk use biosutilities and uefiextract, to
get at the SMSC SCH5545 Environmental Control (EC) firmware.
This firmware is needed for fan control. This is automatically
downloaded and extracted, from Dell UEFI firmware updates.
As with other blobs such as Intel ME, this firmware is then
scrubbed by the release build scripts. The blobutil "inject"
script can be used to re-insert it.
Of note: there is no fixed offset, but no other blobs to
be inserted in CBFS either, so the offset when re-inserting
on release ROMs should still be the same, and thus the ROM
checksums should match, when running blobutil inject.
Signed-off-by: Leah Rowe <leah@libreboot.org>
2023-08-11 13:50:17 +00:00
|
|
|
/biosutilities/
|
|
|
|
/uefitool/
|
2023-09-03 01:00:42 +00:00
|
|
|
/util-fw/
|