]> git.kernelconcepts.de Git - karo-tx-redboot.git/blob - packages/devs/serial/powerpc/quicc/v2_0/src/quicc_smc_serial.h
Initial revision
[karo-tx-redboot.git] / packages / devs / serial / powerpc / quicc / v2_0 / src / quicc_smc_serial.h
1 #ifndef CYGONCE_POWERPC_QUICC_SMC_SERIAL_H
2 #define CYGONCE_POWERPC_QUICC_SMC_SERIAL_H
3
4 // ====================================================================
5 //
6 //      quicc_smc_serial.h
7 //
8 //      Device I/O - Description of PowerPC QUICC/SMC serial hardware
9 //
10 // ====================================================================
11 //####ECOSGPLCOPYRIGHTBEGIN####
12 // -------------------------------------------
13 // This file is part of eCos, the Embedded Configurable Operating System.
14 // Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
15 // Copyright (C) 2003 Gary Thomas
16 //
17 // eCos is free software; you can redistribute it and/or modify it under
18 // the terms of the GNU General Public License as published by the Free
19 // Software Foundation; either version 2 or (at your option) any later version.
20 //
21 // eCos is distributed in the hope that it will be useful, but WITHOUT ANY
22 // WARRANTY; without even the implied warranty of MERCHANTABILITY or
23 // FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
24 // for more details.
25 //
26 // You should have received a copy of the GNU General Public License along
27 // with eCos; if not, write to the Free Software Foundation, Inc.,
28 // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
29 //
30 // As a special exception, if other files instantiate templates or use macros
31 // or inline functions from this file, or you compile this file and link it
32 // with other works to produce a work based on this file, this file does not
33 // by itself cause the resulting work to be covered by the GNU General Public
34 // License. However the source code for this file must still be made available
35 // in accordance with section (3) of the GNU General Public License.
36 //
37 // This exception does not invalidate any other reasons why a work based on
38 // this file might be covered by the GNU General Public License.
39 //
40 // Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
41 // at http://sources.redhat.com/ecos/ecos-license/
42 // -------------------------------------------
43 //####ECOSGPLCOPYRIGHTEND####
44 // ====================================================================
45 //#####DESCRIPTIONBEGIN####
46 //
47 // Author(s):           gthomas
48 // Contributors:        gthomas
49 // Date:                1999-06-21
50 // Purpose:     Internal interfaces for serial I/O drivers
51 // Description:
52 //
53 //####DESCRIPTIONEND####
54 //
55 // ====================================================================
56
57 // Description of serial ports using QUICC/SMC
58
59 #include <cyg/hal/quicc/ppc8xx.h>                  // QUICC structure definitions
60
61 static unsigned int smc_select_word_length[] = {
62     QUICC_SMCMR_CLEN(5),  // 5 bits / word (char)
63     QUICC_SMCMR_CLEN(6),
64     QUICC_SMCMR_CLEN(7),
65     QUICC_SMCMR_CLEN(8)
66 };
67
68 static unsigned int smc_select_stop_bits[] = {
69     0, 
70     QUICC_SMCMR_SB(1),   // 1 stop bit
71     QUICC_SMCMR_SB(1),   // 1.5 stop bit
72     QUICC_SMCMR_SB(2)    // 2 stop bits
73 };
74
75 static unsigned int smc_select_parity[] = {
76     QUICC_SMCMR_PE(0),                     // No parity
77     QUICC_SMCMR_PE(1)|QUICC_SMCMR_PM(1),   // Even parity
78     QUICC_SMCMR_PE(1)|QUICC_SMCMR_PM(0),   // Odd parity
79     0,                                     // Mark parity
80     0,                                     // Space parity
81 };
82
83 static unsigned int scc_select_word_length[] = {
84   QUICC_SCC_PSMR_CLEN(5),  // 5 bits / word (char)
85   QUICC_SCC_PSMR_CLEN(6),
86   QUICC_SCC_PSMR_CLEN(7),
87   QUICC_SCC_PSMR_CLEN(8)
88 };
89
90 static unsigned int scc_select_stop_bits[] = {
91   QUICC_SCC_PSMR_SB(1),   // 0.5 stop bit ??
92   QUICC_SCC_PSMR_SB(1),   // 1   stop bit
93   QUICC_SCC_PSMR_SB(2),   // 1.5 stop bit
94   QUICC_SCC_PSMR_SB(2)    // 2   stop bits
95 };
96
97
98 static unsigned int scc_select_parity[] = {
99   QUICC_SCC_PSMR_PE(0),                                               // No parity
100   QUICC_SCC_PSMR_PE(1)|QUICC_SCC_PSMR_TPM(2)|QUICC_SCC_PSMR_RPM(2), // Even parity
101   QUICC_SCC_PSMR_PE(1)|QUICC_SCC_PSMR_TPM(0)|QUICC_SCC_PSMR_RPM(0), // Odd parity
102   QUICC_SCC_PSMR_PE(1)|QUICC_SCC_PSMR_TPM(3)|QUICC_SCC_PSMR_RPM(3), // High (mark) parity
103   QUICC_SCC_PSMR_PE(1)|QUICC_SCC_PSMR_TPM(1)|QUICC_SCC_PSMR_RPM(1), // Low (space) parity
104 };
105
106 // Baud rate values, based on board clock
107
108 static cyg_int32 select_baud[] = {
109     0,      // Unused
110     50,     // 50
111     75,     // 75
112     110,    // 110
113     0,      // 134.5
114     150,    // 150
115     200,    // 200
116     300,    // 300
117     600,    // 600
118     1200,   // 1200
119     1800,   // 1800
120     2400,   // 2400
121     3600,   // 3600
122     4800,   // 4800
123     7200,   // 7200
124     9600,   // 9600
125     14400,  // 14400
126     19200,  // 19200
127     38400,  // 38400
128     57600,  // 57600
129     115200, // 115200
130     0,      // 230400
131 };
132
133 #define UART_BITRATE(n) ((((int)(CYGHWR_HAL_POWERPC_BOARD_SPEED*1000000)/16)/n)-1)
134 #define UART_SLOW_BITRATE(n) ((int)(CYGHWR_HAL_POWERPC_BOARD_SPEED*1000000)/n))
135
136 // Channel type select
137 #define _SCC_CHAN 0
138 #define _SMC_CHAN 1
139
140 #endif // CYGONCE_POWERPC_QUICC_SMC_SERIAL_H