Statistiques
| Branche: | Révision:

root / Version 1.7 / RS232_MUX.X / hardware_TL16C754C.h @ f4faa2c5

Historique | Voir | Annoter | Télécharger (18,827 ko)

1
/* 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 */
680