-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathexample(flow control).c
54 lines (42 loc) · 1.23 KB
/
example(flow control).c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/*!
* \brief
*
* \author Jan Oleksiewicz <jnk0le@hotmail.com>
* \license SPDX-License-Identifier: MIT
*/
#include <avr/io.h>
#include "usart.h"
int main(void)
{
// set highest possible speed
uart_init(0);
uart_set_U2X();
// configure any interrupt source capable of triggering at both edges
// for single signal INTn isr can be used
PCICR = (1 << PCIE2);
PCMSK2 = (1 << PCINT18); // PD2 is used as an CTS input for USART0
// if hardware flow control is available (eg. 32u4) it should be used instead of soft implementation
// hardware rts will work only when USART_EXTEND_RX_BUFFER is defined
//uart_hardware_flow_control_init(1,1); // cts,rts - pass non zero value to enable
sei();
uint8_t a = 0xff;
while (1)
{
uart_putc(++a);
uart_putc(uart_getc());
//uart_getc(); // if getc echo is enabled
}
}
ISR(PCINT2_vect) // should have higher priority than UDRIEn interrupt
{
cts0_isr_handler();
//cts1_isr_handler();
//cts2_isr_handler();
//...
// add code here if required for other inputs (PCINT only)
}
// single signal INTn interrups can be used with naked handler (reduced overhead and resources usage)
ISR(INT0_vect, ISR_NAKED) // should have higher priority than UDRIEn interrupt
{
naked_cts3_isr_handler();
}