Contiki 2.5
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  * @(#)$Id: contiki-conf.h,v 1.10 2010/03/18 20:11:54 dak664 Exp $
32  */
33 
34 #ifndef __CONTIKI_CONF_H__
35 #define __CONTIKI_CONF_H__
36 
37 #include <inttypes.h>
38 #include <limits.h>
39 
40 #define CC_CONF_REGISTER_ARGS 1
41 #define CC_CONF_FUNCTION_POINTER_ARGS 1
42 #define CC_CONF_FASTCALL
43 #define CC_CONF_VA_ARGS 1
44 
45 #define CCIF
46 #define CLIF
47 
48 typedef uint8_t u8_t;
49 typedef uint16_t u16_t;
50 typedef uint32_t u32_t;
51 typedef int32_t s32_t;
52 typedef unsigned short uip_stats_t;
53 
54 #if UIP_CONF_IPV6
55 /* The Windows build uses wpcap to connect to a host interface. It finds the interface by scanning for
56  * an address, which can be specified here and overridden with the command line.
57  * An ip4 or ip6 address can be used; this allows turning off the ip4 protocol on the interface.
58  * The existing turorials use an ipv4 address, so we leave that as the default.
59  * Non-windows builds don't use this define.
60  */
61 //#define WPCAP_INTERFACE_ADDRESS "fdfd::1" //10.10.10.10 is the default (even for ipv6)
62 
63 /* Minimal-net gets a 6 byte ethernet MAC assigned in uip.c, currently {0x00,0x06,0x98,0x00,0x02,0x32}
64  * This gets converted to a link layer address of [fe80::206:98ff:fe00:232]
65  * You could change the uip.c address when running multiple instances, however HARD_CODED_ADDRESS
66  * can also specify a different MAC address if any of the last three bytes are non-zero. It can also
67  * specify a prefix if any of the first four longs are nonzero. RPL builds use this to pass a prefix
68  * to the border router and also to ensure it has a different link-layer address from the RPL end node.
69  * HARD_CODED_ADDRESS can also be changed in /platform/minimal-net/contiki-main.c so as not to force complete
70  * rebuilds when making multiple instances of a minimal-net client.
71 */
72 //#define HARD_CODED_ADDRESS "::10" //assign link-layer address fe80::ff:fe00:10, wait for RA or RPL prefix
73 //#define HARD_CODED_ADDRESS "fdfd::" //assign prefix; address becomes fdfd::206:98ff:fe00:232
74 //#define HARD_CODED_ADDRESS "fdfd::10" //assign prefix and ipv6 address fdfd::ff:fe00:10
75 
76 /* The status.shtml page shows addresses, neighbors, and routes on ipv6 builds. Use this define to enable
77  * the needed routines in httpd-cgi.c on the webserver6 build. The status page is present in
78  * /apps/webserver/httpd-fs/ but not in the default /apps/webserver/httpd-fsdata.c file.
79  * To include it run the PERL script /../../tools/makefsdata from the /apps/webserver/ directory.
80  * NB: Webserver builds on all platforms will use the current httpd-fsdata.c file. The added 160 bytes
81  * could overflow memory on the smaller platforms.
82  */
83 #define WEBSERVER_CONF_STATUSPAGE 1
84 
85 /* RPL currently works only on Windows. *nix would require converting the tun interface to two pcap tees. */
86 //#define UIP_CONF_IPV6_RPL 0
87 //#define RPL_BORDER_ROUTER 0
88 #endif
89 
90 #if UIP_CONF_IPV6_RPL
91 /* RPL motes use the uip.c link layer address or optionally the harded coded address (but without the prefix!)
92  * Different instances can be made by changing the link layer portion of HARD_CODED_ADDRESS in contiki-main.c
93  * Rename them to e.g. webserver6.10, webserver6.11, ...
94  * They should all attach to a minimal-net rpl border that uses the same primary interface.
95  * For multihop testing, configure intermediate notes as routers.
96  */
97 #define RPL_CONF_ADJUST_LLH_LEN 1
98 #define HARD_CODED_ADDRESS "bbbb::10" //the prefix is ignored for a rpl node
99 #define UIP_CONF_ROUTER 0
100 #define UIP_CONF_ND6_SEND_RA 0
101 #define UIP_CONF_ND6_REACHABLE_TIME 600000
102 #define UIP_CONF_ND6_RETRANS_TIMER 10000
103 
104 #if RPL_BORDER_ROUTER
105 /* RPL border router accepts packets from the host through the fallback and directs them to
106  * the primary interface. Thus the fallback and rpl dag prefix must be the same. The prefix of
107  * the primary interface does not matter!
108  * Rename this build to e.g. webrouter. Then on Windows create two loopback interfaces, bbbb:: and fdfd::
109  * Attach the RPL end nodes to fdfd:: and the webrouter to fdfd:: with bbbb:: as the fallback.
110  * Direct browser to bbbb::ff:fe00:1/status.html, bbbb::ff:fe00:10/status.html, bbbb::ff:fe00:20/status.html.
111  * The traffic will go through the bbbb:: interface to the router, then out the fdfd:: interface to the end
112  * nodes. The end nodes must be explicitly added as neighbors to avoid a blocking NS
113  * netsh interface ipv6 add neighbor bbbb::ff:fe00:10 33-33-ff-33-44-10 interface=16 (# of the bbbb interface)
114  * netsh interface ipv6 add neighbor bbbb::ff:fe00:20 33-33-ff-33-44-20 interface=16 (# of the bbbb interface)
115  *
116  * Instead of using the fdfd:: loopback it is also possible to attach the border router to another interface,
117  * e.g. the jackdaw RNDIS <-> repeater. Then RPL will configure on the radio network and the RF motes will
118  * be reached through bbbb::<mote link layer address>.
119  * Possibly minimal-net RPL motes could also be added to this interface?
120  *
121  */
122 #undef UIP_CONF_ROUTER
123 #define UIP_CONF_ROUTER 1
124 //#define RPL_CONF_STATS 0
125 //#define UIP_CONF_BUFFER_SIZE 1300
126 #undef UIP_FALLBACK_INTERFACE
127 #define UIP_FALLBACK_INTERFACE rpl_interface
128 //#define WPCAP_FALLBACK_ADDRESS "bbbb::1" //bbbb::1 is the default fallback prefix
129 #undef HARD_CODED_ADDRESS
130 #define HARD_CODED_ADDRESS "bbbb::1" //bbbb::ff:fe00:1 is the RPL border router default
131 //#define UIP_CONF_ND6_SEND_RA 0
132 //#define UIP_CONF_ND6_REACHABLE_TIME 600000
133 //#define UIP_CONF_ND6_RETRANS_TIMER 10000
134 #endif
135 
136 #endif
137 
138 #define UIP_CONF_MAX_LISTENPORTS 40
139 #define UIP_CONF_MAX_CONNECTIONS 40
140 #define UIP_CONF_BYTE_ORDER UIP_LITTLE_ENDIAN
141 #define UIP_CONF_TCP_SPLIT 0
142 #define UIP_CONF_IP_FORWARD 0
143 #define UIP_CONF_LOGGING 0
144 #define UIP_CONF_UDP_CHECKSUMS 0
145 
146 /* Not used but avoids compile errors while sicslowpan.c is being developed */
147 #define SICSLOWPAN_CONF_COMPRESSION SICSLOWPAN_COMPRESSION_HC06
148 
149 #define UIP_CONF_UDP 1
150 #define UIP_CONF_TCP 1
151 
152 #if UIP_CONF_IPV6
153 #define UIP_CONF_IPV6_QUEUE_PKT 1
154 #define UIP_CONF_IPV6_CHECKS 1
155 #define UIP_CONF_IPV6_REASSEMBLY 1
156 //#define UIP_CONF_NETIF_MAX_ADDRESSES 5
157 //#define UIP_CONF_ND6_MAX_PREFIXES 3
158 //#define UIP_CONF_ND6_MAX_NEIGHBORS 40
159 //#define UIP_CONF_ND6_MAX_DEFROUTERS 2
160 #define UIP_CONF_DS6_NBR_NBU 100
161 #define UIP_CONF_DS6_DEFRT_NBU 2
162 #define UIP_CONF_DS6_PREFIX_NBU 5
163 #define UIP_CONF_DS6_ROUTE_NBU 100
164 #define UIP_CONF_DS6_ADDR_NBU 10
165 #define UIP_CONF_DS6_MADDR_NBU 0
166 #define UIP_CONF_DS6_AADDR_NBU 0
167 #endif /* UIP_CONF_IPV6 */
168 
169 typedef unsigned long clock_time_t;
170 #define CLOCK_CONF_SECOND 1000
171 #define INFINITE_TIME ULONG_MAX
172 
173 #define LOG_CONF_ENABLED 1
174 
175 /* Not part of C99 but actually present */
176 int strcasecmp(const char*, const char*);
177 
178 #endif /* __CONTIKI_CONF_H__ */