mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-20 15:43:16 +00:00
Add a truely evil workaround (hack!) for some unfortunate BIOS
programming practices. It seems that newer fdc chips have an alternative way of setting the transfer speed (including high speed modes for floppy tape) that doesn't use the control register (which we don't support - we use the old way only). So, they (the BIOS programmers) sometimes leave out the 0x3f6 control register from the PnP ports descriptor(!!). "Hey, it works with windows, so what's the problem?" :-( Anyway, this hack tries to compensate for that. This was discussed with dfr (who did the pnp attachment).
This commit is contained in:
parent
d0029cf5f3
commit
a2639a184d
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=54195
@ -640,13 +640,30 @@ fdc_probe(device_t dev)
|
|||||||
fdc->portt = rman_get_bustag(fdc->res_ioport);
|
fdc->portt = rman_get_bustag(fdc->res_ioport);
|
||||||
fdc->porth = rman_get_bushandle(fdc->res_ioport);
|
fdc->porth = rman_get_bushandle(fdc->res_ioport);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Some bios' report the device at 0x3f2-0x3f5,0x3f7 and some at
|
||||||
|
* 0x3f0-0x3f5,0x3f7. We detect the former by checking the size
|
||||||
|
* and adjust the port address accordingly.
|
||||||
|
*
|
||||||
|
* And some (!!) report 0x3f2-0x3f5 and completely leave out the
|
||||||
|
* control register! It seems that some non-antique controller chips
|
||||||
|
* have a different method of programming the transfer speed which
|
||||||
|
* doesn't require the control register, but it's mighty bogus as the
|
||||||
|
* chip still responds to the address for the control register.
|
||||||
|
* This hack is truely evil as we use the 6th port in a 4-port chunk.
|
||||||
|
*/
|
||||||
|
/* 0x3f2-0x3f5 */
|
||||||
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4 &&
|
||||||
|
bus_get_resource_count(dev, SYS_RES_IOPORT, 1) == 0) {
|
||||||
|
fdc->port_off = -2;
|
||||||
|
ispnp = 0; /* hack, don't reserve second port chunk */
|
||||||
|
}
|
||||||
|
/* 0x3f0-0x3f5 */
|
||||||
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 6 &&
|
||||||
|
bus_get_resource_count(dev, SYS_RES_IOPORT, 1) == 0) {
|
||||||
|
ispnp = 0; /* hack, don't reserve second port chunk */
|
||||||
|
}
|
||||||
if (ispnp) {
|
if (ispnp) {
|
||||||
/*
|
|
||||||
* Some bios' report the device at 0x3f2-0x3f5,0x3f7
|
|
||||||
* and some at 0x3f0-0x3f5,0x3f7. We detect the former
|
|
||||||
* by checking the size and adjust the port address
|
|
||||||
* accordingly.
|
|
||||||
*/
|
|
||||||
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4)
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4)
|
||||||
fdc->port_off = -2;
|
fdc->port_off = -2;
|
||||||
fdc->flags |= FDC_ISPNP;
|
fdc->flags |= FDC_ISPNP;
|
||||||
|
29
sys/isa/fd.c
29
sys/isa/fd.c
@ -640,13 +640,30 @@ fdc_probe(device_t dev)
|
|||||||
fdc->portt = rman_get_bustag(fdc->res_ioport);
|
fdc->portt = rman_get_bustag(fdc->res_ioport);
|
||||||
fdc->porth = rman_get_bushandle(fdc->res_ioport);
|
fdc->porth = rman_get_bushandle(fdc->res_ioport);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Some bios' report the device at 0x3f2-0x3f5,0x3f7 and some at
|
||||||
|
* 0x3f0-0x3f5,0x3f7. We detect the former by checking the size
|
||||||
|
* and adjust the port address accordingly.
|
||||||
|
*
|
||||||
|
* And some (!!) report 0x3f2-0x3f5 and completely leave out the
|
||||||
|
* control register! It seems that some non-antique controller chips
|
||||||
|
* have a different method of programming the transfer speed which
|
||||||
|
* doesn't require the control register, but it's mighty bogus as the
|
||||||
|
* chip still responds to the address for the control register.
|
||||||
|
* This hack is truely evil as we use the 6th port in a 4-port chunk.
|
||||||
|
*/
|
||||||
|
/* 0x3f2-0x3f5 */
|
||||||
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4 &&
|
||||||
|
bus_get_resource_count(dev, SYS_RES_IOPORT, 1) == 0) {
|
||||||
|
fdc->port_off = -2;
|
||||||
|
ispnp = 0; /* hack, don't reserve second port chunk */
|
||||||
|
}
|
||||||
|
/* 0x3f0-0x3f5 */
|
||||||
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 6 &&
|
||||||
|
bus_get_resource_count(dev, SYS_RES_IOPORT, 1) == 0) {
|
||||||
|
ispnp = 0; /* hack, don't reserve second port chunk */
|
||||||
|
}
|
||||||
if (ispnp) {
|
if (ispnp) {
|
||||||
/*
|
|
||||||
* Some bios' report the device at 0x3f2-0x3f5,0x3f7
|
|
||||||
* and some at 0x3f0-0x3f5,0x3f7. We detect the former
|
|
||||||
* by checking the size and adjust the port address
|
|
||||||
* accordingly.
|
|
||||||
*/
|
|
||||||
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4)
|
if (bus_get_resource_count(dev, SYS_RES_IOPORT, 0) == 4)
|
||||||
fdc->port_off = -2;
|
fdc->port_off = -2;
|
||||||
fdc->flags |= FDC_ISPNP;
|
fdc->flags |= FDC_ISPNP;
|
||||||
|
Loading…
Reference in New Issue
Block a user