summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorFederico G. Schwindt <fgsch@cvs.openbsd.org>2000-06-06 01:02:27 +0000
committerFederico G. Schwindt <fgsch@cvs.openbsd.org>2000-06-06 01:02:27 +0000
commit63eb81b817a1ef8e807bba9df5d0088cb67e18ae (patch)
tree2332a0acc4f63af5b55106bede1a37463d1bee31 /sys
parent3989c32b7df6b7530d715b338d6948edb1d17d3b (diff)
* correct some length checkings based on the specs; still a few to fix.
* add 1 to number of memspaces since MS_COUNT it's minus 1. * print the correct function type in case of IOBUS. * clean cfe->flags if intface is present
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pcmcia/pcmcia_cis.c37
1 files changed, 25 insertions, 12 deletions
diff --git a/sys/dev/pcmcia/pcmcia_cis.c b/sys/dev/pcmcia/pcmcia_cis.c
index fc1866f068a..fea548a7aa0 100644
--- a/sys/dev/pcmcia/pcmcia_cis.c
+++ b/sys/dev/pcmcia/pcmcia_cis.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcmcia_cis.c,v 1.4 2000/05/29 21:39:06 fgsch Exp $ */
+/* $OpenBSD: pcmcia_cis.c,v 1.5 2000/06/06 01:02:26 fgsch Exp $ */
/* $NetBSD: pcmcia_cis.c,v 1.9 1998/08/22 23:41:48 msaitoh Exp $ */
/*
@@ -260,15 +260,16 @@ pcmcia_scan_cis(dev, fct, arg)
}
break;
case PCMCIA_CISTPL_LONGLINK_MFC:
- if (tuple.length < 1) {
+ if (tuple.length < 6) {
DPRINTF(("CISTPL_LONGLINK_MFC too "
"short %d\n", tuple.length));
break;
}
- /*
- * this is kind of ad hoc, as I don't have
- * any real documentation
- */
+ if (((tuple.length - 1) % 5) != 0) {
+ DPRINTF(("CISTPL_LONGLINK_MFC bogus "
+ "length %d\n", tuple.length));
+ break;
+ }
{
int i;
@@ -450,7 +451,8 @@ pcmcia_print_cis(sc)
else if (card->cis1_minor == 1)
printf("PCMCIA 2.0 or 2.1\n");
} else if (card->cis1_major >= 5)
- printf("PC Card Standard %d.%d\n", card->cis1_major, card->cis1_minor);
+ printf("PC Card Standard %d.%d\n", card->cis1_major,
+ card->cis1_minor);
else
printf("unknown (major=%d, minor=%d)\n",
card->cis1_major, card->cis1_minor);
@@ -509,6 +511,9 @@ pcmcia_print_cis(sc)
case PCMCIA_FUNCTION_INSTRUMENT:
printf("Instrument");
break;
+ case PCMCIA_FUNCTION_IOBUS:
+ printf("Serial I/O Bus Adapter");
+ break;
default:
printf("unknown (%d)", pf->function);
break;
@@ -766,7 +771,7 @@ pcmcia_parse_cis_tuple(tuple, arg)
break;
case PCMCIA_CISTPL_FUNCID:
- if (tuple->length < 1) {
+ if (tuple->length < 2) {
DPRINTF(("CISTPL_FUNCID too short %d\n",
tuple->length));
break;
@@ -812,7 +817,7 @@ pcmcia_parse_cis_tuple(tuple, arg)
break;
case PCMCIA_CISTPL_CONFIG:
- if (tuple->length < 3) {
+ if (tuple->length < 5) {
DPRINTF(("CISTPL_CONFIG too short %d\n",
tuple->length));
break;
@@ -872,7 +877,11 @@ pcmcia_parse_cis_tuple(tuple, arg)
break;
case PCMCIA_CISTPL_CFTABLE_ENTRY:
- {
+ if (tuple->length < 2) {
+ DPRINTF(("CISTPL_CFTABLE_ENTRY too short %d\n",
+ tuple->length));
+ break;
+ } {
int idx, i, j;
u_int reg, reg2;
u_int intface, def, num;
@@ -957,6 +966,10 @@ pcmcia_parse_cis_tuple(tuple, arg)
if (intface) {
reg = pcmcia_tuple_read_1(tuple, idx);
idx++;
+ cfe->flags &= ~(PCMCIA_CFE_MWAIT_REQUIRED
+ | PCMCIA_CFE_RDYBSY_ACTIVE
+ | PCMCIA_CFE_WP_ACTIVE
+ | PCMCIA_CFE_BVD_ACTIVE);
if (reg & PCMCIA_TPCE_IF_MWAIT)
cfe->flags |= PCMCIA_CFE_MWAIT_REQUIRED;
if (reg & PCMCIA_TPCE_IF_RDYBSY)
@@ -1164,8 +1177,8 @@ pcmcia_parse_cis_tuple(tuple, arg)
reg = pcmcia_tuple_read_1(tuple, idx);
idx++;
- cfe->num_memspace = reg &
- PCMCIA_TPCE_MS_COUNT;
+ cfe->num_memspace = (reg &
+ PCMCIA_TPCE_MS_COUNT) + 1;
if (cfe->num_memspace >
(sizeof(cfe->memspace) /