summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2013-04-29 23:53:43 -0700
committerKeith Packard <keithp@keithp.com>2013-05-07 20:07:54 -0700
commit4fe42801f42f2fc2688555f4585dbebc28bb2d61 (patch)
treeefb860f4f4a26740b86c50c9c4de6d40eff822bd /src
parenteb0e1720be2aa4fb6729ceada09c18947bfee2bc (diff)
altos: Reconfigure CC1120 receiver to match our usage
Open up the AGC to the full range. Set the AGC ref based on our receive BW (100kHz). Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src')
-rw-r--r--src/drivers/ao_cc1120.h62
-rw-r--r--src/drivers/ao_cc1120_CC1120.h43
2 files changed, 98 insertions, 7 deletions
diff --git a/src/drivers/ao_cc1120.h b/src/drivers/ao_cc1120.h
index 60b9621e..5d226b64 100644
--- a/src/drivers/ao_cc1120.h
+++ b/src/drivers/ao_cc1120.h
@@ -215,10 +215,72 @@
#define CC1120_AGC_REF 0x17
#define CC1120_AGC_CS_THR 0x18
#define CC1120_AGC_GAIN_ADJUST 0x19
+
#define CC1120_AGC_CFG3 0x1a
+#define CC1120_AGC_CFG3_RSSI_STEP_THR 7
+#define CC1120_AGC_CFG3_AGC_MIN_GAIN 0
+#define CC1120_AGC_CFG3_AGC_MIN_GAIN_MASK 0x1f
+
#define CC1120_AGC_CFG2 0x1b
+#define CC1120_AGC_CFG2_START_PREVIOUS_GAIN_EN 7
+#define CC1120_AGC_CFG2_FE_PERFORMANCE_MODE 5
+#define CC1120_AGC_CFG2_FE_PERFORMANCE_MODE_OPTIMIZE_LINEARITY 0
+#define CC1120_AGC_CFG2_FE_PERFORMANCE_MODE_NORMAL 1
+#define CC1120_AGC_CFG2_FE_PERFORMANCE_MODE_LOW_POWER 2
+#define CC1120_AGC_CFG2_FE_PERFORMANCE_MODE_MASK 3
+#define CC1120_AGC_CFG2_AGC_MAX_GAIN 0
+#define CC1120_AGC_CFG2_AGC_MAX_MASK 0x1f
+
#define CC1120_AGC_CFG1 0x1c
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR 5
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_UPDATE_AGC_UPDATE_RSSI 0
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_FREEZE_AGC_UPDATE_RSSI 1
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_UPDATE_AGC_UPDATE_RSSI_SLOW 2
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_FREEZE_AGC_FREEZE_RSSI 3
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_UPDATE_AGC_UPDATE_RSSI_4 4
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_FREEZE_AGC_FREEZE_RSSI_5 5
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_UPDATE_AGC_UPDATE_RSSI_SLOW_6 6
+#define CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_FREEZE_AGC_FREEZE_RSSI_7 7
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE 2
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_8 0
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_16 1
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_32 2
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_64 3
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_128 4
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_256 5
+#define CC1120_AGC_CFG1_AGC_WIN_SIZE_MASK 7
+#define CC1120_AGC_CFG1_AGC_SETTLE_WAIT 0
+#define CC1120_AGC_CFG1_AGC_SETTLE_WAIT_24 0
+#define CC1120_AGC_CFG1_AGC_SETTLE_WAIT_32 1
+#define CC1120_AGC_CFG1_AGC_SETTLE_WAIT_40 2
+#define CC1120_AGC_CFG1_AGC_SETTLE_WAIT_48 3
+
#define CC1120_AGC_CFG0 0x1d
+
+#define CC1120_AGC_CFG0_AGC_HYST_LEVEL 6
+#define CC1120_AGC_CFG0_AGC_HYST_LEVEL_2 0
+#define CC1120_AGC_CFG0_AGC_HYST_LEVEL_4 1
+#define CC1120_AGC_CFG0_AGC_HYST_LEVEL_7 2
+#define CC1120_AGC_CFG0_AGC_HYST_LEVEL_10 3
+
+#define CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT 4
+#define CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT_60 0
+#define CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT_30 1
+#define CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT_18 2
+#define CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT_9 3
+
+#define CC1120_AGC_CFG0_RSSI_VALID_CNT 2
+#define CC1120_AGC_CFG0_RSSI_VALID_CNT_2 0
+#define CC1120_AGC_CFG0_RSSI_VALID_CNT_3 1
+#define CC1120_AGC_CFG0_RSSI_VALID_CNT_5 2
+#define CC1120_AGC_CFG0_RSSI_VALID_CNT_9 3
+
+#define CC1120_AGC_CFG0_AGC_ASK_DECAY 0
+#define CC1120_AGC_CFG0_AGC_ASK_DECAY_1_16 0
+#define CC1120_AGC_CFG0_AGC_ASK_DECAY_1_32 1
+#define CC1120_AGC_CFG0_AGC_ASK_DECAY_1_64 2
+#define CC1120_AGC_CFG0_AGC_ASK_DECAY_1_128 3
+
#define CC1120_FIFO_CFG 0x1e
#define CC1120_FIFO_CFG_CRC_AUTOFLUSH 7
#define CC1120_FIFO_CFG_FIFO_THR 0
diff --git a/src/drivers/ao_cc1120_CC1120.h b/src/drivers/ao_cc1120_CC1120.h
index 44cca938..399abc4d 100644
--- a/src/drivers/ao_cc1120_CC1120.h
+++ b/src/drivers/ao_cc1120_CC1120.h
@@ -21,6 +21,10 @@
*
***************************************************************/
+#ifndef AO_CC1120_AGC_GAIN_ADJUST
+#define AO_CC1120_AGC_GAIN_ADJUST -80
+#endif
+
CC1120_SYNC3, 0xD3, /* Sync Word Configuration [31:24] */
CC1120_SYNC2, 0x91, /* Sync Word Configuration [23:16] */
CC1120_SYNC1, 0xD3, /* Sync Word Configuration [15:8] */
@@ -53,24 +57,49 @@
(0 << CC1120_MDMCFG1_SINGLE_ADC_EN),
CC1120_MDMCFG0, 0x05, /* General Modem Parameter Configuration */
- CC1120_AGC_REF, 0x20, /* AGC Reference Level Configuration */
- CC1120_AGC_CS_THR, 0x19, /* Carrier Sense Threshold Configuration */
- CC1120_AGC_GAIN_ADJUST, 0x00, /* RSSI Offset Configuration */
- CC1120_AGC_CFG3, 0x91, /* AGC Configuration */
- CC1120_AGC_CFG2, 0x20, /* AGC Configuration */
- CC1120_AGC_CFG1, 0xa9, /* AGC Configuration */
- CC1120_AGC_CFG0, 0xcf, /* AGC Configuration */
+ /* AGC reference = 10 * log10(receive BW) - 4 = 10 * log10(100e3) - 4 = 46 */
+ CC1120_AGC_REF, 46, /* AGC Reference Level Configuration */
+
+ /* Carrier sense threshold - 25dB above the noise */
+ CC1120_AGC_CS_THR, 25, /* Carrier Sense Threshold Configuration */
+ CC1120_AGC_GAIN_ADJUST, /* RSSI Offset Configuration */
+ AO_CC1120_AGC_GAIN_ADJUST,
+
+ CC1120_AGC_CFG3, /* AGC Configuration */
+ (1 << CC1120_AGC_CFG3_RSSI_STEP_THR) |
+ (17 << CC1120_AGC_CFG3_AGC_MIN_GAIN),
+
+ CC1120_AGC_CFG2, /* AGC Configuration */
+ (0 << CC1120_AGC_CFG2_START_PREVIOUS_GAIN_EN) |
+ (CC1120_AGC_CFG2_FE_PERFORMANCE_MODE_NORMAL << CC1120_AGC_CFG2_FE_PERFORMANCE_MODE) |
+ (0 << CC1120_AGC_CFG2_AGC_MAX_GAIN),
+
+ CC1120_AGC_CFG1, /* AGC Configuration */
+ (CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR_UPDATE_AGC_UPDATE_RSSI_SLOW << CC1120_AGC_CFG1_AGC_SYNC_BEHAVIOR) |
+ (CC1120_AGC_CFG1_AGC_WIN_SIZE_32 << CC1120_AGC_CFG1_AGC_WIN_SIZE) |
+ (CC1120_AGC_CFG1_AGC_SETTLE_WAIT_32 << CC1120_AGC_CFG1_AGC_SETTLE_WAIT),
+
+ CC1120_AGC_CFG0, /* AGC Configuration */
+ (CC1120_AGC_CFG0_AGC_HYST_LEVEL_10 << CC1120_AGC_CFG0_AGC_HYST_LEVEL) |
+ (CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT_60 << CC1120_AGC_CFG0_AGC_SLEWRATE_LIMIT) |
+ (CC1120_AGC_CFG0_RSSI_VALID_CNT_9 << CC1120_AGC_CFG0_RSSI_VALID_CNT) |
+ (CC1120_AGC_CFG0_AGC_ASK_DECAY_1_128 << CC1120_AGC_CFG0_AGC_ASK_DECAY),
+
CC1120_FIFO_CFG, /* FIFO Configuration */
(0 << CC1120_FIFO_CFG_CRC_AUTOFLUSH) |
(0x40 << CC1120_FIFO_CFG_FIFO_THR),
+
CC1120_DEV_ADDR, 0x00, /* Device Address Configuration */
+
CC1120_SETTLING_CFG, /* Frequency Synthesizer Calibration and Settling Configuration */
(CC1120_SETTLING_CFG_FS_AUTOCAL_IDLE_TO_ON << CC1120_SETTLING_CFG_FS_AUTOCAL) |
(CC1120_SETTLING_CFG_LOCK_TIME_50_20 << CC1120_SETTLING_CFG_LOCK_TIME) |
(CC1120_SETTLING_CFG_FSREG_TIME_60 << CC1120_SETTLING_CFG_FSREG_TIME),
+
CC1120_FS_CFG, /* Frequency Synthesizer Configuration */
(1 << CC1120_FS_CFG_LOCK_EN) |
(CC1120_FS_CFG_FSD_BANDSELECT_410_480 << CC1120_FS_CFG_FSD_BANDSELECT),
+
CC1120_WOR_CFG1, 0x08, /* eWOR Configuration, Reg 1 */
CC1120_WOR_CFG0, 0x21, /* eWOR Configuration, Reg 0 */
CC1120_WOR_EVENT0_MSB, 0x00, /* Event 0 Configuration */