Use the combined accessors ioread8() and iowrite8() to read and write
16550 UART registers, to allow the decision between using MMIO and
port I/O to be made at runtime.
Minimise the increase in code size for x86 by ignoring the register
shift, since this is essentially used only for non-x86 SoCs.
Signed-off-by: Michael Brown <mcb30@ipxe.org>
ns16550_write ( struct ns16550_uart *ns16550, unsigned int address,
uint8_t data ) {
- outb ( data, ( ns16550->base + address ) );
+ iowrite8 ( data, ( ns16550->base + address ) );
}
/**
static inline __attribute__ (( always_inline )) uint8_t
ns16550_read ( struct ns16550_uart *ns16550, unsigned int address ) {
- return inb ( ns16550->base + address );
+ return ioread8 ( ns16550->base + address );
}
/* Fixed ISA serial port base addresses */
ns16550_write ( struct ns16550_uart *ns16550, unsigned int address,
uint8_t data ) {
- writeb ( data, ( ns16550->base + ( address << ns16550->shift ) ) );
+ iowrite8 ( data, ( ns16550->base + ( address << ns16550->shift ) ) );
}
/**
static inline __attribute__ (( always_inline )) uint8_t
ns16550_read ( struct ns16550_uart *ns16550, unsigned int address ) {
- return readb ( ns16550->base + ( address << ns16550->shift ) );
+ return ioread8 ( ns16550->base + ( address << ns16550->shift ) );
}
#endif /* _BITS_NS16550_H */