diff options
| author | Bruce Evans <bde@FreeBSD.org> | 2000-01-29 03:02:55 +0000 |
|---|---|---|
| committer | Bruce Evans <bde@FreeBSD.org> | 2000-01-29 03:02:55 +0000 |
| commit | 689315d4f74ad41c763629e95a20593155df8249 (patch) | |
| tree | 83f63d25732a6e22e49bb8cb839b606c35b643c9 | |
| parent | e225ecbbd4092b7e37aaa3ce55492fbfc3813c70 (diff) | |
Notes
| -rw-r--r-- | sys/dev/sio/sio.c | 9 | ||||
| -rw-r--r-- | sys/isa/sio.c | 9 |
2 files changed, 16 insertions, 2 deletions
diff --git a/sys/dev/sio/sio.c b/sys/dev/sio/sio.c index 4fcc02af4dc7..a409a55a7074 100644 --- a/sys/dev/sio/sio.c +++ b/sys/dev/sio/sio.c @@ -677,6 +677,7 @@ sioprobe(dev) if (COM_LLCONSOLE(flags)) { printf("sio%d: reserved for low-level i/o\n", device_get_unit(dev)); + bus_release_resource(dev, SYS_RES_IOPORT, rid, port); return (ENXIO); } @@ -1048,7 +1049,13 @@ sioattach(dev) if (siosetwater(com, com->it_in.c_ispeed) != 0) { enable_intr(); free(com, M_DEVBUF); - return (ENXIO); + /* + * Leave i/o resources allocated if this is a `cn'-level + * console, so that other devices can't snarf them. + */ + if (iobase != siocniobase) + bus_release_resource(dev, SYS_RES_IOPORT, rid, port); + return (ENOMEM); } enable_intr(); termioschars(&com->it_in); diff --git a/sys/isa/sio.c b/sys/isa/sio.c index 4fcc02af4dc7..a409a55a7074 100644 --- a/sys/isa/sio.c +++ b/sys/isa/sio.c @@ -677,6 +677,7 @@ sioprobe(dev) if (COM_LLCONSOLE(flags)) { printf("sio%d: reserved for low-level i/o\n", device_get_unit(dev)); + bus_release_resource(dev, SYS_RES_IOPORT, rid, port); return (ENXIO); } @@ -1048,7 +1049,13 @@ sioattach(dev) if (siosetwater(com, com->it_in.c_ispeed) != 0) { enable_intr(); free(com, M_DEVBUF); - return (ENXIO); + /* + * Leave i/o resources allocated if this is a `cn'-level + * console, so that other devices can't snarf them. + */ + if (iobase != siocniobase) + bus_release_resource(dev, SYS_RES_IOPORT, rid, port); + return (ENOMEM); } enable_intr(); termioschars(&com->it_in); |
