aboutsummaryrefslogtreecommitdiff
path: root/system-clock/src
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2018-01-15 15:09:00 -0700
committerJosh Rahm <joshuarahm@gmail.com>2018-01-15 15:09:00 -0700
commit3b7d25e1586082a7c5d0066a56d80f7c55862e38 (patch)
treef5f6ab68da4b4e4ef4fceecd27b31816545db5ef /system-clock/src
parent79c73cd2734d5e3b3c86885ebcb28aa36a2d0f56 (diff)
downloadstm32l4-3b7d25e1586082a7c5d0066a56d80f7c55862e38.tar.gz
stm32l4-3b7d25e1586082a7c5d0066a56d80f7c55862e38.tar.bz2
stm32l4-3b7d25e1586082a7c5d0066a56d80f7c55862e38.zip
broke apart main.c into delay.* and isr_vector.*
Diffstat (limited to 'system-clock/src')
-rw-r--r--system-clock/src/delay.c9
-rw-r--r--system-clock/src/isr_vector.c132
-rw-r--r--system-clock/src/main.c143
-rw-r--r--system-clock/src/vector.c0
4 files changed, 142 insertions, 142 deletions
diff --git a/system-clock/src/delay.c b/system-clock/src/delay.c
new file mode 100644
index 0000000..077d1ff
--- /dev/null
+++ b/system-clock/src/delay.c
@@ -0,0 +1,9 @@
+#include "delay.h"
+
+void delay(uint32_t delay)
+{
+ while (delay --) {
+ /* needed to keep the compiler from optimizing away the loop. */
+ asm volatile ("");
+ }
+}
diff --git a/system-clock/src/isr_vector.c b/system-clock/src/isr_vector.c
new file mode 100644
index 0000000..a56a8dc
--- /dev/null
+++ b/system-clock/src/isr_vector.c
@@ -0,0 +1,132 @@
+#include "isr_vector.h"
+#include "gpio.h"
+#include "delay.h"
+
+/* Forward-declare the main function. This is implemented in main.c. */
+void main();
+
+const void* vectors[] __attribute__((section(".vectors"))) = {
+ (void *) 0x2000c000, /* Top of stack at top of sram1. 48k */
+ main, /* Reset handler */
+ unhandled_isr, /* NMI */
+ unhandled_isr, /* Hard Fault */
+ unhandled_isr, /* MemManage */
+ unhandled_isr, /* BusFault */
+ unhandled_isr, /* UsageFault */
+ unhandled_isr, /* Reserved */
+ unhandled_isr, /* Reserved */
+ unhandled_isr, /* Reserved */
+ unhandled_isr, /* Reserved */
+ unhandled_isr, /* SVCall */
+ unhandled_isr, /* Debug */
+ unhandled_isr, /* Reserved */
+ unhandled_isr, /* PendSV */
+ unhandled_isr, /* SysTick */
+
+ /* External interrupt handlers follow */
+ unhandled_isr, /* 0 WWDG */
+ unhandled_isr, /* 1 PVD */
+ unhandled_isr, /* 2 TAMP_SAMP */
+ unhandled_isr, /* 3 RTC_WKUP */
+ unhandled_isr, /* 4 FLASH */
+ unhandled_isr, /* 5 RCC */
+ unhandled_isr, /* 6 EXTI0 */
+ unhandled_isr, /* 7 EXTI1 */
+ unhandled_isr, /* 8 EXTI2 */
+ unhandled_isr, /* 9 EXTI3 */
+ unhandled_isr, /* 10 EXTI4 */
+ unhandled_isr, /* 11 DMA_CH1 */
+ unhandled_isr, /* 12 DMA_CH2 */
+ unhandled_isr, /* 13 DMA_CH3 */
+ unhandled_isr, /* 14 DMA_CH4 */
+ unhandled_isr, /* 15 DMA_CH5 */
+ unhandled_isr, /* 16 DMA_CH6 */
+ unhandled_isr, /* 17 DMA_CH7 */
+ unhandled_isr, /* 18 ADC1 */
+ unhandled_isr, /* 19 CAN_TX */
+ unhandled_isr, /* 20 CAN_RX0 */
+ unhandled_isr, /* 21 CAN_RX1 */
+ unhandled_isr, /* 22 CAN_SCE */
+ unhandled_isr, /* 23 EXTI9_5 */
+ unhandled_isr, /* 24 TIM1_BRK/TIM15 */
+ unhandled_isr, /* 25 TIM1_UP/TIM16 */
+ unhandled_isr, /* 26 TIM1_TRG_COM */
+ unhandled_isr, /* 27 TIM1_CC */
+ unhandled_isr, /* 28 TIM2 */
+ unhandled_isr, /* 29 Reserved */
+ unhandled_isr, /* 30 Reserved */
+ unhandled_isr, /* 31 I2C1_EV */
+ unhandled_isr, /* 32 I2C1_ER */
+ unhandled_isr, /* 33 I2C2_EV */
+ unhandled_isr, /* 34 I2C2_ER */
+ unhandled_isr, /* 35 SPI1 */
+ unhandled_isr, /* 36 SPI2 */
+ unhandled_isr, /* 37 USART1 */
+ unhandled_isr, /* 38 USART2 */
+ unhandled_isr, /* 39 USART3 */
+ unhandled_isr, /* 40 EXTI15_10 */
+ unhandled_isr, /* 41 RTCAlarm */
+ unhandled_isr, /* 42 Reserved */
+ unhandled_isr, /* 43 Reserved */
+ unhandled_isr, /* 44 Reserved */
+ unhandled_isr, /* 45 Reserved */
+ unhandled_isr, /* 46 Reserved */
+ unhandled_isr, /* 47 Reserved */
+ unhandled_isr, /* 48 Reserved */
+ unhandled_isr, /* 49 SDMMC1 */
+ unhandled_isr, /* 50 Reserved */
+ unhandled_isr, /* 51 SPI3 */
+ unhandled_isr, /* 52 Reserved */
+ unhandled_isr, /* 53 Reserved */
+ unhandled_isr, /* 54 TIM6_DACUNDER */
+ unhandled_isr, /* 55 TIM7 */
+ unhandled_isr, /* 56 DMA2_CH1 */
+ unhandled_isr, /* 57 DMA2_CH2 */
+ unhandled_isr, /* 58 DMA2_CH3 */
+ unhandled_isr, /* 59 DMA2_CH4 */
+ unhandled_isr, /* 60 DMA2_CH5 */
+ unhandled_isr, /* 61 Reserved */
+ unhandled_isr, /* 62 Reserved */
+ unhandled_isr, /* 63 Reserved*/
+ unhandled_isr, /* 64 COMP */
+ unhandled_isr, /* 65 LPTIM1 */
+ unhandled_isr, /* 66 LPTIM2 */
+ unhandled_isr, /* 67 USB_FS */
+ unhandled_isr, /* 68 DMA_CH6 */
+ unhandled_isr, /* 69 DMA_CH7 */
+ unhandled_isr, /* 70 LPUART1 */
+ unhandled_isr, /* 71 QUADSPI */
+ unhandled_isr, /* 72 I2C3_EV */
+ unhandled_isr, /* 73 I2C3_ER */
+ unhandled_isr, /* 74 SAI1 */
+ unhandled_isr, /* 75 Reserved */
+ unhandled_isr, /* 76 SWPMI1 */
+ unhandled_isr, /* 77 TSC */
+ unhandled_isr, /* 78 Reserved */
+ unhandled_isr, /* 79 AES */
+ unhandled_isr, /* 80 RNG */
+ unhandled_isr, /* 81 FPU */
+ unhandled_isr /* 82 CRS */
+};
+
+/*
+ * Does nothing ... forever.
+ */
+void unhandled_isr()
+{
+ __IO gpio_port_t* port_b = enable_gpio(GPIO_PORT_B);
+ gpio_output_pin_t pin3 = set_gpio_pin_output(port_b, PIN_3);
+ for(;;) {
+
+ /* Flash in a distinct pattern to know that something went wrong. */
+
+ pin_off(pin3);
+ delay(100000);
+ pin_on(pin3);
+ delay(100000);
+ pin_off(pin3);
+ delay(100000);
+ pin_on(pin3);
+ delay(500000);
+ }
+}
diff --git a/system-clock/src/main.c b/system-clock/src/main.c
index f7a30e8..5c9ecfc 100644
--- a/system-clock/src/main.c
+++ b/system-clock/src/main.c
@@ -1,124 +1,5 @@
#include "gpio.h"
-
-int main();
-
-void spin();
-
-/*
- * Interrupt service routine handlers.
- */
-const void* vectors[] __attribute__((section(".vectors"))) = {
- (void *) 0x2000c000, /* Top of stack at top of sram1. 48k */
- main, /* Reset handler */
- spin, /* NMI */
- spin, /* Hard Fault */
- spin, /* MemManage */
- spin, /* BusFault */
- spin, /* UsageFault */
- spin, /* Reserved */
- spin, /* Reserved */
- spin, /* Reserved */
- spin, /* Reserved */
- spin, /* SVCall */
- spin, /* Debug */
- spin, /* Reserved */
- spin, /* PendSV */
- spin, /* SysTick */
-
-/* External interrupt handlers follow */
- spin, /* 0 WWDG */
- spin, /* 1 PVD */
- spin, /* 2 TAMP_SAMP */
- spin, /* 3 RTC_WKUP */
- spin, /* 4 FLASH */
- spin, /* 5 RCC */
- spin, /* 6 EXTI0 */
- spin, /* 7 EXTI1 */
- spin, /* 8 EXTI2 */
- spin, /* 9 EXTI3 */
- spin, /* 10 EXTI4 */
- spin, /* 11 DMA_CH1 */
- spin, /* 12 DMA_CH2 */
- spin, /* 13 DMA_CH3 */
- spin, /* 14 DMA_CH4 */
- spin, /* 15 DMA_CH5 */
- spin, /* 16 DMA_CH6 */
- spin, /* 17 DMA_CH7 */
- spin, /* 18 ADC1 */
- spin, /* 19 CAN_TX */
- spin, /* 20 CAN_RX0 */
- spin, /* 21 CAN_RX1 */
- spin, /* 22 CAN_SCE */
- spin, /* 23 EXTI9_5 */
- spin, /* 24 TIM1_BRK/TIM15 */
- spin, /* 25 TIM1_UP/TIM16 */
- spin, /* 26 TIM1_TRG_COM */
- spin, /* 27 TIM1_CC */
- spin, /* 28 TIM2 */
- spin, /* 29 Reserved */
- spin, /* 30 Reserved */
- spin, /* 31 I2C1_EV */
- spin, /* 32 I2C1_ER */
- spin, /* 33 I2C2_EV */
- spin, /* 34 I2C2_ER */
- spin, /* 35 SPI1 */
- spin, /* 36 SPI2 */
- spin, /* 37 USART1 */
- spin, /* 38 USART2 */
- spin, /* 39 USART3 */
- spin, /* 40 EXTI15_10 */
- spin, /* 41 RTCAlarm */
- spin, /* 42 Reserved */
- spin, /* 43 Reserved */
- spin, /* 44 Reserved */
- spin, /* 45 Reserved */
- spin, /* 46 Reserved */
- spin, /* 47 Reserved */
- spin, /* 48 Reserved */
- spin, /* 49 SDMMC1 */
- spin, /* 50 Reserved */
- spin, /* 51 SPI3 */
- spin, /* 52 Reserved */
- spin, /* 53 Reserved */
- spin, /* 54 TIM6_DACUNDER */
- spin, /* 55 TIM7 */
- spin, /* 56 DMA2_CH1 */
- spin, /* 57 DMA2_CH2 */
- spin, /* 58 DMA2_CH3 */
- spin, /* 59 DMA2_CH4 */
- spin, /* 60 DMA2_CH5 */
- spin, /* 61 Reserved */
- spin, /* 62 Reserved */
- spin, /* 63 Reserved*/
- spin, /* 64 COMP */
- spin, /* 65 LPTIM1 */
- spin, /* 66 LPTIM2 */
- spin, /* 67 USB_FS */
- spin, /* 68 DMA_CH6 */
- spin, /* 69 DMA_CH7 */
- spin, /* 70 LPUART1 */
- spin, /* 71 QUADSPI */
- spin, /* 72 I2C3_EV */
- spin, /* 73 I2C3_ER */
- spin, /* 74 SAI1 */
- spin, /* 75 Reserved */
- spin, /* 76 SWPMI1 */
- spin, /* 77 TSC */
- spin, /* 78 Reserved */
- spin, /* 79 AES */
- spin, /* 80 RNG */
- spin, /* 81 FPU */
- spin /* 82 CRS */
-};
-
-/* Delay for some number of iterations. */
-void delay(uint32_t itrs)
-{
- /* Need to keep the compiler from optimizing this loop out entirely. */
- while(itrs --) {
- asm volatile ("");
- }
-}
+#include "delay.h"
/* Main function. This gets executed from the interrupt vector defined above. */
int main()
@@ -159,25 +40,3 @@ int main()
delay(65535);
}
}
-
-/*
- * Does nothing ... forever.
- */
-void spin()
-{
- __IO gpio_port_t* port_b = enable_gpio(GPIO_PORT_B);
- gpio_output_pin_t pin3 = set_gpio_pin_output(port_b, PIN_3);
- for(;;) {
-
- /* Flash in a distinct pattern to know that something went wrong. */
-
- pin_off(pin3);
- delay(100000);
- pin_on(pin3);
- delay(100000);
- pin_off(pin3);
- delay(100000);
- pin_on(pin3);
- delay(500000);
- }
-}
diff --git a/system-clock/src/vector.c b/system-clock/src/vector.c
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/system-clock/src/vector.c