diff options
author | mjacob <mjacob@FreeBSD.org> | 2000-11-14 08:12:15 +0000 |
---|---|---|
committer | mjacob <mjacob@FreeBSD.org> | 2000-11-14 08:12:15 +0000 |
commit | 363c7c2287703c2a9abc892764f54fefc22b28ad (patch) | |
tree | 4532d604f4bf48c62db8a081c5c16c8ebcab5105 | |
parent | a927d4ab8d54166f53e78dc004eb89413f33985e (diff) | |
download | FreeBSD-src-363c7c2287703c2a9abc892764f54fefc22b28ad.zip FreeBSD-src-363c7c2287703c2a9abc892764f54fefc22b28ad.tar.gz |
Pick up kernelname for bootinfo structure (if possible), otherwise
from environment.
-rw-r--r-- | sys/alpha/alpha/machdep.c | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/sys/alpha/alpha/machdep.c b/sys/alpha/alpha/machdep.c index 0cf74e5..043b903 100644 --- a/sys/alpha/alpha/machdep.c +++ b/sys/alpha/alpha/machdep.c @@ -570,7 +570,7 @@ alpha_init(pfn, ptb, bim, bip, biv) u_long biv; /* bootinfo version */ { int phys_avail_cnt; - char *bootinfo_msg; + char *bootinfo_msg, *bootinfo_booted_kernel; vm_offset_t kernstart, kernend; vm_offset_t kernstartpfn, kernendpfn, pfn0, pfn1; struct mddt *mddtp; @@ -595,6 +595,7 @@ alpha_init(pfn, ptb, bim, bip, biv) * information provided by the boot program). */ bootinfo_msg = NULL; + bootinfo_booted_kernel = NULL; if (bim == BOOTINFO_MAGIC) { if (biv == 0) { /* backward compat */ biv = *(u_long *)bip; @@ -626,6 +627,7 @@ alpha_init(pfn, ptb, bim, bip, biv) bcopy(v1p->booted_kernel, bootinfo.booted_kernel, min(sizeof v1p->booted_kernel, sizeof bootinfo.booted_kernel)); + bootinfo_booted_kernel = bootinfo.booted_kernel; /* booted dev not provided in bootinfo */ init_prom_interface((struct rpb *) ALPHA_PHYS_TO_K0SEG(bootinfo.hwrpb_phys)); @@ -790,10 +792,6 @@ alpha_init(pfn, ptb, bim, bip, biv) if (preload_metadata == NULL) printf("WARNING: loader(8) metadata is missing!\n"); - p = getenv("kernelname"); - if (p) - strncpy(kernelname, p, sizeof(kernelname) - 1); - kernstartpfn = atop(ALPHA_K0SEG_TO_PHYS(kernstart)); kernendpfn = atop(ALPHA_K0SEG_TO_PHYS(kernend)); #ifdef SIMOS @@ -1113,6 +1111,16 @@ alpha_init(pfn, ptb, bim, bip, biv) } /* + * Pick up kernelname. + */ + if (bootinfo_booted_kernel) { + strncpy(kernelname, bootinfo_booted_kernel, + min(sizeof(kernelname), sizeof bootinfo.booted_kernel) - 1); + } else if ((p = getenv("kernelname")) != NULL) { + strncpy(kernelname, p, sizeof(kernelname) - 1); + } + + /* * Initialize debuggers, and break into them if appropriate. */ #ifdef DDB |