Contiki-Inga 3.x
params.h
1 #ifndef PARAMS_H_
2 #define PARAMS_H_
3 /* PARAMETER_STORAGE =
4  * 0 Hard coded, minmal program and eeprom usage.
5  * 1 Stored in fixed eeprom locations, rewritten from flash if corrupt.
6  * This allows parameter changes using a hardware programmer or custom application code.
7  * Corruption test is based on channel verify so get the channel before anything else!
8  * 2 Obtained from eeprom using the general settings manager and read from program flash if not present.
9  * Useful for for testing builds without wearing out flash memory.
10  * 3 Obtained from eeprom using the settings manager and rewritten from flash if not present.
11  * This ensures all parameters are present in upper eeprom flash.
12  *
13  * Note the parameters in this file can be changed without forcing a complete rebuild.
14  */
15 #define CONTIKI_CONF_RANDOM_MAC 0 //adds 78 bytes
16 #define CONTIKI_CONF_SETTINGS_MANAGER 0 //adds 1696 bytes
17 
18 #if CONTIKI_CONF_SETTINGS_MANAGER
19 #if MCU_CONF_LOW_WEAR
20 #define PARAMETER_STORAGE 2
21 #else
22 #define PARAMETER_STORAGE 3
23 #endif
24 #else
25 #if MCU_CONF_LOW_WEAR
26 #define PARAMETER_STORAGE 0
27 #else
28 #define PARAMETER_STORAGE 1
29 #endif
30 #endif
31 
32 /* Include settings.h, then dummy out the write routines */
33 #include "settings.h"
34 #if PARAMETER_STORAGE==2
35 #define settings_add(...) 0
36 #define settings_add_uint8(...) 0
37 #define settings_add_uint16(...) 0
38 #endif
39 
40 #if AVR_WEBSERVER
41 /* Webserver builds can set some defaults in httpd-fsdata.c via makefsdata.h */
42 extern uint8_t eemem_mac_address[8];
43 extern uint8_t eemem_server_name[16];
44 extern uint8_t eemem_domain_name[30];
45 #endif
46 
47 #ifdef SERVER_NAME
48 #define PARAMS_SERVERNAME SERVER_NAME
49 #else
50 #define PARAMS_SERVERNAME "ATMEGA128rfa1"
51 #endif
52 #ifdef DOMAIN_NAME
53 #define PARAMS_DOMAINNAME DOMAIN_NAME
54 #else
55 #define PARAMS_DOMAINNAME "localhost"
56 #endif
57 #ifdef NODE_ID
58 #define PARAMS_NODEID NODE_ID
59 #else
60 #define PARAMS_NODEID 0
61 #endif
62 #ifdef CHANNEL_802_15_4
63 #define PARAMS_CHANNEL CHANNEL_802_15_4
64 #else
65 #define PARAMS_CHANNEL 26
66 #endif
67 #ifdef IEEE802154_PANID
68 #define PARAMS_PANID IEEE802154_PANID
69 #else
70 #define PARAMS_PANID 0xABCD
71 #endif
72 #ifdef IEEE802154_PANADDR
73 #define PARAMS_PANADDR IEEE802154_PANADDR
74 #else
75 #define PARAMS_PANADDR 0
76 #endif
77 #ifdef RF230_MAX_TX_POWER
78 #define PARAMS_TXPOWER RF230_MAX_TX_POWER
79 #else
80 #define PARAMS_TXPOWER 0
81 #endif
82 #ifdef EUI64_ADDRESS
83 #define PARAMS_EUI64ADDR EUI64_ADDRESS
84 #else
85 /* This form of of EUI64 mac allows full 6LoWPAN header compression from mac address */
86 #if UIP_CONF_LL_802154
87 //#define PARAMS_EUI64ADDR {0x02, 0xNN, 0xNN, 0xNN, 0xNN, 0xNN, 0xNN, 0xNN}
88 #define PARAMS_EUI64ADDR {0x02, 0x11, 0x22, 0xff, 0xfe, 0x33, 0x44, 0x55}
89 #else
90 //#define PARAMS_EUI64ADDR {0x02, 0xNN, 0xNN, 0xff, 0xfe, 0xNN, 0xNN, 0xNN}
91 #define PARAMS_EUI64ADDR {0x02, 0x12, 0x34, 0xff, 0xfe, 0x56, 0x79, 0x9A}
92 #endif
93 /* This form of of EUI64 mac allows 16 bit 6LoWPAN header compression on multihops */
94 //#define PARAMS_EUI64ADDR {0x02, 0x00, 0x00, 0xff, 0xfe, 0x00, 0xNN, 0xNN}
95 #endif
96 
97 uint8_t params_get_eui64(uint8_t *eui64);
98 #if PARAMETER_STORAGE==0
99 /* Hard coded program flash parameters */
100 #define params_get_servername(...)
101 #define params_get_nodeid(...) PARAMS_NODEID
102 #define params_get_channel(...) PARAMS_CHANNEL
103 #define params_get_panid(...) PARAMS_PANID
104 #define params_get_panaddr(...) PARAMS_PANADDR
105 #define params_get_txpower(...) PARAMS_TXPOWER
106 #else
107 /* Parameters stored in eeprom */
108 uint16_t params_get_nodeid(void);
109 uint8_t params_get_channel(void);
110 uint16_t params_get_panid(void);
111 uint16_t params_get_panaddr(void);
112 uint8_t params_get_txpower(void);
113 #endif
114 
115 #endif /* PARAMS_H_ */