#include #include #include #include #include #include #include #define CC1100_GDO0 (RF1AIN & BIT0) #define CC1100_GDO1 (RF1AIN & BIT1) #define CC1100_GDO2 (RF1AIN & BIT2) int cc1100_get_gdo0(void) { return CC1100_GDO0; } int cc1100_get_gdo1(void) { return CC1100_GDO1; } int cc1100_get_gdo2(void) { return CC1100_GDO2; } void cc1100_before_send(void) { // Disable GDO2 interrupt before sending packet cc1100_gdo2_disable(); } void cc1100_after_send(void) { // Enable GDO2 interrupt after sending packet cc1100_gdo2_enable(); } void cc1100_gdo0_enable(void) { RF1AIFG &= ~BIT0; RF1AIE |= BIT0; } void cc1100_gdo0_disable(void) { RF1AIE &= ~BIT0; RF1AIFG &= ~BIT0; } void cc1100_gdo2_disable(void) { RF1AIFG &= ~BIT2; // Clear a pending interrupt RF1AIE &= ~BIT2; // Disable the interrupt } void cc1100_gdo2_enable(void) { RF1AIFG &= ~BIT2; // Clear a pending interrupt RF1AIE |= BIT2; // Enable the interrupt } void cc1100_init_interrupts(void) { uint8_t state = disableIRQ(); /* Disable all interrupts */ cc1100_gdo2_enable(); cc1100_gdo0_disable(); restoreIRQ(state); /* Enable all interrupts */ } interrupt (CC1101_VECTOR) __attribute__ ((naked)) cc1100_isr(void){ __enter_isr(); /* Check IFG */ if (RF1AIV == RF1AIV_RFIFG2) { while (RF1AIN & BIT2); /* discard all further interrupts */ RF1AIV = 0; cc1100_gdo2_irq(); } if (RF1AIV == RF1AIV_RFIFG0) { cc1100_gdo0_irq(); RF1AIE &= ~BIT0; } __exit_isr(); }