OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [branches/] [stable_0_2_x/] [or1ksim/] [peripheral/] [16450.h] - Blame information for rev 355

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 31 lampret
/* 16450.h -- Definition of types and structures for 8250/16450 serial UART
2
   Copyright (C) 2000 Damjan Lampret, lampret@opencores.org
3
 
4
This file is part of OpenRISC 1000 Architectural Simulator.
5
 
6
This program is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2 of the License, or
9
(at your option) any later version.
10
 
11
This program is distributed in the hope that it will be useful,
12
but WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
GNU General Public License for more details.
15
 
16
You should have received a copy of the GNU General Public License
17
along with this program; if not, write to the Free Software
18
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
19
 
20
/* Prototypes */
21
void uart_reset();
22
void uart_clock();
23
 
24 341 markom
/* Definitions */
25 355 markom
#define UART_ADDR_SPACE   (8)         /* UART memory address space size in bytes */
26 341 markom
#define UART_RX_BUF       (8192)      /* VAPI should not send more that this amout of char before requesting something back */
27
#define UART_MAX_FIFO_LEN (16)        /* rx FIFO for uart 16550 */
28 355 markom
#define MAX_SKEW          (1)         /* max. clock skew in subclocks */
29 341 markom
 
30 31 lampret
/* Registers */
31
 
32
struct dev_16450 {
33 355 markom
  struct {
34
    unsigned char txbuf[UART_MAX_FIFO_LEN];
35
    unsigned char rxbuf[UART_MAX_FIFO_LEN];
36
    unsigned char dll;
37
    unsigned char dlh;
38
    unsigned char ier;
39
    unsigned char iir;
40
    unsigned char lcr;
41
    unsigned char mcr;
42
    unsigned char lsr;
43
    unsigned char msr;
44
    unsigned char scr;
45
  } regs;   /* Visible registers */
46
  struct {
47
    unsigned long txser;    /* Character just sending */
48
    unsigned long rxser;    /* Character just receiving */
49
    unsigned char loopback;
50
  } iregs;  /* Internal registers */
51
  struct {
52
    int txbuf_head;
53
    int txbuf_tail;
54
    int rxbuf_head;
55
    int rxbuf_tail;
56
    unsigned int txser_full;
57
    unsigned int rxser_full;
58
    unsigned int txbuf_full;
59
    unsigned int rxbuf_full;
60
    unsigned char thre_int;
61
    unsigned long txser_clks;
62
    unsigned long rxser_clks;
63
  } istat;  /* Internal status */
64 341 markom
 
65 355 markom
  /* Clocks per char */
66
  unsigned long char_clks;
67 341 markom
 
68 355 markom
  /* VAPI internal registers */
69
  struct {
70
    unsigned long char_clks;
71
    int dll, dlh;
72
    int lcr;
73
    int skew;
74
  } vapi;
75
 
76
  /* Required by VAPI - circular buffer */
77
 unsigned long vapi_buf[UART_RX_BUF];  /* Buffer to store incoming characters to,
78
                                          since we cannot handle them so fast - we
79
                                          are serial */
80 341 markom
  int vapi_buf_head_ptr;               /* Where we write to */
81
  int vapi_buf_tail_ptr;               /* Where we read from */
82
 
83
  /* Length of FIFO, 16 for 16550, 1 for 16450 */
84
  int fifo_len;
85 355 markom
 
86
  /* Required by standard file streams */
87
  FILE * rxfs;
88
  FILE * txfs;
89 31 lampret
};
90
 
91
/*
92
 * Addresses of visible registers
93
 *
94
 */
95 355 markom
#define UART_RXBUF  0 /* R: Rx buffer, DLAB=0 */
96
#define UART_TXBUF  0 /* W: Tx buffer, DLAB=0 */
97
#define UART_DLL  0 /* R/W: Divisor Latch Low, DLAB=1 */
98
#define UART_DLH  1 /* R/W: Divisor Latch High, DLAB=1 */
99
#define UART_IER  1 /* R/W: Interrupt Enable Register */
100
#define UART_IIR  2 /* R: Interrupt ID Register */
101
#define UART_LCR  3 /* R/W: Line Control Register */
102
#define UART_MCR  4 /* W: Modem Control Register */
103
#define UART_LSR  5 /* R: Line Status Register */
104
#define UART_MSR  6 /* R: Modem Status Register */
105
#define UART_SCR  7 /* R/W: Scratch Register */
106 31 lampret
 
107
/*
108
 * R/W masks for valid bits in 8250/16450 (mask out 16550 and later bits)
109
 *
110
 */
111 355 markom
#define UART_VALID_LCR  0xff
112
#define UART_VALID_LSR  0x7f
113
#define UART_VALID_IIR  0x07
114
#define UART_VALID_IER  0x0f
115
#define UART_VALID_MCR  0x1f
116
#define UART_VALID_MSR  0xff
117 31 lampret
 
118
/*
119
 * Bit definitions for the Line Control Register
120
 *
121
 */
122 355 markom
#define UART_LCR_DLAB 0x80  /* Divisor latch access bit */
123
#define UART_LCR_SBC  0x40  /* Set break control */
124
#define UART_LCR_SPAR 0x20  /* Stick parity (?) */
125
#define UART_LCR_EPAR 0x10  /* Even parity select */
126
#define UART_LCR_PARITY 0x08  /* Parity Enable */
127
#define UART_LCR_STOP 0x04  /* Stop bits: 0=1 stop bit, 1= 2 stop bits */
128
#define UART_LCR_WLEN5  0x00  /* Wordlength: 5 bits */
129
#define UART_LCR_WLEN6  0x01  /* Wordlength: 6 bits */
130
#define UART_LCR_WLEN7  0x02  /* Wordlength: 7 bits */
131
#define UART_LCR_WLEN8  0x03  /* Wordlength: 8 bits */
132 344 markom
#define UART_LCR_RESET  0x03
133 31 lampret
/*
134
 * Bit definitions for the Line Status Register
135
 */
136 355 markom
#define UART_LSR_TXSERE 0x40  /* Transmitter serial register empty */
137
#define UART_LSR_TXBUFE 0x20  /* Transmitter buffer register empty */
138
#define UART_LSR_BREAK  0x10  /* Break interrupt indicator */
139
#define UART_LSR_FRAME  0x08  /* Frame error indicator */
140
#define UART_LSR_PARITY 0x04  /* Parity error indicator */
141
#define UART_LSR_OVRRUN 0x02  /* Overrun error indicator */
142
#define UART_LSR_RDRDY  0x01  /* Receiver data ready */
143 31 lampret
 
144
/*
145
 * Bit definitions for the Interrupt Identification Register
146
 */
147 355 markom
#define UART_IIR_NO_INT 0x01  /* No interrupts pending */
148
#define UART_IIR_ID 0x06  /* Mask for the interrupt ID */
149 31 lampret
 
150 355 markom
#define UART_IIR_MSI  0x00  /* Modem status interrupt (Low priority) */
151
#define UART_IIR_THRI 0x02  /* Transmitter holding register empty */
152
#define UART_IIR_RDI  0x04  /* Receiver data interrupt */
153
#define UART_IIR_RLSI 0x06  /* Receiver line status interrupt (High p.) */
154 31 lampret
 
155
/*
156
 * Bit definitions for the Interrupt Enable Register
157
 */
158 355 markom
#define UART_IER_MSI  0x08  /* Enable Modem status interrupt */
159
#define UART_IER_RLSI 0x04  /* Enable receiver line status interrupt */
160
#define UART_IER_THRI 0x02  /* Enable Transmitter holding register int. */
161
#define UART_IER_RDI  0x01  /* Enable receiver data interrupt */
162 31 lampret
 
163
/*
164
 * Bit definitions for the Modem Control Register
165
 */
166 355 markom
#define UART_MCR_LOOP 0x10  /* Enable loopback mode */
167
#define UART_MCR_AUX2 0x08  /* Auxilary 2  */
168
#define UART_MCR_AUX1 0x04  /* Auxilary 1 */
169
#define UART_MCR_RTS  0x02  /* Force RTS */
170
#define UART_MCR_DTR  0x01  /* Force DTR */
171 31 lampret
 
172
/*
173
 * Bit definitions for the Modem Status Register
174
 */
175 355 markom
#define UART_MSR_DCD  0x80  /* Data Carrier Detect */
176
#define UART_MSR_RI 0x40  /* Ring Indicator */
177
#define UART_MSR_DSR  0x20  /* Data Set Ready */
178
#define UART_MSR_CTS  0x10  /* Clear to Send */
179
#define UART_MSR_DDCD 0x08  /* Delta DCD */
180
#define UART_MSR_TERI 0x04  /* Trailing edge ring indicator */
181
#define UART_MSR_DDSR 0x02  /* Delta DSR */
182
#define UART_MSR_DCTS 0x01  /* Delta CTS */
183 31 lampret
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.