summaryrefslogtreecommitdiff
path: root/sys/dev/isa
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/isa')
-rw-r--r--sys/dev/isa/opti.c158
1 files changed, 105 insertions, 53 deletions
diff --git a/sys/dev/isa/opti.c b/sys/dev/isa/opti.c
index b71cf1a1fd3..fac35d21424 100644
--- a/sys/dev/isa/opti.c
+++ b/sys/dev/isa/opti.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: opti.c,v 1.4 1996/05/27 07:57:09 deraadt Exp $ */
+/* $OpenBSD: opti.c,v 1.5 1996/10/16 12:32:48 deraadt Exp $ */
/*
* Copyright (c) 1996 Michael Shalayeff
@@ -62,43 +62,73 @@ int opti_type = OPTI_C929; /* XXX only one card can be installed */
#define OPTI_cd_valid_ift(i) ((i)==OPTI_SONY||(i)==OPTI_PANASONIC||\
(i)==OPTI_MITSUMI||(i)==OPTI_IDE)
+
+static __inline int OPTI_cd_addr __P((int));
+static __inline int OPTI_cd_irq __P((int));
+static __inline int OPTI_cd_drq __P((int));
+static __inline int OPTI_snd_addr __P((int));
+static __inline int OPTI_snd_irq __P((int));
+static __inline int OPTI_snd_drq __P((int));
+static __inline void opti_outb __P((u_short, u_char));
+static __inline u_char opti_inb __P((u_short));
+static int opti_present __P((void));
+
static __inline int
OPTI_cd_addr(a)
int a;
{
switch(a) {
- case 0x320: return 0xc0;
- case 0x330: return 0x40;
- case 0x340: return 0x00;
- case 0x360: return 0x80;
- default: return -1;
+ case 0x320:
+ return 0xc0;
+ case 0x330:
+ return 0x40;
+ case 0x340:
+ return 0x00;
+ case 0x360:
+ return 0x80;
+ default:
+ return -1;
}
}
+
static __inline int
OPTI_cd_irq(i)
int i;
{
switch(i) {
- case 5: return 0x04;
- case 7: return 0x08;
- case 3: return 0x0c;
- case 9: return 0x10;
- case 10:return 0x14;
- case 11:return 0x18;
- case -1:return 0x00;
- default:return -1;
+ case 5:
+ return 0x04;
+ case 7:
+ return 0x08;
+ case 3:
+ return 0x0c;
+ case 9:
+ return 0x10;
+ case 10:
+ return 0x14;
+ case 11:
+ return 0x18;
+ case -1:
+ return 0x00;
+ default:
+ return -1;
}
}
+
static __inline int
OPTI_cd_drq(d)
int d;
{
switch(d) {
- case 3:
- case 5: return 0;
- case 6: return 1;
- case 7: return 2;
- default:return 3;
+ case 3:
+ case 5:
+ return 0;
+ case 6:
+ return 1;
+ case 7:
+ return 2;
+ default:
+ return 3;
}
}
@@ -109,59 +139,83 @@ OPTI_snd_addr(a)
int a;
{
switch(a) {
- case 0x220: return 0x0;
- case 0x240: return 0x3;
- case 0x530: return 0x8;
- case 0xE80: return 0x9;
- case 0xF40: return 0xa;
- case 0x604: return 0xb;
- default: return -1;
+ case 0x220:
+ return 0x0;
+ case 0x240:
+ return 0x3;
+ case 0x530:
+ return 0x8;
+ case 0xE80:
+ return 0x9;
+ case 0xF40:
+ return 0xa;
+ case 0x604:
+ return 0xb;
+ default:
+ return -1;
}
}
+
static __inline int
OPTI_snd_irq(i)
int i;
{
switch(i) {
- case 5: return 0x04;
- case 7: return 0x08;
- case 3: return 0x0c;
- case 9: return 0x10;
- case 10:return 0x14;
- case 11:return 0x18;
- case -1:return 0x00;
- default:return -1;
+ case 5:
+ return 0x04;
+ case 7:
+ return 0x08;
+ case 3:
+ return 0x0c;
+ case 9:
+ return 0x10;
+ case 10:
+ return 0x14;
+ case 11:
+ return 0x18;
+ case -1:
+ return 0x00;
+ default:
+ return -1;
}
}
+
static __inline int
OPTI_snd_drq(d)
int d;
{
switch(d) {
- case 3:
- case 5: return 0;
- case 6: return 1;
- case 7: return 2;
- default:return 3;
+ case 3:
+ case 5:
+ return 0;
+ case 6:
+ return 1;
+ case 7:
+ return 2;
+ default:
+ return 3;
}
}
static __inline void
-opti_outb( u_short port, u_char byte )
+opti_outb(port, byte)
+ u_short port;
+ u_char byte;
{
outb( OPTI_PASSWD, opti_type );
outb( port, byte );
}
static __inline u_char
-opti_inb( u_short port )
+opti_inb(port)
+ u_short port;
{
outb( OPTI_PASSWD, opti_type );
return inb( port );
}
static int
-opti_present( void )
+opti_present()
{
register u_char a, b;
int s = splhigh();
@@ -186,7 +240,7 @@ opti_present( void )
}
int
-opti_cd_setup( ift, addr, irq, drq )
+opti_cd_setup(ift, addr, irq, drq)
int ift, addr, irq, drq;
{
int ret = 0;
@@ -204,8 +258,7 @@ opti_cd_setup( ift, addr, irq, drq )
XDEBUG( 2, ("opti: wrong CD-ROM irq number.\n"));
else if( OPTI_cd_drq(drq) == -1)
XDEBUG( 2, ("opti: bad CD_ROM drq number.\n"));
- else
- {
+ else {
/* so the setup */
int s = splhigh();
register u_char a, b;
@@ -252,7 +305,7 @@ opti_cd_setup( ift, addr, irq, drq )
}
int
-opti_snd_setup( ift, addr, irq, drq )
+opti_snd_setup(ift, addr, irq, drq)
int ift, addr, irq, drq;
{
XDEBUG( 2, ("opti: do SND setup type=%u,addr=%x,irq=%d,drq=%d\n",
@@ -268,17 +321,16 @@ opti_snd_setup( ift, addr, irq, drq )
XDEBUG( 2, ("opti: wrong SND irq number.\n"));
else if( OPTI_snd_drq(drq) == -1)
XDEBUG( 2, ("opti: bad SND drq number.\n"));
- else
- {
+ else {
/* so the setup */
int s = splhigh();
- register u_char a, b;
+ register u_char a;
if (ift == OPTI_WSS) {
- a = opti_inb( OPTI_IFTP );
- opti_outb( OPTI_IFTP, (a & ~OPTI_SND_MASK)
- | OPTI_snd_addr(addr)*16 + 1 );
- opti_outb( OPTI_ENBL, 0x1a );
+ a = opti_inb(OPTI_IFTP);
+ opti_outb(OPTI_IFTP, ((a & ~OPTI_SND_MASK)
+ | (OPTI_snd_addr(addr)*16)) + 1);
+ opti_outb(OPTI_ENBL, 0x1a);
}
splx(s);