Contiki 3.x
contiki-conf.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2006, Technical University of Munich
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 
34 /**
35  * \file
36  * Configuration for sample STK 501 Contiki kernel
37  *
38  * \author
39  * Simon Barner <barner@in.tum.de
40  */
41 
42 #ifndef CONTIKI_CONF_H_
43 #define CONTIKI_CONF_H_
44 
45 #include <stdint.h>
46 
47 //typedef int32_t s32_t;
48 
49 /*
50  * MCU and clock rate
51  */
52  /* Platform name, type, and MCU clock rate */
53 #define PLATFORM_NAME "RCB"
54 #define PLATFORM_TYPE RCB_B
55 #ifndef F_CPU
56 #define F_CPU 8000000UL
57 #endif
58 
59 /* The AVR tick interrupt usually is done with an 8 bit counter around 128 Hz.
60  * 125 Hz needs slightly more overhead during the interrupt, as does a 32 bit
61  * clock_time_t.
62  */
63 /* Clock ticks per second */
64 #define CLOCK_CONF_SECOND 125
65 
66 typedef uint32_t clock_time_t;
67 #define CLOCK_LT(a,b) ((int32_t)((a)-(b)) < 0)
68 
69 /* These routines are not part of the contiki core but can be enabled in cpu/avr/clock.c */
70 void clock_delay_msec(uint16_t howlong);
71 void clock_adjust_ticks(clock_time_t howmany);
72 
73 /* COM port to be used for SLIP connection */
74 #define SLIP_PORT RS232_PORT_0
75 
76 /* Pre-allocated memory for loadable modules heap space (in bytes)*/
77 #define MMEM_CONF_SIZE 256
78 
79 /* Use the following address for code received via the codeprop
80  * facility
81  */
82 #define EEPROMFS_ADDR_CODEPROP 0x8000
83 
84 #define CCIF
85 #define CLIF
86 
87 #define LINKADDR_CONF_SIZE 8
88 
89 /* Uncomment this lines to activate the specific drivers */
90 //#define NETSTACK_CONF_NETWORK rime_driver
91 //#define NETSTACK_CONF_MAC nullmac_driver
92 //#define NETSTACK_CONF_RDC sicslowmac_driver
93 //#define NETSTACK_CONF_FRAMER framer_802154 /* Framer for 802.15.4 Medium Access Control */
94 #define NETSTACK_CONF_RADIO rf230_driver /* Select the wireless driver, otherwise contiki would operate with the "nulldriver" which does nothing */
95 
96 #define RF230_CONF_AUTOACK 1
97 #define CXMAC_CONF_ANNOUNCEMENTS 10
98 #define NETSTACK_CONF_RDC_CHANNEL_CHECK_RATE 8
99 
100 /* 211 bytes per queue buffer. Burst mode will need 15 for a 1280 byte MTU */
101 #define QUEUEBUF_CONF_NUM 15
102 /* 54 bytes per queue ref buffer */
103 #define QUEUEBUF_CONF_REF_NUM 2
104 
105 #define SICSLOWPAN_CONF_COMPRESSION SICSLOWPAN_COMPRESSION_HC06
106 #define SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS 2
107 #define SICSLOWPAN_CONF_FRAG 1
108 
109 #define SICSLOWPAN_CONF_MAXAGE 5
110 
111 #define UIP_CONF_LL_802154 1
112 #define UIP_CONF_LLH_LEN 0
113 
114 #define UIP_CONF_MAX_CONNECTIONS 2
115 #define UIP_CONF_MAX_LISTENPORTS 2
116 #define UIP_CONF_UDP_CONNS 2
117 
118 #define UIP_CONF_IP_FORWARD 0
119 #define UIP_CONF_FWCACHE_SIZE 0
120 
121 #define UIP_CONF_IPV6_CHECKS 1
122 #define UIP_CONF_IPV6_QUEUE_PKT 0
123 #define UIP_CONF_IPV6_REASSEMBLY 0
124 #define UIP_CONF_NETIF_MAX_ADDRESSES 3
125 #if NETSTACK_CONF_WITH_IPV6 //tcpip.c error on ipv4 build if UIP_CONF_ICMP6 defined
126 #define UIP_CONF_ICMP6 1
127 #endif
128 
129 #define UIP_CONF_UDP 1
130 #define UIP_CONF_UDP_CHECKSUMS 1
131 
132 #define UIP_CONF_TCP 1
133 #define UIP_CONF_TCP_SPLIT 0
134 
135 /* These names are deprecated, use C99 names. */
136 /*typedef unsigned char u8_t;
137 typedef unsigned short u16_t;
138 typedef unsigned long u32_t;
139 */
140 typedef unsigned short uip_stats_t;
141 typedef unsigned long off_t;
142 
143 #endif /* CONTIKI_CONF_H_ */
void clock_delay_msec(uint16_t howlong)
Delay up to 65535 milliseconds.
Definition: clock.c:260
void clock_adjust_ticks(clock_time_t howmany)
Adjust the system current clock time.
Definition: clock.c:289