From nobody Fri Sep 16 15:54:02 2022 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4MTdsl1zrRz4cLKg; Fri, 16 Sep 2022 15:54:03 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4MTdsl1Zj7z3hqS; Fri, 16 Sep 2022 15:54:03 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1663343643; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=HvETLIeYU9SQ8UJ1JrmtEy3q3k7XszFLQfJn9aWM0IE=; b=In+d0kjazP69c87tZuqvPeW1T4ETjGU0iPIeFZ1wpUWGmHSMXULoweSpEoE+4/WhGoO6Y5 PSd2YnmQ5bw9HlN7VWcmvhP9QBtarmYRAFQtih6ldXy6JbSU2WYIqqW10+YQ1tUQ3PYILc 1cXGSzXDcENTAia8MWH6E4lGVuUQohjyqgfMxD8+xzAsnv4uLkdAHOGPdYJXW9fPV+iXvm TlnYqUSNwpoYCfaNatUzGhagm/+L6G7O77ohRdKGg32pkCkE2Y+AgDFoBITB9+DMRYTZDr Xx0NnowmUBBcNPtiQUfpB8umPl7V0GpPRs1mXJ95gdw/XQyNWJSMqts5Ma07/g== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4MTdsl0N1lzPtH; Fri, 16 Sep 2022 15:54:03 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 28GFs2Zq086585; Fri, 16 Sep 2022 15:54:02 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 28GFs2cd086584; Fri, 16 Sep 2022 15:54:02 GMT (envelope-from git) Date: Fri, 16 Sep 2022 15:54:02 GMT Message-Id: <202209161554.28GFs2cd086584@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Warner Losh Subject: git: 4134f677eb39 - main - i386: Make boot loader smaller by reducing size of bootinfo List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: imp X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 4134f677eb39ace176de2967c6ed449d6dfff732 Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1663343643; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=HvETLIeYU9SQ8UJ1JrmtEy3q3k7XszFLQfJn9aWM0IE=; b=KnDC2U7w2VW7K8+2T7dxGoH0+lH0XnDJmL3RB8DBb7AolHHHvDMicpJtl7GMchkLqD6omp JJEqg7KSLE0lIsXriSTdcb41hudR0ofU9Y8v1HeF7JLumXhPQFzke3Qz3fFgB6Z0ozrYfC QDr9YHxYY9TpteGuhDdfq5MDRq94qD0Blqg98iHwFvHwyadPqx/YtobQJhDAn8K4Bll2m2 18vKcx3Zt0dPFXNjm/K07mN8kJhVWaLQcACfRQ/qifMBWMm2UvbG2DJtuTzjjNlKR84wq3 1hOKEQ0QtQUJ3fXPNnupojAt0aR9VlRT7S/7QezqdmDZWgV6PsYi9Q1srnY75w== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1663343643; a=rsa-sha256; cv=none; b=N0M19wC8RwspEO+FWn6OPzp8eiXPUWigK5WDiffDWOTMXyANKrLx8ZzoBFWkYMDb6fynhF +S0wWNU5eVysdK66w/zS55bbKQwZN8/hySz5gTmr/BcGcN9uPryV2MNX2vBE/qHmTqojtc cLB5u3Qf2TrfTrYKShZpHxjVEk5pCpO4GI+aFfyFWFil1xJKQuYRX6lwiAT0PvUfVI+eq6 piOxD5J0wosUXupxYvgc8EVjhYR25bYgCVznDq6KemNs39B7FulnSWNnqNvd0lfHyVMYBr dPlrP7k+obphZmgNfffD4TPxTHuisklYuGid0avuXQyZibZ0QzzXPahZEgJX5Q== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch main has been updated by imp: URL: https://cgit.FreeBSD.org/src/commit/?id=4134f677eb39ace176de2967c6ed449d6dfff732 commit 4134f677eb39ace176de2967c6ed449d6dfff732 Author: Warner Losh AuthorDate: 2022-09-16 15:09:26 +0000 Commit: Warner Losh CommitDate: 2022-09-16 15:18:57 +0000 i386: Make boot loader smaller by reducing size of bootinfo We don't need the 56 bytes at the end of bootinfo, and never had. Don't copy them from old boot loaders, and don't provide them with new boot loaders. Add comments about what versions of FreeBSD 'old' means in various contexts. Add note that old disk loader (from 1.x/2.x) is doomed to failure because it doesn't provide metadata that we now require to boot, and has been since approximately FreeBSD 7.x. Retain all this information to explain why we have 4 arguments that are always 0, even though it's ancient history. This saves 56 bytes in the boot loader. Sponsored by: Netflix Reviewed by: phk, rgrimes, kib Differential Revision: https://reviews.freebsd.org/D36550 --- sys/i386/i386/genassym.c | 1 - sys/i386/i386/locore.s | 34 ++++++++++++++++------------------ sys/i386/include/bootinfo.h | 15 +++------------ 3 files changed, 19 insertions(+), 31 deletions(-) diff --git a/sys/i386/i386/genassym.c b/sys/i386/i386/genassym.c index a0520646dc25..c5cf653bbb9e 100644 --- a/sys/i386/i386/genassym.c +++ b/sys/i386/i386/genassym.c @@ -183,7 +183,6 @@ ASSYM(BOOTINFO_SIZE, sizeof(struct bootinfo)); ASSYM(BI_VERSION, offsetof(struct bootinfo, bi_version)); ASSYM(BI_KERNELNAME, offsetof(struct bootinfo, bi_kernelname)); ASSYM(BI_NFS_DISKLESS, offsetof(struct bootinfo, bi_nfs_diskless)); -ASSYM(BI_ENDCOMMON, offsetof(struct bootinfo, bi_endcommon)); ASSYM(NFSDISKLESS_SIZE, sizeof(struct nfs_diskless)); ASSYM(BI_SIZE, offsetof(struct bootinfo, bi_size)); ASSYM(BI_SYMTAB, offsetof(struct bootinfo, bi_symtab)); diff --git a/sys/i386/i386/locore.s b/sys/i386/i386/locore.s index 6dffc4f97fdd..6b0e397d05be 100644 --- a/sys/i386/i386/locore.s +++ b/sys/i386/i386/locore.s @@ -178,6 +178,9 @@ recover_bootinfo: * and always passed in as 0] * [esym is also known as total in the boot code, and * was never properly supported by the FreeBSD boot code] + * This code from 1.x/2.x doesn't supply now-required metadata and + * likely will fail (we test for it to avoid dereferencing stack + * garbage here). * * Old diskless netboot code: * (*btext)(0,0,0,0,&nfsdiskless,0,0,0); @@ -195,9 +198,11 @@ recover_bootinfo: */ /* - * The old style disk boot blocks fake a frame on the stack and - * did an lret to get here. The frame on the stack has a return - * address of 0. + * The old style disk boot blocks fake a frame on the stack and did an + * lret to get here. The frame on the stack has a return address of 0. + * This style of boot (from 1.x / 2.x) almost certainly won't work, + * since the kernel has required metadata since about 7.x or so and none + * are present. */ cmpl $0,4(%ebp) je olddiskboot @@ -212,9 +217,9 @@ recover_bootinfo: je newboot /* - * Seems we have been loaded by the old diskless boot code, we - * don't stand a chance of running as the diskless structure - * changed considerably between the two, so just halt. + * Seems we have been loaded by the old 1.x/2.x diskless boot code, we + * don't stand a chance of running as the diskless structure changed + * considerably between the two, so just halt. */ hlt @@ -228,6 +233,8 @@ newboot: movl BI_VERSION(%ebx),%eax cmpl $1,%eax /* We only understand version 1 */ je 1f + testl $RB_BOOTINFO,8(%ebp) /* bi_size (and bootinfo) valid? */ + jne 1f movl $1,%eax /* Return status */ leave /* @@ -258,21 +265,12 @@ newboot: 2: /* * Determine the size of the boot loader's copy of the bootinfo - * struct. This is impossible to do properly because old versions - * of the struct don't contain a size field and there are 2 old - * versions with the same version number. - */ - movl $BI_ENDCOMMON,%ecx /* prepare for sizeless version */ - testl $RB_BOOTINFO,8(%ebp) /* bi_size (and bootinfo) valid? */ - je got_bi_size /* no, sizeless version */ - movl BI_SIZE(%ebx),%ecx -got_bi_size: - - /* - * Copy the common part of the bootinfo struct + * struct. Copy min(our size, loader's size) into our bootinfo. + * Incompatible with really old boot loaders from FreeBSD 1.x and 2.0. */ movl %ebx,%esi movl $bootinfo,%edi + movl BI_SIZE(%ebx),%ecx cmpl $BOOTINFO_SIZE,%ecx jbe got_common_bi_size movl $BOOTINFO_SIZE,%ecx diff --git a/sys/i386/include/bootinfo.h b/sys/i386/include/bootinfo.h index 5b9473ddcaba..8e50ae71d5e8 100644 --- a/sys/i386/include/bootinfo.h +++ b/sys/i386/include/bootinfo.h @@ -44,15 +44,13 @@ /* * A zero bootinfo field often means that there is no info available. - * Flags are used to indicate the validity of fields where zero is a - * normal value. + * Assumes booting with a boot loader from FreeBSD 2.1 or newer and + * that bi_size is always valid when bi_version == 1. */ struct bootinfo { - u_int32_t bi_version; + u_int32_t bi_version; /* Must be 1 */ u_int32_t bi_kernelname; /* represents a char * */ u_int32_t bi_nfs_diskless; /* struct nfs_diskless * */ - /* End of fields that are always present. */ -#define bi_endcommon _was_bi_n_bios_used u_int32_t _was_bi_n_bios_used; u_int32_t _was_bi_bios_geom[_WAS_N_BIOS_GEOM]; u_int32_t bi_size; @@ -67,13 +65,6 @@ struct bootinfo { u_int32_t bi_kernend; /* end of kernel space */ u_int32_t bi_envp; /* environment */ u_int32_t bi_modulep; /* preloaded modules */ - uint32_t _was_bi_memdesc_version;/* EFI memory desc version */ - uint64_t _was_bi_memdesc_size; /* sizeof EFI memory desc */ - uint64_t _was_bi_memmap; /* pa of EFI memory map */ - uint64_t _was_bi_memmap_size; /* size of EFI memory map */ - uint64_t _was_bi_hcdp; /* DIG64 HCDP table */ - uint64_t _was_bi_fpswa; /* FPSWA interface */ - uint64_t _was_bi_systab; /* pa of EFI system table */ }; #ifdef _KERNEL