serial_setup() in serial_old.c now returns without doing anything if the specified serial port is disabled in Settings, fixes ports being enabled where they shouldn't be on machines with Super I/O chips;
LPT code now takes the lpt_enabled variable into account at all levels.
This commit is contained in:
18
src/lpt.c
18
src/lpt.c
@@ -60,33 +60,51 @@ uint8_t lpt2_read(uint16_t port, void *priv)
|
|||||||
uint16_t lpt_addr[2] = { 0x378, 0x278 };
|
uint16_t lpt_addr[2] = { 0x378, 0x278 };
|
||||||
|
|
||||||
void lpt_init()
|
void lpt_init()
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_sethandler(0x0378, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
io_sethandler(0x0378, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||||
io_sethandler(0x0278, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
io_sethandler(0x0278, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||||
lpt_addr[0] = 0x378;
|
lpt_addr[0] = 0x378;
|
||||||
lpt_addr[1] = 0x278;
|
lpt_addr[1] = 0x278;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void lpt1_init(uint16_t port)
|
void lpt1_init(uint16_t port)
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_sethandler(port, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
io_sethandler(port, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||||
lpt_addr[0] = port;
|
lpt_addr[0] = port;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
void lpt1_remove()
|
void lpt1_remove()
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_removehandler(lpt_addr[0], 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
io_removehandler(lpt_addr[0], 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
void lpt2_init(uint16_t port)
|
void lpt2_init(uint16_t port)
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_sethandler(port, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
io_sethandler(port, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||||
lpt_addr[1] = port;
|
lpt_addr[1] = port;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
void lpt2_remove()
|
void lpt2_remove()
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_removehandler(lpt_addr[1], 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
io_removehandler(lpt_addr[1], 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void lpt2_remove_ams()
|
void lpt2_remove_ams()
|
||||||
|
{
|
||||||
|
if (lpt_enabled)
|
||||||
{
|
{
|
||||||
io_removehandler(0x0379, 0x0002, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
io_removehandler(0x0379, 0x0002, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -286,6 +286,10 @@ void serial_setup(int port, uint16_t addr, int irq)
|
|||||||
switch(port)
|
switch(port)
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
|
if (!serial_enabled[0])
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (base_address[0] != 0x0000)
|
if (base_address[0] != 0x0000)
|
||||||
{
|
{
|
||||||
serial_remove(port);
|
serial_remove(port);
|
||||||
@@ -298,6 +302,10 @@ void serial_setup(int port, uint16_t addr, int irq)
|
|||||||
serial1.irq = irq;
|
serial1.irq = irq;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
|
if (!serial_enabled[1])
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (base_address[1] != 0x0000)
|
if (base_address[1] != 0x0000)
|
||||||
{
|
{
|
||||||
serial_remove(port);
|
serial_remove(port);
|
||||||
|
|||||||
Reference in New Issue
Block a user