2014-08-27 18:47:31 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013, Freie Universitaet Berlin (FUB). All rights reserved.
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2017-08-24 21:03:16 +02:00
|
|
|
/**
|
|
|
|
* @ingroup cpu_msp430_common
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2019-10-23 21:13:53 +02:00
|
|
|
* @brief Common CPU definitions for MSP430
|
2017-08-24 21:03:16 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef CPU_CONF_H
|
|
|
|
#define CPU_CONF_H
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-10-13 10:53:20 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-06-25 21:32:17 +02:00
|
|
|
/**
|
|
|
|
* @brief This arch uses the inlined IRQ API.
|
|
|
|
*/
|
|
|
|
#define IRQ_API_INLINED (1)
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/**
|
2017-03-07 11:43:08 +01:00
|
|
|
* @name Configure the internal flash memory
|
|
|
|
* @{
|
|
|
|
*/
|
2019-08-05 14:04:30 +02:00
|
|
|
#define FLASHPAGE_SIZE (512U)
|
2017-03-07 11:43:08 +01:00
|
|
|
|
|
|
|
#if defined (CPU_MODEL_MSP430F1611)
|
|
|
|
#define CPU_FLASH_BASE (0x4000)
|
2019-08-05 14:04:30 +02:00
|
|
|
#define FLASHPAGE_NUMOF (96U) /* 48K */
|
2017-03-07 11:43:08 +01:00
|
|
|
#elif defined (CPU_MODEL_MSP430F1612)
|
2019-10-05 21:47:23 +02:00
|
|
|
#define CPU_FLASH_BASE (0x2600) /* first sector is only 256 byte, skip it*/
|
|
|
|
#define FLASHPAGE_NUMOF (109U) /* 54.5K */
|
2017-03-07 11:43:08 +01:00
|
|
|
#elif defined (CPU_MODEL_MSP430F2617)
|
2019-10-05 21:47:23 +02:00
|
|
|
#define CPU_FLASH_BASE (0x3200) /* first sector is only 256 byte, skip it*/
|
|
|
|
#define FLASHPAGE_NUMOF (103U) /* we can currently only access 51.5K */
|
2017-03-07 11:43:08 +01:00
|
|
|
#elif defined (CPU_MODEL_CC430F6137)
|
|
|
|
#define CPU_FLASH_BASE (0x8000)
|
2019-08-05 14:04:30 +02:00
|
|
|
#define FLASHPAGE_NUMOF (64U) /* 32K */
|
2017-03-07 11:43:08 +01:00
|
|
|
#endif
|
2019-08-04 11:39:27 +02:00
|
|
|
|
|
|
|
/* The minimum block size which can be written is 1B. However, the erase
|
|
|
|
* block is always FLASHPAGE_SIZE.
|
|
|
|
*/
|
|
|
|
#define FLASHPAGE_RAW_BLOCKSIZE (1U)
|
|
|
|
/* Writing should be always 2 byte aligned */
|
|
|
|
#define FLASHPAGE_RAW_ALIGNMENT (2U)
|
2017-03-07 11:43:08 +01:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Kernel configuration
|
2010-09-22 15:10:42 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2016-10-17 11:05:22 +02:00
|
|
|
#ifndef THREAD_EXTRA_STACKSIZE_PRINTF
|
|
|
|
# define THREAD_EXTRA_STACKSIZE_PRINTF (256)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef THREAD_EXTRA_STACKSIZE_PRINTF
|
|
|
|
# define THREAD_EXTRA_STACKSIZE_PRINTF_FLOAT (THREAD_EXTRA_STACKSIZE_PRINTF)
|
|
|
|
#endif
|
2013-07-23 13:42:58 +02:00
|
|
|
|
2015-04-28 20:02:05 +02:00
|
|
|
#ifndef THREAD_STACKSIZE_DEFAULT
|
2020-07-30 11:20:59 +02:00
|
|
|
# define THREAD_STACKSIZE_DEFAULT (384)
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif
|
|
|
|
|
2016-10-17 11:05:22 +02:00
|
|
|
#ifndef THREAD_STACKSIZE_IDLE
|
|
|
|
# define THREAD_STACKSIZE_IDLE (96)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ISR_STACKSIZE
|
|
|
|
# define ISR_STACKSIZE (256)
|
|
|
|
#endif
|
2010-12-03 18:42:03 +01:00
|
|
|
|
2020-05-11 15:44:40 +02:00
|
|
|
#ifndef CONFIG_GNRC_PKTBUF_SIZE
|
2016-10-17 11:05:22 +02:00
|
|
|
/* TODO: Make this value overall MTU dependent */
|
2020-05-11 15:44:40 +02:00
|
|
|
# define CONFIG_GNRC_PKTBUF_SIZE (2560)
|
2014-09-01 18:58:11 +02:00
|
|
|
#endif
|
2018-09-26 11:06:05 +02:00
|
|
|
|
|
|
|
#ifndef GNRC_IPV6_STACK_SIZE
|
|
|
|
# define GNRC_IPV6_STACK_SIZE (512)
|
|
|
|
#endif
|
2010-09-22 15:10:42 +02:00
|
|
|
/** @} */
|
|
|
|
|
2014-10-13 10:53:20 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* CPU_CONF_H */
|
2017-08-24 21:03:16 +02:00
|
|
|
/** @} */
|