arch/arm/include/tiva: Add support for cc13xx interrupts. arch/arm/src/armv7-m: Add FPB header file.
This commit is contained in:
parent
ff508f9b12
commit
ffc7dbf36b
99
arch/arm/include/tiva/cc13x0_irq.h
Normal file
99
arch/arm/include/tiva/cc13x0_irq.h
Normal file
@ -0,0 +1,99 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/include/tiva/cc13x0_irq.h
|
||||
*
|
||||
* Copyright (C) 2018 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
************************************************************************************/
|
||||
|
||||
#ifndef __ARCH_ARM_INCLUDE_TIVA_CC13X0_IRQ_H
|
||||
#define __ARCH_ARM_INCLUDE_TIVA_CC13X0_IRQ_H
|
||||
|
||||
/************************************************************************************
|
||||
* Included Files
|
||||
************************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
/******************************************************************************
|
||||
* Pre-processor Definitions
|
||||
******************************************************************************/
|
||||
|
||||
/* IRQ numbers. The IRQ number corresponds vector number and hence map directly to
|
||||
* bits in the NVIC. This does, however, waste several words of memory in the IRQ
|
||||
* to handle mapping tables.
|
||||
*/
|
||||
|
||||
/* External interrupts (vectors >= 16) */
|
||||
|
||||
#define TIVA_IRQ_INTERRUPTS (16) /* Vector number of the first external
|
||||
* interrupt */
|
||||
|
||||
#define TIVA_IRQ_AON_GPIO_EDGE (16) /* Edge detect event from IOC */
|
||||
#define TIVA_IRQ_I2C (17) /* Interrupt event from I2C */
|
||||
#define TIVA_IRQ_RFC_CPE_1 (18) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_AON_RTC_COMB (20) /* Event from AON_RTC */
|
||||
#define TIVA_IRQ_UART0_COMB (21) /* UART0 combined interrupt */
|
||||
#define TIVA_IRQ_AUX_SWEV0 (22) /* AUX software event 0 */
|
||||
#define TIVA_IRQ_SSI0_COMB (23) /* SSI0 combined interrupt */
|
||||
#define TIVA_IRQ_SSI1_COMB (24) /* SSI1 combined interrupt */
|
||||
#define TIVA_IRQ_RFC_CPE_0 (25) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_RFC_HW_COMB (26) /* Combined RFC hardware interrupt */
|
||||
#define TIVA_IRQ_RFC_CMD_ACK (27) /* RFC Doorbell Command
|
||||
* Acknowledgement Interrupt */
|
||||
#define TIVA_IRQ_I2S (28) /* Interrupt event from I2S */
|
||||
#define TIVA_IRQ_AUX_SWEV1 (29) /* AUX software event 1 */
|
||||
#define TIVA_IRQ_WDT (30) /* Watchdog interrupt event */
|
||||
#define TIVA_IRQ_GPT0A (31) /* GPT0A interrupt event */
|
||||
#define TIVA_IRQ_GPT0B (32) /* GPT0B interrupt event */
|
||||
#define TIVA_IRQ_GPT1A (33) /* GPT1A interrupt event */
|
||||
#define TIVA_IRQ_GPT1B (34) /* GPT1B interrupt event */
|
||||
#define TIVA_IRQ_GPT2A (35) /* GPT2A interrupt event */
|
||||
#define TIVA_IRQ_GPT2B (36) /* GPT2B interrupt event */
|
||||
#define TIVA_IRQ_GPT3A (37) /* GPT3A interrupt event */
|
||||
#define TIVA_IRQ_GPT3B (38) /* GPT3B interrupt event */
|
||||
#define TIVA_IRQ_CRYPTO_RESULT_AVAIL (39) /* CRYPTO result available interupt
|
||||
* event */
|
||||
#define TIVA_IRQ_DMA_DONE_COMB (40) /* Combined DMA done */
|
||||
#define TIVA_IRQ_DMA_ERR (41) /* DMA bus error */
|
||||
#define TIVA_IRQ_FLASH (42) /* FLASH controller error event */
|
||||
#define TIVA_IRQ_SWEV0 (43) /* Software event 0 */
|
||||
#define TIVA_IRQ_AUX_COMB (44) /* AUX combined event */
|
||||
#define TIVA_IRQ_AON_PROG0 (45) /* AON programmable event 0 */
|
||||
#define TIVA_IRQ_PROG0 (46) /* Programmable Interrupt 0 */
|
||||
#define TIVA_IRQ_AUX_COMPA (47) /* AUX Compare A event */
|
||||
#define TIVA_IRQ_AUX_ADC (48) /* AUX ADC interrupt event */
|
||||
#define TIVA_IRQ_TRNG (49) /* TRNG Interrupt event */
|
||||
|
||||
#define NR_IRQS (50) /* Number of interrupt vectors */
|
||||
|
||||
#endif /* __ARCH_ARM_INCLUDE_TIVA_CC13X0_IRQ_H */
|
106
arch/arm/include/tiva/cc13x2_cc26x2_v1_irq.h
Normal file
106
arch/arm/include/tiva/cc13x2_cc26x2_v1_irq.h
Normal file
@ -0,0 +1,106 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/include/tiva/cc13x2_cc26x2_v1_irq.h
|
||||
*
|
||||
* Copyright (C) 2018 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
************************************************************************************/
|
||||
|
||||
#ifndef __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V1_IRQ_H
|
||||
#define __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V1_IRQ_H
|
||||
|
||||
/************************************************************************************
|
||||
* Included Files
|
||||
************************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
/******************************************************************************
|
||||
* Pre-processor Definitions
|
||||
******************************************************************************/
|
||||
|
||||
/* IRQ numbers. The IRQ number corresponds vector number and hence map directly to
|
||||
* bits in the NVIC. This does, however, waste several words of memory in the IRQ
|
||||
* to handle mapping tables.
|
||||
*/
|
||||
|
||||
/* External interrupts (vectors >= 16) */
|
||||
|
||||
#define TIVA_IRQ_INTERRUPTS (16) /* Vector number of the first external
|
||||
* interrupt */
|
||||
|
||||
#define TIVA_IRQ_AON_GPIO_EDGE (16) /* Edge detect event from IOC */
|
||||
#define TIVA_IRQ_I2C (17) /* Interrupt event from I2C */
|
||||
#define TIVA_IRQ_RFC_CPE_1 (18) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_PKA (19) /* PKA Interrupt event */
|
||||
#define TIVA_IRQ_AON_RTC_COMB (20) /* Event from AON_RTC */
|
||||
#define TIVA_IRQ_UART0_COMB (21) /* UART0 combined interrupt */
|
||||
#define TIVA_IRQ_AUX_SWEV0 (22) /* AUX software event 0 */
|
||||
#define TIVA_IRQ_SSI0_COMB (23) /* SSI0 combined interrupt */
|
||||
#define TIVA_IRQ_SSI1_COMB (24) /* SSI1 combined interrupt */
|
||||
#define TIVA_IRQ_RFC_CPE_0 (25) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_RFC_HW_COMB (26) /* Combined RFC hardware interrupt */
|
||||
#define TIVA_IRQ_RFC_CMD_ACK (27) /* RFC Doorbell Command
|
||||
* Acknowledgement Interrupt */
|
||||
#define TIVA_IRQ_I2S (28) /* Interrupt event from I2S */
|
||||
#define TIVA_IRQ_AUX_SWEV1 (29) /* AUX software event 1 */
|
||||
#define TIVA_IRQ_WDT (30) /* Watchdog interrupt event */
|
||||
#define TIVA_IRQ_GPT0A (31) /* GPT0A interrupt event */
|
||||
#define TIVA_IRQ_GPT0B (32) /* GPT0B interrupt event */
|
||||
#define TIVA_IRQ_GPT1A (33) /* GPT1A interrupt event */
|
||||
#define TIVA_IRQ_GPT1B (34) /* GPT1B interrupt event */
|
||||
#define TIVA_IRQ_GPT2A (35) /* GPT2A interrupt event */
|
||||
#define TIVA_IRQ_GPT2B (36) /* GPT2B interrupt event */
|
||||
#define TIVA_IRQ_GPT3A (37) /* GPT3A interrupt event */
|
||||
#define TIVA_IRQ_GPT3B (38) /* GPT3B interrupt event */
|
||||
#define TIVA_IRQ_CRYPTO_RESULT_AVAIL (39) /* CRYPTO result available interupt
|
||||
* event */
|
||||
#define TIVA_IRQ_DMA_DONE_COMB (40) /* Combined DMA done */
|
||||
#define TIVA_IRQ_DMA_ERR (41) /* DMA bus error */
|
||||
#define TIVA_IRQ_FLASH (42) /* FLASH controller error event */
|
||||
#define TIVA_IRQ_SWEV0 (43) /* Software event 0 */
|
||||
#define TIVA_IRQ_AUX_COMB (44) /* AUX combined event */
|
||||
#define TIVA_IRQ_AON_PROG0 (45) /* AON programmable event 0 */
|
||||
#define TIVA_IRQ_PROG0 (46) /* Programmable Interrupt 0 */
|
||||
#define TIVA_IRQ_AUX_COMPA (47) /* AUX Compare A event */
|
||||
#define TIVA_IRQ_AUX_ADC (48) /* AUX ADC interrupt event */
|
||||
#define TIVA_IRQ_TRNG (49) /* TRNG Interrupt event */
|
||||
#define TIVA_IRQ_OSC_COMB (50) /* Combined event from Oscillator
|
||||
* control */
|
||||
#define TIVA_IRQ_AUX_TIMER2_EV0 (51) /* AUX Timer2 event 0 */
|
||||
#define TIVA_IRQ_UART1_COMB (52) /* UART1 combined interrupt */
|
||||
#define TIVA_IRQ_BATMON_COMB (53) /* Combined event from battery
|
||||
* monitor */
|
||||
|
||||
#define NR_IRQS (54) /* Number of interrupt vectors */
|
||||
|
||||
#endif /* __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V1_IRQ_H */
|
106
arch/arm/include/tiva/cc13x2_cc26x2_v2_irq.h
Normal file
106
arch/arm/include/tiva/cc13x2_cc26x2_v2_irq.h
Normal file
@ -0,0 +1,106 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/include/tiva/cc13x2_cc26x2_v1_irq.h
|
||||
*
|
||||
* Copyright (C) 2018 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
************************************************************************************/
|
||||
|
||||
#ifndef __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V2_IRQ_H
|
||||
#define __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V2_IRQ_H
|
||||
|
||||
/************************************************************************************
|
||||
* Included Files
|
||||
************************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
/******************************************************************************
|
||||
* Pre-processor Definitions
|
||||
******************************************************************************/
|
||||
|
||||
/* IRQ numbers. The IRQ number corresponds vector number and hence map directly to
|
||||
* bits in the NVIC. This does, however, waste several words of memory in the IRQ
|
||||
* to handle mapping tables.
|
||||
*/
|
||||
|
||||
/* External interrupts (vectors >= 16) */
|
||||
|
||||
#define TIVA_IRQ_INTERRUPTS (16) /* Vector number of the first external
|
||||
* interrupt */
|
||||
|
||||
#define TIVA_IRQ_AON_GPIO_EDGE (16) /* Edge detect event from IOC */
|
||||
#define TIVA_IRQ_I2C (17) /* Interrupt event from I2C */
|
||||
#define TIVA_IRQ_RFC_CPE_1 (18) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_PKA (19) /* PKA Interrupt event */
|
||||
#define TIVA_IRQ_AON_RTC_COMB (20) /* Event from AON_RTC */
|
||||
#define TIVA_IRQ_UART0_COMB (21) /* UART0 combined interrupt */
|
||||
#define TIVA_IRQ_AUX_SWEV0 (22) /* AUX software event 0 */
|
||||
#define TIVA_IRQ_SSI0_COMB (23) /* SSI0 combined interrupt */
|
||||
#define TIVA_IRQ_SSI1_COMB (24) /* SSI1 combined interrupt */
|
||||
#define TIVA_IRQ_RFC_CPE_0 (25) /* Combined Interrupt for CPE
|
||||
* Generated events */
|
||||
#define TIVA_IRQ_RFC_HW_COMB (26) /* Combined RFC hardware interrupt */
|
||||
#define TIVA_IRQ_RFC_CMD_ACK (27) /* RFC Doorbell Command
|
||||
* Acknowledgement Interrupt */
|
||||
#define TIVA_IRQ_I2S (28) /* Interrupt event from I2S */
|
||||
#define TIVA_IRQ_AUX_SWEV1 (29) /* AUX software event 1 */
|
||||
#define TIVA_IRQ_WDT (30) /* Watchdog interrupt event */
|
||||
#define TIVA_IRQ_GPT0A (31) /* GPT0A interrupt event */
|
||||
#define TIVA_IRQ_GPT0B (32) /* GPT0B interrupt event */
|
||||
#define TIVA_IRQ_GPT1A (33) /* GPT1A interrupt event */
|
||||
#define TIVA_IRQ_GPT1B (34) /* GPT1B interrupt event */
|
||||
#define TIVA_IRQ_GPT2A (35) /* GPT2A interrupt event */
|
||||
#define TIVA_IRQ_GPT2B (36) /* GPT2B interrupt event */
|
||||
#define TIVA_IRQ_GPT3A (37) /* GPT3A interrupt event */
|
||||
#define TIVA_IRQ_GPT3B (38) /* GPT3B interrupt event */
|
||||
#define TIVA_IRQ_CRYPTO_RESULT_AVAIL (39) /* CRYPTO result available interrupt
|
||||
* event */
|
||||
#define TIVA_IRQ_DMA_DONE_COMB (40) /* Combined DMA done */
|
||||
#define TIVA_IRQ_DMA_ERR (41) /* DMA bus error */
|
||||
#define TIVA_IRQ_FLASH (42) /* FLASH controller error event */
|
||||
#define TIVA_IRQ_SWEV0 (43) /* Software event 0 */
|
||||
#define TIVA_IRQ_AUX_COMB (44) /* AUX combined event */
|
||||
#define TIVA_IRQ_AON_PROG0 (45) /* AON programmable event 0 */
|
||||
#define TIVA_IRQ_PROG0 (46) /* Programmable Interrupt 0 */
|
||||
#define TIVA_IRQ_AUX_COMPA (47) /* AUX Compare A event */
|
||||
#define TIVA_IRQ_AUX_ADC (48) /* AUX ADC interrupt event */
|
||||
#define TIVA_IRQ_TRNG (49) /* TRNG Interrupt event */
|
||||
#define TIVA_IRQ_OSC_COMB (50) /* Combined event from Oscillator
|
||||
* control */
|
||||
#define TIVA_IRQ_AUX_TIMER2_EV0 (51) /* AUX Timer2 event 0 */
|
||||
#define TIVA_IRQ_UART1_COMB (52) /* UART1 combined interrupt */
|
||||
#define TIVA_IRQ_BATMON_COMB (53) /* Combined event from battery
|
||||
* monitor */
|
||||
|
||||
#define NR_IRQS (54) /* Number of interrupt vectors */
|
||||
|
||||
#endif /* __ARCH_ARM_INCLUDE_TIVA_CC13X2_CC26x2_V2_IRQ_H */
|
@ -175,12 +175,20 @@
|
||||
#define TIVA_IRQ_PENDSV (14) /* Vector 14: Pendable system service request */
|
||||
#define TIVA_IRQ_SYSTICK (15) /* Vector 15: System tick */
|
||||
|
||||
/* Chip-specific Interrupts (vectors 16 and above) */
|
||||
|
||||
#if defined(CONFIG_ARCH_CHIP_LM3S)
|
||||
# include <arch/tiva/lm3s_irq.h>
|
||||
#elif defined(CONFIG_ARCH_CHIP_LM4F)
|
||||
# include <arch/tiva/lm4f_irq.h>
|
||||
#elif defined(CONFIG_ARCH_CHIP_TM4C)
|
||||
# include <arch/tiva/tm4c_irq.h>
|
||||
#elif defined(CONFIG_ARCH_CHIP_CC13X0)
|
||||
# include <arch/tiva/cc13x0_irq.h>
|
||||
#elif defined(CONFIG_ARCH_CHIP_CC13X2_V1)
|
||||
# include <arch/tiva/cc13x2_cc26x2_v1_irq.h>
|
||||
#elif defined(CONFIG_ARCH_CHIP_CC13X2_V2)
|
||||
# include <arch/tiva/cc13x2_cc26x2_v2_irq.h>
|
||||
#else
|
||||
# error "Unsupported Stellaris IRQ file"
|
||||
#endif
|
||||
|
187
arch/arm/src/armv7-m/fpb.h
Normal file
187
arch/arm/src/armv7-m/fpb.h
Normal file
@ -0,0 +1,187 @@
|
||||
/****************************************************************************
|
||||
* arch/arm/src/armv7-m/fpb.h
|
||||
*
|
||||
* Copyright (C) 2018 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Based loosely on BSD licensed header file from TI:
|
||||
*
|
||||
* Copyright (c) 2015-2017, Texas Instruments Incorporated
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __ARCH_ARM_SRC_ARMV&-M_FPB_H
|
||||
#define __ARCH_ARM_SRC_ARMV&-M_FPB_H
|
||||
|
||||
/******************************************************************************
|
||||
* Pre-processor Definitions
|
||||
******************************************************************************/
|
||||
|
||||
/* Flash Patch and Breakpoint Unit FPB ***************************************/
|
||||
|
||||
/* FPB Register Base Address *************************************************/
|
||||
|
||||
#define FPB_BASE 0xe0002000
|
||||
|
||||
/* FPB Register Offsets *******************************************************/
|
||||
|
||||
#define FPB_CTRL_OFFSET 0x0000 /* Control */
|
||||
#define FPB_REMAP_OFFSET 0x0004 /* Remap */
|
||||
#define FPB_COMP0_OFFSET 0x0008 /* Comparator 0 */
|
||||
#define FPB_COMP1_OFFSET 0x000c /* Comparator 1 */
|
||||
#define FPB_COMP2_OFFSET 0x0010 /* Comparator 2 */
|
||||
#define FPB_COMP3_OFFSET 0x0014 /* Comparator 3 */
|
||||
#define FPB_COMP4_OFFSET 0x0018 /* Comparator 4 */
|
||||
#define FPB_COMP5_OFFSET 0x001C /* Comparator 5 */
|
||||
#define FPB_COMP6_OFFSET 0x0020 /* Comparator 6 */
|
||||
#define FPB_COMP7_OFFSET 0x0024 /* Comparator 7 */
|
||||
|
||||
/* FPB Register Addresses *****************************************************/
|
||||
|
||||
#define FPB_CTRL (FPB_BASE + FPB_CTRL_OFFSET)
|
||||
#define FPB_REMAP (FPB_BASE + FPB_REMAP_OFFSET)
|
||||
#define FPB_COMP0 (FPB_BASE + FPB_COMP0_OFFSET)
|
||||
#define FPB_COMP1 (FPB_BASE + FPB_COMP1_OFFSET)
|
||||
#define FPB_COMP2 (FPB_BASE + FPB_COMP2_OFFSET)
|
||||
#define FPB_COMP3 (FPB_BASE + FPB_COMP3_OFFSET)
|
||||
#define FPB_COMP4 (FPB_BASE + FPB_COMP4_OFFSET)
|
||||
#define FPB_COMP5 (FPB_BASE + FPB_COMP5_OFFSET)
|
||||
#define FPB_COMP6 (FPB_BASE + FPB_COMP6_OFFSET)
|
||||
#define FPB_COMP7 (FPB_BASE + FPB_COMP7_OFFSET
|
||||
|
||||
/* FPB Register Bitfield Definitions ******************************************/
|
||||
|
||||
/* FPB_CTRL */
|
||||
|
||||
/* NUM_CODE2
|
||||
*
|
||||
* Number of full banks of code comparators, sixteen comparators per bank.
|
||||
* Where less than sixteen code comparators are provided, the bank count is
|
||||
* zero, and the number present indicated by NUM_CODE1. This read only field
|
||||
* contains 3'b000 to indicate 0 banks for Cortex-M processor.
|
||||
*/
|
||||
|
||||
#define FPB_CTRL_NUM_CODE2_SHIFT 12
|
||||
#define FPB_CTRL_NUM_CODE2_MASK 0x00003000
|
||||
|
||||
/* NUM_LIT
|
||||
*
|
||||
* Number of literal slots field.
|
||||
*
|
||||
* 0: No literal slots
|
||||
* 2: Two literal slots
|
||||
*/
|
||||
|
||||
#define FPB_CTRL_NUM_LIT_SHIFT 8
|
||||
#define FPB_CTRL_NUM_LIT_MASK 0x00000f00
|
||||
|
||||
/* NUM_CODE1
|
||||
*
|
||||
* Number of code slots field.
|
||||
*
|
||||
* 0: No code slots
|
||||
* 2: Two code slots
|
||||
* 6: Six code slots
|
||||
*/
|
||||
|
||||
#define FPB_CTRL_NUM_CODE1_SHIFT 4
|
||||
#define FPB_CTRL_NUM_CODE1_MASK 0x000000f0
|
||||
|
||||
/* KEY
|
||||
*
|
||||
* Key field. In order to write to this register, this bit-field must be
|
||||
* written to '1'. This bit always reads 0.
|
||||
*/
|
||||
|
||||
#define FPB_CTRL_KEY_SHIFT 1
|
||||
#define FPB_CTRL_KEY_MASK 0x00000002
|
||||
# define FPB_CTRL_KEY 0x00000002
|
||||
|
||||
/* ENABLE
|
||||
*
|
||||
* Flash patch unit enable bit
|
||||
*
|
||||
* 0: Flash patch unit disabled
|
||||
* 1: Flash patch unit enabled
|
||||
*/
|
||||
|
||||
#define FPB_CTRL_ENABLE_SHIFT 0
|
||||
#define FPB_CTRL_ENABLE_MASK 0x00000001
|
||||
# define FPB_CTRL_ENABLE 0x00000001
|
||||
|
||||
/* FPB_REMAP */
|
||||
|
||||
/* REMAP
|
||||
*
|
||||
* Remap base address field.
|
||||
*/
|
||||
|
||||
#define FPB_REMAP_REMAP_SHIFT 5
|
||||
#define FPB_REMAP_REMAP_MASK 0x1fffffe0
|
||||
|
||||
/* FPB_COMP0 - FPB_COMP7 */
|
||||
|
||||
/* REPLACE
|
||||
*
|
||||
* This selects what happens when the COMP address is matched. Address
|
||||
* remapping only takes place for the 0x0 setting.
|
||||
*
|
||||
* 0: Remap to remap address. See REMAP.REMAP
|
||||
* 1: Set BKPT on lower halfword, upper is unaffected
|
||||
* 2: Set BKPT on upper halfword, lower is unaffected
|
||||
* 3: Set BKPT on both lower and upper halfwords.
|
||||
*/
|
||||
|
||||
#define FPB_COMP0_REPLACE_SHIFT 30
|
||||
#define FPB_COMP0_REPLACE_MASK 0xc0000000
|
||||
|
||||
/* COMP
|
||||
*
|
||||
* Comparison address.
|
||||
*/
|
||||
|
||||
#define FPB_COMP0_COMP_SHIFT 2
|
||||
#define FPB_COMP0_COMP_MASK 0x1ffffffc
|
||||
|
||||
/* ENABLE
|
||||
*
|
||||
* Compare and remap enable comparator. CTRL.ENABLE must also be set to
|
||||
* enable comparisons.
|
||||
*
|
||||
* 0: Compare and remap for comparator 0 disabled
|
||||
* 1: Compare and remap for comparator 0 enabled
|
||||
*/
|
||||
|
||||
#define FPB_COMP0_ENABLE_MASK 0x00000001
|
||||
#define FPB_COMP0_ENABLE_SHIFT 0
|
||||
# define FPB_COMP0_ENABLE 0x00000001
|
||||
|
||||
#endif /* __ARCH_ARM_SRC_ARMV&-M_FPB_H */
|
@ -126,6 +126,21 @@ config ARCH_CHIP_CC1312R1
|
||||
|
||||
endchoice
|
||||
|
||||
# Chip versions
|
||||
|
||||
choice
|
||||
prompt "CC13x2 Chip Version"
|
||||
default ARCH_CHIP_CC13X2_V1
|
||||
depends on ARCH_CHIP_CC13X2
|
||||
|
||||
config ARCH_CHIP_CC13X2_V1
|
||||
bool "Version 1"
|
||||
|
||||
config ARCH_CHIP_CC13X2_V2
|
||||
bool "Version 2"
|
||||
|
||||
endchoice # CC13x2 Chip Version
|
||||
|
||||
# Chip families
|
||||
|
||||
config ARCH_CHIP_LM3S
|
||||
|
Loading…
Reference in New Issue
Block a user