summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2025-01-27vendor.sh: don't error if grep -v failsLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27vendor.sh: Don't show gbe filename on injectLeah Rowe
it's a temporary file, so printing it may confuse the user. hide it from the output. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: don't say write not needed if errnoLeah Rowe
otherwise, the output is confusing Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: print dump *after* modificationLeah Rowe
this way, we still get an error exit for example when trying to invalidate an already invalid checksum; this error exit was disabled by the last revisions. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: verbosely print the written MACLeah Rowe
This is for user friendliness. Otherwise, many users might try to dump afterward if they specified a random MAC address. This saves the user from having to re-run with the dump command, thus saving time for the user. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: minor cleanup in cmd_dumpLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: show nvm words written on writeGbeLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: clean up readonly check on writeGbeLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: Remove useless gbeFileChanged varLeah Rowe
We don't need it. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: reset errno if any MAC updatedLeah Rowe
instead of setting errno in the for loop, set a variable declaring that the mac was updated, and reset errno based on that. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: reset errno when writing a MACLeah Rowe
if checksum verification passed, then we should reset in case we're operating on a given part and the last one checked was bad. a catch-all reset is already performed in writeGbe, but it's good to do it here too. in practise, if the 2nd part (part 1) is what failed, errno still wouldn't be reset. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: show total number of bytes readLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: rename tbw/bw to tnw/nwLeah Rowe
to match nr in the readGbe function number of bytes written, and total number of bytes written. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: err if bytes read lower than nfLeah Rowe
same as the last change. just covering edge cases. we will likely never trigger this error. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: err if fewer bytes writtenLeah Rowe
it will probably never happen, and this is technically not an error condition of pread/pwrite, but we need it to read and write that exact number of bytes, as per nf Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: Show bytes written in writeGbeLeah Rowe
This will be useful for future debugging, and future work on optimisations. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil swap(): ensure that no overflow occursLeah Rowe
it wouldn't occur, on the current logic, but i wasn't comfortable having the starting point (on little endian) being higher than the checked endpoint, in case of possible integer overflow as a result of future modifications. this is therefore a pre-emptive bug fix, because it doesn't yet fix a bug, but it prevents a bug from being introduced. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: make swap() a bit clearerLeah Rowe
don't sizecode. show the individual steps clearly. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: make 0x3f checksum position a defineLeah Rowe
for code clarity Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil: make 128 (nvm area) a defineLeah Rowe
for code clarity Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-27util/nvmutil swap(): Only handle the nvm areaLeah Rowe
The 128-byte nvm area is all that we need to handle, since that is the only thing we actually work on in nvmutil, based on checksum verification; the latter implies that bytes must be in the correct order. The swap() function previously worked on the entire block, e.g. 4KB on 8KB files, 8KB on 16KB files and 64KB on 128KB files, and it did this twice, so it would have operated on anywhere between 8KB to 128KB of data. It now only operates on 256 bytes at a maximum, or 128 bytes if only handling one block. This is a significant performance optimisation, on big endian host CPUs. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: move write checks to writeGbeLeah Rowe
doing it in main() is messy. better do it from the actual function. now the logic in main is clearer. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: make cmd_swap its own function againLeah Rowe
previous audits sizecoded nvmutil.c, reducing the sloccount, but this resulted in unreadable code. move the swap logic (swap parts) back to its own function, for clarity. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: minor cleanupLeah Rowe
SIZE_64KB no longer needed, and the malloc error is needlessly verbose Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: allocate less memory for setchecksumLeah Rowe
also cmd_brick where the checksum is being corrected or bricked, we only need to handle the 128-byte nvm area on one of the parts similarly, we only need to allocate half the gbe file size when doing a copy command. 256 bytes still allocated for setmac (see previous commit), because we verify both checksums and set both parts if possible. with this, nvmutil is now much more memory-efficient. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: Further reduce memory usageLeah Rowe
Allocate memory based on nf instead of partsize. nf is the number of bytes actually read from each part of the file. Now if the user is running setmac for example, 256 bytes of memory will be allocated regardless of gbe file size, whereas it would have previously allocated 8KB, 16KB or 128KB depending on the file. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: Remove unnecessary buf16 variableLeah Rowe
We can just point to gbe[] directly, in the word macro. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-26util/nvmutil: Only allocate needed memory for fileLeah Rowe
We were allocating 128KB even if we only needed 8KB, for example. It's not a lot of memory, but the principle of the matter is that we must respect the user by not wasting their memory. The design of nvmutil is that it will never overflow, because operations are mapped in memory to the exact size of the gbe file, which can be 8KB, 16KB or 128KB, and this is enforced. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-25util/nvmutil: Remove unnecessary bufferLeah Rowe
The buf variable is only used once, and only so that we can get a pointer. We can point to buf16 instead, for the same result. The gbe pointer (size_t) is later converter to a char * when writing back to the file. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: Show specific error for bad cmd argcLeah Rowe
For example, if the brick command is used without specifying a part number. Instead of saying "Invalid argument", show a much more useful error message to help the user adapt. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: cleaner argument handlingLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: extreme pledge/unveil hardeningLeah Rowe
call pledge *much* earlier, and and lock everything down much sooner. the point of pledge/unveil is precisely that your program must operate under the most restrictive set of conditions possible, and still function. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: more minor cleanupLeah Rowe
just some line breaks Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: more granular MAC parsing errorsLeah Rowe
tell the user exactly what they got wrong, instead of simply printing "bad mac address", which is not very helpful to the user Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: more cleanupLeah Rowe
spread out a few lines, so that they are more readable, and more thoroughly comment some parts. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24remove errant comment in nvmutilLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: support 16kb and 128kb gbe filesLeah Rowe
See: https://edc.intel.com/content/www/us/en/design/ipla/software-development-platforms/client/platforms/alder-lake-mobile-p/intel-600-series-chipset-family-on-package-platform-controller-hub-pch-datash/spi0-for-flash/ The rules described there are universal, and replicated elsewhere for many other platforms. The rules are simply: * Flash descriptor is one block size, e.g. 4KB * GbE is two block sizes, so if IfD is 4KB, GbE is 8KB Intel defines 16KB and 128KB GbE files in specs, pertaining to 8KB and 64KB block sizes respectively. The minimum size is 4KB blocksize, for 8KB GbE files which we already supported. On larger block sizes, the same 4KB parts are observed: a single 4KB IfD area at the start of the block, and: 4KB GbE part at the start of the GbE region, and: 4KB GbE part at the start of GbE region plus block size The empty space inbetween is padding, and we ignore it, except when running swap/copy commands. The nvmutil code has been modified, to create a 128KB buffer in memory instead of 8KB, for loading GbE files. Partsize is set to GbE file size divided by 2, and only the area of memory we need to use is mapped; for example, if we're loading a 8KB GbE file into memory, we only touch the first 8KB part of the buffer, or first 16KB for 128KB files. In practise, we almost never see GbE files with sizes higher than 8KB, but *we have seen it*, *AND NOW IT'S SUPPORTED!" Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: Prevent unveil allowing dir accessLeah Rowe
We were checking directories *after* calling unveil, which means that the sandboxing was incomplete; we only want files to be accessed, not directories. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24typo: nvme should say nvm in nvmutil.cLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-24util/nvmutil: General code cleanupLeah Rowe
A lot of size-coding was performed in prior audits, to make the sloccount lower on nvmutil, but this resulted in code that wasn't very human readable. I've reversed some of it and added comments, for clarity. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-18snipLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-18snipLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-14grub/xhci: Add xHCI non-root-hub fixes from NitrokeyLeah Rowe
See: https://github.com/Nitrokey/nethsm-grub/commits/nethsm-z790?since=2025-01-13&until=2025-01-13 And more generally, see branch: https://github.com/Nitrokey/nethsm-grub/commits/nethsm-z790 This brings in a few minor fixes, and also a not-so-minor fix: Add TT (transaction translation) handling for non-SuperSpeed devices in xhci.c More generally, this patchset will improve non-root hub support in the xHCI code. There is also a patch to work around a quirk on the MSI Z790-P mainboard, which I'm planning to add to Libreboot at a later date. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-12add gnults-devel to fedora 41 dependenciesLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-12grub.cfg: scan luks *inside lvm*Leah Rowe
the user might have boot their kernel inside luks inside lvm for some dumb reason it's theoretically possible that the user would be so silly indeed Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-12grub.cfg: Scan *every* LVM deviceLeah Rowe
We were scanning a hardcoded set up LVM volumes, so in practise, LVM boot didn't really work. We did this because scanning for asterisk is slow on some machines. However, since LVM is the last one, and since most users don't boot directly from LVM, it wasn't that much of an issue in practise. Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-06Libreboot 20241206, 8th revision20241206rev8Leah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-06rom.sh: don't run mkpicotool on dry buildsLeah Rowe
Signed-off-by: Leah Rowe <leah@libreboot.org>
2025-01-06pico-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-06lib.sh: Much safer python version checkLeah Rowe
See: https://docs.python.org/3/library/sys.html#sys.version_info The sys.version_info tuple is a more reliable way to get the version. Our previous logic assumed that Python would always output "Python versionnumber", but this may not always be how it works. We've seen this for example where Debian modifies some GNU toolchains to include Debian something in the output. Python has a standard method built in for outputting exact the information we need. In my system, what I got was this: (3, 11, 2, 'final', 0) That output was from running this command: python -c 'import sys; print(sys.version_info[:])' This is much more robust, so use this instead. Signed-off-by: Leah Rowe <leah@libreboot.org>