|
|
@ -56,12 +56,18 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#define SERIAL_SOFT_RXD_BIT 2
|
|
|
|
#define SERIAL_SOFT_RXD_BIT 2
|
|
|
|
#define SERIAL_SOFT_RXD_VECT INT2_vect
|
|
|
|
#define SERIAL_SOFT_RXD_VECT INT2_vect
|
|
|
|
/* RXD Interupt */
|
|
|
|
/* RXD Interupt */
|
|
|
|
|
|
|
|
#ifdef SERIAL_SOFT_LOGIC_NEGATIVE
|
|
|
|
|
|
|
|
/* enable interrupt: INT2(rising edge) */
|
|
|
|
|
|
|
|
#define INTR_TRIG_EDGE ((1<<ISC21)|(1<<ISC20))
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
/* enable interrupt: INT2(falling edge) */
|
|
|
|
|
|
|
|
#define INTR_TRIG_EDGE ((1<<ISC21)|(0<<ISC20))
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#define SERIAL_SOFT_RXD_INIT() do { \
|
|
|
|
#define SERIAL_SOFT_RXD_INIT() do { \
|
|
|
|
/* pin configuration: input with pull-up */ \
|
|
|
|
/* pin configuration: input with pull-up */ \
|
|
|
|
SERIAL_SOFT_RXD_DDR &= ~(1<<SERIAL_SOFT_RXD_BIT); \
|
|
|
|
SERIAL_SOFT_RXD_DDR &= ~(1<<SERIAL_SOFT_RXD_BIT); \
|
|
|
|
SERIAL_SOFT_RXD_PORT |= (1<<SERIAL_SOFT_RXD_BIT); \
|
|
|
|
SERIAL_SOFT_RXD_PORT |= (1<<SERIAL_SOFT_RXD_BIT); \
|
|
|
|
/* enable interrupt: INT2(rising edge) */ \
|
|
|
|
EICRA |= INTR_TRIG_EDGE; \
|
|
|
|
EICRA |= ((1<<ISC21)|(1<<ISC20)); \
|
|
|
|
|
|
|
|
EIMSK |= (1<<INT2); \
|
|
|
|
EIMSK |= (1<<INT2); \
|
|
|
|
sei(); \
|
|
|
|
sei(); \
|
|
|
|
} while (0)
|
|
|
|
} while (0)
|
|
|
|