summaryrefslogtreecommitdiffstats
path: root/src/arch/x86/include/bits/ns16550.h
blob: dbb1cd51cf326ffaf1686d5a69a13388d5a5e828 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#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 */