stand: Raise limit to 550,000 bytes for loader
authorWarner Losh <imp@FreeBSD.org>
Fri, 12 Aug 2022 04:59:51 +0000 (22:59 -0600)
committerWarner Losh <imp@FreeBSD.org>
Sat, 13 Aug 2022 03:47:02 +0000 (21:47 -0600)
commitf8a199f28f9de46fe7360c3a4a0e19e71be72721
tree61f7c4c945cf7b08b6a128f3569617b5e29536d8
parentb9fd884a8d0b249f77519a2c7f156b786fcc1c62
stand: Raise limit to 550,000 bytes for loader

Raise the limit for /boot/loader to be 550k. The IBM PC imposes a limit
of 640k of RAM below 1MB, which is needed for real mode calls. BTX takes
40k of that. The BIOS takes some amount (25k seems a good "99% take less
than or equal to this" estimate for that, though some systems consume
more). Most typical setups need 25k of stack.  This leaves 550k for
code. We set the limit to 550,000 which gives about an extra 13,000
bytes of buffer for machines that whose setups use a little more stack
or whose BIOS reserves a bit more...

Add this derivation in the Makefile. Also recommend setting LOADERSIZE
lower in /etc/src.conf when the loader has to run on a system whose BIOS
takes up more space, or for a complex setup. Add a recipe for how to
find how much RAM your BIOS uses as well (thanks to jhb@ for the
trick). Network cards that boot via PXE and HBAs with their BIOS enabled
are known to be large consumers of lomem space.

Sponsored by: Netflix
Reviewed by: jhb
Differential Revision: https://reviews.freebsd.org/D36152
stand/i386/loader/Makefile