mirror of
https://github.com/oliverschmidt/contiki.git
synced 2025-01-20 16:32:12 +00:00
d28eb023ef
The CC2538 the WDT cannot be stopped once it has been started. The CC2530/1 WDT can be stopped if it is running in timer mode, but it cannot be stopped once it has been started in watchdog mode. Both platforms currently provide "dummy" implementations of `watchdog_stop()`, one does nothing and the other one basically re-maps `_stop()` to `_periodic()`. This was originally done in order to provide implementations for all prototypes declared in `core/dev/watchdog.h`. In hindsight and as per the discussion in #1088, this is bad practice since, if the build succeeds, the caller will expect that the WDT has in fact been stopped, when in reality it has not. Since the feature (stopping the WDT) is unsupported by the hardware, this pull removes those dummy implementations. Thus, we will now be able to reliably detect - at build time - attempts at using this unsupported feature.
114 lines
3.0 KiB
C
114 lines
3.0 KiB
C
/*
|
|
* \file
|
|
* This file contains a set of configuration for using SDCC as a compiler.
|
|
* This is based on the cc2430 file (which in turn is based on the z80 one)
|
|
*
|
|
* \author
|
|
* Takahide Matsutsuka <markn@markn.org> (Original)
|
|
* George Oikonomou - <oikonomou@users.sourceforge.net>
|
|
* (updates for the cc2530 ports)
|
|
*/
|
|
|
|
#ifndef E051_DEF_H_
|
|
#define E051_DEF_H_
|
|
|
|
#include <stdint.h>
|
|
|
|
/* This port no longer implements the legacy clock_delay. Hack its usages
|
|
* outta the way till it gets phased out completely
|
|
* NB: This also overwrites the prototype so delay_usec() is declared twice */
|
|
#define clock_delay(t) clock_delay_usec(t)
|
|
|
|
/*
|
|
* lint - style defines to help syntax parsers with sdcc-specific 8051 code
|
|
* They don't interfere with actual compilation
|
|
*/
|
|
#if !defined(__SDCC_mcs51) && !defined(SDCC_mcs51)
|
|
#define __data
|
|
#define __xdata
|
|
#define __code
|
|
#define __bit bool
|
|
#define __sfr volatile unsigned char
|
|
#define __sbit volatile bool
|
|
#define __critical
|
|
#define __at(x)
|
|
#define __using(x)
|
|
#define __interrupt(x)
|
|
#define __naked
|
|
#endif
|
|
|
|
#define CC_CONF_FUNCTION_POINTER_ARGS 1
|
|
#define CC_CONF_FASTCALL
|
|
#define CC_CONF_VA_ARGS 1
|
|
#define CC_CONF_UNSIGNED_CHAR_BUGS 0
|
|
#define CC_CONF_REGISTER_ARGS 0
|
|
#define CC_CONF_FUNCTION_POINTER_KEYWORD __reentrant
|
|
#define CC_CONF_NON_BANKED_OPTIMIZATION 1
|
|
|
|
#if (defined(__SDCC_mcs51) || defined(SDCC_mcs51)) && CC_CONF_NON_BANKED_OPTIMIZATION
|
|
#define CC_NON_BANKED __nonbanked
|
|
#else
|
|
#define CC_NON_BANKED
|
|
#endif
|
|
|
|
/*
|
|
* Max Stack Depth manipulation. It is possible to get up to 247 bytes
|
|
* allocated for the stack if:
|
|
* - You set this to 1 and
|
|
* - You have a patched toolchain and
|
|
* - You don't use __bit variables
|
|
* - You do not link libraries using BIT registers (e.g. printf_large)
|
|
* Enabling this will mean ISRs will NOT push bits (#pragma exclude bits) so
|
|
* make sure you know what you're doing
|
|
*
|
|
* More information on the wiki
|
|
*/
|
|
#define CC_CONF_OPTIMIZE_STACK_SIZE 0
|
|
|
|
#if CC_CONF_OPTIMIZE_STACK_SIZE
|
|
#define CC_AT_DATA
|
|
#else
|
|
#define CC_AT_DATA __data
|
|
#endif
|
|
|
|
/* Generic types. */
|
|
typedef unsigned short uip_stats_t;
|
|
|
|
/* Time type. */
|
|
typedef unsigned short clock_time_t;
|
|
#define MAX_TICKS (~((clock_time_t)0) / 2)
|
|
/* Defines tick counts for a second. */
|
|
#define CLOCK_CONF_SECOND 128
|
|
|
|
/* Compiler configurations */
|
|
#define CCIF
|
|
#define CLIF
|
|
|
|
/* Single asm instruction without messing up syntax highlighting */
|
|
#if defined(__SDCC_mcs51) || defined(SDCC_mcs51)
|
|
#define ASM(x) __asm \
|
|
x \
|
|
__endasm
|
|
#else
|
|
#define ASM(x)
|
|
#endif
|
|
|
|
/* Critical section management */
|
|
#define DISABLE_INTERRUPTS() do {EA = 0;} while(0)
|
|
#define ENABLE_INTERRUPTS() do {EA = 1;} while(0)
|
|
|
|
/* Macro for a soft reset. */
|
|
#define SOFT_RESET() do {((void (__code *) (void)) 0x0000) ();} while(0)
|
|
|
|
/* We don't provide architecture-specific checksum calculations */
|
|
#define UIP_ARCH_ADD32 0
|
|
#define UIP_ARCH_CHKSUM 0
|
|
|
|
#define CC_CONF_ASSIGN_AGGREGATE(dest, src) \
|
|
memcpy(dest, src, sizeof(*dest))
|
|
|
|
#define uip_ipaddr_copy(dest, src) \
|
|
memcpy(dest, src, sizeof(*dest))
|
|
|
|
#endif /* E051_DEF_H_ */
|