Subversion Repositories HelenOS

Rev

Rev 3234 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 3234 Rev 4046
Line 33... Line 33...
33
 */
33
 */
34
 
34
 
35
#ifndef KERN_mips32_SERIAL_H_
35
#ifndef KERN_mips32_SERIAL_H_
36
#define KERN_mips32_SERIAL_H_
36
#define KERN_mips32_SERIAL_H_
37
 
37
 
38
#include <console/chardev.h>
-
 
39
 
-
 
40
#define SERIAL_ADDRESS    0x98000000
38
#define SERIAL_ADDRESS    0x98000000
41
 
39
 
42
#define SERIAL_MAX        4
-
 
43
#define SERIAL_COM1       0x3f8
-
 
44
#define SERIAL_COM1_IRQ   4
-
 
45
#define SERIAL_COM2       0x2f8
-
 
46
#define SERIAL_COM2_IRQ   3
-
 
47
 
-
 
48
#define P_WRITEB(where, what)     (*((volatile char *) (SERIAL_ADDRESS + where)) = what)
-
 
49
#define P_READB(where)            (*((volatile char *) (SERIAL_ADDRESS + where)))
-
 
50
 
-
 
51
#define SERIAL_READ(x)            P_READB(x)
-
 
52
#define SERIAL_WRITE(x, c)        P_WRITEB(x, c)
-
 
53
 
-
 
54
/* Interrupt enable register */
-
 
55
#define SERIAL_READ_IER(x)              (P_READB((x) + 1))
-
 
56
#define SERIAL_WRITE_IER(x,c)           (P_WRITEB((x) + 1, c))
-
 
57
 
-
 
58
/* Interrupt identification register */
-
 
59
#define SERIAL_READ_IIR(x)             (P_READB((x) + 2))
-
 
60
 
-
 
61
/* Line status register */
-
 
62
#define SERIAL_READ_LSR(x)             (P_READB((x) + 5))
-
 
63
#define TRANSMIT_EMPTY_BIT      5          
-
 
64
 
-
 
65
typedef struct {
-
 
66
    int port;
-
 
67
    int irq;
-
 
68
}serial_t;
-
 
69
 
-
 
70
extern void serial_console(devno_t devno);
-
 
71
extern int serial_init(void);
-
 
72
 
-
 
73
#endif
40
#endif
74
 
41
 
75
/** @}
42
/** @}
76
 */
43
 */