diff options
author | Christopher Pascoe <pascoe@cvs.openbsd.org> | 2005-08-02 21:49:47 +0000 |
---|---|---|
committer | Christopher Pascoe <pascoe@cvs.openbsd.org> | 2005-08-02 21:49:47 +0000 |
commit | ec3e9c3500c4e4fa5796005153bfbcffc6f50560 (patch) | |
tree | eb28d085d328b541064b0bb10bb6a76d9b0cfed9 /sys | |
parent | b3b3413c24dfd8a2dd8ad5248de327dc94736913 (diff) |
kill 2kB stack offender in cardbus_attach_card.
ok deraadt fgsch
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/cardbus/cardbus.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/sys/dev/cardbus/cardbus.c b/sys/dev/cardbus/cardbus.c index f63b86a2e30..4adfdb3a012 100644 --- a/sys/dev/cardbus/cardbus.c +++ b/sys/dev/cardbus/cardbus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cardbus.c,v 1.20 2005/05/28 19:46:07 jsg Exp $ */ +/* $OpenBSD: cardbus.c,v 1.21 2005/08/02 21:49:46 pascoe Exp $ */ /* $NetBSD: cardbus.c,v 1.24 2000/04/02 19:11:37 mycroft Exp $ */ /* @@ -385,7 +385,7 @@ cardbus_attach_card(sc) cardbustag_t tag; cardbusreg_t id, class, cis_ptr; cardbusreg_t bhlc; - u_int8_t tuple[2048]; + u_int8_t *tuple; int function, nfunction; struct cardbus_devfunc **previous_next = &(sc->sc_funcs); struct device *csc; @@ -438,6 +438,11 @@ cardbus_attach_card(sc) DPRINTF(("%s bhlc 0x%08x -> ", sc->sc_dev.dv_xname, bhlc)); nfunction = CARDBUS_HDRTYPE_MULTIFN(bhlc) ? 8 : 1; + tuple = malloc(2048, M_TEMP, M_NOWAIT); + if (tuple == NULL) { + panic("no room for cardbus tuples"); + } + for(function = 0; function < nfunction; function++) { struct cardbus_attach_args ca; @@ -527,7 +532,7 @@ cardbus_attach_card(sc) ca.ca_intrline = sc->sc_intrline; if (cis_ptr != 0) { - if(cardbus_read_tuples(&ca, cis_ptr, tuple, sizeof(tuple))) { + if(cardbus_read_tuples(&ca, cis_ptr, tuple, 2048)) { printf("cardbus_attach_card: failed to read CIS\n"); } else { #ifdef CARDBUS_DEBUG @@ -554,6 +559,7 @@ cardbus_attach_card(sc) * if no functions were attached). */ disable_function(sc, 8); + free(tuple, M_TEMP); return no_work_funcs; } |