- fix an indentation error in atawd.c
- use partition 'e' for a disk with no NetBSD slice. - add Linux ATAG to feature ELF Linux kernel booting. Commented out for now. - fix errors to retrieve iospace BARs.
This commit is contained in:
parent
14395bf943
commit
e11b7f14dc
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: atawd.c,v 1.4 2008/04/09 06:07:57 nisimura Exp $ */
|
/* $NetBSD: atawd.c,v 1.5 2008/04/09 16:26:29 nisimura Exp $ */
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
@ -256,7 +256,7 @@ wdgetdisklabel(struct wd_softc *wd)
|
|||||||
lp->d_secperunit = UINT32_MAX;
|
lp->d_secperunit = UINT32_MAX;
|
||||||
else
|
else
|
||||||
lp->d_secperunit = wd->sc_capacity;
|
lp->d_secperunit = wd->sc_capacity;
|
||||||
lp->d_rpm = 3600;
|
lp->d_rpm = 3600;
|
||||||
lp->d_interleave = 1;
|
lp->d_interleave = 1;
|
||||||
lp->d_flags = 0;
|
lp->d_flags = 0;
|
||||||
lp->d_partitions[RAW_PART].p_offset = 0;
|
lp->d_partitions[RAW_PART].p_offset = 0;
|
||||||
@ -268,7 +268,7 @@ wdgetdisklabel(struct wd_softc *wd)
|
|||||||
lp->d_checksum = dkcksum(lp);
|
lp->d_checksum = dkcksum(lp);
|
||||||
|
|
||||||
dp = (struct mbr_partition *)(buf + MBR_PART_OFFSET);
|
dp = (struct mbr_partition *)(buf + MBR_PART_OFFSET);
|
||||||
n = RAW_PART + 1;
|
n = 'e' - 'a';
|
||||||
for (i = 0; i < MBR_PART_COUNT; i++, dp++) {
|
for (i = 0; i < MBR_PART_COUNT; i++, dp++) {
|
||||||
if (dp->mbrp_type == MBR_PTYPE_UNUSED)
|
if (dp->mbrp_type == MBR_PTYPE_UNUSED)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: main.c,v 1.14 2008/04/09 00:20:35 nisimura Exp $ */
|
/* $NetBSD: main.c,v 1.15 2008/04/09 16:26:29 nisimura Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 2007 The NetBSD Foundation, Inc.
|
* Copyright (c) 2007 The NetBSD Foundation, Inc.
|
||||||
@ -726,3 +726,52 @@ pcifixup()
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
static const char *cmdln[] = {
|
||||||
|
"console=ttyS0,115200 root=/dev/sda1 rw initrd=0x200000,2M",
|
||||||
|
"console=ttyS0,115200 root=/dev/nfs ip=dhcp"
|
||||||
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
mkatagparams(addr, kcmd)
|
||||||
|
unsigned addr;
|
||||||
|
char *kcmd;
|
||||||
|
{
|
||||||
|
struct tag {
|
||||||
|
unsigned siz;
|
||||||
|
unsigned tag;
|
||||||
|
unsigned val[1];
|
||||||
|
};
|
||||||
|
struct tag *p;
|
||||||
|
#define ATAG_CORE 0x54410001
|
||||||
|
#define ATAG_MEM 0x54410002
|
||||||
|
#define ATAG_INITRD 0x54410005
|
||||||
|
#define ATAG_CMDLINE 0x54410009
|
||||||
|
#define ATAG_NONE 0x00000000
|
||||||
|
#define tagnext(p) (struct tag *)((unsigned *)(p) + (p)->siz)
|
||||||
|
#define tagsize(n) (2 + (n))
|
||||||
|
|
||||||
|
p = (struct tag *)addr;
|
||||||
|
p->tag = ATAG_CORE;
|
||||||
|
p->siz = tagsize(3);
|
||||||
|
p->val[0] = 0; /* flags */
|
||||||
|
p->val[1] = 0; /* pagesize */
|
||||||
|
p->val[2] = 0; /* rootdev */
|
||||||
|
p = tagnext(p);
|
||||||
|
p->tag = ATAG_MEM;
|
||||||
|
p->siz = tagsize(2);
|
||||||
|
p->val[0] = 64 * 1024 * 1024;
|
||||||
|
p->val[1] = 0; /* start */
|
||||||
|
p = tagnext(p);
|
||||||
|
if (kcmd != NULL) {
|
||||||
|
p = tagnext(p);
|
||||||
|
p->tag = ATAG_CMDLINE;
|
||||||
|
p->siz = tagsize((strlen(kcmd) + 1 + 3) >> 2);
|
||||||
|
strcpy((void *)p->val, kcmd);
|
||||||
|
}
|
||||||
|
p = tagnext(p);
|
||||||
|
p->tag = ATAG_NONE;
|
||||||
|
p->siz = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: pciide.c,v 1.4 2008/04/09 01:08:39 nisimura Exp $ */
|
/* $NetBSD: pciide.c,v 1.5 2008/04/09 16:26:29 nisimura Exp $ */
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/disklabel.h>
|
#include <sys/disklabel.h>
|
||||||
@ -65,9 +65,9 @@ pciide_init(unsigned tag, unsigned data)
|
|||||||
cp = &l->channel[ch];
|
cp = &l->channel[ch];
|
||||||
if (PCIIDE_INTERFACE_PCI(ch) & val) {
|
if (PCIIDE_INTERFACE_PCI(ch) & val) {
|
||||||
cp->c_cmdbase =
|
cp->c_cmdbase =
|
||||||
(void *)DEVTOV(pcicfgread(tag, pcibar[ch].cmd));
|
(void *)DEVTOV(~03 & pcicfgread(tag, pcibar[ch].cmd));
|
||||||
cp->c_ctlbase =
|
cp->c_ctlbase =
|
||||||
(void *)DEVTOV(pcicfgread(tag, pcibar[ch].ctl));
|
(void *)DEVTOV(~03 & pcicfgread(tag, pcibar[ch].ctl));
|
||||||
cp->c_data = (u_int16_t *)(cp->c_cmdbase + wd_data);
|
cp->c_data = (u_int16_t *)(cp->c_cmdbase + wd_data);
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
cp->c_cmdreg[i] = cp->c_cmdbase + i;
|
cp->c_cmdreg[i] = cp->c_cmdbase + i;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: siisata.c,v 1.5 2008/04/09 01:08:39 nisimura Exp $ */
|
/* $NetBSD: siisata.c,v 1.6 2008/04/09 16:26:29 nisimura Exp $ */
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/disklabel.h>
|
#include <sys/disklabel.h>
|
||||||
@ -69,8 +69,8 @@ map3112chan(unsigned tag, int ch, struct atac_channel *cp)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
cp->c_cmdbase = (void *)DEVTOV(pcicfgread(tag, regstd[ch].cmd));
|
cp->c_cmdbase = (void *)DEVTOV(~07 & pcicfgread(tag, regstd[ch].cmd));
|
||||||
cp->c_ctlbase = (void *)DEVTOV(pcicfgread(tag, regstd[ch].ctl));
|
cp->c_ctlbase = (void *)DEVTOV(~03 & pcicfgread(tag, regstd[ch].ctl));
|
||||||
cp->c_data = (u_int16_t *)(cp->c_cmdbase + wd_data);
|
cp->c_data = (u_int16_t *)(cp->c_cmdbase + wd_data);
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
cp->c_cmdreg[i] = cp->c_cmdbase + i;
|
cp->c_cmdreg[i] = cp->c_cmdbase + i;
|
||||||
|
Loading…
Reference in New Issue
Block a user