Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/x86/x86 don't try allocating 16KB of scratch space ...



details:   https://anonhg.NetBSD.org/src/rev/28f2e896591e
branches:  trunk
changeset: 1011278:28f2e896591e
user:      jdolecek <jdolecek%NetBSD.org@localhost>
date:      Wed Jun 24 22:28:07 2020 +0000

description:
don't try allocating 16KB of scratch space on stack

it's too early for kmem_alloc(), so use static variable in BSS; it's used
post reloc, so don't need to use the RELOC() macros

XXX compile-tested only on i386

diffstat:

 sys/arch/x86/x86/multiboot2.c |  13 +++++--------
 1 files changed, 5 insertions(+), 8 deletions(-)

diffs (61 lines):

diff -r 0e82fd612687 -r 28f2e896591e sys/arch/x86/x86/multiboot2.c
--- a/sys/arch/x86/x86/multiboot2.c     Wed Jun 24 21:54:57 2020 +0000
+++ b/sys/arch/x86/x86/multiboot2.c     Wed Jun 24 22:28:07 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: multiboot2.c,v 1.4 2020/01/30 01:49:44 manu Exp $      */
+/*     $NetBSD: multiboot2.c,v 1.5 2020/06/24 22:28:07 jdolecek Exp $  */
 
 /*-
  * Copyright (c) 2005, 2006 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: multiboot2.c,v 1.4 2020/01/30 01:49:44 manu Exp $");
+__KERNEL_RCSID(0, "$NetBSD: multiboot2.c,v 1.5 2020/06/24 22:28:07 jdolecek Exp $");
 
 #include "opt_multiboot.h"
 
@@ -115,7 +115,7 @@
 bool multiboot2_enabled = false;
 bool has_syms = false;
 struct multiboot_symbols Multiboot_Symbols;
-
+static char bimbuf[16384];
 
 #define RELOC(type, x) ((type)((vaddr_t)(x) - KERNBASE))
 
@@ -448,7 +448,6 @@
        size_t bim_len;
        struct bi_modulelist_entry *bie;
        struct btinfo_modulelist *bim;
-       char bimbuf[16384];
 
        bim_len = sizeof(*bim) + (module_count * sizeof(*bie));
        if (bim_len > sizeof(bimbuf))
@@ -518,7 +517,6 @@
 static void
 mbi_mmap(struct multiboot_tag_mmap *mbt)
 {
-       char bimbuf[16384];
        struct btinfo_memmap *bim;
        char *cp;
 
@@ -616,15 +614,14 @@
 static void
 mbi_efi_mmap(struct multiboot_tag_efi_mmap *mbt)
 {
-       char biebuf[16384];
-       struct btinfo_efimemmap *bie = (struct btinfo_efimemmap *)biebuf;
+       struct btinfo_efimemmap *bie = (struct btinfo_efimemmap *)bimbuf;
        size_t bie_len;
 
        if (mbt->descr_vers != 0)
                goto out;
 
        bie_len = sizeof(*bie) + mbt->size - sizeof(*mbt);
-       if (bie_len > sizeof(biebuf))
+       if (bie_len > sizeof(bimbuf))
                goto out;
 
        bie->num = (mbt->size - sizeof(*mbt)) / mbt->descr_size;



Home | Main Index | Thread Index | Old Index