OSDN Git Service

v205
[fast-forth/master.git] / TERMINALBAUDRATE.asm
1
2 ; TERM alias eUSCI_Ax : select baudrate versus frequency
3     .IF FREQUENCY = 0.25
4         .SWITCH TERMINALBAUDRATE
5
6         .CASE 9600
7 ; Configure UART_TERM @ 38400 bauds / 1MHz
8 ; N=1000000/38400=26.04166... ==> UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=10, UCBRS0= fn(frac(N))=fn(0.04166)=0x00
9 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
10             MOV     #1,    &TERMBRW
11             MOV.W   #00A1h, &TERMMCTLW
12
13         .CASE 19200  ; PL2303TA baudrate
14 ; Configure UART_TERM @ 38400 bauds / 500kHz
15 ; N=500000/38400=13.20833 ==> UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.20833)=0x11
16 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
17             MOV     #13,     &TERMBRW
18             MOV.W   #1100h,&TERMMCTLW
19
20         .CASE 31250  ; MIDI interface
21 ; Configure UART_TERM @ 31250 bauds / 250kHz
22 ; N=250000/31250=8 ==> UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0)=0
23 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
24             MOV     #8,     &TERMBRW
25             MOV.W   #0000h,&TERMMCTLW
26
27         .CASE 38400
28 ; Configure UART_TERM @ 38400 bauds / 250kHz
29 ; N=250000/38400=6.5124166... ==> UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.512416)=0xAA
30 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
31             MOV     #6,     &TERMBRW
32             MOV.W   #0AA00h,&TERMMCTLW
33
34         .CASE 57600  ; PL2303TA baudrate
35 ; Configure UART_TERM @ 57600 bauds / 250kHz
36 ; N=250000/57600=4.340277.. ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.340277)=0x49
37 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
38             MOV     #4,     &TERMBRW
39             MOV.W   #04900h,&TERMMCTLW
40
41         .ELSECASE
42             .error "UART_TERM / 250 kHz : baudrate not implemented"
43         .ENDCASE
44
45
46     .ELSEIF FREQUENCY = 0.5
47         .SWITCH TERMINALBAUDRATE
48         .CASE 9600
49 ; Configure UART_TERM @ 19200 bauds / 1MHz
50 ; N=1000000/19200=52.0833... ==> UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(0.0833)=0x02
51 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
52             MOV     #3,    &TERMBRW
53             MOV.W   #0241h,&TERMMCTLW
54
55         .CASE 19200
56 ; Configure UART_TERM @ 38400 bauds / 1MHz
57 ; N=1000000/38400=26.04166... ==> UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=10, UCBRS0= fn(frac(N))=fn(0.04166)=0x00
58 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
59             MOV     #1,    &TERMBRW
60             MOV.W   #00A1h, &TERMMCTLW
61
62         .CASE 31250  ; MIDI interface
63 ; Configure UART_TERM @ 31250 bauds / 500kHz
64 ; N=500000/31250=16 ==> UCOS16=0, UCBR0=int(N)=16, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0)=0
65 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
66             MOV     #16,     &TERMBRW
67             MOV.W   #0000h,&TERMMCTLW
68
69         .CASE 38400  ; PL2303TA baudrate
70 ; Configure UART_TERM @ 38400 bauds / 500kHz
71 ; N=500000/38400=13.20833 ==> UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.20833)=0x11
72 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
73             MOV     #13,     &TERMBRW
74             MOV.W   #1100h,&TERMMCTLW
75
76         .CASE 57600
77 ; Configure UART_TERM @ 115200 bauds / 1MHz
78 ; N=1000000/115200=8.68055... ==> UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.68055)=0xD6
79 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
80             MOV     #8,     &TERMBRW
81             MOV.W   #0D600h,&TERMMCTLW
82
83         .CASE 100800  ; PL2303TA baudrate
84 ; Configure UART_TERM @ 201600 bauds / 1MHz
85 ; N=1000000/201600=4.955401 ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.200396)=0xFE
86 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
87             MOV     #4,     &TERMBRW
88             MOV.W   #0FE00h,&TERMMCTLW
89
90         .CASE 115200
91 ; Configure UART_TERM @ 230400 bauds / 1MHz
92 ; N=1000000/230400=4.34027... ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.340277)=0x49
93 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
94             MOV     #4,     &TERMBRW
95             MOV.W   #04900h,&TERMMCTLW
96
97         .CASE 134400  ; PL2303TA baudrate
98 ; Configure UART_TERM @ 268800 bauds / 1MHz
99 ; N=1000000/134400=3.72024 ==> UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.72024)=0xBB
100 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
101             MOV     #3,     &TERMBRW
102             MOV.W   #0BB00h,&TERMMCTLW
103
104 ;        .CASE 161280  ; PL2303TA baudrate
105 ;; Configure UART_TERM @ 161280 bauds / 500kHz
106 ;; N=500000/161280=3.100198 ==> UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.100198)=0x08
107 ;; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
108 ;            MOV     #3,     &TERMBRW
109 ;            MOV.W   #01100h,&TERMMCTLW
110
111         .ELSECASE
112             .error "UART_TERM / 500 kHz : baudrate not implemented"
113         .ENDCASE
114
115
116     .ELSEIF FREQUENCY = 1
117         .SWITCH TERMINALBAUDRATE
118         .CASE 9600
119 ; Configure UART_TERM @ 9600 bauds / 1MHz
120 ; N=1000000/9600=104.166... ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.1666)=0x20
121 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
122             MOV     #6,    &TERMBRW
123             MOV     #2081h, &TERMMCTLW
124
125         .CASE 19200
126 ; Configure UART_TERM @ 19200 bauds / 1MHz
127 ; N=1000000/19200=52.0833... ==> UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(0.0833)=0x02
128 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
129             MOV     #3,    &TERMBRW
130             MOV.W   #0241h,&TERMMCTLW
131
132         .CASE 31250  ; MIDI interface
133 ; Configure UART_TERM @ 31250 bauds / 1MHz
134 ; N=1000000/31250=32 ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
135 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
136             MOV     #2,     &TERMBRW
137             MOV.W   #0001h,&TERMMCTLW
138
139         .CASE 38400
140 ; Configure UART_TERM @ 38400 bauds / 1MHz
141 ; N=1000000/38400=26.04166... ==> UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=10, UCBRS0= fn(frac(N))=fn(0.04166)=0x00
142 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
143             MOV     #1,    &TERMBRW
144             MOV.W   #00A1h, &TERMMCTLW
145
146         .CASE 57600
147 ; Configure UART_TERM @ 57600 bauds / 1MHz
148 ; N=1000000/57600=17.301... ==> UCOS16=0, UCBR0=int(N)=17, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.301)=0x4A
149 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
150             MOV     #17,     &TERMBRW
151             MOV.W   #04A00h,&TERMMCTLW
152
153         .CASE 100800  ; PL2303TA baudrate
154 ; Configure UART_TERM @ 100800 bauds / 1MHz
155 ; N=1000000/100800=9,920634 ==> UCOS16=0, UCBR0=int(N)=9, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.920634)=0xFD
156 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
157             MOV     #9,     &TERMBRW
158             MOV.W   #0FD00h,&TERMMCTLW
159
160         .CASE 115200
161 ; Configure UART_TERM @ 115200 bauds / 1MHz
162 ; N=1000000/115200=8.68055... ==> UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.68055)=0xD6
163 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
164             MOV     #8,     &TERMBRW
165             MOV.W   #0D600h,&TERMMCTLW
166
167         .CASE 134400  ; PL2303TA baudrate
168 ; Configure UART_TERM @ 134400 bauds / 1MHz
169 ; N=1000000/134400=7.440476 ==> UCOS16=0, UCBR0=int(N)=7, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.440476)=0x55
170 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
171             MOV     #7,     &TERMBRW
172             MOV.W   #05500h,&TERMMCTLW
173
174         .CASE 161280  ; PL2303TA baudrate
175 ; Configure UART_TERM @ 161280 bauds / 1MHz
176 ; N=1000000/161280=6.200396 ==> UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.200396)=0x11
177 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
178             MOV     #6,     &TERMBRW
179             MOV.W   #01100h,&TERMMCTLW
180
181         .CASE 201600  ; PL2303TA baudrate
182 ; Configure UART_TERM @ 201600 bauds / 1MHz
183 ; N=1000000/201600=4.955401 ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.200396)=0xFE
184 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
185             MOV     #4,     &TERMBRW
186             MOV.W   #0FE00h,&TERMMCTLW
187
188         .CASE 230400
189 ; Configure UART_TERM @ 230400 bauds / 1MHz
190 ; N=1000000/230400=4.34027... ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.340277)=0x49
191 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
192             MOV     #4,     &TERMBRW
193             MOV.W   #04900h,&TERMMCTLW
194
195         .CASE 250000  ; DMX interface
196 ; Configure UART_TERM @ 250000 bauds / 1MHz
197 ; N=1000000/250000=4 ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0)=0
198 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
199             MOV     #4,     &TERMBRW
200             MOV.W   #0000h,&TERMMCTLW
201
202         .CASE 268800  ; PL2303TA baudrate
203 ; Configure UART_TERM @ 268800 bauds / 1MHz
204 ; N=1000000/268800=3.72024 ==> UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.72024)=0xBB
205 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
206             MOV     #3,     &TERMBRW
207             MOV.W   #0BB00h,&TERMMCTLW
208
209 ;        .CASE 403200  ; PL2303TA baudrate
210 ;; Configure UART_TERM @ 403200 bauds / 1MHz
211 ;; N=1000000/403200=2.48016 ==> UCOS16=0, UCBR0=int(N)=2, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.48016)=0x55
212 ;; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
213 ;            MOV     #2,     &TERMBRW
214 ;            MOV.W   #05500h,&TERMMCTLW
215
216
217         .ELSECASE
218             .error "UART_TERM / 1 MHz : baudrate not implemented"
219         .ENDCASE
220
221     .ELSEIF FREQUENCY = 2
222         .SWITCH TERMINALBAUDRATE
223         .CASE 9600
224 ; Configure UART_TERM @ 19200 bauds / 4MHz
225 ; N=4000000/38400=208.333... ==> UCOS16=1, UCBR0=int(N/16)=13, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.33333)=0x49
226 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
227             MOV     #13,    &TERMBRW
228             MOV.W   #4901h, &TERMMCTLW
229
230         .CASE 19200
231 ; Configure UART_TERM @ 9600 bauds / 1MHz
232 ; N=1000000/9600=104.166... ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.1666)=0x20
233 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
234             MOV     #6,    &TERMBRW
235             MOV     #2081h, &TERMMCTLW
236
237         .CASE 31250  ; MIDI interface
238 ; Configure UART_TERM @ 31250 bauds / 2MHz
239 ; N=2000000/31250=64 ==> UCOS16=1, UCBR0=int(N/16)=4, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
240 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
241             MOV     #4,     &TERMBRW
242             MOV.W   #0001h,&TERMMCTLW
243
244         .CASE 38400
245 ; Configure UART_TERM @ 19200 bauds / 1MHz
246 ; N=1000000/19200=52.0833... ==> UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(0.0833)=0x02
247 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
248             MOV     #3,    &TERMBRW
249             MOV.W   #0241h,&TERMMCTLW
250
251         .CASE 57600
252 ; Configure UART_TERM @ 115200 bauds / 4MHz
253 ; N=8000000/230400=34.7222... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0.72222)=0xBB
254 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
255             MOV     #2,     &TERMBRW
256             MOV.W   #0BB21h,&TERMMCTLW
257
258         .CASE 115200
259 ; Configure UART_TERM @ 57600 bauds / 1MHz
260 ; N=1000000/57600=17.301... ==> UCOS16=0, UCBR0=int(N)=17, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.301)=0x4A
261 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
262             MOV     #17,     &TERMBRW
263             MOV.W   #04A00h,&TERMMCTLW
264
265         .CASE 230400
266 ; Configure UART_TERM @ 115200 bauds / 1MHz
267 ; N=1000000/115200=8.68055... ==> UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.68055)=0xD6
268 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
269             MOV     #8,     &TERMBRW
270             MOV.W   #0D600h,&TERMMCTLW
271
272         .CASE 250000  ; DMX interface
273 ; Configure UART_TERM @ 250000 bauds / 2MHz
274 ; N=2000000/250000=8 ==> UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0)=0
275 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
276             MOV     #8,     &TERMBRW
277             MOV.W   #0000h,&TERMMCTLW
278
279         .CASE 268800  ; PL2303TA baudrate
280 ; Configure UART_TERM @ 134400 bauds / 1MHz
281 ; N=1000000/134400=7.440476 ==> UCOS16=0, UCBR0=int(N)=7, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.440476)=0x55
282 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
283             MOV     #7,     &TERMBRW
284             MOV.W   #05500h,&TERMMCTLW
285
286         .CASE 403200  ; PL2303TA baudrate
287 ; Configure UART_TERM @ 201600 bauds / 1MHz
288 ; N=1000000/201600=4.955401 ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.200396)=0xFE
289 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
290             MOV     #4,     &TERMBRW
291             MOV.W   #0FE00h,&TERMMCTLW
292
293         .CASE 460800 ; CP2102 baudrate
294 ; Configure UART_TERM @ 921600 bauds / 4MHz
295 ; N = 4000000/460800 = 4.34027... ==> {UCOS16=0, UCBR1=int(N)=4, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.34027)=0x49
296 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
297              MOV     #4,     &TERMBRW
298              MOV.W   #04900h,&TERMMCTLW
299
300         .CASE 614400 ; PL2303TA baudrate
301 ; Configure UART_TERM @ 2457600 bauds / 8MHz
302 ; N = 8000000/2457600 = 3.25521... ==> {UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.25521)=0x44
303 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
304              MOV     #3,     &TERMBRW
305              MOV.W   #04400h,&TERMMCTLW
306
307         .CASE 806400  ; PL2303TA baudrate
308 ; Configure UART_TERM @ 806400 bauds / 2MHz
309 ; Configure UART_TERM @ 403200 bauds / 1MHz
310 ; N=1000000/403200=2.48016 ==> UCOS16=0, UCBR0=int(N)=2, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.48016)=0x55
311 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
312             MOV     #2,     &TERMBRW
313             MOV.W   #05500h,&TERMMCTLW
314
315 ;        .CASE 921600
316 ;; Configure UART_TERM @ 921600 bauds / 2MHz
317 ;; N = 2000000/921600 = 2.170138... ==> {UCOS16=0, UCBR1=int(N)=2, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.170138)=0x11
318 ;; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
319 ;             MOV     #2,     &TERMBRW
320 ;             MOV.W   #01100h,&TERMMCTLW
321
322
323         .ELSECASE
324             .error "UART_TERM / 2 MHz : baudrate not implemented"
325         .ENDCASE
326
327     .ELSEIF FREQUENCY = 4
328         .SWITCH TERMINALBAUDRATE
329         .CASE 9600
330 ; Configure UART_TERM @ 9600 bauds / 4MHz
331 ; N=4000000/19200=416.666... ==> UCOS16=1, UCBR0=int(N/16)=26, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.66666)=0xD6
332 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
333             MOV     #26,    &TERMBRW
334             MOV.W   #0D601h,&TERMMCTLW
335
336         .CASE 19200
337 ; Configure UART_TERM @ 19200 bauds / 4MHz
338 ; N=4000000/38400=208.333... ==> UCOS16=1, UCBR0=int(N/16)=13, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.33333)=0x49
339 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
340             MOV     #13,    &TERMBRW
341             MOV.W   #4901h, &TERMMCTLW
342
343         .CASE 31250  ; MIDI interface
344 ; Configure UART_TERM @ 31250 bauds / 4MHz
345 ; N=4000000/31250=128 ==> UCOS16=1, UCBR0=int(N/16)=8, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
346 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
347             MOV     #8,     &TERMBRW
348             MOV.W   #0001h,&TERMMCTLW
349
350         .CASE 38400
351 ; Configure UART_TERM @ 38400 bauds / 4MHz
352 ; N=4000000/38400=104.1666... ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.16666)=0x20
353 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
354             MOV     #6,     &TERMBRW
355             MOV.W   #02081h,&TERMMCTLW
356
357         .CASE 57600
358 ; Configure UART_TERM @ 57600 bauds / 4MHz
359 ; N=8000000/115200=69.444... ==> UCOS16=1, UCBR0=int(N/16)=4, UCBRF0=int(frac(N/16)*16)=5, UCBRS0= fn(frac(N))=fn(0.44444)=0x55
360 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
361             MOV     #4,     &TERMBRW
362             MOV.W   #5551h, &TERMMCTLW
363
364         .CASE 115200
365 ; Configure UART_TERM @ 115200 bauds / 4MHz
366 ; N=8000000/230400=34.7222... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0.72222)=0xBB
367 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
368             MOV     #2,     &TERMBRW
369             MOV.W   #0BB21h,&TERMMCTLW
370
371         .CASE 230400
372 ; Configure UART_TERM @ 230400 bauds / 4MHz
373 ; see table "Recommended Settings for Typical Crystals and Baudrates"
374             MOV     #17,    &TERMBRW
375             MOV.W   #04A00h,&TERMMCTLW
376
377         .CASE 250000  ; DMX interface
378 ; Configure UART_TERM @ 250000 bauds / 4MHz
379 ; N=4000000/250000=16 ==> UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
380 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
381             MOV     #1,     &TERMBRW
382             MOV.W   #0001h, &TERMMCTLW
383
384         .CASE 460800
385 ; Configure UART_TERM @ 460800 bauds / 4MHz
386 ; N = 8000000/921600 = 8.680555... ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.68055)=0xD6
387 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
388              MOV     #8,     &TERMBRW
389              MOV.W   #0D600h,&TERMMCTLW
390
391         .CASE 806400  ; PL2303TA baudrate
392 ; Configure UART_TERM @ 806400 bauds / 4MHz
393 ; Configure UART_TERM @ 201600 bauds / 1MHz
394 ; N=1000000/201600=4.955401 ==> UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.200396)=0xFE
395 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
396             MOV     #4,     &TERMBRW
397             MOV.W   #0FE00h,&TERMMCTLW
398
399         .CASE 921600 ; CP2102 baudrate
400 ; Configure UART_TERM @ 921600 bauds / 4MHz
401 ; N = 8000000/921600 = 4.34027... ==> {UCOS16=0, UCBR1=int(N)=4, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.34027)=0x49
402 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
403              MOV     #4,     &TERMBRW
404              MOV.W   #04900h,&TERMMCTLW
405
406         .CASE 1228800 ; PL2303TA baudrate
407 ; Configure UART_TERM @ 2457600 bauds / 8MHz
408 ; N = 8000000/1228800 = 3.25521... ==> {UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.25521)=0x44
409 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
410              MOV     #3,     &TERMBRW
411              MOV.W   #04400h,&TERMMCTLW
412
413
414         .ELSECASE
415             .error "UART_TERM / 4 MHz : baudrate not implemented"
416         .ENDCASE ; UART_TERM / 4 MHz baudrates
417
418
419     .ELSEIF FREQUENCY = 8
420         .SWITCH TERMINALBAUDRATE
421         .CASE 9600
422 ; Configure UART_TERM @ 9600 bauds / 8MHz
423 ; N=8000000/9600=833.333... ==> UCOS16=1, UCBR0=int(N/16)=52, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0.33333)=0x49
424             MOV     #52,    &TERMBRW
425             MOV     #4911h, &TERMMCTLW
426
427         .CASE 19200
428 ; Configure UART_TERM @ 19200 bauds / 8MHz
429 ; N=8000000/19200=416.666... ==> UCOS16=1, UCBR0=int(N/16)=26, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.66666)=0xD6
430 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
431             MOV     #26,    &TERMBRW
432             MOV.W   #0D601h,&TERMMCTLW
433
434         .CASE 31250  ; MIDI interface
435 ; Configure UART_TERM @ 31250 bauds / 8MHz
436 ; N=8000000/31250=256 ==> UCOS16=1, UCBR0=int(N/16)=16, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
437 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
438             MOV     #16,     &TERMBRW
439             MOV.W   #0001h,&TERMMCTLW
440
441         .CASE 38400
442 ; Configure UART_TERM @ 38400 bauds / 8MHz
443 ; N=8000000/38400=208.333... ==> UCOS16=1, UCBR0=int(N/16)=13, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.33333)=0x49
444 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
445             MOV     #13,    &TERMBRW
446             MOV.W   #4901h, &TERMMCTLW
447
448         .CASE 57600
449 ; Configure UART_TERM @ 57600 bauds / 8MHz
450 ; N=8000000/57600=138.888... ==> UCOS16=1, UCBR0=int(N/16)=8, UCBRF0=int(frac(N/16)*16)=10, UCBRS0= fn(frac(N))=fn(0.88888)=0xF7
451 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
452             MOV     #8,     &TERMBRW
453             MOV.W   #0F7A1h,&TERMMCTLW
454
455         .CASE 115200
456 ; Configure UART_TERM @ 115200 bauds / 8MHz
457 ; N=8000000/115200=69.444... ==> UCOS16=1, UCBR0=int(N/16)=4, UCBRF0=int(frac(N/16)*16)=5, UCBRS0= fn(frac(N))=fn(0.44444)=0x55
458 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
459             MOV     #4,     &TERMBRW
460             MOV.W   #5551h, &TERMMCTLW
461
462         .CASE 230400
463 ; Configure UART_TERM @ 230400 bauds / 8MHz
464 ; N=8000000/230400=34.7222... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0.72222)=0xBB
465 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
466             MOV     #2,     &TERMBRW
467             MOV.W   #0BB21h,&TERMMCTLW
468
469         .CASE 250000  ; DMX interface
470 ; Configure UART_TERM @ 250000 bauds / 8MHz
471 ; N=8000000/250000=32 ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
472 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
473             MOV     #2,     &TERMBRW
474             MOV.W   #0001h, &TERMMCTLW
475
476         .CASE 460800
477 ; Configure UART_TERM @ 460800 bauds / 8MHz
478 ; see table "Recommended Settings for Typical Crystals and Baudrates"
479             MOV     #17,    &TERMBRW
480             MOV.W   #04A00h,&TERMMCTLW
481
482         .CASE 614400 ; PL2303TA baudrate
483 ; Configure UART_TERM @ 614400 bauds / 8MHz
484 ; N = 8000000/614400 = 13.02083... ==> {UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.02083)=0x02
485 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
486              MOV     #13,     &TERMBRW
487              MOV.W   #00200h,&TERMMCTLW
488
489         .CASE 806400  ; PL2303TA baudrate
490 ; Configure UART_TERM @ 806400 bauds / 8MHz
491 ; Configure UART_TERM @ 100800 bauds / 1MHz
492 ; N=1000000/100800=9,920634 ==> UCOS16=0, UCBR0=int(N)=9, UCBRF0=dont_care=0, UCBRS0= fn(frac(N))=fn(0.920634)=0xFD
493 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
494             MOV     #9,     &TERMBRW
495             MOV.W   #0FD00h,&TERMMCTLW
496
497         .CASE 921600
498 ; Configure UART_TERM @ 921600 bauds / 8MHz
499 ; Configure UART_TERM @ 1843200 bauds / 16MHz
500 ; N = 16000000/1843200 = 8.680555... ==> {UCOS16=0, UCBR1=int(N)=8, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.68055)=0xD6
501 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
502              MOV     #8,     &TERMBRW
503              MOV.W   #0D600h,&TERMMCTLW
504
505         .CASE 1000000
506 ; Configure UART_TERM @ 1000000 bauds / 8MHz
507 ; Configure UART_TERM @ 2000000 bauds / 16MHz
508 ; N = 16000000/2000000 = 8 ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
509             MOV     #8 ,    &TERMBRW
510             MOV.W   #00000h,&TERMMCTLW
511
512         .CASE 1228800 ; PL2303TA baudrate
513 ; Configure UART_TERM @ 1228800 bauds / 8MHz
514 ; N = 8000000/1228800 = 6.510416... ==> {UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.510416)=0xAA
515 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
516              MOV     #6,     &TERMBRW
517              MOV.W   #0AA00h,&TERMMCTLW
518
519         .CASE 1382400 ; CP2102 baudrate
520 ; Configure UART_TERM @ 1382400 bauds / 8MHz
521 ; N = 8000000/1382400 = 5.787037... ==> {UCOS16=0, UCBR0=int(N)=5, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.787037)=0xED
522             MOV     #5,    &TERMBRW
523             MOV.W   #0DD00h,&TERMMCTLW
524
525         .CASE 1843200 ; CP2102 baudrate (with programming)
526 ; Configure UART_TERM @ 1843200 bauds / 8MHz
527 ; N = 16000000/1843200 = 4.34027... ==> {UCOS16=0, UCBR1=int(N)=4, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.34027)=0x49
528 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
529              MOV     #4,     &TERMBRW
530              MOV.W   #04900h,&TERMMCTLW
531
532         .CASE 2457600 ; PL2303TA baudrate
533 ; Configure UART_TERM @ 2457600 bauds / 8MHz
534 ; N = 8000000/1228800 = 3.25521... ==> {UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.25521)=0x44
535 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
536              MOV     #3,     &TERMBRW
537              MOV.W   #04400h,&TERMMCTLW
538
539         .CASE 3000000 ; PL2303TA baudrate
540 ; Configure UART_TERM @ 3000000 bauds / 8MHz
541 ; Configure UART_TERM @ 6000000 bauds / 16MHz
542 ; N = 16000000/6000000 = 2.6666.. ==> {UCOS16=0, UCBR0=int(N)=2, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.6666)=0xB6
543             MOV     #2,    &TERMBRW
544             MOV.W   #0B600h,&TERMMCTLW
545
546         .ELSECASE
547             .error "UART_TERM / 8 MHz : baudrate not implemented"
548         .ENDCASE ; UART_TERM / 8 MHz baudrates
549
550
551
552     .ELSEIF FREQUENCY = 10
553         .SWITCH TERMINALBAUDRATE
554         .CASE 9600
555 ; Configure UART_TERM @ 9600 bauds / 10MHz
556 ; Configure UART_TERM @ 19200 bauds / 20MHz
557 ; N=20000000/19200=1041.66666 ==> UCOS16=1, UCBR0=int(N/16)=65, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0.66666)=0xd6
558 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
559             MOV     #65,&TERMBRW
560             MOV     #0D611h,&TERMMCTLW
561
562         .CASE 19200
563 ; Configure UART_TERM @ 19200 bauds / 10MHz
564 ; Configure UART_TERM @ 38400 bauds / 20MHz
565 ; N=20000000/38400=520.833333 ==> UCOS16=1, UCBR0=int(N/16)=32, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0)=0xBF
566 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
567             MOV     #32,&TERMBRW
568             MOV.W   #0BF01h,&TERMMCTLW
569
570         .CASE 31250  ; MIDI interface
571 ; Configure UART_TERM @ 31250 bauds / 10MHz
572 ; N=10000000/31250=320 ==> UCOS16=1, UCBR0=int(N/16)=20, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
573 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
574             MOV     #20,&TERMBRW
575             MOV.W   #0001h,&TERMMCTLW
576
577         .CASE 38400
578 ; Configure UART_TERM @ 38400 bauds / 10MHz
579 ; N=10000000/38400=260.41666 ==> UCOS16=1, UCBR0=int(N/16)=16, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(.04166)=0x92
580 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
581             MOV     #16,&TERMBRW
582             MOV.W   #09241h,&TERMMCTLW
583
584         .CASE 57600
585 ; Configure UART_TERM @ 57600 bauds / 10MHz
586 ; Configure UART_TERM @ 115200 bauds / 20MHz
587 ; N=20000000/115200=173.61111... ==> UCOS16=1, UCBR0=int(N/16)=10, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.6111)=0xAD
588 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
589             MOV     #10,&TERMBRW
590             MOV.W   #0AD01h,&TERMMCTLW
591
592         .CASE 115200
593 ; Configure UART_TERM @ 115200 bauds / 10MHz
594 ; Configure UART_TERM @ 230400 bauds / 20MHz
595 ; N=20000000/230400=86.80555... ==> UCOS16=1, UCBR0=int(N/16)=5, UCBRF0=int(frac(N/16)*16)=6, UCBRS0= fn(frac(N))=fn(0.80555)=0xEE
596 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
597             MOV     #5,&TERMBRW
598             MOV.W   #0EE61h,&TERMMCTLW
599
600         .CASE 230400
601 ; Configure UART_TERM @ 230400 bauds / 10MHz
602 ; Configure UART_TERM @ 460800 bauds / 20MHz
603 ; N=20000000/460800=43.402777... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=0Bh, UCBRS0= fn(frac(N))=fn(0.4027)=0x92
604 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
605             MOV     #2,     &TERMBRW
606             MOV.W   #92B1h,&TERMMCTLW
607
608         .CASE 250000  ; DMX interface
609 ; Configure UART_TERM @ 250000 bauds / 10MHz
610 ; Configure UART_TERM @ 500000 bauds / 20MHz
611 ; N = 20000000/500000 = 40 ==> {UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=8  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
612 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
613             MOV     #2,  &TERMBRW
614             MOV.W   #0081h,&TERMMCTLW
615
616         .CASE 460800
617 ; Configure UART_TERM @ 460800 bauds / 10MHz
618 ; Configure UART_TERM @ 921600 bauds / 20MHz
619 ; N = 20000000/921600 = 21.701388... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=5  UCBRS0=fn(frac(N))=fn(0.70138)=0xB7
620 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
621             MOV     #1,     &TERMBRW
622             MOV.W   #0B751h,&TERMMCTLW
623
624         .CASE 500000 ; CP2102 baudrate
625 ; Configure UART_TERM @ 500000 bauds / 10MHz
626 ; Configure UART_TERM @ 1000000 bauds / 20MHz
627 ; N = 20000000/1000000 = 20 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=4,  UCBRS0=fn(frac(N))=fn(0.000)=0x00
628 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
629             MOV     #1,     &TERMBRW
630             MOV.W   #0041h,&TERMMCTLW
631
632         .CASE 614400
633 ; Configure UART_TERM @ 614400 bauds / 10MHz
634 ; Configure UART_TERM @ 1228800 bauds / 20MHz
635 ; N = 20000000/1228800 = 16.276... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=0,  UCBRS0=fn(frac(N))=fn(0.276)=0x44
636             MOV     #1,     &TERMBRW
637             MOV.W   #04411h,&TERMMCTLW
638
639         .CASE 921600
640 ; Configure UART_TERM @ 921600 bauds / 10MHz
641 ; Configure UART_TERM @ 1843200 bauds / 20MHz
642 ; N = 20000000/1843200 = 10.85069...  {UCOS16=0, UCBR0=int(N)=10, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.85069)=0xDF
643 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
644              MOV     #10,    &TERMBRW
645              MOV.W   #0DF00h,&TERMMCTLW
646
647         .CASE 1000000
648 ; Configure UART_TERM @ 1000000 bauds / 10MHz
649 ; N = 10000000/1000000 = 10 ==> {UCOS16=0, UCBR0=int(N)=10, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.0)=0x00
650 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
651             MOV     #10,     &TERMBRW
652             MOV.W   #0,&TERMMCTLW
653
654         .CASE 1228800
655 ; Configure UART_TERM @ 1228800 bauds / 10MHz
656 ; N = 10000000/1228800 = 8.138.. ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.138)=0x10
657             MOV     #8,     &TERMBRW
658             MOV.W   #01000h,&TERMMCTLW
659
660         .CASE 1382400
661 ; Configure UART_TERM @ 1382400 bauds / 10MHz
662 ; N = 10000000/1382400 = 7.2338.. ==> {UCOS16=0, UCBR0=int(N)=7, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.2338)=0x22
663             MOV     #7,     &TERMBRW
664             MOV.W   #02200h,&TERMMCTLW
665
666         .CASE 1843200
667 ; Configure UART_TERM @ 1843200 bauds / 10MHz
668 ; N = 10000000/1843200 = 5.4253...  {UCOS16=0, UCBR0=int(N)=5, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.4253)=0x92
669 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
670              MOV     #5,    &TERMBRW
671              MOV.W   #09200h,&TERMMCTLW
672
673         .CASE 2457600 ; PL2303TA baudrate
674 ; Configure UART_TERM @ 2457600 bauds / 10MHz
675 ; N = 10000000/2457600 = 4.069010... ==> {UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.06901)=0x01
676 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
677              MOV     #4,     &TERMBRW
678              MOV.W   #00100h,&TERMMCTLW
679
680         .CASE 3000000 ; PL2303TA baudrate
681 ; Configure UART_TERM @ 3000000 bauds / 10MHz
682 ; Configure UART_TERM @ 6000000 bauds / 20MHz
683 ; N = 20000000/6000000 = 3.3333333 ==> {UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.33333)=0x49
684             MOV     #3,&TERMBRW
685              MOV.W   #04900h,&TERMMCTLW
686
687         .ELSECASE
688             .error "UART_TERM / 10 MHz : baudrate not implemented"
689         .ENDCASE ; UART_TERM / 10 MHz baudrates
690
691     .ELSEIF FREQUENCY = 12
692         .SWITCH TERMINALBAUDRATE
693         .CASE 9600
694 ; Configure UART_TERM @ 9600 bauds / 12MHz
695 ; Configure UART_TERM @ 19200 bauds / 24MHz
696 ; N=12000000/19200=1250 ==> UCOS16=1, UCBR0=int(N/16)=78, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0)=0x00
697 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
698             MOV     #78,    &TERMBRW
699             MOV     #0021h, &TERMMCTLW
700
701         .CASE 19200
702 ; Configure UART_TERM @ 19200 bauds / 12MHz
703 ; Configure UART_TERM @ 38400 bauds / 24MHz
704 ; N=24000000/19200=625 ==> UCOS16=1, UCBR0=int(N/16)=39, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0)=0x00
705 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
706             MOV     #39,    &TERMBRW
707             MOV.W   #0011h,&TERMMCTLW
708
709         .CASE 31250  ; MIDI interface
710 ; Configure UART_TERM @ 31250 bauds / 8MHz
711 ; N=12000000/31250=384 ==> UCOS16=1, UCBR0=int(N/16)=24, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
712 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
713             MOV     #24,     &TERMBRW
714             MOV.W   #1,&TERMMCTLW
715
716         .CASE 38400
717 ; Configure UART_TERM @ 38400 bauds / 12MHz
718 ; N=12000000/19200=312.5... ==> UCOS16=1, UCBR0=int(N/16)=19, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.5)=0x55
719 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
720             MOV     #19,    &TERMBRW
721             MOV.W   #05581h,&TERMMCTLW
722
723         .CASE 57600
724 ; Configure UART_TERM @ 57600 bauds / 12MHz
725 ; Configure UART_TERM @ 115200 bauds / 24MHz
726 ; N=24000000/115200=208.333... ==> UCOS16=1, UCBR0=int(N/16)=13, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.333)=0x49
727 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
728             MOV     #13,     &TERMBRW
729             MOV.W   #04901h,&TERMMCTLW
730
731         .CASE 115200
732 ; Configure UART_TERM @ 115200 bauds / 12MHz
733 ; Configure UART_TERM @ 230400 bauds / 24MHz
734 ; N=24000000/230400=104.1666... ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.1666)=0x20
735 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
736             MOV     #6,     &TERMBRW
737             MOV.W   #2081h, &TERMMCTLW
738
739         .CASE 230400
740 ; Configure UART_TERM @ 230400 bauds / 12MHz
741 ; Configure UART_TERM @ 460800 bauds / 24MHz
742 ; N=24000000/460800=52.08333... ==> UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(0.0833)=0x02
743 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
744             MOV     #3,     &TERMBRW
745             MOV.W   #0241h,&TERMMCTLW
746
747         .CASE 250000  ; DMX interface
748 ; Configure UART_TERM @ 250000 bauds / 12MHz
749 ; Configure UART_TERM @ 500000 bauds / 24MHz
750 ; N = 24000000/500000 = 48 ==> {UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
751 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
752 ;            MOV     #3,  &TERMBRW
753 ;            MOV.W   #0001h,&TERMMCTLW
754
755         .CASE 460800
756 ; Configure UART_TERM @ 460800 bauds / 12MHz
757 ; Configure UART_TERM @ 921600 bauds / 24MHz
758 ; N = 24000000/921600 = 26.041666... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=10  UCBRS0=fn(frac(N))=fn(0.0416)=0x00
759 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
760             MOV     #1,     &TERMBRW
761             MOV.W   #00A1h,&TERMMCTLW
762
763         .CASE 500000 ; CP2102 baudrate
764 ; Configure UART_ @ 500000 bauds / 12MHz
765 ; Configure UART_ @ 1000000 bauds / 24MHz
766 ; N = 24000000/1000000 = 24 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=4,  UCBRS0=fn(frac(N))=fn(0.000)=0x00
767 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
768             MOV     #1,     &TERMBRW
769             MOV.W   #0041h,&TERMMCTLW
770
771         .CASE 614400
772 ; Configure UART_TERM @ 614400 bauds / 12MHz
773 ; Configure UART_TERM @ 1228800 bauds / 24MHz
774 ; N = 24000000/1228800 = 19.531... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=3,  UCBRS0=fn(frac(N))=fn(0.531)=0xAA
775             MOV     #1,     &TERMBRW
776             MOV.W   #0AA31h,&TERMMCTLW
777
778         .CASE 921600
779 ; Configure UART_TERM @ 921600 bauds / 12MHz
780 ; Configure UART_TERM @ 1843200 bauds / 24MHz
781 ; N = 24000000/1843200 = 13.08203...  {UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.08203)=0x02
782 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
783             MOV     #17,    &TERMBRW
784             MOV.W   #04A00h,&TERMMCTLW
785
786         .CASE 1000000
787 ; Configure UART_TERM @ 1000000 bauds / 12MHz
788 ; N = 12000000/1000000 = 12 ==> {UCOS16=0, UCBR0=int(N)=12, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
789 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
790             MOV     #12,    &TERMBRW
791             MOV.W   #0,&TERMMCTLW
792
793         .CASE 1228800 ; PL2303TA baudrate
794 ; Configure UART_TERM @ 1228800 bauds / 12MHz
795 ; Configure UART_TERM @ 2457600 bauds / 24MHz
796 ; N = 24000000/2457600 = 9.765625... ==> {UCOS16=0, UCBR0=int(N)=9, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.765625)=0xDD
797 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
798              MOV     #9,     &TERMBRW
799              MOV.W   #0dd00h,&TERMMCTLW
800
801         .CASE 1382400 ; CP2102 baudrate (with programming)
802 ; Configure UART_TERM @ 1382400 bauds / 12MHz
803 ; N = 12000000/1382400 = 8.68055... ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.68055)=0x6B
804             MOV     #8,    &TERMBRW
805             MOV.W   #06B00h,&TERMMCTLW
806
807         .CASE 1843200 ; CP2102 baudrate (with programming)
808 ; Configure UART_TERM @ 1843200 bauds / 12MHz
809 ; N = 12000000/1843200 = 6.510416... ==> {UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.5104)=0xaa
810             MOV     #6,    &TERMBRW
811             MOV.W   #0AA00h,&TERMMCTLW
812
813         .CASE 2000000
814 ; Configure UART_TERM @ 2000000 bauds / 12MHz
815 ; Configure UART_TERM @ 4000000 bauds / 24MHz
816 ; N = 24000000/4000000 = 6... ==> {UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.0000000)=0
817 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
818              MOV     #6,&TERMBRW
819              MOV.W   #0,&TERMMCTLW
820
821         .CASE 2457600 ; PL2303TA baudrate
822 ; Configure UART_TERM @ 1228800 bauds / 12MHz
823 ; N = 12000000/2457600 = 4.8828... ==> {UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.8828)=0xF7
824 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
825              MOV     #4,     &TERMBRW
826              MOV.W   #0F700h,&TERMMCTLW
827
828         .CASE 3000000 ; PL2303TA baudrate
829 ; Configure UART_TERM @ 3000000 bauds / 12MHz
830 ; Configure UART_TERM @ 6000000 bauds / 24MHz
831 ; N = 24000000/6000000 = 4 ==> {UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
832              MOV     #4,     &TERMBRW
833              MOV.W   #0,&TERMMCTLW
834
835         .ELSECASE
836             .error "UART_TERM / 12 MHz : baudrate not implemented"
837         .ENDCASE ; UART_TERM / 12 MHz baudrates
838
839
840
841
842
843     .ELSEIF FREQUENCY = 16
844         .SWITCH TERMINALBAUDRATE
845         .CASE 9600
846 ; Configure UART_TERM @ 9600 bauds / 16MHz
847 ; N=16000000/9600=1666.666... ==> UCOS16=1, UCBR0=int(N/16)=104, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0.66666)=0xD6
848 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
849             MOV     #104,    &TERMBRW
850             MOV     #0D621h, &TERMMCTLW
851
852         .CASE 19200
853 ; Configure UART_TERM @ 19200 bauds / 16MHz
854 ; N=16000000/19200=833.333... ==> UCOS16=1, UCBR0=int(N/16)=52, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0.33333)=0x49
855 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
856             MOV     #52,    &TERMBRW
857             MOV     #4911h, &TERMMCTLW
858
859         .CASE 31250  ; MIDI interface
860 ; Configure UART_TERM @ 31250 bauds / 16MHz
861 ; N=16000000/31250=512 ==> UCOS16=1, UCBR0=int(N/16)=32, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
862 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
863             MOV     #32,     &TERMBRW
864             MOV.W   #0001h,&TERMMCTLW
865
866         .CASE 38400
867 ; Configure UART_TERM @ 38400 bauds / 16MHz
868 ; N=16000000/19200=416.666... ==> UCOS16=1, UCBR0=int(N/16)=26, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.66666)=0xD6
869 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
870             MOV     #26,    &TERMBRW
871             MOV.W   #0D601h,&TERMMCTLW
872
873         .CASE 57600
874 ; Configure UART_TERM @ 57600 bauds / 16MHz
875 ; N=16000000/57600=277.777... ==> UCOS16=1, UCBR0=int(N/16)=17, UCBRF0=int(frac(N/16)*16)=5, UCBRS0= fn(frac(N))=fn(0.77777)=0xDD
876 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
877             MOV     #17,     &TERMBRW
878             MOV.W   #0DD51h,&TERMMCTLW
879
880         .CASE 115200
881 ; Configure UART_TERM @ 115200 bauds / 16MHz
882 ; N=16000000/115200=138.888... ==> UCOS16=1, UCBR0=int(N/16)=8, UCBRF0=int(frac(N/16)*16)=10, UCBRS0= fn(frac(N))=fn(0.88888)=0xF7
883 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
884             MOV     #8,     &TERMBRW
885             MOV.W   #0F7A1h,&TERMMCTLW
886
887         .CASE 230400
888 ; Configure UART_TERM @ 230400 bauds / 16MHz
889 ; N=16000000/230400=69.444... ==> UCOS16=1, UCBR0=int(N/16)=4, UCBRF0=int(frac(N/16)*16)=5, UCBRS0= fn(frac(N))=fn(0.44444)=0x55
890 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
891             MOV     #4,     &TERMBRW
892             MOV.W   #5551h, &TERMMCTLW
893
894         .CASE 250000  ; DMX interface
895 ; Configure UART_TERM @ 250000 bauds / 16MHz
896 ; N=16000000/250000=64 ==> UCOS16=1, UCBR0=int(N/16)=4, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
897 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
898             MOV     #4,     &TERMBRW
899             MOV.W   #0001h, &TERMMCTLW
900
901         .CASE 460800
902 ; Configure UART_TERM @ 460800 bauds / 16MHz
903 ; N=16000000/460800=34.7222... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0.72222)=0xBB
904 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
905             MOV     #2,     &TERMBRW
906             MOV.W   #0BB21h,&TERMMCTLW
907
908         .CASE 500000 ; CP2102 baudrate
909 ; Configure UART_TERM @ 500000 bauds / 16MHz
910 ; N = 16000000/500000 = 32 ==> {UCOS16=1, UCBR0=int(N/16)=2, UCBRF1=int(frac(N/16)*16)=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
911 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
912 ;            MOV     #2,  &TERMBRW
913 ;            MOV.W   #00001h,&TERMMCTLW
914
915         .CASE 921600
916 ;; Configure UART_TERM @ 921600 bauds / 16MHz
917 ; N = 1600000/921600 = 17.3611... ==> {UCOS16=0, UCBR0=int(N)=14, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.3611)=0x4A
918 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
919             MOV     #17,    &TERMBRW
920             MOV.W   #04A00h,&TERMMCTLW
921 ; Configure UART_TERM @ 921600 bauds / 16MHz
922 ; N = 16000000/921600 = 17.3611 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=1  UCBRS0=fn(frac(N))=fn(0.3611)=0x4A
923 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
924 ;            MOV     #1,    &TERMBRW
925 ;            MOV.W   #04A11h,&TERMMCTLW
926
927         .CASE 1000000
928 ; Configure UART_TERM @ 1000000 bauds / 16MHz
929 ; N = 16000000/1000000 = 16 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
930 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
931             MOV     #1,    &TERMBRW
932             MOV.W   #00001h,&TERMMCTLW
933
934         .CASE 1228800 ; PL2303TA baudrate
935 ; Configure UART_TERM @ 1228800 bauds / 16MHz
936 ; Configure UART_TERM @ 614400 bauds / 8MHz
937 ; N = 8000000/614400 = 13.02083... ==> {UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.02083)=0x02
938 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
939              MOV     #13,     &TERMBRW
940              MOV.W   #00200h,&TERMMCTLW
941
942         .CASE 1382400 ; CP2102 baudrate (with programming)
943 ; Configure UART_TERM @ 1382400 bauds / 16MHz
944 ; N = 16000000/1382400 = 11.574074... ==> {UCOS16=0, UCBR0=int(N)=11, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.68055)=0x6B
945             MOV     #11,    &TERMBRW
946             MOV.W   #06B00h,&TERMMCTLW
947
948         .CASE 1843200 ; CP2102 baudrate (with programming)
949 ; Configure UART_TERM @ 1843200 bauds / 16MHz
950 ; N = 16000000/1843200 = 8.680555... ==> {UCOS16=0, UCBR1=int(N)=8, UCBRF1=dont_care=0  UCBRS1=fn(frac(N))=fn(0.68055)=0xD6
951 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
952              MOV     #8,     &TERMBRW
953              MOV.W   #0D600h,&TERMMCTLW
954
955         .CASE 2000000
956 ; Configure UART_TERM @ 2000000 bauds / 16MHz
957 ; N = 16000000/2000000 = 8 ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
958             MOV     #8 ,    &TERMBRW
959             MOV.W   #00000h,&TERMMCTLW
960
961         .CASE 2457600 ; PL2303TA baudrate
962 ; Configure UART_TERM @ 1228800 bauds / 8MHz
963 ; N = 8000000/1228800 = 6.510416... ==> {UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.510416)=0xAA
964 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
965              MOV     #6,     &TERMBRW
966              MOV.W   #0AA00h,&TERMMCTLW
967
968         .CASE 2764800
969 ; Configure UART_TERM @ 2764800 bauds / 16MHz
970 ; N = 16000000/2764800 = 5.787037... ==> {UCOS16=0, UCBR0=int(N)=5, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.787037)=0xED
971             MOV     #5,    &TERMBRW
972             MOV.W   #0DD00h,&TERMMCTLW
973
974         .CASE 3000000 ; PL2303TA baudrate
975 ; Configure UART_TERM @ 3000000 bauds / 16MHz
976 ; N = 16000000/3000000 = 5.333333... ==> {UCOS16=0, UCBR0=int(N)=5, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.333333)=0x49
977 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
978              MOV     #5,     &TERMBRW
979              MOV.W   #04900h,&TERMMCTLW
980
981         .CASE 4000000 ; PL203HXD baudrate
982 ; Configure UART_TERM @ 4000000 bauds / 16MHz
983 ; N = 16000000/4000000 = 4... ==> {UCOS16=0, UCBR0=int(N)=0, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.0000000)=0
984 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
985              MOV     #4,&TERMBRW
986              MOV.W   #0,&TERMMCTLW
987
988         .CASE 5000000 ; PL203HXD baudrate
989 ; Configure UART_TERM @ 5000000 bauds / 16MHz
990 ; N = 16000000/5000000 = 3.2... ==> {UCOS16=0, UCBR0=int(N)=0, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.2)=0x11
991 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
992              MOV     #3,&TERMBRW
993              MOV.W   #02100h,&TERMMCTLW
994
995         .CASE 6000000 ; PL2303TA baudrate
996 ; Configure UART_TERM @ 6000000 bauds / 24MHz
997 ; N = 16000000/6000000 = 2.6666.. ==> {UCOS16=0, UCBR0=int(N)=2, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.6666)=0xB6
998             MOV     #2,&TERMBRW
999             MOV.W   #0B600h,&TERMMCTLW
1000
1001         .ELSECASE
1002             .error "UART_TERM / 16 MHz : baudrate not implemented"
1003         .ENDCASE ; UART_TERM / 16 MHz baudrates
1004
1005     .ELSEIF FREQUENCY = 20
1006         .SWITCH TERMINALBAUDRATE
1007         .CASE 9600
1008 ; Configure UART_TERM @ 9600 bauds / 20MHz
1009 ; N=20000000/9600=2083.3333 ==> UCOS16=1, UCBR0=int(N/16)=130, UCBRF0=int(frac(N/16)*16)=3, UCBRS0= fn(frac(N))=(fn(.3333))=0x25
1010 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1011             MOV     #130,&TERMBRW
1012             MOV     #2531h,&TERMMCTLW
1013
1014         .CASE 19200
1015 ; Configure UART_TERM @ 19200 bauds / 20MHz
1016 ; N=20000000/19200=1041.66666 ==> UCOS16=1, UCBR0=int(N/16)=65, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0.66666)=0xd6
1017 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1018             MOV     #65,&TERMBRW
1019             MOV     #0D611h,&TERMMCTLW
1020
1021         .CASE 31250  ; MIDI interface
1022 ; Configure UART_TERM @ 31250 bauds / 20MHz
1023 ; N=20000000/31250=640 ==> UCOS16=1, UCBR0=int(N/16)=40, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
1024 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1025             MOV     #40,&TERMBRW
1026             MOV.W   #0001h,&TERMMCTLW
1027
1028         .CASE 38400
1029 ; Configure UART_TERM @ 38400 bauds / 20MHz
1030 ; N=20000000/38400=520.833333 ==> UCOS16=1, UCBR0=int(N/16)=32, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0)=0xBF
1031 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1032             MOV     #32,&TERMBRW
1033             MOV.W   #0BF01h,&TERMMCTLW
1034
1035         .CASE 57600
1036 ; Configure UART_TERM @ 57600 bauds / 20MHz
1037 ; N=20000000/57600=346.0207... ==> UCOS16=1, UCBR0=int(N/16)=21, UCBRF0=int(frac(N/16)*16)=0Ah, UCBRS0= fn(frac(N))=fn(0.0207)=0x00
1038 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1039             MOV     #21,&TERMBRW
1040             MOV.W   #000A1h,&TERMMCTLW
1041
1042         .CASE 115200
1043 ; Configure UART_TERM @ 115200 bauds / 20MHz
1044 ; N=20000000/115200=173.61111... ==> UCOS16=1, UCBR0=int(N/16)=10, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.6111)=0xAD
1045 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1046             MOV     #10,&TERMBRW
1047             MOV.W   #0AD01h,&TERMMCTLW
1048
1049         .CASE 230400
1050 ; Configure UART_TERM @ 230400 bauds / 20MHz
1051 ; N=20000000/230400=86.80555... ==> UCOS16=1, UCBR0=int(N/16)=5, UCBRF0=int(frac(N/16)*16)=6, UCBRS0= fn(frac(N))=fn(0.80555)=0xEE
1052 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1053             MOV     #5,&TERMBRW
1054             MOV.W   #0EE61h,&TERMMCTLW
1055
1056         .CASE 250000  ; DMX interface
1057 ; Configure UART_TERM @ 250000 bauds / 20MHz
1058 ; N=20000000/250000=80 ==> UCOS16=1, UCBR0=int(N/16)=5, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
1059 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1060             MOV     #5,     &TERMBRW
1061             MOV.W   #0001h, &TERMMCTLW
1062
1063         .CASE 460800
1064 ; Configure UART_TERM @ 460800 bauds / 20MHz
1065 ; N=20000000/460800=43.402777... ==> UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=0Bh, UCBRS0= fn(frac(N))=fn(0.4027)=0x92
1066 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1067             MOV     #2,     &TERMBRW
1068             MOV.W   #92B1h,&TERMMCTLW
1069
1070         .CASE 500000 ; CP2102 baudrate
1071 ; Configure UART_TERM @ 500000 bauds / 20MHz
1072 ; N = 20000000/500000 = 40 ==> {UCOS16=1, UCBR0=int(N/16)=2, UCBRF0=int(frac(N/16)*16)=8  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
1073 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1074             MOV     #2,  &TERMBRW
1075             MOV.W   #0081h,&TERMMCTLW
1076
1077         .CASE 921600
1078 ; Configure UART_TERM @ 921600 bauds / 20MHz
1079 ; N = 20000000/921600 = 21.701388... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=5  UCBRS0=fn(frac(N))=fn(0.70138)=0xB7
1080 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1081             MOV     #1,     &TERMBRW
1082             MOV.W   #0B751h,&TERMMCTLW
1083
1084         .CASE 1000000
1085 ; Configure UART_TERM @ 1000000 bauds / 20MHz
1086 ; N = 20000000/1000000 = 20 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=4,  UCBRS0=fn(frac(N))=fn(0.000)=0x00
1087 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1088             MOV     #1,     &TERMBRW
1089             MOV.W   #0041h,&TERMMCTLW
1090
1091         .CASE 1228800
1092 ; Configure UART_TERM @ 1228800 bauds / 20MHz
1093 ; N = 20000000/1228800 = 16.276... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=0,  UCBRS0=fn(frac(N))=fn(0.276)=0x44
1094             MOV     #1,     &TERMBRW
1095             MOV.W   #04411h,&TERMMCTLW
1096
1097         .CASE 1382400
1098 ; Configure UART_TERM @ 1382400 bauds / 20MHz
1099 ; N = 20000000/1382400 = 14.46759... ==> {UCOS16=0, UCBR0=int(N)=14, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.46759)=0x55
1100             MOV     #14,     &TERMBRW
1101             MOV.W   #05500h,&TERMMCTLW
1102
1103         .CASE 1843200
1104 ; Configure UART_TERM @ 1843200 bauds / 20MHz
1105 ; N = 20000000/1843200 = 10.85069...  {UCOS16=0, UCBR0=int(N)=10, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.85069)=0xDF
1106 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1107              MOV     #10,    &TERMBRW
1108              MOV.W   #0DF00h,&TERMMCTLW
1109
1110         .CASE 2457600 ; PL2303TA baudrate
1111 ; Configure UART_TERM @ 2457600 bauds / 20MHz
1112 ; N = 20000000/2457600 = 8.13802... ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.13802)=0x11
1113 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1114              MOV     #8,     &TERMBRW
1115              MOV.W   #01100h,&TERMMCTLW
1116
1117         .CASE 3000000 ; PL2303TA baudrate
1118 ; Configure UART_TERM @ 3000000 bauds / 20MHz
1119 ; N = 20000000/3000000 = 6.666666 ==> {UCOS16=0, UCBR0=int(N)=6, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.66666)=0xD6
1120             MOV     #6,&TERMBRW
1121              MOV.W   #0D600h,&TERMMCTLW
1122
1123         .CASE 4000000 ; PL2303HXD baudrate
1124 ; Configure UART_TERM @ 4000000 bauds / 20MHz
1125 ; N = 20000000/4000000 = 5... ==> {UCOS16=0, UCBR0=int(N)=5, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.0000000)=0
1126 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1127              MOV     #5,&TERMBRW
1128              MOV.W   #0,&TERMMCTLW
1129
1130         .CASE 5000000 ; PL203HXD baudrate
1131 ; Configure UART_TERM @ 5000000 bauds / 20MHz
1132 ; N = 20000000/5000000 = 4... ==> {UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.00)=0x00
1133 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1134              MOV     #4,&TERMBRW
1135              MOV.W   #0,&TERMMCTLW
1136
1137         .CASE 6000000 ; PL2303TA baudrate
1138 ; Configure UART_TERM @ 6000000 bauds / 20MHz
1139 ; N = 20000000/6000000 = 3.3333333 ==> {UCOS16=0, UCBR0=int(N)=3, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.33333)=0x49
1140             MOV     #3,&TERMBRW
1141              MOV.W   #04900h,&TERMMCTLW
1142
1143         .ELSECASE
1144             .error "UART_TERM / 20 MHz : baudrate not implemented"
1145         .ENDCASE ; UART_TERM / 20 MHz baudrates
1146
1147     .ELSEIF FREQUENCY = 24
1148         .SWITCH TERMINALBAUDRATE
1149         .CASE 9600
1150 ; Configure UART_TERM @ 9600 bauds / 24MHz
1151 ; N=24000000/9600=2500 ==> UCOS16=1, UCBR0=int(N/16)=156, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=(fn(0))=0x00
1152 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1153             MOV     #156,    &TERMBRW
1154             MOV     #0041h, &TERMMCTLW
1155
1156         .CASE 19200
1157 ; Configure UART_TERM @ 19200 bauds / 24MHz
1158 ; N=24000000/19200=1250 ==> UCOS16=1, UCBR0=int(N/16)=78, UCBRF0=int(frac(N/16)*16)=2, UCBRS0= fn(frac(N))=fn(0)=0x00
1159 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1160             MOV     #78,    &TERMBRW
1161             MOV     #0021h, &TERMMCTLW
1162
1163         .CASE 31250  ; MIDI interface
1164 ; Configure UART_TERM @ 31250 bauds / 8MHz
1165 ; N=24000000/31250=768 ==> UCOS16=1, UCBR0=int(N/16)=48, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
1166 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1167             MOV     #48,     &TERMBRW
1168             MOV.W   #0001h,&TERMMCTLW
1169
1170         .CASE 38400
1171 ; Configure UART_TERM @ 38400 bauds / 24MHz
1172 ; N=24000000/19200=625 ==> UCOS16=1, UCBR0=int(N/16)=39, UCBRF0=int(frac(N/16)*16)=1, UCBRS0= fn(frac(N))=fn(0)=0x00
1173 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1174             MOV     #39,    &TERMBRW
1175             MOV.W   #0011h,&TERMMCTLW
1176
1177         .CASE 57600
1178 ; Configure UART_TERM @ 57600 bauds / 24MHz
1179 ; N=24000000/57600=416.666... ==> UCOS16=1, UCBR0=int(N/16)=26, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.666)=0xD6
1180 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1181             MOV     #26,     &TERMBRW
1182             MOV.W   #0D601h,&TERMMCTLW
1183
1184         .CASE 115200
1185 ; Configure UART_TERM @ 115200 bauds / 24MHz
1186 ; N=24000000/115200=208.333... ==> UCOS16=1, UCBR0=int(N/16)=13, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0.333)=0x49
1187 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1188             MOV     #13,     &TERMBRW
1189             MOV.W   #04901h,&TERMMCTLW
1190
1191         .CASE 230400
1192 ; Configure UART_TERM @ 230400 bauds / 24MHz
1193 ; N=24000000/230400=104.1666... ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=8, UCBRS0= fn(frac(N))=fn(0.1666)=0x20
1194 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1195             MOV     #6,     &TERMBRW
1196             MOV.W   #2081h, &TERMMCTLW
1197
1198         .CASE 250000  ; DMX interface
1199 ; Configure UART_TERM @ 250000 bauds / 24MHz
1200 ; N=24000000/250000=96 ==> UCOS16=1, UCBR0=int(N/16)=6, UCBRF0=int(frac(N/16)*16)=0, UCBRS0= fn(frac(N))=fn(0)=0
1201 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1202             MOV     #6,     &TERMBRW
1203             MOV.W   #0001h, &TERMMCTLW
1204
1205         .CASE 460800
1206 ; Configure UART_TERM @ 460800 bauds / 24MHz
1207 ; N=24000000/460800=52.08333... ==> UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=4, UCBRS0= fn(frac(N))=fn(0.0833)=0x02
1208 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1209             MOV     #3,     &TERMBRW
1210             MOV.W   #0241h,&TERMMCTLW
1211
1212         .CASE 500000 ; CP2102 baudrate
1213 ; Configure UART_TERM @ 500000 bauds / 24MHz
1214 ; N = 24000000/500000 = 48 ==> {UCOS16=1, UCBR0=int(N/16)=3, UCBRF0=int(frac(N/16)*16)=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
1215 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1216 ;            MOV     #3,  &TERMBRW
1217 ;            MOV.W   #0001h,&TERMMCTLW
1218
1219         .CASE 921600
1220 ; Configure UART_TERM @ 921600 bauds / 24MHz
1221 ; N = 24000000/921600 = 26.041666... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=10  UCBRS0=fn(frac(N))=fn(0.0416)=0x00
1222 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1223             MOV     #1,     &TERMBRW
1224             MOV.W   #00A1h,&TERMMCTLW
1225
1226         .CASE 1000000
1227 ; Configure UART_TERM @ 1000000 bauds / 24MHz
1228 ; N = 24000000/1000000 = 24 ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=4,  UCBRS0=fn(frac(N))=fn(0.000)=0x00
1229 ; TERMBRW=UCBR1, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1230             MOV     #1,     &TERMBRW
1231             MOV.W   #0041h,&TERMMCTLW
1232
1233         .CASE 1228800
1234 ; Configure UART_TERM @ 1228800 bauds / 24MHz
1235 ; N = 24000000/1228800 = 19.531... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=3,  UCBRS0=fn(frac(N))=fn(0.531)=0xAA
1236             MOV     #1,     &TERMBRW
1237             MOV.W   #0AA31h,&TERMMCTLW
1238
1239         .CASE 1382400
1240 ; Configure UART_TERM @ 1382400 bauds / 24MHz
1241 ; N = 24000000/1382400 = 17.36111... ==> {UCOS16=1, UCBR0=int(N/16)=1, UCBRF0=int(frac(N/16)*16)=1,  UCBRS0=fn(frac(N))=fn(0.3611)=0x4A
1242             MOV     #1,     &TERMBRW
1243             MOV.W   #04A11h,&TERMMCTLW
1244
1245         .CASE 1843200
1246 ; Configure UART_TERM @ 1843200 bauds / 24MHz
1247 ; N = 24000000/1843200 = 13.08203...  {UCOS16=0, UCBR0=int(N)=13, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.08203)=0x02
1248 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1249              MOV     #13,    &TERMBRW
1250              MOV.W   #0200h,&TERMMCTLW
1251
1252         .CASE 2457600 ; PL2303TA baudrate
1253 ; Configure UART_TERM @ 2457600 bauds / 24MHz
1254 ; N = 24000000/2457600 = 9.765625... ==> {UCOS16=0, UCBR0=int(N)=9, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.765625)=0xDD
1255 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1256              MOV     #9,     &TERMBRW
1257              MOV.W   #0DD00h,&TERMMCTLW
1258
1259         .CASE 3000000 ; PL2303TA baudrate
1260 ; Configure UART_TERM @ 3000000 bauds / 24MHz
1261 ; N = 24000000/3000000 = 8 ==> {UCOS16=0, UCBR0=int(N)=8, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
1262             MOV     #8,&TERMBRW
1263             MOV.W   #0,&TERMMCTLW
1264
1265         .CASE 4000000 ; PL2303HXD baudrate
1266 ; Configure UART_TERM @ 4000000 bauds / 24MHz
1267 ; N = 24000000/4000000 = 6... ==> {UCOS16=0, UCBR0=int(N)=0, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.0000000)=0
1268 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1269              MOV     #6,&TERMBRW
1270              MOV.W   #0,&TERMMCTLW
1271
1272         .CASE 5000000 ; PL203HXD baudrate
1273 ; Configure UART_TERM @ 5000000 bauds / 24MHz
1274 ; N = 24000000/5000000 = 4.8... ==> {UCOS16=0, UCBR0=int(N)=0, UCBRF0=dont_care=0, UCBRS0=fn(frac(N))=fn(0.2)=0x11
1275 ; TERMBRW=UCBR0, TERMMCTLW= (UCBRS0<<8)|(UCBRF0<<4)|UCOS16
1276              MOV     #4,&TERMBRW
1277              MOV.W   #0EE00h,&TERMMCTLW
1278
1279         .CASE 6000000 ; PL2303TA baudrate
1280 ; Configure UART_TERM @ 6000000 bauds / 24MHz
1281 ; N = 24000000/6000000 = 4 ==> {UCOS16=0, UCBR0=int(N)=4, UCBRF0=dont_care=0  UCBRS0=fn(frac(N))=fn(0.00000)=0x00
1282             MOV     #4,&TERMBRW
1283             MOV.W   #0,&TERMMCTLW
1284
1285         .ELSECASE
1286             .error "UART_TERM / 24 MHz : baudrate not implemented"
1287         .ENDCASE ; UART_TERM / 24MHz baudrates
1288
1289     .ELSEIF 
1290         .error "UART_TERM frequency not implemented"
1291     .ENDIF ; frequency
1292