59 lines
1.3 KiB
C
59 lines
1.3 KiB
C
|
#ifndef DEVICE_PNP_H
|
||
|
#define DEVICE_PNP_H
|
||
|
|
||
|
static inline void pnp_write_config(unsigned char port, unsigned char value, unsigned char reg)
|
||
|
{
|
||
|
outb(reg, port);
|
||
|
outb(value, port +1);
|
||
|
}
|
||
|
|
||
|
static inline unsigned char pnp_read_config(unsigned char port, unsigned char reg)
|
||
|
{
|
||
|
outb(reg, port);
|
||
|
return inb(port +1);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_logical_device(unsigned char port, int device)
|
||
|
{
|
||
|
pnp_write_config(port, device, 0x07);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_enable(unsigned char port, int enable)
|
||
|
{
|
||
|
pnp_write_config(port, enable?0x1:0x0, 0x30);
|
||
|
}
|
||
|
|
||
|
static inline int pnp_read_enable(unsigned char port)
|
||
|
{
|
||
|
return !!pnp_read_config(port, 0x30);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_iobase0(unsigned char port, unsigned iobase)
|
||
|
{
|
||
|
pnp_write_config(port, (iobase >> 8) & 0xff, 0x60);
|
||
|
pnp_write_config(port, iobase & 0xff, 0x61);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_iobase1(unsigned char port, unsigned iobase)
|
||
|
{
|
||
|
pnp_write_config(port, (iobase >> 8) & 0xff, 0x62);
|
||
|
pnp_write_config(port, iobase & 0xff, 0x63);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_irq0(unsigned char port, unsigned irq)
|
||
|
{
|
||
|
pnp_write_config(port, irq, 0x70);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_irq1(unsigned char port, unsigned irq)
|
||
|
{
|
||
|
pnp_write_config(port, irq, 0x72);
|
||
|
}
|
||
|
|
||
|
static inline void pnp_set_drq(unsigned char port, unsigned drq)
|
||
|
{
|
||
|
pnp_write_config(port, drq & 0xff, 0x74);
|
||
|
}
|
||
|
|
||
|
#endif /* DEVICE_PNP_H */
|