aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--system-clock/include/delay.h12
-rw-r--r--system-clock/include/isr_vector.h21
-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
6 files changed, 175 insertions, 142 deletions
diff --git a/system-clock/include/delay.h b/system-clock/include/delay.h
new file mode 100644
index 0000000..65a26d6
--- /dev/null
+++ b/system-clock/include/delay.h
@@ -0,0 +1,12 @@
+#ifndef H__DELAY__
+#define H__DELAY__
+
+#include <stdint.h>
+
+/*
+ * Loops and count-downs the delay, the time this takes depends on the speed
+ * of the clock.
+ */
+void delay(uint32_t delay);
+
+#endif /* H__DELAY__ */
diff --git a/system-clock/include/isr_vector.h b/system-clock/include/isr_vector.h
new file mode 100644
index 0000000..eee1a51
--- /dev/null
+++ b/system-clock/include/isr_vector.h
@@ -0,0 +1,21 @@
+#ifndef h__ISR_VECTOR_H__
+#define h__ISR_VECTOR_H__
+
+/*
+ * Include file for interrupt service routines.
+ */
+
+/*
+ * The interrupt service routines. These link in the function `main` as the
+ * main function.
+ */
+extern const void* isr_vector[];
+
+
+/*
+ * Defines an error state. This loops forever and defines a distinct flashing
+ * pattern to let the user know an unhandled ISR happened.
+ */
+void unhandled_isr();
+
+#endif /* h___ISR_VECTOR_H__ */
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