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:
40
src/lpt.c
40
src/lpt.c
@@ -61,32 +61,50 @@ uint16_t lpt_addr[2] = { 0x378, 0x278 };
|
||||
|
||||
void lpt_init()
|
||||
{
|
||||
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);
|
||||
lpt_addr[0] = 0x378;
|
||||
lpt_addr[1] = 0x278;
|
||||
if (lpt_enabled)
|
||||
{
|
||||
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);
|
||||
lpt_addr[0] = 0x378;
|
||||
lpt_addr[1] = 0x278;
|
||||
}
|
||||
}
|
||||
|
||||
void lpt1_init(uint16_t port)
|
||||
{
|
||||
io_sethandler(port, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||
lpt_addr[0] = port;
|
||||
if (lpt_enabled)
|
||||
{
|
||||
io_sethandler(port, 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||
lpt_addr[0] = port;
|
||||
}
|
||||
}
|
||||
void lpt1_remove()
|
||||
{
|
||||
io_removehandler(lpt_addr[0], 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||
if (lpt_enabled)
|
||||
{
|
||||
io_removehandler(lpt_addr[0], 0x0003, lpt1_read, NULL, NULL, lpt1_write, NULL, NULL, NULL);
|
||||
}
|
||||
}
|
||||
void lpt2_init(uint16_t port)
|
||||
{
|
||||
io_sethandler(port, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
lpt_addr[1] = port;
|
||||
if (lpt_enabled)
|
||||
{
|
||||
io_sethandler(port, 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
lpt_addr[1] = port;
|
||||
}
|
||||
}
|
||||
void lpt2_remove()
|
||||
{
|
||||
io_removehandler(lpt_addr[1], 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
if (lpt_enabled)
|
||||
{
|
||||
io_removehandler(lpt_addr[1], 0x0003, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
void lpt2_remove_ams()
|
||||
{
|
||||
io_removehandler(0x0379, 0x0002, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
if (lpt_enabled)
|
||||
{
|
||||
io_removehandler(0x0379, 0x0002, lpt2_read, NULL, NULL, lpt2_write, NULL, NULL, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user