|
|
@ -55,7 +55,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
#define SERIAL_BAUD 19200 |
|
|
|
#define SERIAL_BAUD 19200 |
|
|
|
#define SERIAL_PARITY_ODD |
|
|
|
#define SERIAL_PARITY_ODD |
|
|
|
#define SERIAL_BIT_ORDER_MSB |
|
|
|
#define SERIAL_BIT_ORDER_LSB |
|
|
|
|
|
|
|
|
|
|
|
#define SERIAL_RXD_DDR DDRD |
|
|
|
#define SERIAL_RXD_DDR DDRD |
|
|
|
#define SERIAL_RXD_PORT PORTD |
|
|
|
#define SERIAL_RXD_PORT PORTD |
|
|
@ -67,7 +67,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
SERIAL_RXD_DDR &= ~(1<<SERIAL_RXD_BIT); \
|
|
|
|
SERIAL_RXD_DDR &= ~(1<<SERIAL_RXD_BIT); \
|
|
|
|
SERIAL_RXD_PORT |= (1<<SERIAL_RXD_BIT); \
|
|
|
|
SERIAL_RXD_PORT |= (1<<SERIAL_RXD_BIT); \
|
|
|
|
/* enable interrupt: INT2(rising edge) */ \
|
|
|
|
/* enable interrupt: INT2(rising edge) */ \
|
|
|
|
EICRA |= ((1<<ISC21)|(1<<ISC20)); \
|
|
|
|
/*EICRA |= ((1<<ISC21)|(1<<ISC20));*/ \
|
|
|
|
|
|
|
|
/* enable interrupt: INT2(falling edge) */ \
|
|
|
|
|
|
|
|
EICRA |= ((1<<ISC21)|(0<<ISC20)); \
|
|
|
|
EIMSK |= (1<<INT2); \
|
|
|
|
EIMSK |= (1<<INT2); \
|
|
|
|
} while (0) |
|
|
|
} while (0) |
|
|
|
#define SERIAL_RXD_INT_ENTER() |
|
|
|
#define SERIAL_RXD_INT_ENTER() |
|
|
@ -75,7 +77,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
/* clear interrupt flag */ \
|
|
|
|
/* clear interrupt flag */ \
|
|
|
|
EIFR = (1<<INTF2); \
|
|
|
|
EIFR = (1<<INTF2); \
|
|
|
|
} while (0) |
|
|
|
} while (0) |
|
|
|
#define SERIAL_RXD_READ() (~SERIAL_RXD_PIN&(1<<SERIAL_RXD_BIT)) |
|
|
|
//#define SERIAL_RXD_READ() (~SERIAL_RXD_PIN&(1<<SERIAL_RXD_BIT))
|
|
|
|
|
|
|
|
#define SERIAL_RXD_READ() ((SERIAL_RXD_PIN&(1<<SERIAL_RXD_BIT))) |
|
|
|
|
|
|
|
|
|
|
|
#define SERIAL_TXD_DDR DDRD |
|
|
|
#define SERIAL_TXD_DDR DDRD |
|
|
|
#define SERIAL_TXD_PORT PORTD |
|
|
|
#define SERIAL_TXD_PORT PORTD |
|
|
|