4 * This file is part of BeRTOS.
6 * Bertos is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 * As a special exception, you may use this file as part of a free software
21 * library without restriction. Specifically, if other files instantiate
22 * templates or use macros or inline functions from this file, or you compile
23 * this file and link it with other files to produce an executable, this
24 * file does not by itself cause the resulting executable to be covered by
25 * the GNU General Public License. This exception does not however
26 * invalidate any other reasons why the executable file might be covered by
27 * the GNU General Public License.
29 * Copyright 2003, 2004, 2006 Develer S.r.l. (http://www.develer.com/)
33 * \brief DevLib configuration options
35 * You should copy this header in your project and rename it to
36 * "config.h" and delete the CONFIG_ macros for the modules
39 * <h2>Working with multiple applications</h2>
41 * If your project is made of multiple DevLib-based applications,
42 * create a custom "config.h" file in each application subdirectory
43 * and play with the compiler include path to get the desired result.
44 * You can share common options by creationg a "config_common.h" header
45 * and including it from all your "config.h" copies.
47 * <h2>Configuration style</h2>
49 * For improved compile-time checking of configuration options,
50 * the preferred way to use a \c CONFIG_ symbol is keeping it
51 * always defined with a value of either 0 or 1. This lets
52 * you write tests like this:
61 * #endif // CONFIG_FOO
64 * In most cases, we rely on the optimizer to discard checks
65 * on constant values and performing dead-code elimination.
68 * \author Bernardo Innocenti <bernie@develer.com>
69 * \author Stefano Fedrigo <aleph@develer.com>
72 #ifndef APPCONFIG_COMMON_H
73 #define APPCONFIG_COMMON_H
76 #define CONFIG_KDEBUG_PORT 0
79 /** Baud-rate for the kdebug console */
80 #define CONFIG_KDEBUG_BAUDRATE 19200
83 * printf()-style formatter configuration.
86 * \sa PRINTF_NOMODIFIERS
91 #define CONFIG_PRINTF PRINTF_FULL
94 * Multithreading kernel.
98 #define CONFIG_KERNEL 0
101 * \name Serial driver parameters
104 /** [bytes] Size of the outbound FIFO buffer for port 0. */
105 #define CONFIG_UART0_TXBUFSIZE 32
107 /** [bytes] Size of the inbound FIFO buffer for port 0. */
108 #define CONFIG_UART0_RXBUFSIZE 64
110 /** [bytes] Size of the outbound FIFO buffer for port 1. */
111 #define CONFIG_UART1_TXBUFSIZE 32
113 /** [bytes] Size of the inbound FIFO buffer for port 1. */
114 #define CONFIG_UART1_RXBUFSIZE 64
116 /** [bytes] Size of the outbound FIFO buffer for SPI port (AVR only). */
117 #define CONFIG_SPI_TXBUFSIZE 16
119 /** [bytes] Size of the inbound FIFO buffer for SPI port (AVR only). */
120 #define CONFIG_SPI_RXBUFSIZE 32
122 /** SPI data order (AVR only). */
123 #define CONFIG_SPI_DATA_ORDER SER_MSB_FIRST
125 /** SPI clock division factor (AVR only). */
126 #define CONFIG_SPI_CLOCK_DIV 16
128 /** SPI clock polarity: 0 = normal low, 1 = normal high (AVR only). */
129 #define CONFIG_SPI_CLOCK_POL 0
131 /** SPI clock phase: 0 = sample on first edge, 1 = sample on second clock edge (AVR only). */
132 #define CONFIG_SPI_CLOCK_PHASE 0
134 /** Default transmit timeout (ms). Set to -1 to disable timeout support */
135 #define CONFIG_SER_TXTIMEOUT -1
137 /** Default receive timeout (ms). Set to -1 to disable timeout support */
138 #define CONFIG_SER_RXTIMEOUT -1
140 /** Use RTS/CTS handshake */
141 #define CONFIG_SER_HWHANDSHAKE 0
143 /** Default baud rate (set to 0 to disable) */
144 #define CONFIG_SER_DEFBAUDRATE 0
146 /** Enable ser_gets() and ser_gets_echo() */
147 #define CONFIG_SER_GETS 0
149 /** Enable second serial port in emulator. */
150 #define CONFIG_EMUL_UART1 0
153 * Transmit always something on serial port 0 TX
154 * to avoid interference when sending burst of data,
155 * using AVR multiprocessor serial mode
157 #define CONFIG_SER_TXFILL 0
159 #define CONFIG_SER_STROBE 0
162 /// Hardware timer selection for drv/timer.c
163 #define CONFIG_TIMER TIMER_ON_OUTPUT_COMPARE2
165 /// Debug timer interrupt using a strobe pin.
166 #define CONFIG_TIMER_STROBE 0
168 /// Enable ADS strobe.
169 #define CONFIG_ADC_STROBE 0
171 /// Enable watchdog timer.
172 #define CONFIG_WATCHDOG 0
174 /// EEPROM type for drv/eeprom.c
175 #define CONFIG_EEPROM_TYPE EEPROM_24XX256
177 /// Select bitmap pixel format.
178 #define CONFIG_BITMAP_FMT BITMAP_FMT_PLANAR_V_LSB
180 /// Enable line clipping algorithm.
181 #define CONFIG_GFX_CLIPPING 1
183 /// Enable text rendering in bitmaps.
184 #define CONFIG_GFX_TEXT 1
186 /// Enable virtual coordinate system.
187 #define CONFIG_GFX_VCOORDS 1
189 /// Keyboard polling method
190 #define CONFIG_KBD_POLL KBD_POLL_SOFTINT
192 /// Enable keyboard event delivery to observers
193 #define CONFIG_KBD_OBSERVER 0
196 #define CONFIG_KBD_BEEP 1
198 /// Enable long pression handler for keys
199 #define CONFIG_KBD_LONGPRESS 1
202 * \name Type for the chart dataset
205 #define CONFIG_CHART_TYPE_X uint8_t
206 #define CONFIG_CHART_TYPE_Y uint8_t
209 /// Enable button bar behind menus
210 #define CONFIG_MENU_MENUBAR 0
212 /// Enable smooth scrolling in menus
213 #define CONFIG_MENU_SMOOTH 1
215 /// Size of block for MD2 algorithm.
216 #define CONFIG_MD2_BLOCK_LEN 16
218 /// Use standard permutation in MD2 algorithm.
219 #define CONFIG_MD2_STD_PERM 0
221 /// Define a size, in byte, of entropy pool.
222 #define CONFIG_SIZE_ENTROPY_POOL 64
224 /// Turn on or off timer support in Randpool.
225 #define CONFIG_RANDPOOL_TIMER 1
227 #endif /* APPCONFIG_H */