blob: dbb1cd51cf326ffaf1686d5a69a13388d5a5e828 [file] [log] [blame]
#ifndef _BITS_NS16550_H
#define _BITS_NS16550_H
/** @file
*
* 16550-compatible UART
*
*/
FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
#include <stdint.h>
#include <ipxe/io.h>
/**
* Write to UART register
*
* @v ns16550 16550 UART
* @v address Register address
* @v data Data
*/
static inline __attribute__ (( always_inline )) void
ns16550_write ( struct ns16550_uart *ns16550, unsigned int address,
uint8_t data ) {
iowrite8 ( data, ( ns16550->base + address ) );
}
/**
* Read from UART register
*
* @v ns16550 16550 UART
* @v address Register address
* @ret data Data
*/
static inline __attribute__ (( always_inline )) uint8_t
ns16550_read ( struct ns16550_uart *ns16550, unsigned int address ) {
return ioread8 ( ns16550->base + address );
}
/* Fixed ISA serial port base addresses */
#define COM1_BASE 0x3f8
#define COM2_BASE 0x2f8
#define COM3_BASE 0x3e8
#define COM4_BASE 0x2e8
/* Fixed ISA serial ports */
extern struct uart com1;
extern struct uart com2;
extern struct uart com3;
extern struct uart com4;
/* Fixed ISA serial port names */
#define COM1 &com1
#define COM2 &com2
#define COM3 &com3
#define COM4 &com4
#endif /* _BITS_NS16550_H */