root / Version 1.7 / RS232_MUX.X / hardware_TL16C754C.h @ master
Historique | Voir | Annoter | Télécharger (18,827 ko)
1 | f4faa2c5 | Enzo Niro | /* Microchip Technology Inc. and its subsidiaries. You may use this software
|
---|---|---|---|
2 | * and any derivatives exclusively with Microchip products.
|
||
3 | *
|
||
4 | * THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES, WHETHER
|
||
5 | * EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE, INCLUDING ANY IMPLIED
|
||
6 | * WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A
|
||
7 | * PARTICULAR PURPOSE, OR ITS INTERACTION WITH MICROCHIP PRODUCTS, COMBINATION
|
||
8 | * WITH ANY OTHER PRODUCTS, OR USE IN ANY APPLICATION.
|
||
9 | *
|
||
10 | * IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE,
|
||
11 | * INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND
|
||
12 | * WHATSOEVER RELATED TO THE SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS
|
||
13 | * BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE
|
||
14 | * FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS
|
||
15 | * IN ANY WAY RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF
|
||
16 | * ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE.
|
||
17 | *
|
||
18 | * MICROCHIP PROVIDES THIS SOFTWARE CONDITIONALLY UPON YOUR ACCEPTANCE OF THESE
|
||
19 | * TERMS.
|
||
20 | */
|
||
21 | |||
22 | /*
|
||
23 | * File: hardware_TL16C754C.h
|
||
24 | * Author: Enzo Niro
|
||
25 | * Comments: Library for MUX232 to handle TL16C754C chip
|
||
26 | * Revision history: 1.6
|
||
27 | */
|
||
28 | |||
29 | |||
30 | #ifndef RS232_HARDWARETL16_H
|
||
31 | #define RS232_HARDWARETL16_H
|
||
32 | |||
33 | #include <xc.h> // include processor files - each processor file is guarded. |
||
34 | #include "hardware_config.h" |
||
35 | |||
36 | |||
37 | |||
38 | //////////////////////////////////////
|
||
39 | //prototypes functions
|
||
40 | |||
41 | |||
42 | //////////////////////////
|
||
43 | //High level functions
|
||
44 | |||
45 | void initPortA(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit);
|
||
46 | void initPortB(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit);
|
||
47 | void initPortC(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit);
|
||
48 | void initPortD(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit);
|
||
49 | |||
50 | //Send bytes throught serial port
|
||
51 | void txWriteA(uint8_t b);
|
||
52 | void txWriteB(uint8_t b);
|
||
53 | void txWriteC(uint8_t b);
|
||
54 | void txWriteD(uint8_t b);
|
||
55 | |||
56 | //Receive bytes from serial port
|
||
57 | uint8_t rxReadA(void);
|
||
58 | uint8_t rxReadB(void);
|
||
59 | uint8_t rxReadC(void);
|
||
60 | uint8_t rxReadD(void);
|
||
61 | |||
62 | //RX buffer control
|
||
63 | |||
64 | //available functions
|
||
65 | bool portA_available();
|
||
66 | bool portB_available();
|
||
67 | bool portC_available();
|
||
68 | bool portD_available();
|
||
69 | |||
70 | //parity functions
|
||
71 | |||
72 | bool getParitySetA();
|
||
73 | bool getParitySetB();
|
||
74 | bool getParitySetC();
|
||
75 | bool getParitySetD();
|
||
76 | |||
77 | /*
|
||
78 |
|
||
79 | TODO : Implement functions...
|
||
80 |
|
||
81 | */
|
||
82 | |||
83 | |||
84 | //////////////////////////
|
||
85 | //Low level functions
|
||
86 | |||
87 | |||
88 | void writePortA(uint8_t reg, uint8_t addr);
|
||
89 | void writePortB(uint8_t reg, uint8_t addr);
|
||
90 | void writePortC(uint8_t reg, uint8_t addr);
|
||
91 | void writePortD(uint8_t reg, uint8_t addr);
|
||
92 | uint8_t readPortA(uint8_t addr); |
||
93 | uint8_t readPortB(uint8_t addr); |
||
94 | uint8_t readPortC(uint8_t addr); |
||
95 | uint8_t readPortD(uint8_t addr); |
||
96 | |||
97 | |||
98 | void setWait(uint16_t cnt); //fast delay |
||
99 | |||
100 | |||
101 | //////////////////////////////////////////////////////////
|
||
102 | //Values definitions (not supposed to use it directly)
|
||
103 | |||
104 | #define DLAB_ERF_EN_BIT 0x80 |
||
105 | |||
106 | |||
107 | #define LCR_REG 0x3 //Static register |
||
108 | |||
109 | ///////////////////////////////////////////
|
||
110 | // READ Registers
|
||
111 | |||
112 | #define RHR_REG 0x0 |
||
113 | #define IIR_REG 0x2 |
||
114 | #define LSR_REG 0x5 |
||
115 | #define MSR_REG 0x6 |
||
116 | #define FIFORDY_REG 0x7 |
||
117 | |||
118 | ///////////////////////////////////////////
|
||
119 | // WRITE Registers
|
||
120 | |||
121 | #define THR_REG 0x0 |
||
122 | #define FCR_REG 0x2 |
||
123 | |||
124 | ///////////////////////////////////////////
|
||
125 | // READ/WRITE Registers
|
||
126 | |||
127 | #define IER_REG 0x1 |
||
128 | #define LCR_REG 0x3 |
||
129 | #define MCR_REG 0x4 |
||
130 | #define SPR_REG 0x7 |
||
131 | #define DLL_REG 0x0 |
||
132 | #define DLH_REG 0x1 |
||
133 | #define EFR_REG 0x2 |
||
134 | #define XON1_REG 0x4 |
||
135 | #define XON2_REG 0x5 |
||
136 | #define XOFF1_REG 0x6 |
||
137 | #define XOFF2_REG 0x7 |
||
138 | #define TCR_REG 0x6 |
||
139 | #define TLR_REG 0x7 |
||
140 | |||
141 | |||
142 | |||
143 | |||
144 | ///////////////////////////////////////////////////////
|
||
145 | //CTRL, ADDR and DATA buses
|
||
146 | |||
147 | //Data pins
|
||
148 | #define DATAWRITE(x) PORTD.OUT = x
|
||
149 | #define DATADIR(x) PORTD.DIR = x
|
||
150 | #define DATAREAD PORTD.IN
|
||
151 | |||
152 | //Address pins
|
||
153 | #define ADDRWRITE(x) PORTE.OUT = x
|
||
154 | #define ADDR_ENABLE PORTE.DIR |= 0x07 |
||
155 | |||
156 | |||
157 | //Controls pins
|
||
158 | #define ENABLE_POW_SUPPLY_PIN PORTF.DIR |= 0x01 |
||
159 | #define ENABLE_WR_RD_PINS PORTB.DIR |= 0x30 |
||
160 | #define ENABLE_CS_PINS PORTB.DIR |= 0x0F |
||
161 | #define ENABLE_RESET_PIN PORTE.DIR |= 0x08 |
||
162 | #define POWER_ON PORTF.OUT |= 0x01 |
||
163 | #define POWER_OFF PORTF.OUT &= ~(0x01) |
||
164 | #define SETRST PORTE.OUT |= 0x08 |
||
165 | #define SETWR PORTB.OUT |= 0x10 |
||
166 | #define SETRD PORTB.OUT |= 0x20 |
||
167 | #define SETCSA PORTB.OUT |= 0x01 |
||
168 | #define SETCSB PORTB.OUT |= 0x02 |
||
169 | #define SETCSC PORTB.OUT |= 0x04 |
||
170 | #define SETCSD PORTB.OUT |= 0x08 |
||
171 | #define CLRRST PORTE.OUT &= ~(0x08) |
||
172 | #define CLRWR PORTB.OUT &= ~(0x10) |
||
173 | #define CLRRD PORTB.OUT &= ~(0x20) |
||
174 | #define CLRCSA PORTB.OUT &= ~(0x01) |
||
175 | #define CLRCSB PORTB.OUT &= ~(0x02) |
||
176 | #define CLRCSC PORTB.OUT &= ~(0x04) |
||
177 | #define CLRCSD PORTB.OUT &= ~(0x08) |
||
178 | |||
179 | |||
180 | ///////////////////////////////////////////////////////////////////////////////
|
||
181 | //Private vars
|
||
182 | |||
183 | bool _portA_parity_set;
|
||
184 | bool _portB_parity_set;
|
||
185 | bool _portC_parity_set;
|
||
186 | bool _portD_parity_set;
|
||
187 | |||
188 | |||
189 | |||
190 | ///////////////////////////////////////////////////////////////////////////////
|
||
191 | //Functions
|
||
192 | |||
193 | //////////////////////////////////////
|
||
194 | //High level functions
|
||
195 | |||
196 | void initPortA(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit)
|
||
197 | { |
||
198 | |||
199 | uint16_t speedCfg[] = { DL_9600_BAUDS, DL_19200_BAUDS, DL_38400_BAUDS }; |
||
200 | uint8_t parityCfg[] = { TL16C_NO_PARITY, TL16C_EVEN_PARITY, TL16C_ODD_PARITY }; |
||
201 | uint8_t dataCfg[] = { F5BIT_MODE, F6BIT_MODE, F7BIT_MODE, F8BIT_MODE }; |
||
202 | uint8_t stopCfg[] = { ONE_STOPBIT, TWO_STOPBITS }; |
||
203 | |||
204 | |||
205 | uint8_t regVal = 0; //temp value for reading register and change it's value without clearing it |
||
206 | |||
207 | _portA_parity_set = (parity > 0); //Parity set (even or odd) ? |
||
208 | |||
209 | |||
210 | //Read register first...
|
||
211 | regVal = readPortA(LCR_REG); |
||
212 | //_delay_ms(1);
|
||
213 | setWait(20);
|
||
214 | regVal = DLAB_ERF_EN_BIT; //set LCR[7] = 1 -> enable divisor latch mode
|
||
215 | writePortA(regVal, LCR_REG); //switch Mode
|
||
216 | //_delay_ms(1);
|
||
217 | setWait(20);
|
||
218 | //Set bus speed (according of 8MHz OSC. -> DL = Fosc/(16*Fbauds*DIV));
|
||
219 | //DIV = 1 or 4 (see TL16C datasheet p.14), we use here DIV = 1
|
||
220 | writePortA(0x00, DLH_REG); //Always 0x00 in our cfg... MAX 12MHz |
||
221 | //_delay_ms(1);
|
||
222 | setWait(20);
|
||
223 | //writePortA(busSpeed > 2 ? DL_38400_BAUDS : baudsValues[busSpeed], DLL_REG);
|
||
224 | writePortA(speedCfg[busSpeed], DLL_REG); |
||
225 | //_delay_ms(1);
|
||
226 | setWait(20);
|
||
227 | |||
228 | regVal = readPortA(LCR_REG); |
||
229 | regVal &= ~(DLAB_ERF_EN_BIT); //set LCR[7] = 0 -> disable divisor latch mode
|
||
230 | |||
231 | //regVal |= dataBits > 3 ? TL16C_WORD_8BITS : wordValues[dataBits]; //set 8bits mode
|
||
232 | //regVal |= (stopBit > 1 ? TL16C_STOPBIT_TWO : stopBitValues[stopBit]) << 2; //set stop bits
|
||
233 | //regVal |= (parity > 2 ? TL16C_PARITY_EVEN : parityValues[parity]) << 3; //set stop bits
|
||
234 | regVal |= dataCfg[dataBits]; //set 8bits mode
|
||
235 | regVal |= stopCfg[stopBit] << 2; //set stop bits |
||
236 | regVal |= parityCfg[parity] << 3; //set stop bits |
||
237 | writePortA(regVal, LCR_REG); |
||
238 | //_delay_ms(1);
|
||
239 | setWait(20);
|
||
240 | writePortA(0x01, FCR_REG); //enable FIFO |
||
241 | setWait(20);
|
||
242 | } |
||
243 | |||
244 | |||
245 | void initPortB(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit)
|
||
246 | { |
||
247 | |||
248 | uint16_t speedCfg[] = { DL_9600_BAUDS, DL_19200_BAUDS, DL_38400_BAUDS }; |
||
249 | uint8_t parityCfg[] = { TL16C_NO_PARITY, TL16C_EVEN_PARITY, TL16C_ODD_PARITY }; |
||
250 | uint8_t dataCfg[] = { F5BIT_MODE, F6BIT_MODE, F7BIT_MODE, F8BIT_MODE }; |
||
251 | uint8_t stopCfg[] = { ONE_STOPBIT, TWO_STOPBITS }; |
||
252 | |||
253 | |||
254 | uint8_t regVal = 0; //temp value for reading register and change it's value without clearing it |
||
255 | |||
256 | _portB_parity_set = (parity > 0); //Parity set (even or odd) ? |
||
257 | |||
258 | |||
259 | //Read register first...
|
||
260 | regVal = readPortB(LCR_REG); |
||
261 | //_delay_ms(1);
|
||
262 | setWait(20);
|
||
263 | regVal = DLAB_ERF_EN_BIT; //set LCR[7] = 1 -> enable divisor latch mode
|
||
264 | writePortB(regVal, LCR_REG); //switch Mode
|
||
265 | //_delay_ms(1);
|
||
266 | setWait(20);
|
||
267 | //Set bus speed (according of 8MHz OSC. -> DL = Fosc/(16*Fbauds*DIV));
|
||
268 | //DIV = 1 or 4 (see TL16C datasheet p.14), we use here DIV = 1
|
||
269 | writePortB(0x00, DLH_REG); //Always 0x00 in our cfg... MAX 12MHz |
||
270 | //_delay_ms(1);
|
||
271 | setWait(20);
|
||
272 | //writePortA(busSpeed > 2 ? DL_38400_BAUDS : baudsValues[busSpeed], DLL_REG);
|
||
273 | writePortB(speedCfg[busSpeed], DLL_REG); |
||
274 | //_delay_ms(1);
|
||
275 | setWait(20);
|
||
276 | |||
277 | regVal = readPortB(LCR_REG); |
||
278 | regVal &= ~(DLAB_ERF_EN_BIT); //set LCR[7] = 0 -> disable divisor latch mode
|
||
279 | |||
280 | //regVal |= dataBits > 3 ? TL16C_WORD_8BITS : wordValues[dataBits]; //set 8bits mode
|
||
281 | //regVal |= (stopBit > 1 ? TL16C_STOPBIT_TWO : stopBitValues[stopBit]) << 2; //set stop bits
|
||
282 | //regVal |= (parity > 2 ? TL16C_PARITY_EVEN : parityValues[parity]) << 3; //set stop bits
|
||
283 | regVal |= dataCfg[dataBits]; //set 8bits mode
|
||
284 | regVal |= stopCfg[stopBit] << 2; //set stop bits |
||
285 | regVal |= parityCfg[parity] << 3; //set stop bits |
||
286 | writePortB(regVal, LCR_REG); |
||
287 | //_delay_ms(1);
|
||
288 | setWait(20);
|
||
289 | writePortB(0x01, FCR_REG); //enable FIFO |
||
290 | setWait(20);
|
||
291 | } |
||
292 | |||
293 | |||
294 | void initPortC(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit)
|
||
295 | { |
||
296 | |||
297 | uint16_t speedCfg[] = { DL_9600_BAUDS, DL_19200_BAUDS, DL_38400_BAUDS }; |
||
298 | uint8_t parityCfg[] = { TL16C_NO_PARITY, TL16C_EVEN_PARITY, TL16C_ODD_PARITY }; |
||
299 | uint8_t dataCfg[] = { F5BIT_MODE, F6BIT_MODE, F7BIT_MODE, F8BIT_MODE }; |
||
300 | uint8_t stopCfg[] = { ONE_STOPBIT, TWO_STOPBITS }; |
||
301 | |||
302 | uint8_t regVal = 0; //temp value for reading register and change it's value without clearing it |
||
303 | |||
304 | _portC_parity_set = (parity > 0); //Parity set (even or odd) ? |
||
305 | |||
306 | |||
307 | //Read register first...
|
||
308 | regVal = readPortC(LCR_REG); |
||
309 | //_delay_ms(1);
|
||
310 | setWait(20);
|
||
311 | regVal = DLAB_ERF_EN_BIT; //set LCR[7] = 1 -> enable divisor latch mode
|
||
312 | writePortC(regVal, LCR_REG); //switch Mode
|
||
313 | //_delay_ms(1);
|
||
314 | setWait(20);
|
||
315 | //Set bus speed (according of 8MHz OSC. -> DL = Fosc/(16*Fbauds*DIV));
|
||
316 | //DIV = 1 or 4 (see TL16C datasheet p.14), we use here DIV = 1
|
||
317 | writePortC(0x00, DLH_REG); //Always 0x00 in our cfg... MAX 12MHz |
||
318 | //_delay_ms(1);
|
||
319 | setWait(20);
|
||
320 | //writePortA(busSpeed > 2 ? DL_38400_BAUDS : baudsValues[busSpeed], DLL_REG);
|
||
321 | writePortC(speedCfg[busSpeed], DLL_REG); |
||
322 | //_delay_ms(1);
|
||
323 | setWait(20);
|
||
324 | |||
325 | regVal = readPortC(LCR_REG); |
||
326 | regVal &= ~(DLAB_ERF_EN_BIT); //set LCR[7] = 0 -> disable divisor latch mode
|
||
327 | |||
328 | //regVal |= dataBits > 3 ? TL16C_WORD_8BITS : wordValues[dataBits]; //set 8bits mode
|
||
329 | //regVal |= (stopBit > 1 ? TL16C_STOPBIT_TWO : stopBitValues[stopBit]) << 2; //set stop bits
|
||
330 | //regVal |= (parity > 2 ? TL16C_PARITY_EVEN : parityValues[parity]) << 3; //set stop bits
|
||
331 | regVal |= dataCfg[dataBits]; //set 8bits mode
|
||
332 | regVal |= stopCfg[stopBit] << 2; //set stop bits |
||
333 | regVal |= parityCfg[parity] << 3; //set stop bits |
||
334 | writePortC(regVal, LCR_REG); |
||
335 | //_delay_ms(1);
|
||
336 | setWait(20);
|
||
337 | writePortC(0x01, FCR_REG); //enable FIFO |
||
338 | setWait(20);
|
||
339 | } |
||
340 | |||
341 | |||
342 | |||
343 | void initPortD(uint8_t busSpeed, uint8_t dataBits, uint8_t parity, uint8_t stopBit)
|
||
344 | { |
||
345 | |||
346 | uint16_t speedCfg[] = { DL_9600_BAUDS, DL_19200_BAUDS, DL_38400_BAUDS }; |
||
347 | uint8_t parityCfg[] = { TL16C_NO_PARITY, TL16C_EVEN_PARITY, TL16C_ODD_PARITY }; |
||
348 | uint8_t dataCfg[] = { F5BIT_MODE, F6BIT_MODE, F7BIT_MODE, F8BIT_MODE }; |
||
349 | uint8_t stopCfg[] = { ONE_STOPBIT, TWO_STOPBITS }; |
||
350 | |||
351 | uint8_t regVal = 0; //temp value for reading register and change it's value without clearing it |
||
352 | |||
353 | _portD_parity_set = (parity > 0); //Parity set (even or odd) ? |
||
354 | |||
355 | |||
356 | //Read register first...
|
||
357 | regVal = readPortD(LCR_REG); |
||
358 | //_delay_ms(1);
|
||
359 | setWait(20);
|
||
360 | regVal = DLAB_ERF_EN_BIT; //set LCR[7] = 1 -> enable divisor latch mode
|
||
361 | writePortD(regVal, LCR_REG); //switch Mode (and clear default cfg...)
|
||
362 | //_delay_ms(1);
|
||
363 | setWait(20);
|
||
364 | //Set bus speed (according of 8MHz OSC. -> DL = Fosc/(16*Fbauds*DIV));
|
||
365 | //DIV = 1 or 4 (see TL16C datasheet p.14), we use here DIV = 1
|
||
366 | writePortD(0x00, DLH_REG); //Always 0x00 in our cfg... MAX 12MHz |
||
367 | //_delay_ms(1);
|
||
368 | setWait(20);
|
||
369 | //writePortA(busSpeed > 2 ? DL_38400_BAUDS : baudsValues[busSpeed], DLL_REG);
|
||
370 | writePortD(speedCfg[busSpeed], DLL_REG); |
||
371 | //_delay_ms(1);
|
||
372 | setWait(20);
|
||
373 | |||
374 | regVal = readPortD(LCR_REG); |
||
375 | regVal &= ~(DLAB_ERF_EN_BIT); //set LCR[7] = 0 -> disable divisor latch mode
|
||
376 | |||
377 | //regVal |= dataBits > 3 ? TL16C_WORD_8BITS : wordValues[dataBits]; //set 8bits mode
|
||
378 | //regVal |= (stopBit > 1 ? TL16C_STOPBIT_TWO : stopBitValues[stopBit]) << 2; //set stop bits
|
||
379 | //regVal |= (parity > 2 ? TL16C_PARITY_EVEN : parityValues[parity]) << 3; //set stop bits
|
||
380 | regVal |= dataCfg[dataBits]; //set 8bits mode
|
||
381 | regVal |= stopCfg[stopBit] << 2; //set stop bits |
||
382 | regVal |= parityCfg[parity] << 3; //set stop bits |
||
383 | writePortD(regVal, LCR_REG); |
||
384 | //_delay_ms(1);
|
||
385 | setWait(20);
|
||
386 | writePortD(0x01, FCR_REG); //enable FIFO |
||
387 | setWait(20);
|
||
388 | } |
||
389 | |||
390 | |||
391 | |||
392 | //////////////////////////////////////////////
|
||
393 | //UART send/reiceive
|
||
394 | |||
395 | void txWriteA(uint8_t b)
|
||
396 | { |
||
397 | writePortA(b, THR_REG); //write to Transmit Holding (that goes into TX FIFO buffer)
|
||
398 | } |
||
399 | |||
400 | |||
401 | void txWriteB(uint8_t b)
|
||
402 | { |
||
403 | writePortB(b, THR_REG); //write to Transmit Holding (that goes into TX FIFO buffer)
|
||
404 | } |
||
405 | |||
406 | |||
407 | void txWriteC(uint8_t b)
|
||
408 | { |
||
409 | writePortC(b, THR_REG); //write to Transmit Holding (that goes into TX FIFO buffer)
|
||
410 | } |
||
411 | |||
412 | |||
413 | void txWriteD(uint8_t b)
|
||
414 | { |
||
415 | writePortD(b, THR_REG); //write to Transmit Holding (that goes into TX FIFO buffer)
|
||
416 | } |
||
417 | |||
418 | |||
419 | |||
420 | uint8_t rxReadA(void)
|
||
421 | { |
||
422 | return readPortA(RHR_REG); //read Receive Holding (from RX FIFO buffer) |
||
423 | } |
||
424 | |||
425 | |||
426 | uint8_t rxReadB(void)
|
||
427 | { |
||
428 | return readPortB(RHR_REG); //read Receive Holding (from RX FIFO buffer) |
||
429 | } |
||
430 | |||
431 | |||
432 | uint8_t rxReadC(void)
|
||
433 | { |
||
434 | return readPortC(RHR_REG); //read Receive Holding (from RX FIFO buffer) |
||
435 | } |
||
436 | |||
437 | |||
438 | uint8_t rxReadD(void)
|
||
439 | { |
||
440 | return readPortD(RHR_REG); //read Receive Holding (from RX FIFO buffer) |
||
441 | } |
||
442 | |||
443 | |||
444 | ////////////////////////////////////////
|
||
445 | //RX buf state functions
|
||
446 | |||
447 | bool portA_available()
|
||
448 | { |
||
449 | return (readPortA(LSR_REG) & 0x01); //check if RX FIFO buffer has at least one byte available |
||
450 | } |
||
451 | |||
452 | |||
453 | bool portB_available()
|
||
454 | { |
||
455 | return (readPortB(LSR_REG) & 0x01); //check if RX FIFO buffer has at least one byte available |
||
456 | } |
||
457 | |||
458 | |||
459 | bool portC_available()
|
||
460 | { |
||
461 | return (readPortC(LSR_REG) & 0x01); //check if RX FIFO buffer has at least one byte available |
||
462 | } |
||
463 | |||
464 | |||
465 | bool portD_available()
|
||
466 | { |
||
467 | return (readPortD(LSR_REG) & 0x01); //check if RX FIFO buffer has at least one byte available |
||
468 | } |
||
469 | |||
470 | |||
471 | ///////////////////////////////////////////////////////////////////////
|
||
472 | //Parity configuration status
|
||
473 | |||
474 | //get status if port has been configured with a parity into the frame
|
||
475 | bool getParitySetA()
|
||
476 | { |
||
477 | return _portA_parity_set;
|
||
478 | } |
||
479 | |||
480 | bool getParitySetB()
|
||
481 | { |
||
482 | return _portB_parity_set;
|
||
483 | } |
||
484 | |||
485 | bool getParitySetC()
|
||
486 | { |
||
487 | return _portC_parity_set;
|
||
488 | } |
||
489 | |||
490 | bool getParitySetD()
|
||
491 | { |
||
492 | return _portD_parity_set;
|
||
493 | } |
||
494 | |||
495 | |||
496 | |||
497 | //Get parity/stopbit error status when frame received on port
|
||
498 | |||
499 | bool getErrorStatusA()
|
||
500 | { |
||
501 | return ((readPortA(LSR_REG) & 0x80) == 0x80); |
||
502 | } |
||
503 | |||
504 | bool getErrorStatusB()
|
||
505 | { |
||
506 | return ((readPortB(LSR_REG) & 0x80) == 0x80); |
||
507 | } |
||
508 | |||
509 | bool getErrorStatusC()
|
||
510 | { |
||
511 | return ((readPortC(LSR_REG) & 0x80) == 0x80); |
||
512 | } |
||
513 | |||
514 | bool getErrorStatusD()
|
||
515 | { |
||
516 | return ((readPortD(LSR_REG) & 0x80) == 0x80); |
||
517 | } |
||
518 | |||
519 | |||
520 | ///////////////////////////////////////////////////////
|
||
521 | //write functions
|
||
522 | |||
523 | |||
524 | |||
525 | void writePortA(uint8_t reg, uint8_t addr)
|
||
526 | { |
||
527 | DATADIR(0xFF); //set I/O on write mode |
||
528 | ADDRWRITE(addr); //search uartn register
|
||
529 | DATAWRITE(reg); //write data
|
||
530 | CLRCSA; //enable uartA call
|
||
531 | setWait(3);
|
||
532 | CLRWR; //enable write mode
|
||
533 | setWait(3);
|
||
534 | SETWR; //disable write mode
|
||
535 | setWait(3);
|
||
536 | SETCSA; //disable uartA call
|
||
537 | DATADIR(0x00); //set input mode (to reduce power consumption) |
||
538 | } |
||
539 | |||
540 | void writePortB(uint8_t reg, uint8_t addr)
|
||
541 | { |
||
542 | DATADIR(0xFF); //set I/O on write mode |
||
543 | ADDRWRITE(addr); //search uartn register
|
||
544 | DATAWRITE(reg); //write data
|
||
545 | CLRCSB; //enable uartA call
|
||
546 | setWait(3);
|
||
547 | CLRWR; //enable write mode
|
||
548 | setWait(3);
|
||
549 | SETWR; //disable write mode
|
||
550 | setWait(3);
|
||
551 | SETCSB; //disable uartA call
|
||
552 | DATADIR(0x00); //set input mode (to reduce power consumption) |
||
553 | } |
||
554 | |||
555 | void writePortC(uint8_t reg, uint8_t addr)
|
||
556 | { |
||
557 | DATADIR(0xFF); //set I/O on write mode |
||
558 | ADDRWRITE(addr); //search uartn register
|
||
559 | DATAWRITE(reg); //write data
|
||
560 | CLRCSC; //enable uartA call
|
||
561 | setWait(3);
|
||
562 | CLRWR; //enable write mode
|
||
563 | setWait(3);
|
||
564 | SETWR; //disable write mode
|
||
565 | setWait(3);
|
||
566 | SETCSC; //disable uartA call
|
||
567 | DATADIR(0x00); //set input mode (to reduce power consumption) |
||
568 | } |
||
569 | |||
570 | void writePortD(uint8_t reg, uint8_t addr)
|
||
571 | { |
||
572 | DATADIR(0xFF); //set I/O on write mode |
||
573 | ADDRWRITE(addr); //search uartn register
|
||
574 | DATAWRITE(reg); //write data
|
||
575 | CLRCSD; //enable uartA call
|
||
576 | setWait(3);
|
||
577 | CLRWR; //enable write mode
|
||
578 | setWait(3);
|
||
579 | SETWR; //disable write mode
|
||
580 | setWait(3);
|
||
581 | SETCSD; //disable uartA call
|
||
582 | DATADIR(0x00); //set input mode (to reduce power consumption) |
||
583 | } |
||
584 | |||
585 | |||
586 | ///////////////////////////////////////////////////////
|
||
587 | //read functions
|
||
588 | |||
589 | |||
590 | uint8_t readPortA(uint8_t addr) |
||
591 | { |
||
592 | uint8_t result; |
||
593 | DATADIR(0x00); //set I/O on read mode |
||
594 | ADDRWRITE(addr); //search uartn register
|
||
595 | CLRCSA; //enable uartA call
|
||
596 | setWait(3);
|
||
597 | CLRRD; //enable read mode
|
||
598 | setWait(3);
|
||
599 | result = PORTD.IN; //set I/O on read mode
|
||
600 | setWait(3);
|
||
601 | SETRD; //disable read mode
|
||
602 | setWait(3);
|
||
603 | SETCSA; //hang up uartA call
|
||
604 | return result;
|
||
605 | } |
||
606 | |||
607 | uint8_t readPortB(uint8_t addr) |
||
608 | { |
||
609 | uint8_t result; |
||
610 | DATADIR(0x00); //set I/O on read mode |
||
611 | ADDRWRITE(addr); //search uartn register
|
||
612 | CLRCSB; //enable uartB call
|
||
613 | setWait(3);
|
||
614 | CLRRD; //enable read mode
|
||
615 | setWait(3);
|
||
616 | result = PORTD.IN; //set I/O on read mode
|
||
617 | setWait(3);
|
||
618 | SETRD; //disable read mode
|
||
619 | setWait(3);
|
||
620 | SETCSB; //hang up uartB call
|
||
621 | return result;
|
||
622 | } |
||
623 | |||
624 | uint8_t readPortC(uint8_t addr) |
||
625 | { |
||
626 | uint8_t result; |
||
627 | DATADIR(0x00); //set I/O on read mode |
||
628 | ADDRWRITE(addr); //search uartn register
|
||
629 | CLRCSC; //enable uartC call
|
||
630 | setWait(3);
|
||
631 | CLRRD; //enable read mode
|
||
632 | setWait(3);
|
||
633 | result = PORTD.IN; //set I/O on read mode
|
||
634 | setWait(3);
|
||
635 | SETRD; //disable read mode
|
||
636 | setWait(3);
|
||
637 | SETCSC; //hang up uartC call
|
||
638 | return result;
|
||
639 | } |
||
640 | |||
641 | uint8_t readPortD(uint8_t addr) |
||
642 | { |
||
643 | uint8_t result; |
||
644 | DATADIR(0x00); //set I/O on read mode |
||
645 | ADDRWRITE(addr); //search uartn register
|
||
646 | CLRCSD; //enable uartD call
|
||
647 | setWait(3);
|
||
648 | CLRRD; //enable read mode
|
||
649 | setWait(3);
|
||
650 | result = PORTD.IN; //set I/O on read mode
|
||
651 | setWait(3);
|
||
652 | SETRD; //disable read mode
|
||
653 | setWait(3);
|
||
654 | SETCSD; //hang up uartD call
|
||
655 | return result;
|
||
656 | } |
||
657 | |||
658 | |||
659 | |||
660 | |||
661 | |||
662 | ///////////////////////////////////////////
|
||
663 | //Miscellaneous functions
|
||
664 | |||
665 | void setWait(uint16_t cnt)
|
||
666 | { |
||
667 | uint16_t k = 0;
|
||
668 | while(k < cnt)
|
||
669 | { |
||
670 | asm("nop"); |
||
671 | k++; |
||
672 | } |
||
673 | } |
||
674 | |||
675 | |||
676 | |||
677 | |||
678 | |||
679 | #endif /* XC_HEADER_TEMPLATE_H */ |