1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 11:12:43 +01:00
RIOT/cpu/cc26xx_cc13xx/include/cc26xx_cc13xx_ccfg.h

93 lines
2.5 KiB
C
Raw Normal View History

2016-01-23 14:38:51 +01:00
/*
* Copyright (C) 2016 Leon George
*
* 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.
*/
/**
* @ingroup cpu_cc26xx_cc13xx_definitions
2016-01-23 14:38:51 +01:00
* @{
*
* @file
* @brief CC26xx/CC13xx CCFG register definitions
2016-01-23 14:38:51 +01:00
*/
#ifndef CC26XX_CC13XX_CCFG_H
#define CC26XX_CC13XX_CCFG_H
2016-01-23 14:38:51 +01:00
#include <cc26xx_cc13xx.h>
2016-01-23 14:38:51 +01:00
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief CCFG registers
2016-01-23 14:38:51 +01:00
*/
typedef struct {
reg32_t EXT_LF_CLK; /**< extern LF clock config */
reg32_t MODE_CONF_1; /**< mode config 1 */
reg32_t SIZE_AND_DIS_FLAGS; /**< CCFG size and disable flags */
reg32_t MODE_CONF; /**< mmode config 0 */
reg32_t VOLT_LOAD_0; /**< voltage load 0 */
reg32_t VOLT_LOAD_1; /**< voltage load 1 */
reg32_t RTC_OFFSET; /**< RTC offset */
reg32_t FREQ_OFFSET; /**< frequency offset */
reg32_t IEEE_MAC_0; /**< IEEE MAC address 0 */
reg32_t IEEE_MAC_1; /**< IEEE MAC address 1 */
reg32_t IEEE_BLE_0; /**< IEEE BLE address 0 */
reg32_t IEEE_BLE_1; /**< IEEE BLE address 1 */
reg32_t BL_CONFIG; /**< bootloader config */
reg32_t ERASE_CONF; /**< erase config */
reg32_t CCFG_TI_OPTIONS; /**< TI options */
reg32_t CCFG_TAP_DAP_0; /**< test access points enable 0 */
reg32_t CCFG_TAP_DAP_1; /**< test access points enable 1 */
reg32_t IMAGE_VALID_CONF; /**< image valid */
reg32_t CCFG_PROT_31_0; /**< protect sectors 0-31 */
reg32_t CCFG_PROT_63_32; /**< protect sectors 32-63 */
reg32_t CCFG_PROT_95_64; /**< protect sectors 64-95 */
reg32_t CCFG_PROT_127_96; /**< protect sectors 96-127 */
} ccfg_regs_t;
/**
* @brief CCFG register values
* @{
*/
#define CCFG_MODE_CONF_1_ALT_DCDC_IPEAK_s 16
#define CCFG_MODE_CONF_VDDR_EXT_LOAD 0x02000000
#define CCFG_MODE_CONF_VDDS_BOD_LEVEL 0x01000000
#define CCFG_SIZE_AND_DIS_FLAGS_DIS_GPRAM 0x00000004
#define CCFG_SIZE_AND_DIS_FLAGS_DIS_ALT_DCDC_SETTING 0x00000002
/** @} */
/**
* @ingroup cpu_specific_peripheral_memory_map
* @{
*/
/**
* @brief CCFG base address
*/
#define CCFG_BASE (0x50003000)
/** @} */
#ifdef CPU_VARIANT_X0
/**
* @brief CCFG register bank
*/
#define CCFG ((ccfg_regs_t *) (CCFG_BASE + 0xFA8))
#else
/**
* @brief CCFG register bank
*/
#define CCFG ((ccfg_regs_t *) (CCFG_BASE + 0x1FA8))
#endif
2016-01-23 14:38:51 +01:00
#ifdef __cplusplus
} /* end extern "C" */
#endif
#endif /* CC26XX_CC13XX_CCFG_H */
2016-01-23 14:38:51 +01:00
/** @} */