summaryrefslogtreecommitdiff
path: root/config
AgeCommit message (Collapse)Author
13 dayspico-sdk: Import picotool as a dependencyLeah Rowe
We were previously not handling picotool at all, and pico-sdk would download picotool itself, at build time. This means that the source archive, if created, would not contain picotool. While not strictly required, for complete corresponding source, since it's a toolchain and not the actual pico-serprog firmware, it is my policy that releases must include full corresponding source code, when it is feasible to do so. I must say, I intensely dislike cmake, with such burning passion; I am thoroughly displeased by how hacky this is, but it works and now nothing is in my way for a Libreboot 20241206 rev8 release! Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-06coreboot/next uprev: Fix T480 backlight keysLeah Rowe
Backlight controls already worked on the T480/T480s, if you used software-based controls e.g. set a hotkey for xbacklight, but the actual Fn buttons on the keyboard did not function at all; this patch fixes that issue This also fixes LEDs on T480, on warm reboot, which are otherwise off. It sets them back to the state they were at on cold boot. Both fixes are from Mate Kukri in the new T480 patchset. In addition to these fixes, Mate made several code quality improvements as part of efforts to upstream this code into coreboot's main branch. Updated coreboot T480 patchset to patchset 25. This change will be reflected next in a modification to the Libreboot documentation. I had to make several other fixes on top of this; see diff. A debug option was being enabled relating to stack overflow detection, which we ought to avoid to mitigate over-zealous build errors and stack corruption at boot; an errant option for an EC we don't use was also being enabled, by some code in coreboot relating to a Dasharo board; both issues have been mitigated in this lbmk patch, by patching the upstream coreboot build system in this patch. As part of this change, the coreboot/next tree within lbmk has been updated. Existing patches have been rebased. This brings in the following changes from upstream, relative to the previous revision used on coreboot/next: * 2f1e4e5e85 mb/hp/snb_ivb_desktops/z220*: Remove leftover old usb configurations * 9e859154ea mb/hp/snb_ivb_desktops: Remove unused includes * 70b33cb38d ec/google/chromeec/acpi: Add support for generic LPC memory range * f2ad73b5d1 mb/google/rauru: Raise little core CPU frequency from 700MHz to 2.4GHz * 044017b4cd mb/google/rauru: Initialize PMICs in romstage * 397c3e3c52 mb/google/fatcat/var/fatcat: Add touchpad wake source * e18f0f53cb mb/google/fatcat/var/fatcat: Change touchpad interrupt to edge trigger * a8b4ee246d mb/google/nissa/var/rull: Configure Acoustic noise mitigation * c09fd09edf tree: Use "true", "false" for has_power_resource * 1e64875265 mb/google/fatcat: Remove unused <stdio.h> * f316ab6796 mb/google/fatcat/var/francka: Fix early pad configuration for TPM * 6ca2c3c415 soc/mediatek/mt8196: Fix indentation in Makefile.mk * 94c1307fdb soc/mediatek/mt8196: Add dynamic power-saving for peripheral clocks * 67b140a949 tree: Use "true", "false" for fine_grained_control * 97923aebe1 mb/prodrive/atlas: Add initial support for options * 1a16146795 Fix up CFR's open issues * 7e8d8cdea2 mb/google/rauru: Initialize SPM * 3153432b83 soc/intel/alderlake: Add function to force disable memory channels * 8ea2b0ab46 mb/google/fatcat/var/francka: Use RAM ID 2 for MT62F2G32D4DS-020 WT:F * 5f600a8ee9 mb/google/fatcat: Limit Power Limit when battery is missing * 5213646241 ec/google/chromeec: Add function to detect barrel charger * 5ef70e5f22 ec/google/chromeec: Add API to check if battery is critically low * 42fd35b486 ec/google/chromeec: Add API to check if charger is present * 56370d0283 ec/google/chromeec: Add API to check if a USB PD charger is attached * 001e7a0b45 soc/mediatek/mt8196: Add MT6685 Clock IC driver * 5852841ca7 soc/intel/meteorlake: Use ASPM helpers from Alder Lake * b04f057efd mb/google/rex/var/kanix: Add Synaptics touchpad * af0c2e7a2e mb/prodrive/atlas: Remove the workaround for CLKREQ pins * 13316c644b mb/google/fatcat/var/fatcat: Modify interrupt GPIO for LPSS I2C touchpad * 825e9173b4 soc/mediatek: Distinguish pmic_init_setting function name * d65ff8492c soc/intel/xeon_sp/spr/acpi: Fix regression * 291778a1bd mb/google/corsola: Add new board variant Wyrdeer * 745dcc861d mb/google/corsola: Refactor mipi_panel_power_on function * 79f60c6b22 mb/google/nissa/var/telith: Disable stylus function * d7934bdd53 Doc/soc/amd/family15h: Fix URLs to AMD documents * 3cb7db4075 soc/mediatek/mt8196: Add PMIC MT6316 driver * 60bce10750 drivers/mipi: Add support for KD_KD110N11_51IE panel * d4c80054a4 soc/mediatek/mt8189: Enable timer compensation v2.5 * 403846f177 soc/mediatek/mt8196: Define MFGPLL_*_BASE using MFGSYS_BASE * b3edaa7b10 mb/google/rauru: Implement SKU ID * b470b48718 mb/google/rauru: Add support for getting storage id * 24a5048948 mb/google/nissa/var/pujjo: Add new supported memory part * c6e27c5fbf mb/google/nissa/var/rull: Add G2 touchscreen to devicetree * 639def1d84 mb/google/fatcat/var/fatcat: Enable FPS * acb8c870b2 mb/google/fatcat: Suppress unnecessary extra space in device trees * d79ba5565d mb/google/nissa/var/telith: Modify PLD for typeC and typeA * 620d2fab06 soc/mediatek/mt8189: Replace SPDX identifiers to GPL-2.0-only OR MIT * d90b1322ab commonlib: Refactor CSE sync eventLog * 4ef6c13b38 mb/google/brya: Adjust EC memory map range to support indexed IO * 1e90bbadfa ec/google/chromeec: Add indexed IO support * a8ab708584 mb/google/nissa/var/quandiso2: Create a quandiso2 variant * 78f610a0ae util/docker/doc.coreboot.org: Allow git to work in envs owned by root * 38ee22f6da util/docker/doc.coreboot.org: Use Alpine minor instead of point releases * 0196c3b6a4 util/docker/doc.coreboot.org: Get rid of bash workarounds * 897b46693b util/docker/doc.coreboot.org: Don't create volumes * a0c45cbf1f 3rdparty/fsp: Update submodule to upstream master * aa562d2881 soc/mediatek/mt8189: Add GPIO driver * 40a863cd60 soc/mediatek/mt8189: Initialize watchdog * 1380ed0cd2 soc/mediatek: Add support for MediaTek firmware support package * 4f92943c89 soc/mediatek/common: Rename GPT_MHZ to TIMER_MHZ for readability * 5a73692e0c soc/mediatek/mt8196: Add SPM loader * 306660c2de util/crossgcc: Update CMake from 3.30.2 to 3.31.3 * f3adc74e44 mb/google/fatcat: Keep GSPIx interface default PCI * 809e704101 soc/intel/pantherlake: Rename GSPI2 to GSPI0A * 222ef676f9 soc/intel/pantherlake: Add ACPI name for GSPI2 * 1fda7027c0 util/crossgcc: Update ACPICA from 20230628 to 20241212 * e35175bb38 Update vboot submodule to upstream main * 9eb4c5aff8 util/ifdtool: Fix memory leaks * 87ae3573b5 mb/starlabs/starlite_adl: Configure GPIO interrupt for Virtual Button * eaf87422b1 ec/starlabs/merlin: Add Intel Virtual Button Driver for Tablet Mode * a1532790b9 docs: Add 24.12 release notes * 8c0df740c7 mb/google/nissa/var/gothrax: Add probe and GPIO config for HDMI and touchpanel * f6fcff5511 docs/security/vboot: Update supported boards * 0dba17da0c mb/google/brya/uldrenite: Add WWAN RW350R-GL power on sequence * 2c4af7cd29 mb/topton/adl: Enable TPM2 (Intel fTPM/PTT) * c11558d4c7 mb/asus/p8z77-m: Drop GPIO by I/O * 4f1a1adef6 mb/topton/adl: Disable mapped SATA port * 81cbe11361 mb/asus/p8z77-m: Revert SIO IRQ settings carried from OEM * 9578c67c77 mb/google/brox: Include CSE reset in mainboard reset expectation * 5af5e66686 util/cbfstool: eliminate late sign of life event * 0797c40d52 src/soc/intel/cmn/blk/cse: Log cse sync information * 9a15a1ed21 soc/intel: Log CSE Sync Early Sign of Life event from a better place * c812c78618 mb/trulo/var/uldrenite: Support USB_OC on the A0 port * ee1a766f05 mb/trulo/var/uldrenite: Set GPP_B5 and B6 to ISH function * 87c9d93a62 mb/google/skywalker: Add MediaTek MT8189 reference board * 6bd51ce42a soc/mediatek/mt8189: Add a stub implementation of MT8189 SoC * ea646c0514 mb/google/rauru: Add pwrsel init in romstage * c3265da005 soc/mediatek/mt8196: Add pwrsel driver * 30d8e1880a ec/google/chromeec: Publish LPC GMR address range via CREC _CRS * bb85775d92 soc/intel/cmn/acpi: Add ACPI method to get LGMR address * 84347d0b45 payloads/Linuxboot: Fix u-root build * 7bcec7a2ef payloads/LinuxBoot: Build x86_64 with host toolchain * e3150e819d util/crossgcc: Add libstdcxx target * 61385c4976 soc/mediatek/common: Move SPM_SYSTEM_BASE_OFFSET to soc folders * 6625dee027 soc/mediatek/common: Use array to represent spm_sw_rsv registers * cd8d6861f6 soc/mediatek/common: Move some functions to spm_v1.c * 91fe658714 drivers/option: Add forms in cbtables * 4d4776f320 mb/emulation/qemu-sbsa: Configure flash region for MMU * dfef1895f2 mainboard: Add MiTAC Computing Whitestone-2 (LGA-4677) * caf8f9f60f mb/google/brya/var/uldrenite: Enable PMC, HECI and SRAM devices * b668c756bf mb/trulo/var/uldrenite: Configure audio (max9360a, rt5682) * 941f994809 mb/trulo/var/uldrenite: Configure Network * 600e7810fb mb/trulo/var/uldrenite: Configure USB ports and mapping * 0261cbe8e9 mb/trulo/var/uldrenite: Configure serial_io and I2C * 113205bcd1 mb/trulo/var/uldrenite: Enable eMMC and DLL tuning parameters * 0dd227f9c1 mb/trulo/var/uldrenite: Enable DPTF, S0ix and configure FIVR setting * 0ce153c8df mb/google/nissa/var/rull: For probe, change unprovisioned to unknown * b57308f437 mb/google/rauru: Add SD card configurations * e969a3df87 soc/mediatek/mt8196: Add SD card configurations * 8be835ce3c soc/mediatek/mt8196: Add tracker driver * 78560f9958 soc/mediatek/mt8196: Add MMinfra driver support * 0b252ef8b4 util/mtkheader: Add GFH header for mt8189 bootblock code * 540eb5ba73 cpu/qemu: Enable IDT_IN_EVERY_STAGE * f9d6fd4e0f soc/intel/xeon_sp: Enable IDT_IN_EVERY_STAGE * c3dee9eaba cpu/intel/car/romstage: Fix false-positive stack corruption * b659fb5cea mb/ocp/tiogapass: Wait for BMC * 7c0556244d drivers/wifi: Update Drive Strength BRI Rsp Table revision * 70bdd2e1fa cpu/x86/topology: Simplify CPU topology initialization * 3a2ffba231 soc/intel/xeon_sp: Introduce early_pch_init * 48ed4b0f85 soc/intel/xeon_sp/lbg: Add support to hide HDA * a857c81122 arch/x86: Disable DEBUG_STACK_OVERFLOW_BREAKPOINTS_IN_ALL_STAGES * 45dabe846d mb/google/brox: Apply ISH_FW_VERSION in Kconfig * e0b1a0dbec vc/intel/fsp/mtl: Update MTL fsp header files from 3471_91 to 4122_21 * c20fd2fc3f 3rdparty/fsp: Update submodule to upstream master * e5b5fc345a soc/intel/xeon_sp: Improve PCI INTx IRQ routing for Gen6 * 673075f102 util/cbfstool: Add eventLog support for ELOG_TYPE_FW_CSE_SYNC * 3235b7c6d5 commonlib: Add ELOG_TYPE_FW_CSE_SYNC eventLog type * 4a0c49e671 soc/intel/pantherlake: Keep image clock configuration enable * 51cc2bacb6 soc/intel/pantherlake: Disable stack overflow debug options * eeb6f67eec Docs: Convert bare URLs into hyperlinks * 2609519704 mb/google/rauru: Implement regulator interface * 8c6426c1b4 soc/mediatek/mt8196: Add PMIC MT6373 driver * bda5b83661 mb/google/brya/var/uldrenite: update gpio settings * afb11d05b9 mb/google/trulo/var/uldrenite: Add memory config * 46df9e1d38 mb/google/brya/var/marasov: Enable GPP_F9 GPIO for early panel power-on * 04d33b90ec mb/google/fatcat: config GPP_F23 as ISH gpio pin * 16ab83b34a soc/mediatek/mt8196: Initialize SSPM * b793209b80 mb/google/brox/var/jubilant: Disable Tccold Handshake * 2f1e67bbc7 mb/google/nissa/var/glassway: Modify touch screen ILIT2901 sequence * a1c50f233d soc/mediatek/mt8196: Add PMIC MT6363 ADC driver * 8910b6ba7d soc/mediatek/mt8196: Add PMIC MT6363 driver * c215889442 soc/mediatek/mt8196: Add PMIF and PMIC driver support * 27fa0595de soc/mediatek/mt8196: Add mtcmos init support * 61a00269a2 mb/amb/birman*/gpio: remove configuration for VDD_MEM_VID[0,1] * 38b59164ca ec/google/chromeec: Define ACPI_NOTIFY_CROS_EC_MKBP constant * 50c9747d87 drivers/usb/intel_bluetooth: Add GBTR Method * 0bb4a220a8 soc/intel/common/cnvi: Fix GBTE path in comment * d33244c3af drivers/usb/intel_bluetooth: Relocate BTRK to \_SB.PCI0 * 04b9627e07 drivers/usb/intel_bluetooth: Fix GBTE to return Local0 * c3f9dd3af3 drivers/usb/intel_bluetooth: Change the Power Resource to S0 * 1cf8d84f3b mb/google/nissa/var/rull: Add 6W and 15W DPTF parameters * 62a9d670bf mb/google/brya/var/uldrenite: Add HDA verb tables * 56278eeed8 mb/google/rex/var/kanix: Enable/Disable PCIE WLAN based on fw_config * 6d3346068b intel/common/block: Program the right power_limits_config entry * 35bf4bc59c commonlib: Add generic word-at-a-time optimization to ipchksum() * e987ba45d6 soc/mediatek/mt8196: Add booker driver * aa3cfd5c69 haswell NRI: Post-process selected timings * 4a4ad2b1e6 haswell NRI: Initialise MPLL * 41c2e1685e soc/intel/xeon_sp: Add PCU PCI drivers * 8721757aca soc/intel/xeon_sp/skx: Configure IOAPICs * e9c546b153 arch/x86: Rename breakpoint removal function * 0351872731 arch/x86: Add breakpoint to stack canary * 572da7c524 acpi/acpigen: generate Create*Field() from name string directly * 2e9aebf63f mb/google/fatcat: Enable Intel DPTF support and configure policies * a8ff286185 mb/google/fatcat: Enable Bayhub Level 2 errata * 230e646d98 mb/google/fatcat: Remove redundant GPIOs for x1 slot * fbacae625a soc/intel/ptl: Enable UFS functionality by adding IRQ programming * b67e001a85 soc/intel/pantherlake: Fix UFS ACPI _ADR calculation * 2496943b5c mb/google/brox/var/jubilant: Set PCIe root port 5 speed to Gen2 * dfdb210e26 soc/intel/common/block: Fixup itss_get_on_chip_dev_pirq * 223dabef56 soc/intel/common/block: Add const qualifier for input of pirq ops * afc49fa013 soc/intel/xeon_sp: Remove lpc_lockdown_config * 1a4ab38035 soc/mediatek/mt8196: Rename SCP to SPM base variables * 3189afbdee soc/intel/common: Drop locking function fast_spi_set_vcl * 01bf34cb28 soc/intel/xeon_sp: Support _PRT reporting for domain * 1399dd8086 soc/intel/xeon_sp: Skip not pre-routed devices in _PRT reporting * a5362f6d73 soc/mediatek/mt8196: Enable ARM Trusted Firmware integration * 42a696090f Update arm-trusted-firmware submodule to upstream master * 861413b295 mb/google/nissa/var/riven: Set PCIe root port 4 speed to Gen2 * d5a11293ff soc/intel/alderlake: Add support for PCIe speed setting * 5b447d00f5 soc/intel/pantherlake: Fix UFS ACPI inclusion in southbridge.asl * 1c51c3e57f device/pci_ids: Add Pantherlake-H GT2 (DID2) * 15109603c6 mainboard/ocp/tiogapass: Enable TPM * 94d200c394 soc/intel/xeon_sp/cpx: Add missing FADT fields * 534585d7bd soc/intel/xeon_sp/skx: Drop ACPI_FADT_8042 * 98ca450a53 soc/intel/xeon_sp: Use generate_p_state_entries * 28c03b501e mb/ocp/tiogapass: Implement mainboard_dimm_slot_exists * 74ee80d207 soc/intel/xeon_sp/cpx: Fix register lock * e1a0e6b738 soc/intel/xeon_sp/skx: Fix CPU init * b04ecb2a5f arch/x86: Enable support for IOAPIC devices * a7437ca340 soc/intel/common/block/cse: allow CSE telemetry on non-lite CSE SKU * 0d284bfc36 soc/intel/mtl/acpi/gpio.asl: fix missing gpio.h include * aeb5ccd129 ec/dasharo/ec: add Dasharo features * 820c7e06d2 soc/mediatek/mt8196: Set DRAMC_PARAM_HEADER_VERSION to 4 * d8104af174 mb/google/rex/var/kanix: Disable FP_MCU based on fw_config * 075a13b775 mb/google/fatcat: Update Soundwire codec address based on devicetree * 2411942a05 drivers/soundwire/alc711: Add common Kconfig for ALC7xx soundwire codecs * 534f81d165 mb/google/fatcat: Update flash layout * 1b175a64e3 soc/intel/ptl: Populate SMBIOS Type 4 with unique serial number * 4b574281f0 soc/intel/cmn/pmc: Retrieve SoC QDF information via PMC IPC * 4ce5304879 soc/intel/xeon_sp: Advertise DIMMs on skylake_sp as well * 5613f0e6be soc/intel/xeon_sp: Fix debug print * 0d827a5810 soc/intel/xeon_sp: Drop SOC_INTEL_MMAPVTD_ONLY_FOR_DPR * d3aa108acf drivers/ipmi/ocp: Add missing include * 37e9c22089 libpayload: configs: Add new config.featuretest to broaden CI * bcced7caea commonlib/device_tree: Make END token part of struct_size * 8ad1ee9b0a util/intelp2m: Print the current project version * 1b9c312273 intelp2m/patform/sunrise: Add unit tests * 2394795279 intelp2m/patform/lewisburg: Add unit tests * bce3363412 intelp2m/patform/apollolake: Add unit tests * 6abf66c8f3 util/intelp2m/parser/template: Add unit test * 6b43e4ba33 MAINTAINERS: Add Yuchi and Vasiliy for Intel Atom Snow Ridge SoC * 5cedebf874 soc/intel/xeon_xp: Remove 1 bytes losing in lower DRAM * cd30d94ae5 mb/google/brya/var/uldrenite: Generate RAM ID and SPD file * cda1e7e553 mb/google/nissa: Create pujjogatwin variant * c0ccace4d5 .checkpatch.conf: Set max line length to 96 * 6f2a8ee8cc soc/mediatek/mt8196: Require DRAM blob to exist * 850cf7d07a Update blobs submodule to upstream main * 75424efdc4 soc/amd/common/psp/psp_def.h: increase P2C_BUFFER_MAXSIZE * 179945291c soc/amd/common/psp/rpmc: fix printk format string * 9b308f4d54 soc/amd/common/psp/psp_smi: report errors in 'handle_psp_command' * 5613f209c7 soc/amd/common/psp_smi_flash: implement SPI flash RPMC command handling * b1f954bc6c soc/amd/common/block/psp/psp_smi_flash.h: fix struct element types * ce01117aa5 drivers/spi: add RPMC support * 78270ef3f1 Documentation/tutorial/managing_local_additions.md: Add symlink info * 0a7c3ed514 soc/mediatek/mt8195: Fix SCP register address * 4c8547704f mb/google/rauru: Add 2nd source TAS2563 amps to support beep * ac83b48cba soc/mediatek/mt8196: Add audio base address definition * c661933a24 soc/mediatek/common: Add read16/write16 support for PMIF * c107755701 vc/intel/fsp: Update PTL FSP headers from 2382_01 to 2431.00 * a417acdfbc mb/google/fatcat: Remove unnecessary prototype * d095f1ea45 soc/amd/glinda: Update MCA banks * 8df4eefd44 soc/mediatek/mt8196: Reserve DRAM buffers for HW TX TRACKING * 5c766bc150 mb/purism/librem_cnl: Add ramtop to cmos.layout for librem_mini * 2007792b08 mb/purism/librem_l1um_v2/ramstage.c: Use DEV_PTR macro * 7f54139a81 Docs/mb/starlabs/labtop_cml.md: Fix footnote syntax Signed-off-by: Leah Rowe <leah@libreboot.org> wip2 Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-04add libx86 to arch dependenciesLeah Rowe
needed to compile the "int" tool defined under config/git/ Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-04add less to arch dependenciesLeah Rowe
probably not actually needed, but it annoys me that it doesn't come installed by default, and it's needed for certain git operations Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-03submodule/grub: use codeberg for 1st gnulib mirrorLeah Rowe
the gnu.org mirror is always slow for some reason, but only for gnulib. it may only be for me, because routing in other countries/networks may differ. when i'm freshly cloning lbmk modules, gnulib is always really slow, like 300KB/s (bytes, not bits) i have 1gbps internet and wish to not have 2005-era speeds, thank you kindly! Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31hp820g2: fix vendorfile inject and set release=yLeah Rowe
I believed that the compressed nature of refcode was the only non-reproducible thing, but turns out you also need to run rmodtool on the refcode to make the binary relocatable in cbfs. This is based on my reading of the coreboot Makefile. With this change, I can now provide release binaries for the HP EliteBook 820 G2. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31fedora41/dependencies: add libuuid-develLeah Rowe
it seems to be required for uuid/uuid.h Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31add uuid-devel to fedora41 dependenciesLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31support ./mk dependencies fedora reinstallLeah Rowe
dnf reinstall package or dnf install package for reinstall, do this: ./mk dependencies fedora41 re this is an example command the 4th argument prefixes "install" in dnf install a bit hacky but it should work Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31fix missing semicolon in grub nvme patchLeah Rowe
i forgot this when rebasing on the recent uprev Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31bump seabios to rev 1602647f1 (7 November 2024)Leah Rowe
This brings in a *single* change from SeaBIOS, because there has only been one change in the main branch, and it's a bug fix. The change from upstream is as follows: commit 1602647f1be24fe63d11138d802e735c8e674e63 Author: Daniel Khodabakhsh <d.khodabakhsh@gmail.com> Date: Thu Nov 7 18:46:16 2024 -0800 boot: Force display of the boot menu when boot-menu-wait is a negative number Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31Bump GRUB revision to 6811f6f09 (26 November 2024)Leah Rowe
Although this is for a stable release revision, namely Libreboot 20241206 revision 8, I've carefully audited the upstream changes and they all seem fine. Several important bug fixes have been imported with this change. Most interestly, GRUB has also added support for TPM2 Key Protectors; we don't use this feature yet, and probably won't for the time being, since TPM is largely security threatre for our purposes anyway. There's no harm including all upstream revisions, up to those ones, since those modules are not yet added in lbmk. Most notably, there are several file system fixes, and minor fixes to the graphics terminal of GRUB. Minor fixes only, in terms of what Libreboot actually uses at present. The full list of imported changes are as follows, relative to the previous GRUB revision, which was b53ec06a1 from 17 June 2024: * 6811f6f09 tpm2_key_protector: Enable build for powerpc_ieee1275 * ff14b89bd ieee1275/tcg2: Add TCG2 driver for ieee1275 PowerPC firmware * 72092a864 ieee1275/tcg2: Refactor grub_ieee1275_tpm_init() * 8c0b5f200 ieee1275/ibmvpm: Move TPM initialization functions to own file * 7344b3c7c ieee1275: Consolidate repeated definitions of IEEE1275_IHANDLE_INVALID * 29d1bd2a9 term/ieee1275/serial: Cast 0 to proper type * 99ee68a01 tss2: Adjust bit fields for big endian targets * 3770a6905 docs: Document TPM2 key protector * f898440cc tests: Add tpm2_key_protector_test * 76a2bcb99 tpm2_key_protector: Add grub-emu support * 135e0bc88 diskfilter: Look up cryptodisk devices first * b35480b48 cryptodisk: Wipe out the cached keys from protectors * 6abf8af3c cryptodisk: Fallback to passphrase * fba3a474e tpm2_key_protector: Implement NV index * 550ada7d6 tpm2_key_protector: Support authorized policy * 5f6a2fd51 util/grub-protect: Add new tool * ad0c52784 cryptodisk: Support key protectors * 48e230c31 key_protector: Add TPM2 Key Protector * 35c9904df tss2: Add TPM2 Software Stack (TSS2) support * 63a78f4b4 tss2: Add TPM2 types and Marshal/Unmarshal functions * 2ad159d9b tss2: Add TPM2 buffer handling functions * 5d260302d key_protector: Add key protectors framework * 3d60732f9 libtasn1: Add the documentation * 99cda6788 asn1_test: Test module for libtasn1 * 504058e82 libtasn1: Compile into asn1 module * 8a0fedef2 asn1_test: Enable the testcase only when GRUB_LONG_MAX is larger than GRUB_INT_MAX * 66cf4cb14 asn1_test: Use the grub-specific functions and types * 0d0913fc6 asn1_test: Print the error messages with grub_printf() * 2e93a8e4b asn1_test: Remove "verbose" and the unnecessary printf() * b7568e335 asn1_test: Return either 0 or 1 to reflect the results * d60a04bae asn1_test: Rename the main functions to the test names * 54e0e19a2 asn1_test: Include asn1_test.h only * 0ad1d4ba8 libtasn1: Fix the potential buffer overrun * 4160ca983 libtasn1: Use grub_divmod64() for division * 8f56e5e5c libtasn1: Adjust the header paths in libtasn1.h * d86df91cb libtasn1: Replace strcat() with _asn1_str_cat() * 32fdfe600 libtasn1: Replace strcat() with strcpy() in _asn1_str_cat() * fa498af7b libtasn1: Disable code not needed in GRUB * 9a26abbc3 libtasn1: Import libtasn1-4.19.0 * c85c2b9f5 posix_wrap: Tweaks in preparation for libtasn1 * 4f6c46091 kern/fs: Honour file->read_hook() in grub_fs_blocklist_read() * 792132c72 docs: Fix incorrect and potentially confusing language and minor formatting * 1763d83f5 docs: Correct GRUB config file name for network boot * 097fd9d9a docs: Correct chainloader UEFI secure boot info * f48e6af11 docs: Correct PXE environment variables descriptions * dd743ba42 loader/multiboot: Do not add modules before successful download * 9a9082b50 grub-mkimage: Add SBAT metadata into ELF note for PowerPC targets * f97d4618a grub-mkimage: Create new ELF note for SBAT * f26b39860 commands/legacycfg: Avoid closing file twice * 337cb2486 nx: Rename GRUB_DL_ALIGN to DL_ALIGN * 31de991de kern/acpi: Fix out of bounds access in grub_acpi_xsdt_find_table() * f5bb766e6 nx: Set the NX compatible flag for the GRUB EFI images * 94649c026 nx: Set page permissions for loaded modules * 09ca66673 nx: Add memory attribute get/set API * 9fb80dd57 modules: Load module sections at page-aligned addresses * 6e2fe134e modules: Don't allocate space for non-allocable sections * 2b79d550f modules: Strip .llvm_addrsig sections and similar * 246c82cda modules: Make .module_license read-only * 616adeb80 i386/memory: Rename PAGE_SIZE to GRUB_PAGE_SIZE and make it global * 95a7bfef5 i386/memory: Rename PAGE_SHIFT to GRUB_PAGE_SHIFT * 1b1061409 i386/msr: Extract and improve MSR support detection code * 929fafdf5 i386/msr: Rename grub_msr_read() and grub_msr_write() * d96cfd7bf i386/msr: Merge rdmsr.h and wrmsr.h into msr.h * 86ec48882 commands/tpm: Skip loopback image measurement * 3808b1a9b net/drivers/efi/efinet: Skip virtual VLAN devices during card enumeration * e5f047be0 efi/console: Properly clear leftover artifacts from the screen * c5ae124e1 kern/riscv/efi/init: Use time register in grub_efi_get_time_ms() * 9c34d56c2 loader/efi/linux: Reset freed pointer * 92bed41bf loader/efi/linux: Reuse len variable * 33cb8aecd lib/x86_64/relocator_asm: Use .quad instead of .long * 77cd623de lib/x86_64/relocator_asm: Fix comment in code * 95145eea5 loader/efi/linux: Update comment * d333e8bb3 util/grub-mkimagexx: Explicitly move modules to __bss_start for MIPS targets * 34b7f3721 include/grub/offsets.h: Set mod_align to 4 on MIPS * ed0651673 gentpl: Put boot/mips/startup_raw.S into beginning of the image * 648f2d16c configure: Add -mno-gpopt option for mips and mipsel targets * f0710d2d8 lib/xzembed/xz_dec_bcj: Silence warning when no BCJ is available * e61157bbd fs/erofs: Replace 64-bit modulo with bitwise operations * 5313fa839 configure: Look for .otf fonts * 33b94f2a9 loader/efi/chainloader: Do not print device path of chainloaded file * ab1e6fc04 docs: Document all GRUB modules * 9537f4403 commands/bli: Fix crash in get_part_uuid() Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31t480/3050micro: force power off post power failureLeah Rowe
The T480 has no option table, because it lacks nvram, so the default option applies, which seems to be power on after power failure. This is undesirable on a laptop. It's triggered simply when your laptop battery runs out, and once triggered, it couldn't be configured at all. Hard-code this. The documentation will be updated later on after this patch is pushed, telling those users who want to change this behaviour how to modify/remove the patch, if they wish to to do so, because some people may actually want to run a server on the OptiPlex 3050 Micro (or if they're crazy like I am, they will host libreboot.org on a ThinkPad). Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31flashprog: Disable -WerrorLeah Rowe
We haven't seen any build errors, but it seems flashprog sets -Werror on CFLAGS. If you provide WARNERROR=no as a make argument, it avoids -Werror entirely. This is a preventative fix, for over-zealous compilers. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-31bump flashprog to revision eb2c041 (14 Nov 2024)Leah Rowe
This brings in several important bug fixes from upstream. With this, the following upstream changes have been imported: * eb2c041 cli_wp: Fix bail-out when multiple chips are detected * e05e334 cli_common: Rename local `optarg' variable * efad610 manibuilder: Include NetBSD (anita tags) in `native' target * 09289fb manibuilder: Replace unmaintained DEFAULT_TAGS list * 1457cc6 manibuilder: Stop build testing oldest, EOL targets * 1faffa5 manibuilder: Fix Ubuntu Noble Numbat (24.04) for amd64 * 61dbe36 udev rules: Use `uaccess' tag instead of `plugdev' group * 63d30a2 install: Install binary into bin/, not sbin/ * 6ce26a7 flashchips: add Winbond W25R512NW / W74M51NW * 612519b ichspi: Add Intel Arrow Lake support * d5a61ef ichspi: Add Intel Lunar Lake support * 5e0d9b0 ichspi: Add Intel Meteor Lake SoC * 0ef2eb8 ichspi: Add Intel Snow Ridge SoC * 42daab1 ichspi: Properly add Emmitsburg PCH * af26008 ich_descriptors_tool: Add missing options for EHL & C620 * 82fe123 ich_descriptors: Hard code number of masters for newer gens * 157b818 ich_descriptors: Guard MCH strap handling by chipset version * db878fb ich_descriptors: Drop chipset detection based on `freq_read` * b3cc2c6 ich_descriptors: Unify pretty printing of PCH100+ masters * 8e4151d chipset_enable: Remove hidden-spidev workaround for Elkhart Lake * 6d72efa chipset_enable: Remove hidden-spidev workaround for all 14nm PCHs * 092a699 chipset_enable: Remove hidden-spidev workaround for TGP+ * 5bbd324 chipset_enable: Add missing PCI ID for Intel PCH H410 * a088475 chipset_enable: Factor PCH100 hidden-spidev workaround out * 5eb7a58 Drop 1s delay before automatic verification * 7427569 libflashprog: Run programmer_shutdown() on failed setup * 5a9d6ea chipset_enable: Fix memory leaks introduced with AMD SPI100 * e149fbe Only try to check erase opcodes for SPI25 chips * 07ebc68 Avoid NULL deref in check_block_eraser() * 2405310 chipset_enable: Mark Intel QM87 as DEP * 9897063 flashchips: Allow volatile register writes for W25Q128.V * c972aed flashchips: Configure WP for MX25L25635F/45G * 8f7122c cli: Add new write-protect CLI * eed122d layout: Implement flashprog_layout_get_region_range() * 1f693db cli: Add new `config' CLI for status/config registers * 85c2cf8 cli: Implement "command" option parser * 24c0977 cli: Add print function for generic CLI options * b82aadc cli: Move some declarations into `cli.h` * a705043 cli: Add a new CLI wrapper * d39c7d6 cli: Extract basic CLI init into cli_common * df6ce9f cli: Extract log argument parsing into cli_common * 0da839b cli: Extract layout argument processing * d91822a cli: Extract layout argument parsing into cli_common * e7899a9 cli: Move all long-option keys into cli.h * 34e783a cli: Extract flash argument parsing into cli_common * e68b08b cli_classic: Rewrite programmer argument parsing * 6898f5b spi25_statusreg: Prefer volatile status register writes * 55e7884 Introduce FLASHPROG_FLAG_NON_VOLATILE_WRSR * fbba454 Install udev rules * 768cfc4 flashchips: Add GigaDevice GD25LR512ME Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-30replace liblz4-tool with lz4 and liblz4-devLeah Rowe
In Debian dependencies files. These are available in Debian Stable, but liblz4-tool is a transitional package referring to lz4; liblz4-tool transition package is unavailable in Debian sid, so remove it from the dependencies files. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-30lib.sh dependencies: support --reinstall argumentLeah Rowe
./mk dependencies debian --reinstall Add --reinstall and it'll do: apt-get install --reinstall This can be useful when updating from a stable release to a testing release. The variable, "reinstall" can be configured for other distros, but it's currently only configured for Debian-based distros. Also, it can be anything. For example, you could add -y; however, a 4th argument will not be accepted. For example, you cannot do: ./mk dependencies debian --reinstall -y If you do this, it'll only see --reinstall; similarly, if you did this command: ./mk dependencies debian -y --reinstall then -y would be passed, but not --reinstall. This is an intentional design decision, in case you accidentally pasted or subshelled something that outputted something undesirable, to prevent possible abuse. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-30Fix U-Boot build issue with Swig 4.3.0Leah Rowe
Tested on Debian Sid, as of 30 December 2024, which uses Swig 4.3.0. Context here: commit a63456b9191fae2fe49f4b121e025792022e3950 Author: Markus Volk <f_l_k@t-online.de> Date: Wed Oct 30 06:07:16 2024 +0100 scripts/dtc/pylibfdt/libfdt.i_shipped: Use SWIG_AppendOutput This patch from U-Boot upstream has been backported to the release revision used by Libreboot. Swig has, since 4.3.0, changed the language-specific AppendOutput functions, but the helper macro SWIG_AppendOutput is identical; therefore, upstream switched to this function. The benefit of this fix is that since the newly used macro is also the same on older Swig versions, and behaves the same, this shouldn't fix building on older Swig versions. For reference, the initial Libreboot 20241206 release, and revisions of it before revision 8, was built on Debian 12 which uses Swig 4.1.0. The rev8 release will still be compiled on Debian 12, but with this change, it should also compile on Debian Sid, and bleeding edge distros like Arch Linux. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-30remove auto-confirm on distro dependenciesLeah Rowe
because if it says yes to everything, and the package manager would otherwise ask whether you want to give it your first born son, you are therefore agreeing to it. so remove -y for safety Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-29t480/3050micro: disable hyperthreadingLeah Rowe
Hyperthreading is a risk factor for spectre/meltdown and other attacks. Disabling it is a best practise. Those who need it can always turn this option back on. Otherwise, disabling it by default is a simply courtesy to the average user, in the interest of security. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-29t480/t480s: Disable TPM2 to mitigate SeaBIOS lagLeah Rowe
SeaBIOS was lagging a lot, on startup and when executing almost any payload, especially when doing anything in the ESC menu. I set the debug level to *21*, and thoroughly analysed the logs. I found entries such as this: Checking for bootsplash WARNING - Timeout at wait_reg8:81! TCGBIOS: Return value from sending TPM2_CC_StirRandom = 0x00000000 WARNING - Timeout at wait_reg8:81! TCGBIOS: Return value from sending TPM2_CC_GetRandom = 0x00000000 WARNING - Timeout at wait_reg8:81! TCGBIOS: Return value from sending TPM2_CC_HierarchyChangeAuth = 0x00000000 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc16e WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc1c5 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc211 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc25d WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc2a9 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc2f5 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc341 WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc38d WARNING - Timeout at wait_reg8:81! TCGBIOS: LASA = 0x7a9fc000, next entry = 0x7a9fc3d9 Searching bootorder for: HALT Mapping hd drive 0x000f49e0 to 0 I'm not quite certain what the problem is, but disabling TPM2 made the problem go away; SeaBIOS is snappy again. TPM is security threatre anyway. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-28rom.sh: Name pico directory serprog_picoLeah Rowe
Previously serprog_rp2040, but we now also support the RP2530 boards. Therefore, serprog_pico is a nice generic name. The directory on release archives will now be serprog_pico instead of serprog_rp2040; it will contain serprog images for both RP2040 and RP2530 devices. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-28pico-sdk: update to 2.1.0Riku Viitanen
this brings support for a new microcontroller platform rp2530. total number of pico boards supported now: 97 TEST: built them all Tested-by: Riku Viitanen <riku.viitanen@protonmail.com> Signed-off-by: Riku Viitanen <riku.viitanen@protonmail.com>
2024-12-27add spdx headers to dependencies configsLeah Rowe
these used to be separate scripts under gpl 3+, so it makes sense to clarify the licensing situation Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-27dependencies/debian: fix debian sidLeah Rowe
change python3-distutils to python3-distutils-extra the latter is still available in debian sid, but not the former. however, installing this should still provide the additional files required. with this, the debian script is now compatible with both debian sid and debian stable(bookworm, presently). Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-27add spdx headers to various config filesLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-26vendor.sh: Handle FSP insertion post-releaseLeah Rowe
The Libreboot 20241206 release provided FSP pre-assembled and inserted into the ROM images; the only file inserted by vendor.sh was the Intel ME. Direct distribution of an unmodified FSP image is permitted by Intel, provided that the license notice is given among other requirements. Due to how coreboot works, it must split up the FSP into subcomponents, and adjust certain pointers within the -M component (for raminit). Such build-time modifications are perfectly fine in a coreboot context, where it is expected that you are building from source. The end result is simply what you use. In a distribution such as Libreboot, where we provide pre-built images, this becomes problematic. It's a technicality of the license, and it seems that Intel themselves probably intended for Libreboot to use the FSP this way anyway, since it is they who seem to be the author of SplitFspBin.py, which is the utility that coreboot uses for splitting up the FSP image. Due to the technicality of the licensing, the FSP shall now be scrubbed from releases, and re-inserted. Coreboot was inserting the -S component with LZ4 compression, which is bad news for ./mk inject beacuse the act of compression is currently not reproducible. Therefore, coreboot has been modified not to compress this section, and the inject command doesn't compress it either. This means that the S file is using about 180KB in flash, instead of about 140KB. This is totally OK. The _fsp targets are retained, but set to release=n, because these targets *still* don't scrub fsp.bin; if released, they would include fsp files, so they've been set to release=n. These can be used on older Libreboot release archives, for compatibility. The new ROM images released for the affected machines are: t480_vfsp_16mb t480s_vfsp_16mb dell3050micro_vfsp_16mb Note the use of _vfsp instead of _fsp. These images are released, unlike _fsp, and they lack fspm/fsps in the image. FSP S/M must be inserted using ./mk inject. This has been tested and confirmed to boot just fine. The 20241206 images will be re-compiled and re-uploaded with this and other recent changes, to make Libreboot 20241206 rev8. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-24data/deguard: Remove unused patchLeah Rowe
The appdir.patch file was used on the older deguard version, prior to Mate Kukri's rewrite. This patch is no longer required, and no longer used, so it can be removed safely from lbmk. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-22remove geteltorito and mtools from lbmkLeah Rowe
we needed these for extracting intel vga roms from lenovoo updates, for t480, very briefly. about an hour after i pushed that patch, mate kukri fixed libgfxinit and then i removed the vgarom integration because it wasn't needed anymore. however, i forgot to remove geteltorito/mtools from dependencies. some distros like fedora were problematic about it. the best thing about bugs is when you don't have to fix them. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-18rom.sh: support grub-first setupsLeah Rowe
in this setup, seabios is never the default payload, grub is, but only if grub is enabled. set this in target.cfg: payload_grubsea="y" if payload_grub isn't enabled, this is auto-set to n ditto if initmode=normal NOTE: if flashing libgfx setups, you should make sure that you're not booting with a graphics card, only intel graphics. this setting will intentionally not be documented, because it's not recommended, but is being implemented for testing purposes (and i implemented it for some guy who i think is cool). i'll probably also use this myself, since i already do grub-only setups on all my own machines. seagrub is the default on x86 because of past instabilities with grub. to mitigate in case of future issues, since seabios is always stable, we reduce the chance of bricks. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-18vendor.sh: make TBFW pad size configurableLeah Rowe
we encountered 1MB flash so far, but we may encounter other sizes on other machines when added to libreboot later on Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-18T480/T480S: Support fetching ThunderBolt firmwareLeah Rowe
Though not used in coreboot builds, and not injected into the builds in any way, these files are now created seperately when handling T480/T480s vendor files: vendorfiles/t480/tb.bin vendorfiles/t480s/tb.bin These are created by extracting Lenovo's ThunderBolt firmware from update files. The updated firmware fixes a bug; older firmware enabled debug commands that wrote logs to the TB controller's own flash IC, and it'd get full up with logs, bricking the controller. If you've already been screwed by this, you must flash externally, using a padded firmware from Lenovo's updates. Lenovo's own updater requires creating a boot CD or booting Windows. This patch in lbmk auto-downloads just the firmware, and you can flash it externally. You could simply do this as a matter of course, when installing Libreboot. You are recommended to update the Lenovo UEFI/EC firmwares first, before installing Libreboot; please look at the Libreboot documentation to know exactly which versions. Then dump the ThunderBolt firmware first, to be sure, and then you can flash these files. Flashing these updates will prevent the bug described here: https://pcsupport.lenovo.com/us/en/products/laptops-and-netbooks/thinkpad-t-series-laptops/thinkpad-t480-type-20l5-20l6/20l5/solutions/ht508988 You can download Lenovo's installers for various ThinkPad models there, including T480s/T480s. It is these downloads that this lbmk patch uses, to extract those files directly. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-17also de-rainbow the u-boot menu20241206rev6Leah Rowe
boring is good Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-17Revert "use rainbow deer on the grub background"20241206rev5Leah Rowe
libreboot has a lot of users worldwide, some of whom live in countries that punish being gay; if they look at libreboot or boot it and it has the pride colours on it, it could actually get them in trouble. this fact occured to me, and i've decided therefore to revert back to the boring plain logo. though, perhaps we could actually properly design a new logo? a new, modern logo, and a nicer website. we'll see! This reverts commit 401efb24b2213454732e769531f660605771e538.
2024-12-17use rainbow deer on the grub backgroundLeah Rowe
same as on u-boot recently Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-11disable 3050micro nvme hotplug20241206rev3Leah Rowe
see patch for rationale. this should prevent instability caused when the nvme randomly replugs under linux. sometimes e.g. nvme0n1 becomes nvme0n2 while the system is running. in my case, that caused my raid1 to become unsynced every few days. this issue was fixed on t480 by disabling pcie hotplug for its nvme device, so the same fix has been applied for dell optiplex 3050 micro. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-10fix t480 spd size (512, not 256)Leah Rowe
this was done with the following command: ./mk -u coreboot t480s_fsp_16mb t480_fsp_16mb it was set to 256 but should be 512. the SPD is what contains configuration data for raminit, which training code uses so that the timings will be correct. if the SPD size is wrong, the machine won't boot in practise, lbmk always runs "make oldconfig" on a coreboot config, before building it, so this was already being corrected automatically at build time. however, if that fact ever changes in the future, this wrong configuration would cause the machines not to boot. therefore, this can be considered a preventative or perhaps pre-emptive bug fix. this fix does not need to be applied to the 20241206 release, because of the behaviour described above. the final ROM images do have the spd size set correctly to 512, because of this design feature in lbmk. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-06Libreboot 20241206 releaseLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-05Libreboot 20241205 release20241205Leah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-05Revert "Revert "disable u-boot on thinkpad t480""Leah Rowe
Nope! Bootflow menu is cursed on this machine. Too many issues in U-Boot on this machine. I did however boot a Debian installer after it booted, using bootflow. The installed system wouldn't boot with bootflow, but I could then boot it with "bootefi bootmgr". I'll rig up a uart on the T480 when I get round to it and start investigating U-Boot bugs on this board. I don't want people flashing something that doesn't work. GRUB and SeaBIOS work, so ship those, and don't ship U-Boot. This reverts commit 19ec440a6f79dcbb089715fef814808a0fd40ae0.
2024-12-05Revert "disable u-boot on thinkpad t480"Leah Rowe
u-boot does work after a few reboots. it just boot loops. let it run. it should be able to boot from nvme. sata still needs some work (sata only works in grub, on this machine) This reverts commit cd9baca5d664d392316d94ccaa7deb209d4e1828. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-05add patch from mkukri fixing t480 sataLeah Rowe
nvme worked but not sata. with this, t480 users with sata ssds should be able to boot linux nicely Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-05disable u-boot on thinkpad t480Leah Rowe
it just bootloops and doesn't seem reliable at the moment Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-04remove the purple patch on arm64 u-bootLeah Rowe
it's green there. different colour scheme apparently. still works on x86. alper said his kevin chromebook was green! Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-04Merge pull request 'u-boot: Use bootflow menu by default for ARM64 boards' ↵Leah Rowe
(#254) from alpernebbi/lbmk:u-boot-arm64-bootflow-menu into master Reviewed-on: https://codeberg.org/libreboot/lbmk/pulls/254
2024-12-04i made u-boot purpleLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-04u-boot: Use bootflow menu by default for ARM64 boardsAlper Nebi Yasak
The bootflow menu is already the default boot command on x86. Switch arm64 boards to that as well, so instead of booting the first thing we find, we can easily choose what to boot. Signed-off-by: Alper Nebi Yasak <alpernebiyasak@gmail.com>
2024-12-04Add bootflow/branding patches to arm64 U-Boot tooLeah Rowe
U-Boot on ARM64 also enables the bootflow menu. Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-04Add libreboot branding/version to U-Boot bootflowLeah Rowe
Show it in the bootflow menu Signed-off-by: Leah Rowe <leah@libreboot.org>
2024-12-04Add auto-boot timeout for U-Boot's bootflow menuLeah Rowe
Otherwise, you have to press enter to boot your distro. With this, a timeout is created. After a number of seconds, which can be reconfigured, the first option selected will be booted, when generating a bootflow menu. The timeout is disabled when you navigate the menu; it only kicks in if you don't input anything on the keyboard. More information about how this works is in the U-Boot patches, within this patch. I've set the timeout to 8 seconds. Signed-off-by: Leah Rowe <leah@libreboot.org>