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

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [sh/] [sh3/] [v2_0/] [include/] [mod_regs_ser.h] - Blame information for rev 174

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 27 unneback
//=============================================================================
2
//
3
//      mod_regs_ser.h
4
//
5
//      SCI, SCIF, and IRDA (serial) Module register definitions
6
//
7
//=============================================================================
8
//####ECOSGPLCOPYRIGHTBEGIN####
9
// -------------------------------------------
10
// This file is part of eCos, the Embedded Configurable Operating System.
11
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
12
//
13
// eCos is free software; you can redistribute it and/or modify it under
14
// the terms of the GNU General Public License as published by the Free
15
// Software Foundation; either version 2 or (at your option) any later version.
16
//
17
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
18
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
19
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
20
// for more details.
21
//
22
// You should have received a copy of the GNU General Public License along
23
// with eCos; if not, write to the Free Software Foundation, Inc.,
24
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
25
//
26
// As a special exception, if other files instantiate templates or use macros
27
// or inline functions from this file, or you compile this file and link it
28
// with other works to produce a work based on this file, this file does not
29
// by itself cause the resulting work to be covered by the GNU General Public
30
// License. However the source code for this file must still be made available
31
// in accordance with section (3) of the GNU General Public License.
32
//
33
// This exception does not invalidate any other reasons why a work based on
34
// this file might be covered by the GNU General Public License.
35
//
36
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
37
// at http://sources.redhat.com/ecos/ecos-license/
38
// -------------------------------------------
39
//####ECOSGPLCOPYRIGHTEND####
40
//=============================================================================
41
//#####DESCRIPTIONBEGIN####
42
//
43
// Author(s):   jskov
44
// Contributors:jskov
45
// Date:        2000-10-30
46
// Note:        All three serial module definitions kept in the same file
47
//              since they share some of the information.
48
//####DESCRIPTIONEND####
49
//
50
//=============================================================================
51
 
52
//++++++ Module SCI ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
53
 
54
//--------------------------------------------------------------------------
55
// Serial registers. All 8 bit registers.
56
#define CYGARC_REG_SCI_SCSMR                0xfffffe80 // serial mode register
57
#define CYGARC_REG_SCI_SCBRR                0xfffffe82 // bit rate register
58
#define CYGARC_REG_SCI_SCSCR                0xfffffe84 // serial control register
59
#define CYGARC_REG_SCI_SCTDR                0xfffffe86 // transmit data register
60
#define CYGARC_REG_SCI_SCSSR                0xfffffe88 // serial status register
61
#define CYGARC_REG_SCI_SCRDR                0xfffffe8a // receive data register
62
 
63
// Serial Mode Register
64
#define CYGARC_REG_SCI_SCSMR_CA             0x80 // communication mode
65
#define CYGARC_REG_SCI_SCSMR_CHR            0x40 // character length (7 if set)
66
#define CYGARC_REG_SCI_SCSMR_PE             0x20 // parity enable
67
#define CYGARC_REG_SCI_SCSMR_OE             0x10 // parity mode
68
#define CYGARC_REG_SCI_SCSMR_STOP           0x08 // stop bit length
69
#define CYGARC_REG_SCI_SCSMR_MP             0x04 // multiprocessor mode
70
#define CYGARC_REG_SCI_SCSMR_CKS1           0x02 // clock select 1
71
#define CYGARC_REG_SCI_SCSMR_CKS0           0x01 // clock select 0
72
#define CYGARC_REG_SCI_SCSMR_CKSx_MASK      0x03 // mask
73
 
74
// Serial Control Register
75
#define CYGARC_REG_SCI_SCSCR_TIE            0x80 // transmit interrupt enable
76
#define CYGARC_REG_SCI_SCSCR_RIE            0x40 // receive interrupt enable
77
#define CYGARC_REG_SCI_SCSCR_TE             0x20 // transmit enable
78
#define CYGARC_REG_SCI_SCSCR_RE             0x10 // receive enable
79
#define CYGARC_REG_SCI_SCSCR_MPIE           0x08 // multiprocessor interrupt enable
80
#define CYGARC_REG_SCI_SCSCR_TEIE           0x04 // transmit-end interrupt enable
81
#define CYGARC_REG_SCI_SCSCR_CKE1           0x02 // clock enable 1
82
#define CYGARC_REG_SCI_SCSCR_CKE0           0x01 // clock enable 0
83
 
84
// Serial Status Register
85
#define CYGARC_REG_SCI_SCSSR_TDRE           0x80 // transmit data register empty
86
#define CYGARC_REG_SCI_SCSSR_RDRF           0x40 // receive data register full
87
#define CYGARC_REG_SCI_SCSSR_ORER           0x20 // overrun error
88
#define CYGARC_REG_SCI_SCSSR_FER            0x10 // framing error
89
#define CYGARC_REG_SCI_SCSSR_PER            0x08 // parity error
90
#define CYGARC_REG_SCI_SCSSR_TEND           0x04 // transmit end
91
#define CYGARC_REG_SCI_SCSSR_MPB            0x02 // multiprocessor bit
92
#define CYGARC_REG_SCI_SCSSR_MPBT           0x01 // multiprocessor bit transfer
93
 
94
// When clearing the status register, always write the value:
95
// CYGARC_REG_SCSSR_CLEARMASK & ~bit
96
// to prevent other bits than the one of interest to be cleared.
97
#define CYGARC_REG_SCI_SCSSR_CLEARMASK      0xf8
98
 
99
 
100
#if (CYGARC_SH_MOD_SCI >= 2)
101
# define CYGARC_REG_SCI_SCSPTR               0xfffffe7c // serial port register
102
#endif
103
 
104
 
105
// Baud rate values calculation, depending on peripheral clock (Pf)
106
// n is CKS setting (0-3)
107
// N = (Pf/(64*2^(2n-1)*B))-1
108
// With CYGARC_SCBRR_CKSx providing the values 1, 4, 16, 64 we get
109
//       N = (Pf/(32*_CKS*B))-1
110
//
111
// The CYGARC_SCBRR_OPTIMAL_CKS macro should compute the minimal CKS
112
// setting for the given baud rate and peripheral clock.
113
//
114
// The error of the CKS+count value can be computed by:
115
//  E(%) = ((Pf/((N+1)*B*(64^(n-1)))-1)*100 
116
//
117
#define CYGARC_SCBRR_PRESCALE(_b_) \
118
((((CYGHWR_HAL_SH_ONCHIP_PERIPHERAL_SPEED/32/1/(_b_))-1)<256) ? 1 : \
119
 (((CYGHWR_HAL_SH_ONCHIP_PERIPHERAL_SPEED/32/4/(_b_))-1)<256) ? 4 : \
120
 (((CYGHWR_HAL_SH_ONCHIP_PERIPHERAL_SPEED/32/16/(_b_))-1)<256) ? 16 : 64)
121
 
122
// Add half the divisor to reduce rounding errors to .5
123
#define CYGARC_SCBRR_ROUNDING(_b_) \
124
  16*CYGARC_SCBRR_PRESCALE(_b_)*(_b_)
125
 
126
// These two macros provide the static values we need to stuff into the
127
// registers.
128
#define CYGARC_SCBRR_CKSx(_b_) \
129
    ((1 == CYGARC_SCBRR_PRESCALE(_b_)) ? 0 : \
130
     (4 == CYGARC_SCBRR_PRESCALE(_b_)) ? 1 : \
131
     (16 == CYGARC_SCBRR_PRESCALE(_b_)) ? 2 : 3)
132
#define CYGARC_SCBRR_N(_b_)     \
133
    (((_b_) < 4800) ? 0 :       \
134
      ((_b_) > 115200) ? 0 :    \
135
       (((CYGHWR_HAL_SH_ONCHIP_PERIPHERAL_SPEED+CYGARC_SCBRR_ROUNDING(_b_))/32/CYGARC_SCBRR_PRESCALE(_b_)/(_b_))-1))
136
 
137
 
138
//++++++ Module SCIF +++++++++++++++++++++++++++++++++++++++++++++++++++++++
139
#ifdef CYGARC_SH_MOD_SCIF
140
 
141
//--------------------------------------------------------------------------
142
// Serial w FIFO registers (and IRDA)
143
 
144
// SCIF1
145
#define CYGARC_REG_SCIF_SCSMR1               0xa4000140 // Serial mode          
146
#define CYGARC_REG_SCIF_SCBRR1               0xa4000142 // Bit rate             
147
#define CYGARC_REG_SCIF_SCSCR1               0xa4000144 // Serial control       
148
#define CYGARC_REG_SCIF_SCFTDR1              0xa4000146 // Transmit FIFO data   
149
#define CYGARC_REG_SCIF_SCSSR1               0xa4000148 // Serial status        
150
#define CYGARC_REG_SCIF_SCFRDR1              0xa400014a // Receive data FIFO    
151
#define CYGARC_REG_SCIF_SCFCR1               0xa400014c // FIFO control register
152
#define CYGARC_REG_SCIF_SCFDR1               0xa400014e // FIFO data count set
153
 
154
// SCIF2
155
#define CYGARC_REG_SCIF_SCSMR2               0xa4000150 // Serial mode
156
#define CYGARC_REG_SCIF_SCBRR2               0xa4000152 // Bit rate
157
#define CYGARC_REG_SCIF_SCSCR2               0xa4000154 // Serial control
158
#define CYGARC_REG_SCIF_SCFTDR2              0xa4000156 // Transmit FIFO data
159
#define CYGARC_REG_SCIF_SCSSR2               0xa4000158 // Serial status
160
#define CYGARC_REG_SCIF_SCFRDR2              0xa400015a // Receive data FIFO
161
#define CYGARC_REG_SCIF_SCFCR2               0xa400015c // FIFO control register
162
#define CYGARC_REG_SCIF_SCFDR2               0xa400015e // FIFO data count set
163
 
164
 
165
// Serial Mode Register - normal mode
166
#define CYGARC_REG_SCIF_SCSMR_CHR             0x40 // character length (7 if set)
167
#define CYGARC_REG_SCIF_SCSMR_PE              0x20 // parity enable
168
#define CYGARC_REG_SCIF_SCSMR_OE              0x10 // parity mode
169
#define CYGARC_REG_SCIF_SCSMR_STOP            0x08 // stop bit length
170
#define CYGARC_REG_SCIF_SCSMR_CKS1            0x02 // clock select 1
171
#define CYGARC_REG_SCIF_SCSMR_CKS0            0x01 // clock select 0
172
#define CYGARC_REG_SCIF_SCSMR_CKSx_MASK       0x03 // mask
173
 
174
// Serial Mode Register - IrDA mode alternative definitions
175
#define CYGARC_REG_SCIF_SCSMR_IRMOD           0x80 // IrDA Mode
176
#define CYGARC_REG_SCIF_SCSMR_ICK_MASK        0x78 // IR pulse width
177
#define CYGARC_REG_SCIF_SCSMR_PSEL            0x04 // IR pulse selector(?)
178
 
179
// Serial Control Register
180
#define CYGARC_REG_SCIF_SCSCR_TIE             0x80 // transmit interrupt enable
181
#define CYGARC_REG_SCIF_SCSCR_RIE             0x40 // receive interrupt enable
182
#define CYGARC_REG_SCIF_SCSCR_TE              0x20 // transmit enable
183
#define CYGARC_REG_SCIF_SCSCR_RE              0x10 // receive enable
184
#define CYGARC_REG_SCIF_SCSCR_CKE1            0x02 // clock enable 1
185
#define CYGARC_REG_SCIF_SCSCR_CKE0            0x01 // clock enable 0
186
 
187
// Serial Status Register
188
#define CYGARC_REG_SCIF_SCSSR_PER_MASK        0xf000 // number of parity errors
189
#define CYGARC_REG_SCIF_SCSSR_PER_shift       12
190
#define CYGARC_REG_SCIF_SCSSR_FER_MASK        0x0f00 // number of framing errors
191
#define CYGARC_REG_SCIF_SCSSR_FER_shift       8
192
#define CYGARC_REG_SCIF_SCSSR_ER              0x0080 // receive error
193
#define CYGARC_REG_SCIF_SCSSR_TEND            0x0040 // transmit end
194
#define CYGARC_REG_SCIF_SCSSR_TDFE            0x0020 // transmit fifo data empty
195
#define CYGARC_REG_SCIF_SCSSR_BRK             0x0010 // break detection
196
#define CYGARC_REG_SCIF_SCSSR_FER             0x0008 // framing error
197
#define CYGARC_REG_SCIF_SCSSR_PER             0x0004 // parity error
198
#define CYGARC_REG_SCIF_SCSSR_RDF             0x0002 // receive fifo data full
199
#define CYGARC_REG_SCIF_SCSSR_DR              0x0001 // receive data ready
200
 
201
// When clearing the status register, always write the value:
202
// CYGARC_REG_SCSSR_CLEARMASK & ~bit
203
// to prevent other bits than the one of interest to be cleared.
204
#define CYGARC_REG_SCIF_SCSSR_CLEARMASK       0x00f3
205
 
206
// Serial FIFO Control Register
207
#define CYGARC_REG_SCIF_SCFCR_RTRG_MASK       0xc0   // receive fifo data trigger
208
#define CYGARC_REG_SCIF_SCFCR_RTRG_1          0x00   // trigger on 1 char 
209
#define CYGARC_REG_SCIF_SCFCR_RTRG_4          0x40   // trigger on 4 chars
210
#define CYGARC_REG_SCIF_SCFCR_RTRG_8          0x80   // trigger on 8 chars
211
#define CYGARC_REG_SCIF_SCFCR_RTRG_14         0xc0   // trigger on 14 chars 
212
 
213
#define CYGARC_REG_SCIF_SCFCR_TTRG_MASK       0x30   // transmit fifo data trigger
214
#define CYGARC_REG_SCIF_SCFCR_TTRG_8          0x00   // trigger on 8 chars 
215
#define CYGARC_REG_SCIF_SCFCR_TTRG_4          0x10   // trigger on 4 chars
216
#define CYGARC_REG_SCIF_SCFCR_TTRG_2          0x20   // trigger on 2 chars
217
#define CYGARC_REG_SCIF_SCFCR_TTRG_1          0x30   // trigger on 1 char
218
 
219
#define CYGARC_REG_SCIF_SCFCR_MCE             0x08   // modem control enable
220
#define CYGARC_REG_SCIF_SCFCR_TFRST           0x04   // transmit fifo reset
221
#define CYGARC_REG_SCIF_SCFCR_RFRST           0x02   // receive fifo reset
222
#define CYGARC_REG_SCIF_SCFCR_LOOP            0x01   // loop back test
223
 
224
// Serial FIFO Data Count Set Register
225
#define CYGARC_REG_SCIF_SCFDR_RCOUNT_MASK    0x001f // number of chars in r fifo
226
#define CYGARC_REG_SCIF_SCFDR_RCOUNT_shift   0
227
#define CYGARC_REG_SCIF_SCFDR_TCOUNT_MASK    0x1f00 // number of chars in t fifo
228
#define CYGARC_REG_SCIF_SCFDR_TCOUNT_shift   8
229
 
230
#endif /* CYGARC_SH_MOD_SCIF */

powered by: WebSVN 2.1.0

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