µracoli Manual
Version foo
µracoli
User Guide
Reference Guide
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 */
trx_regaddr_t
uint8_t trx_regaddr_t
Definition:
transceiver.h:89
trx_regval_t
uint8_t trx_regval_t
Definition:
transceiver.h:85
trx_ramaddr_t
uint8_t trx_ramaddr_t
Definition:
transceiver.h:81
install
inc
at86rf231.h
Generated on Sat Aug 29 2015 08:07:13 for µracoli Manual by
1.8.10