µracoli Manual  Version foo
at86rf231.h
1 /* THIS FILE IS GENERATED by ds2reg.py FROM INPUT Templates/at86rf231.txt */
2 
3 /* Copyright (c) 2008 Axel Wachtler
4  All rights reserved.
5 
6  Redistribution and use in source and binary forms, with or without
7  modification, are permitted provided that the following conditions
8  are met:
9 
10  * Redistributions of source code must retain the above copyright
11  notice, this list of conditions and the following disclaimer.
12  * Redistributions in binary form must reproduce the above copyright
13  notice, this list of conditions and the following disclaimer in the
14  documentation and/or other materials provided with the distribution.
15  * Neither the name of the authors nor the names of its contributors
16  may be used to endorse or promote products derived from this software
17  without specific prior written permission.
18 
19  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
23  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  POSSIBILITY OF SUCH DAMAGE. */
30 
31 /* $Id$ */
36 #ifndef AT86RF231_H
37 #define AT86RF231_H (1)
38 
39 /* === Includes ============================================================== */
40 
41 /* === Externals ============================================================= */
42 
43 /* === Types ================================================================= */
44 
45 typedef uint8_t trx_ramaddr_t;
46 typedef uint8_t trx_regval_t;
47 typedef uint8_t trx_regaddr_t;
48 
49 /* === Macros ================================================================ */
51 #define RG_TRX_STATUS (0x1)
52 
53  #define SR_CCA_DONE 0x1,0x80,7
54 
55  #define SR_CCA_STATUS 0x1,0x40,6
56 
57  #define SR_TRX_STATUS 0x1,0x1f,0
58 #ifndef P_ON
59  #define P_ON (0)
60 #endif /* P_ON */
61 #ifndef BUSY_RX
62  #define BUSY_RX (1)
63 #endif /* BUSY_RX */
64 #ifndef BUSY_TX
65  #define BUSY_TX (2)
66 #endif /* BUSY_TX */
67 #ifndef RX_ON
68  #define RX_ON (6)
69 #endif /* RX_ON */
70 #ifndef TRX_OFF
71  #define TRX_OFF (8)
72 #endif /* TRX_OFF */
73 #ifndef PLL_ON
74  #define PLL_ON (9)
75 #endif /* PLL_ON */
76 #ifndef TRX_SLEEP
77  #define TRX_SLEEP (15)
78 #endif /* TRX_SLEEP */
79 #ifndef BUSY_RX_AACK
80  #define BUSY_RX_AACK (17)
81 #endif /* BUSY_RX_AACK */
82 #ifndef BUSY_TX_ARET
83  #define BUSY_TX_ARET (18)
84 #endif /* BUSY_TX_ARET */
85 #ifndef RX_AACK_ON
86  #define RX_AACK_ON (22)
87 #endif /* RX_AACK_ON */
88 #ifndef TX_ARET_ON
89  #define TX_ARET_ON (25)
90 #endif /* TX_ARET_ON */
91 #ifndef RX_ON_NOCLK
92  #define RX_ON_NOCLK (28)
93 #endif /* RX_ON_NOCLK */
94 #ifndef RX_AACK_ON_NOCLK
95  #define RX_AACK_ON_NOCLK (29)
96 #endif /* RX_AACK_ON_NOCLK */
97 #ifndef BUSY_RX_AACK_NOCLK
98  #define BUSY_RX_AACK_NOCLK (30)
99 #endif /* BUSY_RX_AACK_NOCLK */
100 
101 #define RG_TRX_STATE (0x2)
102 
103  #define SR_TRAC_STATUS 0x2,0xe0,5
104 #ifndef TRAC_SUCCESS
105  #define TRAC_SUCCESS (0)
106 #endif /* TRAC_SUCCESS */
107 #ifndef TRAC_SUCCESS_DATA_PENDING
108  #define TRAC_SUCCESS_DATA_PENDING (1)
109 #endif /* TRAC_SUCCESS_DATA_PENDING */
110 #ifndef TRAC_SUCCESS_WAIT_FOR_ACK
111  #define TRAC_SUCCESS_WAIT_FOR_ACK (2)
112 #endif /* TRAC_SUCCESS_WAIT_FOR_ACK */
113 #ifndef TRAC_CHANNEL_ACCESS_FAILURE
114  #define TRAC_CHANNEL_ACCESS_FAILURE (3)
115 #endif /* TRAC_CHANNEL_ACCESS_FAILURE */
116 #ifndef TRAC_NO_ACK
117  #define TRAC_NO_ACK (5)
118 #endif /* TRAC_NO_ACK */
119 #ifndef TRAC_INVALID
120  #define TRAC_INVALID (7)
121 #endif /* TRAC_INVALID */
122 
123  #define SR_TRX_CMD 0x2,0x1f,0
124 #ifndef CMD_NOP
125  #define CMD_NOP (0)
126 #endif /* CMD_NOP */
127 #ifndef CMD_TX_START
128  #define CMD_TX_START (2)
129 #endif /* CMD_TX_START */
130 #ifndef CMD_FORCE_TRX_OFF
131  #define CMD_FORCE_TRX_OFF (3)
132 #endif /* CMD_FORCE_TRX_OFF */
133 #ifndef CMD_RX_ON
134  #define CMD_RX_ON (6)
135 #endif /* CMD_RX_ON */
136 #ifndef CMD_TRX_OFF
137  #define CMD_TRX_OFF (8)
138 #endif /* CMD_TRX_OFF */
139 #ifndef CMD_PLL_ON
140  #define CMD_PLL_ON (9)
141 #endif /* CMD_PLL_ON */
142 #ifndef CMD_RX_AACK_ON
143  #define CMD_RX_AACK_ON (22)
144 #endif /* CMD_RX_AACK_ON */
145 #ifndef CMD_TX_ARET_ON
146  #define CMD_TX_ARET_ON (25)
147 #endif /* CMD_TX_ARET_ON */
148 
149 #define RG_TRX_CTRL_0 (0x3)
150 
151  #define SR_PAD_IO 0x3,0xe0,5
152 
153  #define SR_PAD_IO_CLKM 0x3,0x10,4
154 #ifndef CLKM_2mA
155  #define CLKM_2mA (0)
156 #endif /* CLKM_2mA */
157 #ifndef CLKM_4mA
158  #define CLKM_4mA (1)
159 #endif /* CLKM_4mA */
160 #ifndef CLKM_6mA
161  #define CLKM_6mA (2)
162 #endif /* CLKM_6mA */
163 #ifndef CLKM_8mA
164  #define CLKM_8mA (3)
165 #endif /* CLKM_8mA */
166 
167  #define SR_CLKM_SHA_SEL 0x3,0x8,3
168 
169  #define SR_CLKM_CTRL 0x3,0x7,0
170 #ifndef CLKM_no_clock
171  #define CLKM_no_clock (0)
172 #endif /* CLKM_no_clock */
173 #ifndef CLKM_1MHz
174  #define CLKM_1MHz (1)
175 #endif /* CLKM_1MHz */
176 #ifndef CLKM_2MHz
177  #define CLKM_2MHz (2)
178 #endif /* CLKM_2MHz */
179 #ifndef CLKM_4MHz
180  #define CLKM_4MHz (3)
181 #endif /* CLKM_4MHz */
182 #ifndef CLKM_8MHz
183  #define CLKM_8MHz (4)
184 #endif /* CLKM_8MHz */
185 #ifndef CLKM_16MHz
186  #define CLKM_16MHz (5)
187 #endif /* CLKM_16MHz */
188 
189 #define RG_TRX_CTRL_1 (0x4)
190 
191  #define SR_PA_EXT_EN 0x4,0x80,7
192 
193  #define SR_IRQ_2_EXT_EN 0x4,0x40,6
194 
195  #define SR_TX_AUTO_CRC_ON 0x4,0x20,5
196 
197  #define SR_RX_BL_CTRL 0x4,0x10,4
198 
199  #define SR_SPI_CMD_MODE 0x4,0xc,2
200 
201  #define SR_IRQ_POLARITY 0x4,0x1,0
202 
203  #define SR_IRQ_MASK_MODE 0x4,0x2,1
204 
205 #define RG_PHY_TX_PWR (0x5)
206 
207  #define SR_PA_BUF_LT 0x5,0xc0,6
208 
209  #define SR_PA_LT 0x5,0x30,4
210 
211  #define SR_TX_PWR 0x5,0xf,0
212 
213 #define RG_PHY_RSSI (0x6)
214 
215  #define SR_RX_CRC_VALID 0x6,0x80,7
216 
217  #define SR_RND_VALUE 0x6,0x60,5
218 
219  #define SR_RSSI 0x6,0x1f,0
220 
221 #define RG_PHY_ED_LEVEL (0x7)
222 
223  #define SR_ED_LEVEL 0x7,0xff,0
224 
225 #define RG_PHY_CC_CCA (0x8)
226 
227  #define SR_CCA_REQUEST 0x8,0x80,7
228 
229  #define SR_CCA_MODE 0x8,0x60,5
230 
231  #define SR_CHANNEL 0x8,0x1f,0
232 
233 #define RG_CCA_THRES (0x9)
234 
235  #define SR_CCA_ED_THRES 0x9,0xf,0
236 
237 #define RG_RX_CTRL (0xa)
238 
239  #define SR_PDT_THRES 0xa,0xf,0
240 
241 #define RG_SFD_VALUE (0xb)
242 
243  #define SR_SFD_VALUE 0xb,0xff,0
244 
245 #define RG_TRX_CTRL_2 (0xc)
246 
247  #define SR_RX_SAFE_MODE 0xc,0x80,7
248 
249  #define SR_OQPSK_DATA_RATE 0xc,0x3,0
250 
251 #define RG_ANT_DIV (0xd)
252 
253  #define SR_ANT_SEL 0xd,0x80,7
254 
255  #define SR_ANT_DIV_EN 0xd,0x8,3
256 
257  #define SR_ANT_EXT_SW_EN 0xd,0x4,2
258 
259  #define SR_ANT_CTRL 0xd,0x3,0
260 
261 #define RG_IRQ_MASK (0xe)
262 
263  #define SR_MASK_BAT_LOW 0xe,0x80,7
264 
265  #define SR_MASK_TRX_UR 0xe,0x40,6
266 
267  #define SR_MASK_AMI 0xe,0x20,5
268 
269  #define SR_MASK_CCA_ED_READY 0xe,0x10,4
270 
271  #define SR_MASK_TRX_END 0xe,0x8,3
272 
273  #define SR_MASK_TRX_START 0xe,0x4,2
274 
275  #define SR_MASK_PLL_LOCK 0xe,0x1,0
276 
277  #define SR_MASK_PLL_UNLOCK 0xe,0x2,1
278 
279 #define RG_IRQ_STATUS (0xf)
280 
281  #define SR_BAT_LOW 0xf,0x80,7
282 
283  #define SR_TRX_UR 0xf,0x40,6
284 
285  #define SR_AMI 0xf,0x20,5
286 
287  #define SR_CCA_ED_READY 0xf,0x10,4
288 
289  #define SR_RX_END 0xf,0x8,3
290 
291  #define SR_RX_START 0xf,0x4,2
292 
293  #define SR_PLL_LOCK 0xf,0x1,0
294 
295  #define SR_PLL_UNLOCK 0xf,0x2,1
296 
297 #define RG_VREG_CTRL (0x10)
298 
299  #define SR_AVREG_EXT 0x10,0x80,7
300 
301  #define SR_AVDD_OK 0x10,0x40,6
302 
303  #define SR_DVREG_EXT 0x10,0x8,3
304 
305  #define SR_DVDD_OK 0x10,0x4,2
306 
307 #define RG_BATMON (0x11)
308 
309  #define SR_BATMON_OK 0x11,0x20,5
310 
311  #define SR_BATMON_HR 0x11,0x10,4
312 
313  #define SR_BATMON_VTH 0x11,0xf,0
314 
315 #define RG_XOSC_CTRL (0x12)
316 
317  #define SR_XTAL_MODE 0x12,0xf0,4
318 
319  #define SR_XTAL_TRIM 0x12,0xf,0
320 
321 #define RG_RX_SYN (0x15)
322 
323  #define SR_RX_PDT_DIS 0x15,0x80,7
324 
325  #define SR_RX_PDT_LEVEL 0x15,0xf,0
326 
327 #define RG_XAH_CTRL_1 (0x17)
328 
329  #define SR_AACK_FLTR_RES_FT 0x17,0x20,5
330 
331  #define SR_AACK_UPLD_RES_FT 0x17,0x10,4
332 
333  #define SR_AACK_ACK_TIME 0x17,0x4,2
334 
335  #define SR_AACK_PROM_MODE 0x17,0x2,1
336 
337 #define RG_FTN_CTRL (0x18)
338 
339  #define SR_FTN_START 0x18,0x80,7
340 
341 #define RG_PLL_CF (0x1a)
342 
343  #define SR_PLL_CF_START 0x1a,0x80,7
344 
345 #define RG_PLL_DCU (0x1b)
346 
347  #define SR_PLL_DCU_START 0x1b,0x80,7
348 
349 #define RG_PART_NUM (0x1c)
350 
351  #define SR_PART_NUM 0x1c,0xff,0
352 #ifndef RF231A_PART_NUM
353  #define RF231A_PART_NUM (3)
354 #endif /* RF231A_PART_NUM */
355 
356 #define RG_VERSION_NUM (0x1d)
357 
358  #define SR_VERSION_NUM 0x1d,0xff,0
359 #ifndef RF231A_VERSION_NUM
360  #define RF231A_VERSION_NUM (2)
361 #endif /* RF231A_VERSION_NUM */
362 
363 #define RG_MAN_ID_0 (0x1e)
364 
365  #define SR_MAN_ID_0 0x1e,0xff,0
366 
367 #define RG_MAN_ID_1 (0x1f)
368 
369  #define SR_MAN_ID_1 0x1f,0xff,0
370 
371 #define RG_SHORT_ADDR_0 (0x20)
372 
373  #define SR_SHORT_ADDR_0 0x20,0xff,0
374 
375 #define RG_SHORT_ADDR_1 (0x21)
376 
377  #define SR_SHORT_ADDR_1 0x21,0xff,0
378 
379 #define RG_PAN_ID_0 (0x22)
380 
381  #define SR_PAN_ID_0 0x22,0xff,0
382 
383 #define RG_PAN_ID_1 (0x23)
384 
385  #define SR_PAN_ID_1 0x23,0xff,0
386 
387 #define RG_IEEE_ADDR_0 (0x24)
388 
389  #define SR_IEEE_ADDR_0 0x24,0xff,0
390 
391 #define RG_IEEE_ADDR_1 (0x25)
392 
393  #define SR_IEEE_ADDR_1 0x25,0xff,0
394 
395 #define RG_IEEE_ADDR_2 (0x26)
396 
397  #define SR_IEEE_ADDR_2 0x26,0xff,0
398 
399 #define RG_IEEE_ADDR_3 (0x27)
400 
401  #define SR_IEEE_ADDR_3 0x27,0xff,0
402 
403 #define RG_IEEE_ADDR_4 (0x28)
404 
405  #define SR_IEEE_ADDR_4 0x28,0xff,0
406 
407 #define RG_IEEE_ADDR_5 (0x29)
408 
409  #define SR_IEEE_ADDR_5 0x29,0xff,0
410 
411 #define RG_IEEE_ADDR_6 (0x2a)
412 
413  #define SR_IEEE_ADDR_6 0x2a,0xff,0
414 
415 #define RG_IEEE_ADDR_7 (0x2b)
416 
417  #define SR_IEEE_ADDR_7 0x2b,0xff,0
418 
419 #define RG_XAH_CTRL_0 (0x2c)
420 
421  #define SR_MAX_FRAME_RETRES 0x2c,0xf0,4
422 
423  #define SR_SLOTTED_OPERATION 0x2c,0x1,0
424 
425  #define SR_MAX_CSMA_RETRES 0x2c,0xe,1
426 
427 #define RG_CSMA_SEED_0 (0x2d)
428 
429  #define SR_CSMA_SEED_0 0x2d,0xff,0
430 
431 #define RG_CSMA_SEED_1 (0x2e)
432 
433  #define SR_AACK_FVN_MODE 0x2e,0xc0,6
434 
435  #define SR_AACK_SET_PD 0x2e,0x20,5
436 
437  #define SR_AACK_DIS_ACK 0x2e,0x10,4
438 
439  #define SR_AACK_I_AM_COORD 0x2e,0x8,3
440 
441  #define SR_CSMA_SEED_1 0x2e,0x7,0
442 
443 #define RG_CSMA_BE (0x2f)
444 
445  #define SR_MAX_BE 0x2f,0xf0,4
446 
447  #define SR_MIN_BE 0x2f,0xf,0
448 
449 #define RADIO_NAME "AT86RF231"
450 
451 #define RADIO_PART_NUM (RF231A_PART_NUM)
452 
453 #define RADIO_VERSION_NUM (RF231A_VERSION_NUM)
454 
456 #define TRX_CMD_RW (_BV(7) | _BV(6))
457 
458 #define TRX_CMD_RR (_BV(7))
459 
460 #define TRX_CMD_FW (_BV(6) | _BV(5))
461 
462 #define TRX_CMD_FR (_BV(5))
463 
464 #define TRX_CMD_SW (_BV(6))
465 
466 #define TRX_CMD_SR (0)
467 
468 #define TRX_CMD_RADDR_MASK (0x3f)
469 
471 #define TRX_RESET_TIME_US (6)
472 
474 #define TRX_INIT_TIME_US (510)
475 
477 #define TRX_PLL_LOCK_TIME_US (180)
478 
479 
481 #define TRX_CCA_TIME_US (140)
482 
484 #define TRX_IRQ_PLL_LOCK _BV(0)
485 
487 #define TRX_IRQ_PLL_UNLOCK _BV(1)
488 
490 #define TRX_IRQ_RX_START _BV(2)
491 
493 #define TRX_IRQ_TRX_END _BV(3)
494 
496 #define TRX_IRQ_CCA_ED _BV(4)
497 
499 #define TRX_IRQ_AMI _BV(5)
500 
502 #define TRX_IRQ_UR _BV(6)
503 
505 #define TRX_IRQ_BAT_LOW _BV(7)
506 
508 #define TRAC_SUCCESS (0)
509 
510 #define TRAC_CHANNEL_ACCESS_FAILURE (3)
511 
512 #define TRAC_NO_ACK (5)
513 
514 
516 #define TRX_MIN_CHANNEL (11)
517 
519 #define TRX_MAX_CHANNEL (26)
520 
522 #define TRX_NB_CHANNELS (16)
523 
528 #define TRX_SUPPORTED_CHANNELS (0x7fff800UL)
529 
530 #define TRX_SUPPORTS_BAND_2400 (1)
531 
535 #define TRX_SUPPORTED_PAGES (42)
536 
538 #define TRX_OQPSK250 (0)
539 
541 #define TRX_OQPSK500 (1)
542 
544 #define TRX_OQPSK1000 (2)
545 
546 #define TRX_OQPSK2000 (3)
547 
548 #define TRX_NONE (255)
549 
550 #endif /* ifndef AT86RF231_H */
uint8_t trx_regaddr_t
Definition: transceiver.h:89
uint8_t trx_regval_t
Definition: transceiver.h:85
uint8_t trx_ramaddr_t
Definition: transceiver.h:81