2010-12-06 12:05:03 +01:00
|
|
|
#include <stdint.h>
|
2013-12-16 17:54:58 +01:00
|
|
|
#include <cc430f6137.h>
|
2010-12-06 12:05:03 +01:00
|
|
|
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "cpu.h"
|
|
|
|
#include "irq.h"
|
|
|
|
#include "cc110x_ng.h"
|
|
|
|
#include "cc110x-arch.h"
|
2010-12-06 12:05:03 +01:00
|
|
|
|
2010-12-09 13:24:24 +01:00
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
#define CC1100_GDO0 (RF1AIN & BIT0)
|
2010-12-10 18:00:31 +01:00
|
|
|
#define CC1100_GDO1 (RF1AIN & BIT1)
|
|
|
|
#define CC1100_GDO2 (RF1AIN & BIT2)
|
2010-12-06 12:05:03 +01:00
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
int cc110x_get_gdo0(void)
|
|
|
|
{
|
|
|
|
return CC1100_GDO0;
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
int cc110x_get_gdo1(void)
|
|
|
|
{
|
|
|
|
return CC1100_GDO1;
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
int cc110x_get_gdo2(void)
|
|
|
|
{
|
|
|
|
return CC1100_GDO2;
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2010-12-11 12:09:20 +01:00
|
|
|
void cc110x_before_send(void)
|
2010-12-06 12:05:03 +01:00
|
|
|
{
|
2013-07-29 16:41:43 +02:00
|
|
|
// Disable GDO2 interrupt before sending packet
|
|
|
|
cc110x_gdo2_disable();
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2010-12-11 12:09:20 +01:00
|
|
|
void cc110x_after_send(void)
|
2010-12-06 12:05:03 +01:00
|
|
|
{
|
2013-07-29 16:41:43 +02:00
|
|
|
// Enable GDO2 interrupt after sending packet
|
|
|
|
cc110x_gdo2_enable();
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
void cc110x_gdo0_enable(void)
|
|
|
|
{
|
2010-12-10 18:00:31 +01:00
|
|
|
RF1AIFG &= ~BIT0;
|
|
|
|
RF1AIE |= BIT0;
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
void cc110x_gdo0_disable(void)
|
|
|
|
{
|
2010-12-10 18:00:31 +01:00
|
|
|
RF1AIE &= ~BIT0;
|
|
|
|
RF1AIFG &= ~BIT0;
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
void cc110x_gdo2_disable(void)
|
|
|
|
{
|
2010-12-10 18:00:31 +01:00
|
|
|
RF1AIFG &= ~BIT2; // Clear a pending interrupt
|
2013-07-29 16:41:43 +02:00
|
|
|
RF1AIE &= ~BIT2; // Disable the interrupt
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
void cc110x_gdo2_enable(void)
|
|
|
|
{
|
2010-12-10 18:00:31 +01:00
|
|
|
RF1AIFG &= ~BIT2; // Clear a pending interrupt
|
2013-07-29 16:41:43 +02:00
|
|
|
RF1AIE |= BIT2; // Enable the interrupt
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
void cc110x_init_interrupts(void)
|
|
|
|
{
|
|
|
|
uint8_t state = disableIRQ(); /* Disable all interrupts */
|
2010-12-11 12:09:20 +01:00
|
|
|
cc110x_gdo2_enable();
|
|
|
|
cc110x_gdo0_disable();
|
2013-07-29 16:41:43 +02:00
|
|
|
restoreIRQ(state); /* Enable all interrupts */
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
|
|
|
|
2013-07-29 16:41:43 +02:00
|
|
|
interrupt(CC1101_VECTOR) __attribute__((naked)) cc110x_isr(void)
|
|
|
|
{
|
2010-12-06 12:05:03 +01:00
|
|
|
__enter_isr();
|
2013-07-29 16:41:43 +02:00
|
|
|
|
|
|
|
/* Check IFG */
|
|
|
|
if (RF1AIV == RF1AIV_RFIFG2) {
|
2010-12-10 18:00:31 +01:00
|
|
|
while (RF1AIN & BIT2);
|
2013-07-29 16:41:43 +02:00
|
|
|
|
2010-12-10 18:00:31 +01:00
|
|
|
/* discard all further interrupts */
|
|
|
|
RF1AIV = 0;
|
2013-07-29 16:41:43 +02:00
|
|
|
cc110x_gdo2_irq();
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|
2013-07-29 16:41:43 +02:00
|
|
|
|
|
|
|
if (RF1AIV == RF1AIV_RFIFG0) {
|
2010-12-11 12:09:20 +01:00
|
|
|
cc110x_gdo0_irq();
|
2010-12-10 18:00:31 +01:00
|
|
|
RF1AIE &= ~BIT0;
|
2013-07-29 16:41:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
__exit_isr();
|
2010-12-06 12:05:03 +01:00
|
|
|
}
|