Allow md_root_setconf() to set in a miniroot as the root file system
even if MEMORY_DISK_IS_ROOT is not defined (a runtime override).
This commit is contained in:
parent
3f1b4f1759
commit
1253c2cad4
|
@ -1,4 +1,4 @@
|
||||||
/* $NetBSD: md.h,v 1.8 2007/03/04 06:01:42 christos Exp $ */
|
/* $NetBSD: md.h,v 1.9 2008/05/02 13:02:31 ad Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1995 Gordon W. Ross
|
* Copyright (c) 1995 Gordon W. Ross
|
||||||
|
@ -87,7 +87,7 @@ struct md_conf {
|
||||||
*/
|
*/
|
||||||
extern void md_attach_hook(int, struct md_conf *);
|
extern void md_attach_hook(int, struct md_conf *);
|
||||||
extern void md_open_hook(int, struct md_conf *);
|
extern void md_open_hook(int, struct md_conf *);
|
||||||
#ifdef MEMORY_DISK_DYNAMIC
|
|
||||||
extern void md_root_setconf(char *, size_t);
|
extern void md_root_setconf(char *, size_t);
|
||||||
#endif
|
|
||||||
|
extern int md_is_root;
|
||||||
#endif /* _KERNEL */
|
#endif /* _KERNEL */
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $NetBSD: md_root.c,v 1.14 2008/04/28 20:23:47 martin Exp $ */
|
/* $NetBSD: md_root.c,v 1.15 2008/05/02 13:02:31 ad Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1996 The NetBSD Foundation, Inc.
|
* Copyright (c) 1996 The NetBSD Foundation, Inc.
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: md_root.c,v 1.14 2008/04/28 20:23:47 martin Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: md_root.c,v 1.15 2008/05/02 13:02:31 ad Exp $");
|
||||||
|
|
||||||
#include "opt_md.h"
|
#include "opt_md.h"
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ char md_root_image[ROOTBYTES] = "|This is the root ramdisk!\n";
|
||||||
void
|
void
|
||||||
md_root_setconf(char *addr, size_t size)
|
md_root_setconf(char *addr, size_t size)
|
||||||
{
|
{
|
||||||
|
md_is_root = 1;
|
||||||
md_root_image = addr;
|
md_root_image = addr;
|
||||||
md_root_size = size;
|
md_root_size = size;
|
||||||
}
|
}
|
||||||
|
@ -96,13 +97,13 @@ md_attach_hook(int unit, struct md_conf *md)
|
||||||
{
|
{
|
||||||
char pbuf[9];
|
char pbuf[9];
|
||||||
|
|
||||||
if (unit == 0) {
|
if (unit == 0 && md_is_root) {
|
||||||
/* Setup root ramdisk */
|
/* Setup root ramdisk */
|
||||||
md->md_addr = (void *)md_root_image;
|
md->md_addr = (void *)md_root_image;
|
||||||
md->md_size = (size_t)md_root_size;
|
md->md_size = (size_t)md_root_size;
|
||||||
md->md_type = MD_KMEM_FIXED;
|
md->md_type = MD_KMEM_FIXED;
|
||||||
format_bytes(pbuf, sizeof(pbuf), md->md_size);
|
format_bytes(pbuf, sizeof(pbuf), md->md_size);
|
||||||
aprint_normal("md%d: internal %s image area\n", unit, pbuf);
|
aprint_verbose("md%d: internal %s image area\n", unit, pbuf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +114,7 @@ void
|
||||||
md_open_hook(int unit, struct md_conf *md)
|
md_open_hook(int unit, struct md_conf *md)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (unit == 0) {
|
if (unit == 0 && md_is_root) {
|
||||||
/* The root ramdisk only works single-user. */
|
/* The root ramdisk only works single-user. */
|
||||||
boothowto |= MEMORY_RBFLAGS;
|
boothowto |= MEMORY_RBFLAGS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $NetBSD: kern_subr.c,v 1.186 2008/04/28 20:24:03 martin Exp $ */
|
/* $NetBSD: kern_subr.c,v 1.187 2008/05/02 13:02:31 ad Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1997, 1998, 1999, 2002, 2007, 2008 The NetBSD Foundation, Inc.
|
* Copyright (c) 1997, 1998, 1999, 2002, 2007, 2008 The NetBSD Foundation, Inc.
|
||||||
|
@ -79,7 +79,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: kern_subr.c,v 1.186 2008/04/28 20:24:03 martin Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: kern_subr.c,v 1.187 2008/05/02 13:02:31 ad Exp $");
|
||||||
|
|
||||||
#include "opt_ddb.h"
|
#include "opt_ddb.h"
|
||||||
#include "opt_md.h"
|
#include "opt_md.h"
|
||||||
|
@ -723,17 +723,16 @@ isswap(struct device *dv)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "md.h"
|
#include "md.h"
|
||||||
#if NMD == 0
|
|
||||||
#undef MEMORY_DISK_HOOKS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
#if NMD > 0
|
||||||
static struct device fakemdrootdev[NMD];
|
static struct device fakemdrootdev[NMD];
|
||||||
extern struct cfdriver md_cd;
|
extern struct cfdriver md_cd;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MEMORY_DISK_IS_ROOT
|
#ifdef MEMORY_DISK_IS_ROOT
|
||||||
#define BOOT_FROM_MEMORY_HOOKS 1
|
int md_is_root = 1;
|
||||||
|
#else
|
||||||
|
int md_is_root = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -757,9 +756,6 @@ setroot(struct device *bootdv, int bootpartition)
|
||||||
{
|
{
|
||||||
struct device *dv;
|
struct device *dv;
|
||||||
int len, majdev;
|
int len, majdev;
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
|
||||||
int i;
|
|
||||||
#endif
|
|
||||||
dev_t nrootdev;
|
dev_t nrootdev;
|
||||||
dev_t ndumpdev = NODEV;
|
dev_t ndumpdev = NODEV;
|
||||||
char buf[128];
|
char buf[128];
|
||||||
|
@ -776,7 +772,9 @@ setroot(struct device *bootdv, int bootpartition)
|
||||||
boothowto |= RB_ASKNAME;
|
boothowto |= RB_ASKNAME;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
#if NMD > 0
|
||||||
|
if (md_is_root) {
|
||||||
|
int i;
|
||||||
for (i = 0; i < NMD; i++) {
|
for (i = 0; i < NMD; i++) {
|
||||||
fakemdrootdev[i].dv_class = DV_DISK;
|
fakemdrootdev[i].dv_class = DV_DISK;
|
||||||
fakemdrootdev[i].dv_cfdata = NULL;
|
fakemdrootdev[i].dv_cfdata = NULL;
|
||||||
|
@ -786,11 +784,9 @@ setroot(struct device *bootdv, int bootpartition)
|
||||||
snprintf(fakemdrootdev[i].dv_xname,
|
snprintf(fakemdrootdev[i].dv_xname,
|
||||||
sizeof(fakemdrootdev[i].dv_xname), "md%d", i);
|
sizeof(fakemdrootdev[i].dv_xname), "md%d", i);
|
||||||
}
|
}
|
||||||
#endif /* MEMORY_DISK_HOOKS */
|
|
||||||
|
|
||||||
#ifdef MEMORY_DISK_IS_ROOT
|
|
||||||
bootdv = &fakemdrootdev[0];
|
bootdv = &fakemdrootdev[0];
|
||||||
bootpartition = 0;
|
bootpartition = 0;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1117,19 +1113,19 @@ static struct device *
|
||||||
finddevice(const char *name)
|
finddevice(const char *name)
|
||||||
{
|
{
|
||||||
const char *wname;
|
const char *wname;
|
||||||
#if defined(BOOT_FROM_MEMORY_HOOKS)
|
|
||||||
int j;
|
|
||||||
#endif /* BOOT_FROM_MEMORY_HOOKS */
|
|
||||||
|
|
||||||
if ((wname = getwedgename(name, strlen(name))) != NULL)
|
if ((wname = getwedgename(name, strlen(name))) != NULL)
|
||||||
return dkwedge_find_by_wname(wname);
|
return dkwedge_find_by_wname(wname);
|
||||||
|
|
||||||
#ifdef BOOT_FROM_MEMORY_HOOKS
|
#if NMD > 0
|
||||||
|
if (md_is_root) {
|
||||||
|
int j;
|
||||||
for (j = 0; j < NMD; j++) {
|
for (j = 0; j < NMD; j++) {
|
||||||
if (strcmp(name, fakemdrootdev[j].dv_xname) == 0)
|
if (strcmp(name, fakemdrootdev[j].dv_xname) == 0)
|
||||||
return &fakemdrootdev[j];
|
return &fakemdrootdev[j];
|
||||||
}
|
}
|
||||||
#endif /* BOOT_FROM_MEMORY_HOOKS */
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return device_find_by_xname(name);
|
return device_find_by_xname(name);
|
||||||
}
|
}
|
||||||
|
@ -1138,17 +1134,16 @@ static struct device *
|
||||||
getdisk(char *str, int len, int defpart, dev_t *devp, int isdump)
|
getdisk(char *str, int len, int defpart, dev_t *devp, int isdump)
|
||||||
{
|
{
|
||||||
struct device *dv;
|
struct device *dv;
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
|
||||||
int i;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if ((dv = parsedisk(str, len, defpart, devp)) == NULL) {
|
if ((dv = parsedisk(str, len, defpart, devp)) == NULL) {
|
||||||
printf("use one of:");
|
printf("use one of:");
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
#if NMD > 0
|
||||||
if (isdump == 0)
|
if (isdump == 0 && md_is_root) {
|
||||||
|
int i;
|
||||||
for (i = 0; i < NMD; i++)
|
for (i = 0; i < NMD; i++)
|
||||||
printf(" %s[a-%c]", fakemdrootdev[i].dv_xname,
|
printf(" %s[a-%c]", fakemdrootdev[i].dv_xname,
|
||||||
'a' + MAXPARTITIONS - 1);
|
'a' + MAXPARTITIONS - 1);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
TAILQ_FOREACH(dv, &alldevs, dv_list) {
|
TAILQ_FOREACH(dv, &alldevs, dv_list) {
|
||||||
if (DEV_USES_PARTITIONS(dv))
|
if (DEV_USES_PARTITIONS(dv))
|
||||||
|
@ -1189,9 +1184,6 @@ parsedisk(char *str, int len, int defpart, dev_t *devp)
|
||||||
const char *wname;
|
const char *wname;
|
||||||
char *cp, c;
|
char *cp, c;
|
||||||
int majdev, part;
|
int majdev, part;
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
|
||||||
int i;
|
|
||||||
#endif
|
|
||||||
if (len == 0)
|
if (len == 0)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
|
@ -1218,12 +1210,16 @@ parsedisk(char *str, int len, int defpart, dev_t *devp)
|
||||||
} else
|
} else
|
||||||
part = defpart;
|
part = defpart;
|
||||||
|
|
||||||
#ifdef MEMORY_DISK_HOOKS
|
#if NMD > 0
|
||||||
for (i = 0; i < NMD; i++)
|
if (md_is_root) {
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < NMD; i++) {
|
||||||
if (strcmp(str, fakemdrootdev[i].dv_xname) == 0) {
|
if (strcmp(str, fakemdrootdev[i].dv_xname) == 0) {
|
||||||
dv = &fakemdrootdev[i];
|
dv = &fakemdrootdev[i];
|
||||||
goto gotdisk;
|
goto gotdisk;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
dv = finddevice(str);
|
dv = finddevice(str);
|
||||||
|
|
Loading…
Reference in New Issue