1
0
mirror of https://github.com/oliverschmidt/contiki.git synced 2025-01-07 21:31:37 +00:00

Made CC1200 test mode and rx watchdog selectable

This commit is contained in:
Antonio Lignan 2015-09-27 12:29:54 +02:00
parent 222a75426a
commit 50ee33630e
2 changed files with 26 additions and 14 deletions

View File

@ -73,6 +73,17 @@
#define CC1200_MAX_PAYLOAD_LEN 127 #define CC1200_MAX_PAYLOAD_LEN 127
#endif #endif
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
/*
* The RX watchdog is used to check whether the radio is in RX mode at regular
* intervals (once per second). Can be used to improve reliability especially
* if NullRDC is used. Turned of by default.
*/
#ifdef CC1200_CONF_USE_RX_WATCHDOG
#define CC1200_USE_RX_WATCHDOG CC1200_CONF_USE_RX_WATCHDOG
#else
#define CC1200_USE_RX_WATCHDOG 0
#endif
/*---------------------------------------------------------------------------*/
/* /*
* Use 802.15.4g frame format? Supports frame lenghts up to 2047 bytes! * Use 802.15.4g frame format? Supports frame lenghts up to 2047 bytes!
*/ */

View File

@ -57,8 +57,7 @@
* - 3: Print errors + warnings + information (what's going on...) * - 3: Print errors + warnings + information (what's going on...)
*/ */
#define DEBUG_LEVEL 2 #define DEBUG_LEVEL 2
/* If set to 1, we use a timer to poll RX mode inside the cc1200 process */
#define USE_RX_WATCHDOG 1
/* /*
* RF test mode. Blocks inside "configure()". * RF test mode. Blocks inside "configure()".
* - Set this parameter to 1 in order to produce an modulated carrier (PN9) * - Set this parameter to 1 in order to produce an modulated carrier (PN9)
@ -66,14 +65,16 @@
* - Set this parameter to 3 in order to switch to rx synchronous mode * - Set this parameter to 3 in order to switch to rx synchronous mode
* The channel is set according to CC1200_DEFAULT_CHANNEL * The channel is set according to CC1200_DEFAULT_CHANNEL
*/ */
#define RF_TESTMODE 0 #ifndef CC1200_RF_TESTMODE
#if RF_TESTMODE #define CC1200_RF_TESTMODE 0
#endif
#if CC1200_RF_TESTMODE
#undef CC1200_RF_CFG #undef CC1200_RF_CFG
#if RF_TESTMODE == 1 #if CC1200_RF_TESTMODE == 1
#define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps #define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps
#elif RF_TESTMODE == 2 #elif CC1200_RF_TESTMODE == 2
#define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps #define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps
#elif RF_TESTMODE == 3 #elif CC1200_RF_TESTMODE == 3
#define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps #define CC1200_RF_CFG cc1200_802154g_863_870_fsk_50kbps
#endif #endif
#endif #endif
@ -1442,7 +1443,7 @@ configure(void)
{ {
uint8_t reg; uint8_t reg;
#if RF_TESTMODE #if CC1200_RF_TESTMODE
uint32_t freq; uint32_t freq;
#endif #endif
@ -1471,7 +1472,7 @@ configure(void)
* RF test modes needed during hardware development * RF test modes needed during hardware development
**************************************************************************/ **************************************************************************/
#if (RF_TESTMODE == 1) || (RF_TESTMODE == 2) #if (CC1200_RF_TESTMODE == 1) || (CC1200_RF_TESTMODE == 2)
strobe(CC1200_SFTX); strobe(CC1200_SFTX);
single_write(CC1200_TXFIRST, 0); single_write(CC1200_TXFIRST, 0);
@ -1487,7 +1488,7 @@ configure(void)
printf("RF: Freq1 0x%02x\n", ((uint8_t *)&freq)[1]); printf("RF: Freq1 0x%02x\n", ((uint8_t *)&freq)[1]);
printf("RF: Freq2 0x%02x\n", ((uint8_t *)&freq)[2]); printf("RF: Freq2 0x%02x\n", ((uint8_t *)&freq)[2]);
#if (RF_TESTMODE == 1) #if (CC1200_RF_TESTMODE == 1)
single_write(CC1200_SYNC_CFG1, 0xE8); single_write(CC1200_SYNC_CFG1, 0xE8);
single_write(CC1200_PREAMBLE_CFG1, 0x00); single_write(CC1200_PREAMBLE_CFG1, 0x00);
single_write(CC1200_MDMCFG1, 0x46); single_write(CC1200_MDMCFG1, 0x46);
@ -1498,7 +1499,7 @@ configure(void)
single_write(CC1200_FS_DVC0, 0x17); single_write(CC1200_FS_DVC0, 0x17);
#endif #endif
#if (RF_TESTMODE == 2) #if (CC1200_RF_TESTMODE == 2)
single_write(CC1200_SYNC_CFG1, 0xE8); single_write(CC1200_SYNC_CFG1, 0xE8);
single_write(CC1200_PREAMBLE_CFG1, 0x00); single_write(CC1200_PREAMBLE_CFG1, 0x00);
single_write(CC1200_MDMCFG1, 0x06); single_write(CC1200_MDMCFG1, 0x06);
@ -1513,7 +1514,7 @@ configure(void)
strobe(CC1200_STX); strobe(CC1200_STX);
while(1) { while(1) {
#if (RF_TESTMODE == 1) #if (CC1200_RF_TESTMODE == 1)
watchdog_periodic(); watchdog_periodic();
BUSYWAIT_UNTIL(0, RTIMER_SECOND / 10); BUSYWAIT_UNTIL(0, RTIMER_SECOND / 10);
leds_off(LEDS_YELLOW); leds_off(LEDS_YELLOW);
@ -1534,7 +1535,7 @@ configure(void)
#endif #endif
} }
#elif (RF_TESTMODE == 3) #elif (CC1200_RF_TESTMODE == 3)
/* CS on GPIO3 */ /* CS on GPIO3 */
single_write(CC1200_IOCFG3, CC1200_IOCFG_CARRIER_SENSE); single_write(CC1200_IOCFG3, CC1200_IOCFG_CARRIER_SENSE);
@ -1568,7 +1569,7 @@ configure(void)
} }
#endif /* #if RF_TESTMODE == ... */ #endif /* #if CC1200_RF_TESTMODE == ... */
/*************************************************************************** /***************************************************************************
* Set the stuff we need for this driver to work. Don't touch! * Set the stuff we need for this driver to work. Don't touch!