Fixes a few more high priority, nested interrupt logic
This commit is contained in:
parent
22e208dbf9
commit
d41bfe4d5b
10
ChangeLog
10
ChangeLog
@ -6273,3 +6273,13 @@
|
|||||||
(2013-12-22).
|
(2013-12-22).
|
||||||
* configs/viewtool-stm32f107/scripts: Need to do some special things
|
* configs/viewtool-stm32f107/scripts: Need to do some special things
|
||||||
in linking of the common vectors are used (2013-12-22).
|
in linking of the common vectors are used (2013-12-22).
|
||||||
|
* arch/arm/include/*/irq*.h: Add definition NR_VECTORS so that the RAM
|
||||||
|
vector logic can know how many vectors there are. NR_IRQS is often
|
||||||
|
not equal to NR_VECTORS (2013-12-23).
|
||||||
|
* arch/arm/src/*_vectors.S: Standardize the name of the vector table
|
||||||
|
and the name of the common vector handling logic so that the MCU-
|
||||||
|
independent logic and work with these (2013-12-23).
|
||||||
|
* configs/viewtool-stm32f107/scripts: Move the RAM vector tables to the
|
||||||
|
beginning of SRAM. It seems to require this alignament. Also, we
|
||||||
|
don't need different scripts for the CMNVECTOR case now that the vector
|
||||||
|
table has a common name.
|
||||||
|
@ -294,7 +294,7 @@
|
|||||||
|
|
||||||
/* Note that the total number of IRQ numbers supported is equal to the number of
|
/* Note that the total number of IRQ numbers supported is equal to the number of
|
||||||
* valid interrupt vectors. This is wasteful in that certain tables are sized by
|
* valid interrupt vectors. This is wasteful in that certain tables are sized by
|
||||||
* this value. There are only 97 valid interrupts so, potentially the numver of
|
* this value. There are only 97 valid interrupts so, potentially the number of
|
||||||
* IRQs to could be reduced to 97. However, equating IRQ numbers with vector numbers
|
* IRQs to could be reduced to 97. However, equating IRQ numbers with vector numbers
|
||||||
* also simplifies operations on NVIC registers and (at least in my state of mind
|
* also simplifies operations on NVIC registers and (at least in my state of mind
|
||||||
* now) seems to justify the waste.
|
* now) seems to justify the waste.
|
||||||
|
@ -118,6 +118,7 @@
|
|||||||
|
|
||||||
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (71)
|
||||||
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
||||||
|
|
||||||
#elif defined(CONFIG_ARCH_CHIP_LM3S6432)
|
#elif defined(CONFIG_ARCH_CHIP_LM3S6432)
|
||||||
@ -183,7 +184,9 @@
|
|||||||
|
|
||||||
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (71)
|
||||||
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
||||||
|
|
||||||
#elif defined(CONFIG_ARCH_CHIP_LM3S6965)
|
#elif defined(CONFIG_ARCH_CHIP_LM3S6965)
|
||||||
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
||||||
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
||||||
@ -247,7 +250,9 @@
|
|||||||
|
|
||||||
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (71)
|
||||||
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
||||||
|
|
||||||
#elif defined(CONFIG_ARCH_CHIP_LM3S9B96)
|
#elif defined(CONFIG_ARCH_CHIP_LM3S9B96)
|
||||||
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
||||||
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
||||||
@ -312,7 +317,9 @@
|
|||||||
# define LM_IRQ_GPIOJ (70) /* Vector 70: GPIO Port J */
|
# define LM_IRQ_GPIOJ (70) /* Vector 70: GPIO Port J */
|
||||||
# define LM_RESERVED_71 (71) /* Vector 71: Reserved */
|
# define LM_RESERVED_71 (71) /* Vector 71: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (72)
|
||||||
# define NR_IRQS (71) /* (Really less because of reserved vectors) */
|
# define NR_IRQS (71) /* (Really less because of reserved vectors) */
|
||||||
|
|
||||||
#elif defined(CONFIG_ARCH_CHIP_LM3S8962)
|
#elif defined(CONFIG_ARCH_CHIP_LM3S8962)
|
||||||
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
# define LM_IRQ_GPIOA (16) /* Vector 16: GPIO Port A */
|
||||||
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
# define LM_IRQ_GPIOB (17) /* Vector 17: GPIO Port B */
|
||||||
@ -376,7 +383,9 @@
|
|||||||
|
|
||||||
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
# define LM_RESERVED_70 (70) /* Vector 70: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (71)
|
||||||
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
# define NR_IRQS (60) /* (Really less because of reserved vectors) */
|
||||||
|
|
||||||
#else
|
#else
|
||||||
# error "IRQ Numbers not specified for this Stellaris chip"
|
# error "IRQ Numbers not specified for this Stellaris chip"
|
||||||
#endif
|
#endif
|
||||||
|
@ -211,6 +211,7 @@
|
|||||||
# define LM_RESERVED_153 (153) /* Vector 153: Reserved */
|
# define LM_RESERVED_153 (153) /* Vector 153: Reserved */
|
||||||
# define LM_RESERVED_154 (154) /* Vector 154: Reserved */
|
# define LM_RESERVED_154 (154) /* Vector 154: Reserved */
|
||||||
|
|
||||||
|
# define NR_VECTORS (155)
|
||||||
# define NR_IRQS (123) /* (Really fewer because of reserved vectors) */
|
# define NR_IRQS (123) /* (Really fewer because of reserved vectors) */
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -223,6 +223,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS LPC17_IRQ_NIRQS
|
||||||
#define NR_IRQS (LPC17_IRQ_EXTINT+LPC17_IRQ_NEXTINT+LPC17_NGPIOAIRQS)
|
#define NR_IRQS (LPC17_IRQ_EXTINT+LPC17_IRQ_NEXTINT+LPC17_NGPIOAIRQS)
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
@ -269,6 +269,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS LPC17_IRQ_NIRQS
|
||||||
#define NR_IRQS (LPC17_IRQ_EXTINT+LPC17_IRQ_NEXTINT+LPC17_NGPIOAIRQS)
|
#define NR_IRQS (LPC17_IRQ_EXTINT+LPC17_IRQ_NEXTINT+LPC17_NGPIOAIRQS)
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
@ -133,6 +133,7 @@
|
|||||||
* supported)
|
* supported)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define NR_VECTORS LPC43M4_IRQ_NIRQS
|
||||||
#define NR_IRQS LPC43M4_IRQ_NIRQS
|
#define NR_IRQS LPC43M4_IRQ_NIRQS
|
||||||
|
|
||||||
/* Cortex-M0 External interrupts (vectors >= 16) */
|
/* Cortex-M0 External interrupts (vectors >= 16) */
|
||||||
@ -183,6 +184,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
#define NR_VECTORS LPC43M0_IRQ_NIRQS
|
||||||
#define NR_IRQS LPC43M0_IRQ_NIRQS
|
#define NR_IRQS LPC43M0_IRQ_NIRQS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -238,6 +238,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS SAM_IRQ_NIRQS
|
||||||
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
||||||
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
||||||
|
|
||||||
|
@ -392,6 +392,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS SAM_IRQ_NIRQS
|
||||||
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
||||||
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS + \
|
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS + \
|
||||||
SAM_NGPIODIRQS + SAM_NGPIOEIRQS + SAM_NGPIOFIRQS)
|
SAM_NGPIODIRQS + SAM_NGPIOEIRQS + SAM_NGPIOFIRQS)
|
||||||
|
@ -296,6 +296,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS SAM_IRQ_NIRQS
|
||||||
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
||||||
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS + \
|
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS + \
|
||||||
SAM_NGPIODIRQS + SAM_NGPIOEIRQS)
|
SAM_NGPIODIRQS + SAM_NGPIOEIRQS)
|
||||||
|
@ -299,6 +299,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS SAM_IRQ_NIRQS
|
||||||
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
||||||
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
||||||
|
|
||||||
|
@ -249,6 +249,7 @@
|
|||||||
|
|
||||||
/* Total number of IRQ numbers */
|
/* Total number of IRQ numbers */
|
||||||
|
|
||||||
|
#define NR_VECTORS SAM_IRQ_NIRQS
|
||||||
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
#define NR_IRQS (SAM_IRQ_EXTINT + SAM_IRQ_NEXTINT + \
|
||||||
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
SAM_NGPIOAIRQS + SAM_NGPIOBIRQS + SAM_NGPIOCIRQS)
|
||||||
|
|
||||||
|
@ -128,6 +128,8 @@
|
|||||||
# define STM32_IRQ_DMA2CH3 (74) /* 58: DMA2 Channel 3 global interrupt */
|
# define STM32_IRQ_DMA2CH3 (74) /* 58: DMA2 Channel 3 global interrupt */
|
||||||
# define STM32_IRQ_DMA2CH45 (75) /* 59: DMA2 Channel 4 and 5 global interrupt */
|
# define STM32_IRQ_DMA2CH45 (75) /* 59: DMA2 Channel 4 and 5 global interrupt */
|
||||||
# define STM32_IRQ_DMA2CH5 (76) /* 60: DMA2 Channel 5 global interrupt */
|
# define STM32_IRQ_DMA2CH5 (76) /* 60: DMA2 Channel 5 global interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (77)
|
||||||
# define NR_IRQS (77)
|
# define NR_IRQS (77)
|
||||||
|
|
||||||
/* Connectivity Line Devices */
|
/* Connectivity Line Devices */
|
||||||
@ -201,6 +203,8 @@
|
|||||||
# define STM32_IRQ_CAN2RX1 (81) /* 65: CAN2 RX1 interrupt */
|
# define STM32_IRQ_CAN2RX1 (81) /* 65: CAN2 RX1 interrupt */
|
||||||
# define STM32_IRQ_CAN2SCE (82) /* 66: CAN2 SCE interrupt */
|
# define STM32_IRQ_CAN2SCE (82) /* 66: CAN2 SCE interrupt */
|
||||||
# define STM32_IRQ_OTGFS (83) /* 67: USB On The Go FS global interrupt */
|
# define STM32_IRQ_OTGFS (83) /* 67: USB On The Go FS global interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (84)
|
||||||
# define NR_IRQS (84)
|
# define NR_IRQS (84)
|
||||||
|
|
||||||
/* Medium and High Density Devices */
|
/* Medium and High Density Devices */
|
||||||
@ -266,6 +270,8 @@
|
|||||||
# define STM32_IRQ_DMA2CH2 (73) /* 57: DMA2 Channel 2 global interrupt */
|
# define STM32_IRQ_DMA2CH2 (73) /* 57: DMA2 Channel 2 global interrupt */
|
||||||
# define STM32_IRQ_DMA2CH3 (74) /* 58: DMA2 Channel 3 global interrupt */
|
# define STM32_IRQ_DMA2CH3 (74) /* 58: DMA2 Channel 3 global interrupt */
|
||||||
# define STM32_IRQ_DMA2CH45 (75) /* 59: DMA2 Channel 4&5 global interrupt */
|
# define STM32_IRQ_DMA2CH45 (75) /* 59: DMA2 Channel 4&5 global interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (76)
|
||||||
# define NR_IRQS (76)
|
# define NR_IRQS (76)
|
||||||
|
|
||||||
/* Convenience definitions for interrupts with multiple functions */
|
/* Convenience definitions for interrupts with multiple functions */
|
||||||
|
@ -150,6 +150,7 @@
|
|||||||
#define STM32_IRQ_HASH (STM32_IRQ_INTERRUPTS+80) /* 80: Hash and Rng global interrupt */
|
#define STM32_IRQ_HASH (STM32_IRQ_INTERRUPTS+80) /* 80: Hash and Rng global interrupt */
|
||||||
#define STM32_IRQ_RNG (STM32_IRQ_INTERRUPTS+80) /* 80: Hash and Rng global interrupt */
|
#define STM32_IRQ_RNG (STM32_IRQ_INTERRUPTS+80) /* 80: Hash and Rng global interrupt */
|
||||||
|
|
||||||
|
#define NR_VECTORS (STM32_IRQ_INTERRUPTS+81)
|
||||||
#define NR_IRQS (STM32_IRQ_INTERRUPTS+81)
|
#define NR_IRQS (STM32_IRQ_INTERRUPTS+81)
|
||||||
|
|
||||||
/****************************************************************************************************
|
/****************************************************************************************************
|
||||||
|
@ -161,6 +161,7 @@
|
|||||||
#define STM32_IRQ_RESERVED80 (STM32_IRQ_INTERRUPTS+80) /* 80: Reserved */
|
#define STM32_IRQ_RESERVED80 (STM32_IRQ_INTERRUPTS+80) /* 80: Reserved */
|
||||||
#define STM32_IRQ_FPU (STM32_IRQ_INTERRUPTS+81) /* 81: FPU global interrupt */
|
#define STM32_IRQ_FPU (STM32_IRQ_INTERRUPTS+81) /* 81: FPU global interrupt */
|
||||||
|
|
||||||
|
#define NR_VECTORS (STM32_IRQ_INTERRUPTS+82)
|
||||||
#define NR_IRQS (STM32_IRQ_INTERRUPTS+82)
|
#define NR_IRQS (STM32_IRQ_INTERRUPTS+82)
|
||||||
|
|
||||||
/****************************************************************************************************
|
/****************************************************************************************************
|
||||||
|
@ -154,21 +154,29 @@
|
|||||||
#define STM32_IRQ_FPU (STM32_IRQ_INTERRUPTS+81) /* 81: FPU global interrupt */
|
#define STM32_IRQ_FPU (STM32_IRQ_INTERRUPTS+81) /* 81: FPU global interrupt */
|
||||||
|
|
||||||
#if !defined(CONFIG_STM32_STM32F427) && !defined(CONFIG_STM32_STM32F429)
|
#if !defined(CONFIG_STM32_STM32F427) && !defined(CONFIG_STM32_STM32F429)
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+82)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+82)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+82)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
# define STM32_IRQ_UART7 (STM32_IRQ_INTERRUPTS+82) /* 82: UART7 interrupt */
|
# define STM32_IRQ_UART7 (STM32_IRQ_INTERRUPTS+82) /* 82: UART7 interrupt */
|
||||||
# define STM32_IRQ_UART8 (STM32_IRQ_INTERRUPTS+83) /* 83: UART8 interrupt */
|
# define STM32_IRQ_UART8 (STM32_IRQ_INTERRUPTS+83) /* 83: UART8 interrupt */
|
||||||
# define STM32_IRQ_SPI4 (STM32_IRQ_INTERRUPTS+84) /* 84: SPI4 interrupt */
|
# define STM32_IRQ_SPI4 (STM32_IRQ_INTERRUPTS+84) /* 84: SPI4 interrupt */
|
||||||
# define STM32_IRQ_SPI5 (STM32_IRQ_INTERRUPTS+85) /* 85: SPI5 interrupt */
|
# define STM32_IRQ_SPI5 (STM32_IRQ_INTERRUPTS+85) /* 85: SPI5 interrupt */
|
||||||
# define STM32_IRQ_SPI6 (STM32_IRQ_INTERRUPTS+86) /* 86: SPI6 interrupt */
|
# define STM32_IRQ_SPI6 (STM32_IRQ_INTERRUPTS+86) /* 86: SPI6 interrupt */
|
||||||
|
|
||||||
#if defined(CONFIG_STM32_STM32F429)
|
#if defined(CONFIG_STM32_STM32F429)
|
||||||
# define STM32_IRQ_SAI1 (STM32_IRQ_INTERRUPTS+87) /* 87: SAI1 interrupt */
|
# define STM32_IRQ_SAI1 (STM32_IRQ_INTERRUPTS+87) /* 87: SAI1 interrupt */
|
||||||
# define STM32_IRQ_LTDCINT (STM32_IRQ_INTERRUPTS+88) /* 88: LTDCINT interrupt */
|
# define STM32_IRQ_LTDCINT (STM32_IRQ_INTERRUPTS+88) /* 88: LTDCINT interrupt */
|
||||||
# define STM32_IRQ_LTDCERRINT (STM32_IRQ_INTERRUPTS+89) /* 89: LTDCERRINT interrupt */
|
# define STM32_IRQ_LTDCERRINT (STM32_IRQ_INTERRUPTS+89) /* 89: LTDCERRINT interrupt */
|
||||||
# define STM32_IRQ_DMA2D (STM32_IRQ_INTERRUPTS+90) /* 90: DMA2D interrupt */
|
# define STM32_IRQ_DMA2D (STM32_IRQ_INTERRUPTS+90) /* 90: DMA2D interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+91)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+91)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+91)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+87)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+87)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+87)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -108,6 +108,7 @@
|
|||||||
# define STM32_IRQ_TIM6 (STM32_IRQ_INTERRUPTS+43) /* 43: TIM6 global interrupt */
|
# define STM32_IRQ_TIM6 (STM32_IRQ_INTERRUPTS+43) /* 43: TIM6 global interrupt */
|
||||||
# define STM32_IRQ_TIM7 (STM32_IRQ_INTERRUPTS+44) /* 44: TIM7 global interrupt */
|
# define STM32_IRQ_TIM7 (STM32_IRQ_INTERRUPTS+44) /* 44: TIM7 global interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+45)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+45)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+45)
|
||||||
|
|
||||||
/* External interrupts (vectors >= 16) medium+ density devices */
|
/* External interrupts (vectors >= 16) medium+ density devices */
|
||||||
@ -170,6 +171,7 @@
|
|||||||
# define STM32_IRQ_AES (STM32_IRQ_INTERRUPTS+52) /* 52: AES global interrupt */
|
# define STM32_IRQ_AES (STM32_IRQ_INTERRUPTS+52) /* 52: AES global interrupt */
|
||||||
# define STM32_IRQ_COMPACQ (STM32_IRQ_INTERRUPTS+53) /* 53: Comparator Channel Acquisition Interrupt */
|
# define STM32_IRQ_COMPACQ (STM32_IRQ_INTERRUPTS+53) /* 53: Comparator Channel Acquisition Interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+54)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+54)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+54)
|
||||||
|
|
||||||
/* External interrupts (vectors >= 16) high density devices */
|
/* External interrupts (vectors >= 16) high density devices */
|
||||||
@ -235,6 +237,7 @@
|
|||||||
# define STM32_IRQ_AES (STM32_IRQ_INTERRUPTS+55) /* 55: AES global interrupt */
|
# define STM32_IRQ_AES (STM32_IRQ_INTERRUPTS+55) /* 55: AES global interrupt */
|
||||||
# define STM32_IRQ_COMPACQ (STM32_IRQ_INTERRUPTS+56) /* 56: Comparator Channel Acquisition Interrupt */
|
# define STM32_IRQ_COMPACQ (STM32_IRQ_INTERRUPTS+56) /* 56: Comparator Channel Acquisition Interrupt */
|
||||||
|
|
||||||
|
# define NR_VECTORS (STM32_IRQ_INTERRUPTS+57)
|
||||||
# define NR_IRQS (STM32_IRQ_INTERRUPTS+57)
|
# define NR_IRQS (STM32_IRQ_INTERRUPTS+57)
|
||||||
#else
|
#else
|
||||||
# error "Unknown STM32L density"
|
# error "Unknown STM32L density"
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* arch/arm/src/armv7-m/ram_vectors.h
|
* arch/arm/src/armv7-m/ram_vectors.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
@ -31,48 +31,37 @@
|
|||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifndef __ARCH_ARM_SRC_COMMON_ARMV7_M_RAM_VECTORS_H
|
#ifndef __ARCH_ARM_SRC_COMMON_ARMV7_M_RAM_VECTORS_H
|
||||||
#define __ARCH_ARM_SRC_COMMON_ARMV7_M_RAM_VECTORS_H
|
#define __ARCH_ARM_SRC_COMMON_ARMV7_M_RAM_VECTORS_H
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Included Files
|
* Included Files
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
#include <arch/irq.h>
|
||||||
|
|
||||||
/* If CONFIG_ARMV7M_CMNVECTOR is defined then the number of peripheral interrupts
|
|
||||||
* is provided in chip.h.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "chip.h"
|
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_RAMVECTORS
|
#ifdef CONFIG_ARCH_RAMVECTORS
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
/* This logic currently only works if CONFIG_ARMV7M_CMNVECTOR is defined. That is
|
|
||||||
* because CONFIG_ARMV7M_CMNVECTOR is needed to induce chip.h into giving us the
|
/* This is the size of the vector table (in 4-byte entries). This size
|
||||||
* number of peripheral interrupts. "Oh want a tangled web we weave..."
|
* includes the (1) the peripheral interrupts, (2) space for 15 Cortex-M
|
||||||
|
* exceptions, and (3) IDLE stack pointer which lies at the beginning of the
|
||||||
|
* table.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef CONFIG_ARMV7M_CMNVECTOR
|
#define ARMV7M_VECTAB_SIZE (NR_VECTORS + 16)
|
||||||
# error "This logic requires CONFIG_ARMV7M_CMNVECTOR"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* This, then is the size of the vector table (in 4-byte entries). This size
|
/****************************************************************************
|
||||||
* includes the (1) the device interrupts, (2) space for 15 Cortex-M excpetions, and
|
|
||||||
* (3) IDLE stack pointer which lies at the beginning of the table.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define ARMV7M_VECTAB_SIZE (ARMV7M_PERIPHERAL_INTERRUPTS + 16)
|
|
||||||
|
|
||||||
/************************************************************************************
|
|
||||||
* Public Data
|
* Public Data
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* If CONFIG_ARCH_RAMVECTORS is defined, then the ARM logic must provide
|
/* If CONFIG_ARCH_RAMVECTORS is defined, then the ARM logic must provide
|
||||||
* ARM-specific implementations of irq_initialize(), irq_attach(), and
|
* ARM-specific implementations of irq_initialize(), irq_attach(), and
|
||||||
@ -80,15 +69,18 @@
|
|||||||
* table resides in RAM, has the name up_ram_vectors, and has been
|
* table resides in RAM, has the name up_ram_vectors, and has been
|
||||||
* properly positioned and aligned in memory by the linker script.
|
* properly positioned and aligned in memory by the linker script.
|
||||||
*
|
*
|
||||||
* REVISIT: Can this alignment requirement vary from core-to-core?
|
* REVISIT: Can this alignment requirement vary from core-to-core? Yes, it
|
||||||
|
* depends on the number of vectors supported by the MCU. The safest thing
|
||||||
|
* to do is to put the vector table at the beginning of RAM in order toforce
|
||||||
|
* the highest alignment possible.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
extern up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
||||||
__attribute__ ((section (".ram_vectors"), aligned (128)));
|
__attribute__ ((section (".ram_vectors"), aligned (128)));
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Public Function Prototypes
|
* Public Function Prototypes
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: up_ramvec_initialize
|
* Name: up_ramvec_initialize
|
||||||
|
@ -105,7 +105,7 @@ int up_ramvec_attach(int irq, up_vector_t vector)
|
|||||||
|
|
||||||
intvdbg("%s IRQ%d\n", vector ? "Attaching" : "Detaching", irq);
|
intvdbg("%s IRQ%d\n", vector ? "Attaching" : "Detaching", irq);
|
||||||
|
|
||||||
if ((unsigned)irq < (STM32_IRQ_INTERRUPTS + ARMV7M_PERIPHERAL_INTERRUPTS))
|
if ((unsigned)irq < NR_VECTORS)
|
||||||
{
|
{
|
||||||
irqstate_t flags;
|
irqstate_t flags;
|
||||||
|
|
||||||
|
@ -84,7 +84,10 @@
|
|||||||
* table resides in RAM, has the name up_ram_vectors, and has been
|
* table resides in RAM, has the name up_ram_vectors, and has been
|
||||||
* properly positioned and aligned in memory by the linker script.
|
* properly positioned and aligned in memory by the linker script.
|
||||||
*
|
*
|
||||||
* REVISIT: Can this alignment requirement vary from core-to-core?
|
* REVISIT: Can this alignment requirement vary from core-to-core? Yes, it
|
||||||
|
* depends on the number of vectors supported by the MCU. The safest thing
|
||||||
|
* to do is to put the vector table at the beginning of RAM in order toforce
|
||||||
|
* the highest alignment possible.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
||||||
|
@ -76,7 +76,7 @@ extern char _ebss;
|
|||||||
* As all exceptions (interrupts) are routed via exception_common, we just need to
|
* As all exceptions (interrupts) are routed via exception_common, we just need to
|
||||||
* fill this array with pointers to it.
|
* fill this array with pointers to it.
|
||||||
*
|
*
|
||||||
* Note that the [ ... ] desginated initialiser is a GCC extension.
|
* Note that the [ ... ] designated initialiser is a GCC extension.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
unsigned _vectors[] __attribute__((section(".vectors"))) =
|
unsigned _vectors[] __attribute__((section(".vectors"))) =
|
||||||
|
@ -119,7 +119,7 @@
|
|||||||
.thumb_func
|
.thumb_func
|
||||||
\label:
|
\label:
|
||||||
mov r0, #\irqno
|
mov r0, #\irqno
|
||||||
b kinetis_common
|
b exception_common
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
/************************************************************************************************
|
/************************************************************************************************
|
||||||
@ -129,10 +129,10 @@
|
|||||||
.section .vectors, "ax"
|
.section .vectors, "ax"
|
||||||
.code 16
|
.code 16
|
||||||
.align 2
|
.align 2
|
||||||
.globl kinetis_vectors
|
.globl _vectors
|
||||||
.type kinetis_vectors, function
|
.type _vectors, function
|
||||||
|
|
||||||
kinetis_vectors:
|
_vectors:
|
||||||
|
|
||||||
/* Processor Exceptions *************************************************************************/
|
/* Processor Exceptions *************************************************************************/
|
||||||
|
|
||||||
@ -614,7 +614,10 @@ handlers:
|
|||||||
* We are in handler mode and the current SP is the MSP
|
* We are in handler mode and the current SP is the MSP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
kinetis_common:
|
.globl exception_common
|
||||||
|
.type exception_common, function
|
||||||
|
|
||||||
|
exception_common:
|
||||||
|
|
||||||
/* Complete the context save */
|
/* Complete the context save */
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@
|
|||||||
* Public Data
|
* Public Data
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
extern void lm_vectors(void);
|
extern void _vectors(void);
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
|
@ -126,7 +126,7 @@
|
|||||||
.thumb_func
|
.thumb_func
|
||||||
\label:
|
\label:
|
||||||
mov r0, #\irqno
|
mov r0, #\irqno
|
||||||
b lm_irqcommon
|
b exception_common
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
@ -136,10 +136,10 @@
|
|||||||
.section .vectors, "ax"
|
.section .vectors, "ax"
|
||||||
.code 16
|
.code 16
|
||||||
.align 2
|
.align 2
|
||||||
.globl lm_vectors
|
.globl _vectors
|
||||||
.type lm_vectors, function
|
.type _vectors, function
|
||||||
|
|
||||||
lm_vectors:
|
_vectors:
|
||||||
|
|
||||||
/* Processor Exceptions */
|
/* Processor Exceptions */
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ lm_vectors:
|
|||||||
#define UNUSED(i) .word lm_reserved
|
#define UNUSED(i) .word lm_reserved
|
||||||
|
|
||||||
#include "chip/chip/lm_vectors.h"
|
#include "chip/chip/lm_vectors.h"
|
||||||
.size lm_vectors, .-lm_vectors
|
.size _vectors, .-_vectors
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* .text
|
* .text
|
||||||
@ -218,7 +218,9 @@ handlers:
|
|||||||
* We are in handler mode and the current SP is the MSP
|
* We are in handler mode and the current SP is the MSP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
lm_irqcommon:
|
.globl exception_common
|
||||||
|
.type exception_common, function
|
||||||
|
exception_common:
|
||||||
|
|
||||||
/* Complete the context save */
|
/* Complete the context save */
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@
|
|||||||
.thumb_func
|
.thumb_func
|
||||||
\label:
|
\label:
|
||||||
mov r0, #\irqno
|
mov r0, #\irqno
|
||||||
b lpc17_common
|
b exception_common
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
/************************************************************************************************
|
/************************************************************************************************
|
||||||
@ -131,10 +131,10 @@
|
|||||||
.section .vectors, "ax"
|
.section .vectors, "ax"
|
||||||
.code 16
|
.code 16
|
||||||
.align 2
|
.align 2
|
||||||
.globl lpc17_vectors
|
.globl _vectors
|
||||||
.type lpc17_vectors, function
|
.type _vectors, function
|
||||||
|
|
||||||
lpc17_vectors:
|
_vectors:
|
||||||
|
|
||||||
/* Processor Exceptions */
|
/* Processor Exceptions */
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ lpc17_vectors:
|
|||||||
# error "Unrecognized LPC17xx family"
|
# error "Unrecognized LPC17xx family"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
.size lpc17_vectors, .-lpc17_vectors
|
.size _vectors, .-_vectors
|
||||||
|
|
||||||
/************************************************************************************************
|
/************************************************************************************************
|
||||||
* .text
|
* .text
|
||||||
@ -226,7 +226,10 @@ handlers:
|
|||||||
* We are in handler mode and the current SP is the MSP
|
* We are in handler mode and the current SP is the MSP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
lpc17_common:
|
.globl exception_common
|
||||||
|
.type exception_common, function
|
||||||
|
|
||||||
|
exception_common:
|
||||||
|
|
||||||
/* Complete the context save */
|
/* Complete the context save */
|
||||||
|
|
||||||
|
@ -74,6 +74,8 @@
|
|||||||
|
|
||||||
volatile uint32_t *current_regs;
|
volatile uint32_t *current_regs;
|
||||||
|
|
||||||
|
extern uint32_t _vectors[];
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Data
|
* Private Data
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -345,7 +347,7 @@ void up_irqinitialize(void)
|
|||||||
#if defined(CONFIG_ARCH_RAMVECTORS)
|
#if defined(CONFIG_ARCH_RAMVECTORS)
|
||||||
up_ramvec_initialize();
|
up_ramvec_initialize();
|
||||||
#elif defined(CONFIG_SAM_BOOTLOADER)
|
#elif defined(CONFIG_SAM_BOOTLOADER)
|
||||||
putreg32((uint32_t)sam_vectors, NVIC_VECTAB);
|
putreg32((uint32_t)_vectors, NVIC_VECTAB);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Set all interrupts (and exceptions) to the default priority */
|
/* Set all interrupts (and exceptions) to the default priority */
|
||||||
|
@ -120,7 +120,7 @@
|
|||||||
.thumb_func
|
.thumb_func
|
||||||
\label:
|
\label:
|
||||||
mov r0, #\irqno
|
mov r0, #\irqno
|
||||||
b sam_common
|
b exception_common
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
/************************************************************************************************
|
/************************************************************************************************
|
||||||
@ -130,10 +130,10 @@
|
|||||||
.section .vectors, "ax"
|
.section .vectors, "ax"
|
||||||
.code 16
|
.code 16
|
||||||
.align 2
|
.align 2
|
||||||
.globl sam_vectors
|
.globl _vectors
|
||||||
.type sam_vectors, function
|
.type _vectors, function
|
||||||
|
|
||||||
sam_vectors:
|
_vectors:
|
||||||
|
|
||||||
/* Processor Exceptions */
|
/* Processor Exceptions */
|
||||||
|
|
||||||
@ -174,7 +174,7 @@ sam_vectors:
|
|||||||
# error Unrecognized SAM architecture
|
# error Unrecognized SAM architecture
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
.size sam_vectors, .-sam_vectors
|
.size _vectors, .-_vectors
|
||||||
|
|
||||||
/************************************************************************************************
|
/************************************************************************************************
|
||||||
* .text
|
* .text
|
||||||
@ -231,7 +231,10 @@ handlers:
|
|||||||
* We are in handler mode and the current SP is the MSP
|
* We are in handler mode and the current SP is the MSP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
sam_common:
|
.globl exception_common
|
||||||
|
.type exception_common, function
|
||||||
|
|
||||||
|
exception_common:
|
||||||
|
|
||||||
/* Complete the context save */
|
/* Complete the context save */
|
||||||
|
|
||||||
|
@ -151,7 +151,7 @@ static int stm32_nmi(int irq, FAR void *context)
|
|||||||
static int stm32_busfault(int irq, FAR void *context)
|
static int stm32_busfault(int irq, FAR void *context)
|
||||||
{
|
{
|
||||||
(void)irqsave();
|
(void)irqsave();
|
||||||
dbg("PANIC!!! Bus fault recived\n");
|
dbg("PANIC!!! Bus fault received: %08x\n", getreg32(NVIC_CFAULTS));
|
||||||
PANIC();
|
PANIC();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -159,7 +159,7 @@ static int stm32_busfault(int irq, FAR void *context)
|
|||||||
static int stm32_usagefault(int irq, FAR void *context)
|
static int stm32_usagefault(int irq, FAR void *context)
|
||||||
{
|
{
|
||||||
(void)irqsave();
|
(void)irqsave();
|
||||||
dbg("PANIC!!! Usage fault received\n");
|
dbg("PANIC!!! Usage fault received: %08x\n", getreg32(NVIC_CFAULTS));
|
||||||
PANIC();
|
PANIC();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -321,7 +321,7 @@ void up_irqinitialize(void)
|
|||||||
#if defined(CONFIG_ARCH_RAMVECTORS)
|
#if defined(CONFIG_ARCH_RAMVECTORS)
|
||||||
up_ramvec_initialize();
|
up_ramvec_initialize();
|
||||||
#elif defined(CONFIG_STM32_DFU)
|
#elif defined(CONFIG_STM32_DFU)
|
||||||
putreg32((uint32_t)stm32_vectors, NVIC_VECTAB);
|
putreg32((uint32_t)_vectors, NVIC_VECTAB);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Set all interrupts (and exceptions) to the default priority */
|
/* Set all interrupts (and exceptions) to the default priority */
|
||||||
|
@ -83,7 +83,7 @@ extern "C"
|
|||||||
* and we will need to set the NVIC vector location to this alternative location.
|
* and we will need to set the NVIC vector location to this alternative location.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern uint32_t stm32_vectors[]; /* See stm32_vectors.S */
|
extern uint32_t _vectors[]; /* See stm32_vectors.S */
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Inline Functions
|
* Inline Functions
|
||||||
|
@ -127,7 +127,7 @@
|
|||||||
.thumb_func
|
.thumb_func
|
||||||
\label:
|
\label:
|
||||||
mov r0, #\irqno
|
mov r0, #\irqno
|
||||||
b stm32_common
|
b exception_common
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
@ -137,10 +137,10 @@
|
|||||||
.section .vectors, "ax"
|
.section .vectors, "ax"
|
||||||
.code 16
|
.code 16
|
||||||
.align 2
|
.align 2
|
||||||
.globl stm32_vectors
|
.globl _vectors
|
||||||
.type stm32_vectors, function
|
.type _vectors, function
|
||||||
|
|
||||||
stm32_vectors:
|
_vectors:
|
||||||
|
|
||||||
/* Processor Exceptions */
|
/* Processor Exceptions */
|
||||||
|
|
||||||
@ -182,7 +182,7 @@ stm32_vectors:
|
|||||||
#else
|
#else
|
||||||
# error "No vectors for STM32 chip"
|
# error "No vectors for STM32 chip"
|
||||||
#endif
|
#endif
|
||||||
.size stm32_vectors, .-stm32_vectors
|
.size _vectors, .-_vectors
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* .text
|
* .text
|
||||||
@ -241,7 +241,10 @@ handlers:
|
|||||||
* We are in handler mode and the current SP is the MSP
|
* We are in handler mode and the current SP is the MSP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
stm32_common:
|
.globl exception_common
|
||||||
|
.type exception_common, function
|
||||||
|
|
||||||
|
exception_common:
|
||||||
|
|
||||||
/* Complete the context save */
|
/* Complete the context save */
|
||||||
|
|
||||||
|
@ -38,9 +38,9 @@ include ${TOPDIR}/tools/Config.mk
|
|||||||
include ${TOPDIR}/arch/arm/src/armv7-m/Toolchain.defs
|
include ${TOPDIR}/arch/arm/src/armv7-m/Toolchain.defs
|
||||||
|
|
||||||
ifeq ($(CONFIG_STM32_DFU),y)
|
ifeq ($(CONFIG_STM32_DFU),y)
|
||||||
LDSCRIPT = cmndfu.ld
|
LDSCRIPT = dfu.ld
|
||||||
else
|
else
|
||||||
LDSCRIPT = cmnflash.ld
|
LDSCRIPT = flash.ld
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(WINTOOL),y)
|
ifeq ($(WINTOOL),y)
|
||||||
|
@ -1,112 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
* configs/viewtool-stm32f107/scripts/cmndfu.ld
|
|
||||||
*
|
|
||||||
* Copyright (C) 2013 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.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
MEMORY
|
|
||||||
{
|
|
||||||
flash (rx) : ORIGIN = 0x08003000, LENGTH = 208K
|
|
||||||
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
|
|
||||||
}
|
|
||||||
|
|
||||||
OUTPUT_ARCH(arm)
|
|
||||||
EXTERN(_vectors)
|
|
||||||
ENTRY(_stext)
|
|
||||||
SECTIONS
|
|
||||||
{
|
|
||||||
.text : {
|
|
||||||
_stext = ABSOLUTE(.);
|
|
||||||
*(.vectors)
|
|
||||||
*(.text .text.*)
|
|
||||||
*(.fixup)
|
|
||||||
*(.gnu.warning)
|
|
||||||
*(.rodata .rodata.*)
|
|
||||||
*(.gnu.linkonce.t.*)
|
|
||||||
*(.glue_7)
|
|
||||||
*(.glue_7t)
|
|
||||||
*(.got)
|
|
||||||
*(.gcc_except_table)
|
|
||||||
*(.gnu.linkonce.r.*)
|
|
||||||
_etext = ABSOLUTE(.);
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
.init_section : {
|
|
||||||
_sinit = ABSOLUTE(.);
|
|
||||||
*(.init_array .init_array.*)
|
|
||||||
_einit = ABSOLUTE(.);
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
.ARM.extab : {
|
|
||||||
*(.ARM.extab*)
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
__exidx_start = ABSOLUTE(.);
|
|
||||||
.ARM.exidx : {
|
|
||||||
*(.ARM.exidx*)
|
|
||||||
} > flash
|
|
||||||
__exidx_end = ABSOLUTE(.);
|
|
||||||
|
|
||||||
_eronly = ABSOLUTE(.);
|
|
||||||
|
|
||||||
/* The STM32F103Z has 64Kb of SRAM beginning at the following address */
|
|
||||||
|
|
||||||
.data : {
|
|
||||||
_sdata = ABSOLUTE(.);
|
|
||||||
*(.data .data.*)
|
|
||||||
*(.gnu.linkonce.d.*)
|
|
||||||
CONSTRUCTORS
|
|
||||||
_edata = ABSOLUTE(.);
|
|
||||||
} > sram AT > flash
|
|
||||||
|
|
||||||
.bss : {
|
|
||||||
_sbss = ABSOLUTE(.);
|
|
||||||
*(.bss .bss.*)
|
|
||||||
*(.gnu.linkonce.b.*)
|
|
||||||
*(COMMON)
|
|
||||||
_ebss = ABSOLUTE(.);
|
|
||||||
} > sram
|
|
||||||
|
|
||||||
/* Stabs debugging sections. */
|
|
||||||
.stab 0 : { *(.stab) }
|
|
||||||
.stabstr 0 : { *(.stabstr) }
|
|
||||||
.stab.excl 0 : { *(.stab.excl) }
|
|
||||||
.stab.exclstr 0 : { *(.stab.exclstr) }
|
|
||||||
.stab.index 0 : { *(.stab.index) }
|
|
||||||
.stab.indexstr 0 : { *(.stab.indexstr) }
|
|
||||||
.comment 0 : { *(.comment) }
|
|
||||||
.debug_abbrev 0 : { *(.debug_abbrev) }
|
|
||||||
.debug_info 0 : { *(.debug_info) }
|
|
||||||
.debug_line 0 : { *(.debug_line) }
|
|
||||||
.debug_pubnames 0 : { *(.debug_pubnames) }
|
|
||||||
.debug_aranges 0 : { *(.debug_aranges) }
|
|
||||||
}
|
|
@ -1,113 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
* configs/viewtool-stm32f107/scripts/cmnflash.ld
|
|
||||||
*
|
|
||||||
* Copyright (C) 2013 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.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
MEMORY
|
|
||||||
{
|
|
||||||
flash (rx) : ORIGIN = 0x08000000, LENGTH = 256K
|
|
||||||
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
OUTPUT_ARCH(arm)
|
|
||||||
EXTERN(_vectors)
|
|
||||||
ENTRY(_stext)
|
|
||||||
SECTIONS
|
|
||||||
{
|
|
||||||
.text : {
|
|
||||||
_stext = ABSOLUTE(.);
|
|
||||||
*(.vectors)
|
|
||||||
*(.text .text.*)
|
|
||||||
*(.fixup)
|
|
||||||
*(.gnu.warning)
|
|
||||||
*(.rodata .rodata.*)
|
|
||||||
*(.gnu.linkonce.t.*)
|
|
||||||
*(.glue_7)
|
|
||||||
*(.glue_7t)
|
|
||||||
*(.got)
|
|
||||||
*(.gcc_except_table)
|
|
||||||
*(.gnu.linkonce.r.*)
|
|
||||||
_etext = ABSOLUTE(.);
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
.init_section : {
|
|
||||||
_sinit = ABSOLUTE(.);
|
|
||||||
*(.init_array .init_array.*)
|
|
||||||
_einit = ABSOLUTE(.);
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
.ARM.extab : {
|
|
||||||
*(.ARM.extab*)
|
|
||||||
} > flash
|
|
||||||
|
|
||||||
__exidx_start = ABSOLUTE(.);
|
|
||||||
.ARM.exidx : {
|
|
||||||
*(.ARM.exidx*)
|
|
||||||
} > flash
|
|
||||||
__exidx_end = ABSOLUTE(.);
|
|
||||||
|
|
||||||
_eronly = ABSOLUTE(.);
|
|
||||||
|
|
||||||
/* The STM32F107VC has 64Kb of SRAM beginning at the following address */
|
|
||||||
|
|
||||||
.data : {
|
|
||||||
_sdata = ABSOLUTE(.);
|
|
||||||
*(.data .data.*)
|
|
||||||
*(.gnu.linkonce.d.*)
|
|
||||||
CONSTRUCTORS
|
|
||||||
_edata = ABSOLUTE(.);
|
|
||||||
} > sram AT > flash
|
|
||||||
|
|
||||||
.bss : {
|
|
||||||
_sbss = ABSOLUTE(.);
|
|
||||||
*(.bss .bss.*)
|
|
||||||
*(.gnu.linkonce.b.*)
|
|
||||||
*(COMMON)
|
|
||||||
_ebss = ABSOLUTE(.);
|
|
||||||
} > sram
|
|
||||||
|
|
||||||
/* Stabs debugging sections. */
|
|
||||||
.stab 0 : { *(.stab) }
|
|
||||||
.stabstr 0 : { *(.stabstr) }
|
|
||||||
.stab.excl 0 : { *(.stab.excl) }
|
|
||||||
.stab.exclstr 0 : { *(.stab.exclstr) }
|
|
||||||
.stab.index 0 : { *(.stab.index) }
|
|
||||||
.stab.indexstr 0 : { *(.stab.indexstr) }
|
|
||||||
.comment 0 : { *(.comment) }
|
|
||||||
.debug_abbrev 0 : { *(.debug_abbrev) }
|
|
||||||
.debug_info 0 : { *(.debug_info) }
|
|
||||||
.debug_line 0 : { *(.debug_line) }
|
|
||||||
.debug_pubnames 0 : { *(.debug_pubnames) }
|
|
||||||
.debug_aranges 0 : { *(.debug_aranges) }
|
|
||||||
}
|
|
@ -40,6 +40,7 @@ MEMORY
|
|||||||
}
|
}
|
||||||
|
|
||||||
OUTPUT_ARCH(arm)
|
OUTPUT_ARCH(arm)
|
||||||
|
EXTERN(_vectors)
|
||||||
ENTRY(_stext)
|
ENTRY(_stext)
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
@ -77,7 +78,11 @@ SECTIONS
|
|||||||
|
|
||||||
_eronly = ABSOLUTE(.);
|
_eronly = ABSOLUTE(.);
|
||||||
|
|
||||||
/* The STM32F103Z has 64Kb of SRAM beginning at the following address */
|
/* The RAM vector table (if present) should lie at the beginning of SRAM */
|
||||||
|
|
||||||
|
.ram_vectors : {
|
||||||
|
*(.ram_vectors)
|
||||||
|
} > sram
|
||||||
|
|
||||||
.data : {
|
.data : {
|
||||||
_sdata = ABSOLUTE(.);
|
_sdata = ABSOLUTE(.);
|
||||||
|
@ -37,10 +37,10 @@ MEMORY
|
|||||||
{
|
{
|
||||||
flash (rx) : ORIGIN = 0x08000000, LENGTH = 256K
|
flash (rx) : ORIGIN = 0x08000000, LENGTH = 256K
|
||||||
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
|
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
OUTPUT_ARCH(arm)
|
OUTPUT_ARCH(arm)
|
||||||
|
EXTERN(_vectors)
|
||||||
ENTRY(_stext)
|
ENTRY(_stext)
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
@ -78,7 +78,11 @@ SECTIONS
|
|||||||
|
|
||||||
_eronly = ABSOLUTE(.);
|
_eronly = ABSOLUTE(.);
|
||||||
|
|
||||||
/* The STM32F107VC has 64Kb of SRAM beginning at the following address */
|
/* The RAM vector table (if present) should lie at the beginning of SRAM */
|
||||||
|
|
||||||
|
.ram_vectors : {
|
||||||
|
*(.ram_vectors)
|
||||||
|
} > sram
|
||||||
|
|
||||||
.data : {
|
.data : {
|
||||||
_sdata = ABSOLUTE(.);
|
_sdata = ABSOLUTE(.);
|
||||||
|
Loading…
Reference in New Issue
Block a user