summaryrefslogtreecommitdiff
path: root/sys/arch/amd64/stand/libsa
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/amd64/stand/libsa')
-rw-r--r--sys/arch/amd64/stand/libsa/biosdev.c124
1 files changed, 63 insertions, 61 deletions
diff --git a/sys/arch/amd64/stand/libsa/biosdev.c b/sys/arch/amd64/stand/libsa/biosdev.c
index b389d1adc69..4d8082b9cce 100644
--- a/sys/arch/amd64/stand/libsa/biosdev.c
+++ b/sys/arch/amd64/stand/libsa/biosdev.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: biosdev.c,v 1.13 2011/03/14 22:14:40 krw Exp $ */
+/* $OpenBSD: biosdev.c,v 1.14 2011/03/15 14:00:26 krw Exp $ */
/*
* Copyright (c) 1996 Michael Shalayeff
@@ -61,13 +61,13 @@ struct biosdisk {
#endif
struct EDD_CB {
- u_int8_t edd_len; /* size of packet */
- u_int8_t edd_res1; /* reserved */
- u_int8_t edd_nblk; /* # of blocks to transfer */
- u_int8_t edd_res2; /* reserved */
- u_int16_t edd_off; /* address of buffer (offset) */
- u_int16_t edd_seg; /* address of buffer (segment) */
- u_int64_t edd_daddr; /* starting block */
+ u_int8_t edd_len; /* size of packet */
+ u_int8_t edd_res1; /* reserved */
+ u_int8_t edd_nblk; /* # of blocks to transfer */
+ u_int8_t edd_res2; /* reserved */
+ u_int16_t edd_off; /* address of buffer (offset) */
+ u_int16_t edd_seg; /* address of buffer (segment) */
+ u_int64_t edd_daddr; /* starting block */
};
/*
@@ -77,9 +77,11 @@ static int
biosdreset(int dev)
{
int rv;
+
__asm __volatile (DOINT(0x13) "; setc %b0" : "=a" (rv)
- : "0" (0), "d" (dev) : "%ecx", "cc");
- return (rv & 0xff)? rv >> 8 : 0;
+ : "0" (0), "d" (dev) : "%ecx", "cc");
+
+ return ((rv & 0xff)? rv >> 8 : 0);
}
/*
@@ -100,23 +102,23 @@ bios_getdiskinfo(int dev, bios_diskinfo_t *pdi)
printf("getinfo: try #8, 0x%x, %p\n", dev, pdi);
#endif
__asm __volatile (DOINT(0x13) "\n\t"
- "setc %b0; movzbl %h1, %1\n\t"
- "movzbl %%cl, %3; andb $0x3f, %b3\n\t"
- "xchgb %%cl, %%ch; rolb $2, %%ch"
- : "=a" (rv), "=d" (pdi->bios_heads),
- "=c" (pdi->bios_cylinders),
- "=b" (pdi->bios_sectors)
- : "0" (0x0800), "1" (dev) : "cc");
+ "setc %b0; movzbl %h1, %1\n\t"
+ "movzbl %%cl, %3; andb $0x3f, %b3\n\t"
+ "xchgb %%cl, %%ch; rolb $2, %%ch"
+ : "=a" (rv), "=d" (pdi->bios_heads),
+ "=c" (pdi->bios_cylinders),
+ "=b" (pdi->bios_sectors)
+ : "0" (0x0800), "1" (dev) : "cc");
#ifdef BIOS_DEBUG
if (debug) {
printf("getinfo: got #8\n");
printf("disk 0x%x: %d,%d,%d\n", dev, pdi->bios_cylinders,
- pdi->bios_heads, pdi->bios_sectors);
+ pdi->bios_heads, pdi->bios_sectors);
}
#endif
if (rv & 0xff)
- return (1);
+ return 1;
/* Fix up info */
pdi->bios_number = dev;
@@ -171,13 +173,13 @@ bios_getdiskinfo(int dev, bios_diskinfo_t *pdi)
/* Sanity check */
if (!pdi->bios_cylinders || !pdi->bios_heads || !pdi->bios_sectors)
- return(1);
+ return 1;
/* CD-ROMs sometimes return heads == 1 */
if (pdi->bios_heads < 2)
- return(1);
+ return 1;
- return(0);
+ return 0;
}
/*
@@ -191,22 +193,22 @@ CHS_rw(int rw, int dev, int cyl, int head, int sect, int nsect, void *buf)
rw = rw == F_READ ? 2 : 3;
BIOS_regs.biosr_es = (u_int32_t)buf >> 4;
__asm __volatile ("movb %b7, %h1\n\t"
- "movb %b6, %%dh\n\t"
- "andl $0xf, %4\n\t"
- /* cylinder; the highest 2 bits of cyl is in %cl */
- "xchgb %%ch, %%cl\n\t"
- "rorb $2, %%cl\n\t"
- "orb %b5, %%cl\n\t"
- "inc %%cx\n\t"
- DOINT(0x13) "\n\t"
- "setc %b0"
- : "=a" (rv)
- : "0" (nsect), "d" (dev), "c" (cyl),
- "b" (buf), "m" (sect), "m" (head),
- "m" (rw)
- : "cc", "memory");
-
- return (rv & 0xff)? rv >> 8 : 0;
+ "movb %b6, %%dh\n\t"
+ "andl $0xf, %4\n\t"
+ /* cylinder; the highest 2 bits of cyl is in %cl */
+ "xchgb %%ch, %%cl\n\t"
+ "rorb $2, %%cl\n\t"
+ "orb %b5, %%cl\n\t"
+ "inc %%cx\n\t"
+ DOINT(0x13) "\n\t"
+ "setc %b0"
+ : "=a" (rv)
+ : "0" (nsect), "d" (dev), "c" (cyl),
+ "b" (buf), "m" (sect), "m" (head),
+ "m" (rw)
+ : "cc", "memory");
+
+ return ((rv & 0xff)? rv >> 8 : 0);
}
static __inline int
@@ -232,14 +234,14 @@ EDD_rw(int rw, int dev, u_int32_t daddr, u_int32_t nblk, void *buf)
/* if offset/segment are zero, punt */
if (!cb.edd_seg && !cb.edd_off)
- return (1);
+ return 1;
/* Call extended read/write (with disk packet) */
BIOS_regs.biosr_ds = (u_int32_t)&cb >> 4;
__asm __volatile (DOINT(0x13) "; setc %b0" : "=a" (rv)
- : "0" ((rw == F_READ)? 0x4200: 0x4300),
- "d" (dev), "S" ((int) (&cb) & 0xf) : "%ecx", "cc");
- return (rv & 0xff)? rv >> 8 : 0;
+ : "0" ((rw == F_READ)? 0x4200: 0x4300),
+ "d" (dev), "S" ((int) (&cb) & 0xf) : "%ecx", "cc");
+ return ((rv & 0xff)? rv >> 8 : 0);
}
/*
@@ -422,7 +424,7 @@ bios_getdisklabel(bios_diskinfo_t *bd, struct disklabel *label)
/* Sanity check */
if (bd->bios_edd == -1 &&
(bd->bios_heads == 0 || bd->bios_sectors == 0))
- return("failed to read disklabel");
+ return "failed to read disklabel";
/* MBR is a harddisk thing */
if (bd->bios_number & 0x80) {
@@ -440,13 +442,13 @@ bios_getdisklabel(bios_diskinfo_t *bd, struct disklabel *label)
buf = alloca(DEV_BSIZE);
#ifdef BIOS_DEBUG
if (debug)
- printf("loading disklabel @ %u\n", off);
+ printf("loading disklabel @ %u\n", start);
#endif
/* read disklabel */
error = biosd_io(F_READ, bd, start, 1, buf);
- if(error)
- return("failed to read disklabel");
+ if (error)
+ return "failed to read disklabel";
/* Fill in disklabel */
return (getdisklabel(buf, label));
@@ -457,7 +459,7 @@ biosopen(struct open_file *f, ...)
{
va_list ap;
register char *cp, **file;
- dev_t maj, unit, part;
+ dev_t maj, unit, part;
struct diskinfo *dip;
int biosdev;
@@ -480,8 +482,8 @@ biosopen(struct open_file *f, ...)
cp++;
}
- for (maj = 0; maj < nbdevs &&
- strncmp(*file, bdevs[maj], cp - *file); maj++);
+ for (maj = 0; maj < nbdevs && strncmp(*file, bdevs[maj], cp - *file); )
+ maj++;
if (maj >= nbdevs) {
printf("Unknown device: ");
for (cp = *file; *cp != ':'; cp++)
@@ -504,7 +506,7 @@ biosopen(struct open_file *f, ...)
printf("Bad partition id\n");
return EPART;
}
-
+
cp++; /* skip ':' */
if (*cp != 0)
*file = cp;
@@ -534,9 +536,9 @@ biosopen(struct open_file *f, ...)
{ dev_t bsd_dev;
bsd_dev = dip->bios_info.bsd_dev;
dip->bsddev = MAKEBOOTDEV(B_TYPE(bsd_dev), B_ADAPTOR(bsd_dev),
- B_CONTROLLER(bsd_dev), unit, part);
+ B_CONTROLLER(bsd_dev), unit, part);
dip->bootdev = MAKEBOOTDEV(B_TYPE(bsd_dev), B_ADAPTOR(bsd_dev),
- B_CONTROLLER(bsd_dev), B_UNIT(bsd_dev), part);
+ B_CONTROLLER(bsd_dev), B_UNIT(bsd_dev), part);
}
#if 0
@@ -547,13 +549,13 @@ biosopen(struct open_file *f, ...)
#ifdef BIOS_DEBUG
if (debug) {
printf("BIOS geometry: heads=%u, s/t=%u; EDD=%d\n",
- dip->bios_info.bios_heads, dip->bios_info.bios_sectors,
- dip->bios_info.bios_edd);
+ dip->bios_info.bios_heads, dip->bios_info.bios_sectors,
+ dip->bios_info.bios_edd);
}
#endif
/* Try for disklabel again (might be removable media) */
- if(dip->bios_info.flags & BDI_BADLABEL){
+ if (dip->bios_info.flags & BDI_BADLABEL) {
const char *st = bios_getdisklabel(&dip->bios_info,
&dip->disklabel);
#ifdef BIOS_DEBUG
@@ -564,7 +566,7 @@ biosopen(struct open_file *f, ...)
dip->bios_info.flags &= ~BDI_BADLABEL;
dip->bios_info.flags |= BDI_GOODLABEL;
} else
- return (ERDLAB);
+ return ERDLAB;
}
f->f_devdata = dip;
@@ -614,7 +616,7 @@ biosdisk_err(u_int error)
register const u_char *p = bidos_errs;
while (*p && *p != error)
- while(*p++);
+ while (*p++);
return ++p;
}
@@ -632,7 +634,7 @@ const struct biosdisk_errors {
{ 0x0C, ENXIO },
{ 0x0D, EINVAL },
{ 0x10, EECC },
- { 0x20, EHER },
+ { 0x20, EHER },
{ 0x31, ENXIO },
{ 0x32, ENXIO },
{ 0x00, EIO }
@@ -643,7 +645,7 @@ biosdisk_errno(u_int error)
{
register const struct biosdisk_errors *p;
- if (!error)
+ if (error == 0)
return 0;
for (p = tab; p->error && p->error != error; p++);
@@ -682,13 +684,14 @@ biosstrategy(void *devdata, int rw, daddr32_t blk, size_t size, void *buf,
if (rsize != NULL)
*rsize = nsect * DEV_BSIZE;
- return biosdisk_errno(error);
+ return (biosdisk_errno(error));
}
int
biosclose(struct open_file *f)
{
f->f_devdata = NULL;
+
return 0;
}
@@ -697,4 +700,3 @@ biosioctl(struct open_file *f, u_long cmd, void *data)
{
return 0;
}
-