-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSI4707_DEFINITIONS.h
executable file
·155 lines (152 loc) · 9.16 KB
/
SI4707_DEFINITIONS.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
/*
SI4707_DEFINITIONS.h
Si4707 Weather Band Receiver Commands and Property Definitions.
Adapted for use by Arduino by Ray H. Dees & Richard Vogel.
*/
#ifndef SI4707_DEFINITIONS_h
#define SI4707_DEFINITIONS_h
//
// Weather Band definitions.
//
#define WB_CHANNEL_SPACING 0x0A // 25 kHz.
#define WB_MIN_FREQUENCY 0xFDC0 // 162.400 mHz.
#define WB_MAX_FREQUENCY 0xFDFC // 162.550 mHz.
//
// Si4707 Command definitions.
//
#define POWER_UP 0x01 // Powerup device.
#define GET_REV 0x10 // Returns revision information on the device.
#define POWER_DOWN 0x11 // Powerdown device.
#define SET_PROPERTY 0x12 // Sets the value of a property.
#define GET_PROPERTY 0x13 // Retrieves a property’s value.
#define GET_INT_STATUS 0x14 // Read interrupt status bits.
#define PATCH_ARGS 0x15 // Reserved command used for firmware file downloads.
#define PATCH_DATA 0x16 // Reserved command used for firmware file downloads.
#define WB_TUNE_FREQ 0x50 // Selects the WB tuning frequency.
#define WB_TUNE_STATUS 0x52 // Queries the status of the previous WB_TUNE_FREQ command.
#define WB_RSQ_STATUS 0x53 // Queries the status of the Received Signal Quality (RSQ) of the current channel.
#define WB_SAME_STATUS 0x54 // Returns SAME information for the current channel.
#define WB_ASQ_STATUS 0x55 // Queries the status of the 1050 Hz alert tone.
#define WB_AGC_STATUS 0x57 // Queries the status of the AGC.
#define WB_AGC_OVERRIDE 0x58 // Enable or disable the AGC.
#define GPIO_CTL 0x80 // Configures GPO as output or Hi-Z.
#define GPIO_SET 0X81 // Sets GPO output level (low or high).
//
// Si4707 Property definitions.
//
#define GPO_IEN 0x0001 // Enables GPO2 interrupt sources.
#define REFCLK_FREQ 0x0201 // Sets frequency of reference clock in Hz.
#define REFCLK_PRESCALE 0x0202 // Sets the prescaler value for RCLK input.
#define RX_VOLUME 0x4000 // Sets the output volume.
#define RX_HARD_MUTE 0x4001 // Mutes the audio output.
#define WB_MAX_TUNE_ERROR 0x5108 // Maximum change from the WB_TUNE_FREQ to which the AFC will lock.
#define WB_RSQ_INT_SOURCE 0x5200 // Configures interrupts related to RSQ metrics.
#define WB_RSQ_SNR_HIGH_THRESHOLD 0x5201 // Sets high threshold for SNR interrupt.
#define WB_RSQ_SNR_LOW_THRESHOLD 0x5202 // Sets low threshold for SNR interrupt.
#define WB_RSQ_RSSI_HIGH_THRESHOLD 0x5203 // Sets high threshold for RSSI interrupt.
#define WB_RSQ_RSSI_LOW_THRESHOLD 0x5204 // Sets low threshold for RSSI interrupt.
#define WB_VALID_SNR_THRESHOLD 0x5403 // Sets SNR threshold to indicate a valid channel.
#define WB_VALID_RSSI_THRESHOLD 0x5404 // Sets RSSI threshold to indicate a valid channel.
#define WB_SAME_INTERRUPT_SOURCE 0x5500 // Configures SAME interrupt sources.
#define WB_ASQ_INT_SOURCE 0x5600 // Configures 1050 Hz alert tone interrupts.
//
// Si4707 Power Up Command Arguments.
//
#define WB 0x03 // Function, 3 = WB receive.
#define QUERY 0x0F // Function, 15 = Query Library ID.
#define XOSCEN 0x10 // Crystal Oscillator Enable.
#define PATCH 0x20 // Patch Enable.
#define GPO2EN 0x40 // GPO2 Output Enable.
#define CTSEN 0x80 // CTS Interrupt Enable.
//
#define OPMODE 0x05 // Application Setting, 5 = Analog L & R outputs.
//
// Si4707 Returned Interrupt Status Bits.
//
#define STCINT 0x01 // Seek/Tune Complete Interrupt.
#define ASQINT 0x02 // 1050 Hz Alert Tone Interrupt.
#define SAMEINT 0x04 // SAME Interrupt.
#define RSQINT 0x08 // Received Signal Quality Interrupt.
#define ERRINT 0x40 // Error Interrupt.
#define CTSINT 0x80 // Clear To Send Interrupt.
//
// Si4707 Status Register Masks.
//
#define VALID 0x01 // Valid Channel.
#define AFCRL 0x02 // AFC Rail Indicator.
//
#define RSSILINT 0x01 // RSSI was Detected Low.
#define RSSIHINT 0x02 // RSSI was Detected High.
#define SNRLINT 0x04 // SNR was Detected Low.
#define SNRHINT 0x08 // SNR was Detected High.
//
#define HDRRDY 0x01 // SAME Header Ready was detected.
#define PREDET 0x02 // SAME Preamble was Detected.
#define SOMDET 0x04 // SAME Start Of Message was Detected.
#define EOMDET 0x08 // SAME End Of Message was Detected.
//
#define ALERTON 0x01 // Alert Tone has not been detected on since last WB_TUNE_FREQ.
#define ALERTOF 0x02 // Alert Tone has not been detected off since last WB_TUNE_FREQ.
#define ALERT 0x01 // Alert Tone is currently present.
//
// Si4707 Interrupt Acknowledge Commands.
//
#define CHECK 0x00 // Allows checking of status without clearing interrupt.
#define INTACK 0x01 // If set, this bit clears the current interrupt.
#define CLRBUF 0x02 // If set, the SAME buffer is cleared.
//
// Si4707 Sources for GPO2/INT Interrupt pin.
//
#define STCIEN 0x0001 // Seek/Tune Complete Interrupt Enable.
#define ASQIEN 0x0002 // ASQ Interrupt Enable.
#define SAMEIEN 0x0004 // SAME Interrupt Enable.
#define RSQIEN 0x0008 // RSQ Interrupt Enable.
#define ERRIEN 0x0040 // Error Interrupt Enable.
#define CTSIEN 0x0080 // CTS Interrupt Enable.
#define STCREP 0X0100 // Repeat STCINT even if it is already set.
#define ASQREP 0x0200 // Repeat ASQINT even if it is already set.
#define SAMEREP 0x0400 // Repeat SAMEINT even if it is already set.
#define RSQREP 0x0800 // Repeat RSQINT even if it is already set.
//
#define RSSILIEN 0x0001 // RSSI detect Low Interrupt Enable.
#define RSSIHIEN 0x0002 // RSSI detect High Interrupt Enable.
#define SNRLIEN 0x0004 // SNR detect Low Interrupt Enable.
#define SNRHIEN 0x0008 // SNR detect High Interrupt Enable.
//
#define HDRRDYIEN 0x0001 // SAME Header Ready Interrupt Enable.
#define PREDETIEN 0x0002 // SAME Preamble Detected Interrupt Enable.
#define SOMDETIEN 0x0004 // SAME Start Of Message Detected Interrupt Enable.
#define EOMDETIEN 0x0008 // SAME End Of Message Detected Interrupt Enable.
//
#define ALERTONIEN 0x0001 // Sets 1050 Hz tone on as source of ASQ Interrupt.
#define ALERTOFIEN 0x0002 // Sets 1050 Hz tone off as source of ASQ Interrupt.
//
// Si4707 GPO Control / Set Functions.
//
#define GPO1OEN 0x02 // GPO1 Output Enable.
#define GPO2OEN 0x04 // GPO2 Output Enable. The use of GPO2 as an interrupt pin will override this.
#define GPO3OEN 0x08 // GPO3 Output Enable.
#define GPO1LEVEL 0x02 // Sets GPO1 High.
#define GPO2LEVEL 0x04 // Sets GPO2 High.
#define GPO3LEVEL 0x08 // Sets GPO3 High.
//
// SAME Confidence Level Masks and Bit Shift Positions.
//
#define SAME_STATUS_OUT_CONF0 0x03
#define SAME_STATUS_OUT_CONF1 0x0C
#define SAME_STATUS_OUT_CONF2 0x30
#define SAME_STATUS_OUT_CONF3 0xC0
#define SAME_STATUS_OUT_CONF4 0x03
#define SAME_STATUS_OUT_CONF5 0x0C
#define SAME_STATUS_OUT_CONF6 0x30
#define SAME_STATUS_OUT_CONF7 0xC0
#define SAME_STATUS_OUT_CONF0_SHFT 0
#define SAME_STATUS_OUT_CONF1_SHFT 2
#define SAME_STATUS_OUT_CONF2_SHFT 4
#define SAME_STATUS_OUT_CONF3_SHFT 6
#define SAME_STATUS_OUT_CONF4_SHFT 0
#define SAME_STATUS_OUT_CONF5_SHFT 2
#define SAME_STATUS_OUT_CONF6_SHFT 4
#define SAME_STATUS_OUT_CONF7_SHFT 6
//
#endif