Contiki 3.x
contiki-conf.h
1 /*
2  * Copyright (c) 2005, Swedish Institute of Computer Science
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the Institute nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  * This file is part of the Contiki operating system.
30  *
31  */
32 
33 #ifndef CONTIKI_CONF_H_
34 #define CONTIKI_CONF_H_
35 
36 #include <inttypes.h>
37 #include <limits.h>
38 
39 #define CC_CONF_REGISTER_ARGS 1
40 #define CC_CONF_FUNCTION_POINTER_ARGS 1
41 #define CC_CONF_FASTCALL
42 #define CC_CONF_VA_ARGS 1
43 
44 #define CCIF
45 #define CLIF
46 
47 #ifndef EEPROM_CONF_SIZE
48 #define EEPROM_CONF_SIZE 1024
49 #endif
50 
51 /* These names are deprecated, use C99 names. */
52 typedef uint8_t u8_t;
53 typedef uint16_t u16_t;
54 typedef uint32_t u32_t;
55 typedef int32_t s32_t;
56 
57 typedef unsigned short uip_stats_t;
58 
59 
60 #if UIP_CONF_IPV6
61 /* The Windows build uses wpcap to connect to a host interface. It finds the interface by scanning for
62  * an address, which can be specified here and overridden with the command line.
63  * An ip4 or ip6 address can be used; this allows turning off the ip4 protocol on the interface.
64  * The existing turorials use an ipv4 address, so we leave that as the default.
65  * Non-windows builds don't use this define.
66  */
67 //#define WPCAP_INTERFACE_ADDRESS "fdfd::1" //10.10.10.10 is the default (even for ipv6)
68 
69 /* Minimal-net gets a 6 byte ethernet MAC assigned in uip.c, currently {0x00,0x06,0x98,0x00,0x02,0x32}
70  * This gets converted to a link layer address of [fe80::206:98ff:fe00:232]
71  * You could change the uip.c address when running multiple instances, however HARD_CODED_ADDRESS
72  * can also specify a different MAC address if any of the last three bytes are non-zero. It can also
73  * specify a prefix if any of the first four longs are nonzero. RPL builds use this to pass a prefix
74  * to the border router and also to ensure it has a different link-layer address from the RPL end node.
75  * HARD_CODED_ADDRESS can also be changed in /platform/minimal-net/contiki-main.c so as not to force complete
76  * rebuilds when making multiple instances of a minimal-net client.
77 */
78 //#define HARD_CODED_ADDRESS "::10" //assign link-layer address fe80::ff:fe00:10, wait for RA or RPL prefix
79 //#define HARD_CODED_ADDRESS "fdfd::" //assign prefix; address becomes fdfd::206:98ff:fe00:232
80 //#define HARD_CODED_ADDRESS "fdfd::10" //assign prefix and ipv6 address fdfd::ff:fe00:10
81 
82 /* The status.shtml page shows addresses, neighbors, and routes on ipv6 builds. Use this define to enable
83  * the needed routines in httpd-cgi.c on the webserver6 build. The status page is present in
84  * /apps/webserver/httpd-fs/ but not in the default /apps/webserver/httpd-fsdata.c file.
85  * To include it run the PERL script /../../tools/makefsdata from the /apps/webserver/ directory.
86  * NB: Webserver builds on all platforms will use the current httpd-fsdata.c file. The added 160 bytes
87  * could overflow memory on the smaller platforms.
88  */
89 #define WEBSERVER_CONF_STATUSPAGE 1
90 
91 /* RPL currently works only on Windows. *nix would require converting the tun interface to two pcap tees. */
92 //#define UIP_CONF_IPV6_RPL 0
93 //#define RPL_BORDER_ROUTER 0
94 #endif
95 
96 #if UIP_CONF_IPV6_RPL
97 /* RPL motes use the uip.c link layer address or optionally the harded coded address (but without the prefix!)
98  * Different instances can be made by changing the link layer portion of HARD_CODED_ADDRESS in contiki-main.c
99  * Rename them to e.g. webserver6.10, webserver6.11, ...
100  * They should all attach to a minimal-net rpl border that uses the same primary interface.
101  * For multihop testing, configure intermediate notes as routers.
102  */
103 #define HARD_CODED_ADDRESS "bbbb::10" //the prefix is ignored for a rpl node
104 #define UIP_CONF_ROUTER 0
105 #define UIP_CONF_ND6_SEND_RA 0
106 #define UIP_CONF_ND6_REACHABLE_TIME 600000
107 #define UIP_CONF_ND6_RETRANS_TIMER 10000
108 
109 #if RPL_BORDER_ROUTER
110 /* RPL border router accepts packets from the host through the fallback and directs them to
111  * the primary interface. Thus the fallback and rpl dag prefix must be the same. The prefix of
112  * the primary interface does not matter!
113  * Rename this build to e.g. webrouter. Then on Windows create two loopback interfaces, bbbb:: and fdfd::
114  * Attach the RPL end nodes to fdfd:: and the webrouter to fdfd:: with bbbb:: as the fallback.
115  * Direct browser to bbbb::ff:fe00:1/status.html, bbbb::ff:fe00:10/status.html, bbbb::ff:fe00:20/status.html.
116  * The traffic will go through the bbbb:: interface to the router, then out the fdfd:: interface to the end
117  * nodes. The end nodes must be explicitly added as neighbors to avoid a blocking NS
118  * netsh interface ipv6 add neighbor bbbb::ff:fe00:10 33-33-ff-33-44-10 interface=16 (# of the bbbb interface)
119  * netsh interface ipv6 add neighbor bbbb::ff:fe00:20 33-33-ff-33-44-20 interface=16 (# of the bbbb interface)
120  *
121  * Instead of using the fdfd:: loopback it is also possible to attach the border router to another interface,
122  * e.g. the jackdaw RNDIS <-> repeater. Then RPL will configure on the radio network and the RF motes will
123  * be reached through bbbb::<mote link layer address>.
124  * Possibly minimal-net RPL motes could also be added to this interface?
125  *
126  */
127 #undef UIP_CONF_ROUTER
128 #define UIP_CONF_ROUTER 1
129 //#define RPL_CONF_STATS 0
130 //#define UIP_CONF_BUFFER_SIZE 1300
131 #undef UIP_FALLBACK_INTERFACE
132 #define UIP_FALLBACK_INTERFACE rpl_interface
133 //#define WPCAP_FALLBACK_ADDRESS "bbbb::1" //bbbb::1 is the default fallback prefix
134 #undef HARD_CODED_ADDRESS
135 #define HARD_CODED_ADDRESS "bbbb::1" //bbbb::ff:fe00:1 is the RPL border router default
136 //#define UIP_CONF_ND6_SEND_RA 0
137 //#define UIP_CONF_ND6_REACHABLE_TIME 600000
138 //#define UIP_CONF_ND6_RETRANS_TIMER 10000
139 #endif
140 
141 #endif
142 
143 #define UIP_CONF_LLH_LEN 14
144 #define UIP_CONF_MAX_LISTENPORTS 40
145 #define UIP_CONF_MAX_CONNECTIONS 40
146 #define UIP_CONF_BYTE_ORDER UIP_LITTLE_ENDIAN
147 #define UIP_CONF_TCP_SPLIT 0
148 #define UIP_CONF_IP_FORWARD 0
149 #define UIP_CONF_LOGGING 0
150 #define UIP_CONF_UDP_CHECKSUMS 1
151 
152 /* Not used but avoids compile errors while sicslowpan.c is being developed */
153 #define SICSLOWPAN_CONF_COMPRESSION SICSLOWPAN_COMPRESSION_HC06
154 
155 #define UIP_CONF_UDP 1
156 #define UIP_CONF_TCP 1
157 
158 #if UIP_CONF_IPV6
159 #define UIP_CONF_IPV6_QUEUE_PKT 1
160 #define UIP_CONF_IPV6_CHECKS 1
161 #define UIP_CONF_IPV6_REASSEMBLY 1
162 //#define UIP_CONF_NETIF_MAX_ADDRESSES 5
163 //#define UIP_CONF_ND6_MAX_PREFIXES 3
164 //#define UIP_CONF_ND6_MAX_DEFROUTERS 2
165 #define NBR_TABLE_CONF_MAX_NEIGHBORS 100
166 #define UIP_CONF_DS6_DEFRT_NBU 2
167 #define UIP_CONF_DS6_PREFIX_NBU 5
168 #define UIP_CONF_MAX_ROUTES 100
169 #define UIP_CONF_DS6_ADDR_NBU 10
170 #define UIP_CONF_DS6_MADDR_NBU 0
171 #define UIP_CONF_DS6_AADDR_NBU 0
172 #endif /* UIP_CONF_IPV6 */
173 
174 typedef unsigned long clock_time_t;
175 #define CLOCK_CONF_SECOND 1000
176 #define INFINITE_TIME ULONG_MAX
177 
178 #define LOG_CONF_ENABLED 1
179 
180 /* Not part of C99 but actually present */
181 int strcasecmp(const char*, const char*);
182 
183 #endif /* CONTIKI_CONF_H_ */