Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 1 | #include "cape/digital.h" |
| 2 | |
| 3 | #include <STM32F2XX.h> |
| 4 | |
| 5 | #include "cape/util.h" |
| 6 | |
| 7 | static void digital_capture_default(void) {} |
| 8 | |
| 9 | void digital_capture_0P(void) ALIAS_WEAK(digital_capture_default); |
| 10 | void digital_capture_0N(void) ALIAS_WEAK(digital_capture_default); |
| 11 | void digital_capture_1P(void) ALIAS_WEAK(digital_capture_default); |
| 12 | void digital_capture_1N(void) ALIAS_WEAK(digital_capture_default); |
| 13 | void digital_capture_2P(void) ALIAS_WEAK(digital_capture_default); |
| 14 | void digital_capture_2N(void) ALIAS_WEAK(digital_capture_default); |
| 15 | void digital_capture_3P(void) ALIAS_WEAK(digital_capture_default); |
| 16 | void digital_capture_3N(void) ALIAS_WEAK(digital_capture_default); |
| 17 | void digital_capture_4P(void) ALIAS_WEAK(digital_capture_default); |
| 18 | void digital_capture_4N(void) ALIAS_WEAK(digital_capture_default); |
| 19 | void digital_capture_5P(void) ALIAS_WEAK(digital_capture_default); |
| 20 | void digital_capture_5N(void) ALIAS_WEAK(digital_capture_default); |
| 21 | void digital_capture_6P(void) ALIAS_WEAK(digital_capture_default); |
| 22 | void digital_capture_6N(void) ALIAS_WEAK(digital_capture_default); |
| 23 | void digital_capture_7P(void) ALIAS_WEAK(digital_capture_default); |
| 24 | void digital_capture_7N(void) ALIAS_WEAK(digital_capture_default); |
| 25 | void digital_capture_8P(void) ALIAS_WEAK(digital_capture_default); |
| 26 | void digital_capture_8N(void) ALIAS_WEAK(digital_capture_default); |
| 27 | void digital_capture_9P(void) ALIAS_WEAK(digital_capture_default); |
| 28 | void digital_capture_9N(void) ALIAS_WEAK(digital_capture_default); |
| 29 | void digital_capture_10P(void) ALIAS_WEAK(digital_capture_default); |
| 30 | void digital_capture_10N(void) ALIAS_WEAK(digital_capture_default); |
| 31 | void digital_capture_11P(void) ALIAS_WEAK(digital_capture_default); |
| 32 | void digital_capture_11N(void) ALIAS_WEAK(digital_capture_default); |
| 33 | void digital_capture_12P(void) ALIAS_WEAK(digital_capture_default); |
| 34 | void digital_capture_12N(void) ALIAS_WEAK(digital_capture_default); |
| 35 | |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 36 | void EXTI2_IRQHandler(void) { |
| 37 | uint32_t inputs = GPIOB->IDR; |
| 38 | EXTI->PR = EXTI_PR_PR2; |
| 39 | if (inputs & (1 << 2)) { |
| 40 | digital_capture_11N(); |
| 41 | } else { |
| 42 | digital_capture_11P(); |
| 43 | } |
| 44 | } |
| 45 | |
| 46 | void EXTI4_IRQHandler(void) { |
| 47 | uint32_t inputs = GPIOC->IDR; |
| 48 | EXTI->PR = EXTI_PR_PR4; |
| 49 | if (inputs & (1 << 4)) { |
| 50 | digital_capture_0N(); |
| 51 | } else { |
| 52 | digital_capture_0P(); |
| 53 | } |
| 54 | } |
| 55 | |
| 56 | static void EXTI5_Handler(uint32_t inputs) { |
| 57 | if (inputs & (1 << 5)) { |
| 58 | digital_capture_1N(); |
| 59 | } else { |
| 60 | digital_capture_1P(); |
| 61 | } |
| 62 | } |
| 63 | |
| 64 | static void EXTI7_Handler(uint32_t inputs) { |
| 65 | if (inputs & (1 << 7)) { |
| 66 | digital_capture_10N(); |
| 67 | } else { |
| 68 | digital_capture_10P(); |
| 69 | } |
| 70 | } |
| 71 | |
| 72 | static void EXTI8_Handler(uint32_t inputs) { |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 73 | if (inputs & (1 << 8)) { |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 74 | digital_capture_7N(); |
| 75 | } else { |
| 76 | digital_capture_7P(); |
| 77 | } |
| 78 | } |
| 79 | |
| 80 | static void EXTI9_Handler(uint32_t inputs) { |
| 81 | if (inputs & (1 << 9)) { |
| 82 | digital_capture_6N(); |
| 83 | } else { |
| 84 | digital_capture_6P(); |
| 85 | } |
| 86 | } |
| 87 | |
| 88 | void EXTI9_5_IRQHandler(void) { |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 89 | uint32_t a_inputs = GPIOA->IDR, b_inputs = GPIOB->IDR, c_inputs = GPIOC->IDR; |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 90 | uint32_t exti = __clz(EXTI->PR); |
| 91 | EXTI->PR = (1 << 31) >> exti; |
| 92 | switch (exti) { |
| 93 | case 31 - 5: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 94 | EXTI5_Handler(c_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 95 | break; |
| 96 | case 31 - 7: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 97 | EXTI7_Handler(a_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 98 | break; |
| 99 | case 31 - 8: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 100 | EXTI8_Handler(b_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 101 | break; |
| 102 | case 31 - 9: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 103 | EXTI9_Handler(b_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 104 | break; |
| 105 | } |
| 106 | } |
| 107 | |
| 108 | static void EXTI10_Handler(uint32_t inputs) { |
| 109 | if (inputs & (1 << 10)) { |
| 110 | digital_capture_5N(); |
| 111 | } else { |
| 112 | digital_capture_5P(); |
| 113 | } |
| 114 | } |
| 115 | |
| 116 | static void EXTI11_Handler(uint32_t inputs) { |
| 117 | if (inputs & (1 << 11)) { |
| 118 | digital_capture_9N(); |
| 119 | } else { |
| 120 | digital_capture_9P(); |
| 121 | } |
| 122 | } |
| 123 | |
| 124 | static void EXTI12_Handler(uint32_t inputs) { |
| 125 | if (inputs & (1 << 12)) { |
| 126 | digital_capture_8N(); |
| 127 | } else { |
| 128 | digital_capture_8P(); |
| 129 | } |
| 130 | } |
| 131 | |
| 132 | static void EXTI13_Handler(uint32_t inputs) { |
| 133 | if (inputs & (1 << 13)) { |
| 134 | digital_capture_2N(); |
| 135 | } else { |
| 136 | digital_capture_2P(); |
| 137 | } |
| 138 | } |
| 139 | |
| 140 | static void EXTI14_Handler(uint32_t inputs) { |
| 141 | if (inputs & (1 << 14)) { |
| 142 | digital_capture_3N(); |
| 143 | } else { |
| 144 | digital_capture_3P(); |
| 145 | } |
| 146 | } |
| 147 | |
| 148 | static void EXTI15_Handler(uint32_t inputs) { |
| 149 | if (inputs & (1 << 15)) { |
| 150 | digital_capture_4N(); |
| 151 | } else { |
| 152 | digital_capture_4P(); |
| 153 | } |
| 154 | } |
| 155 | |
| 156 | void EXTI15_10_IRQHandler(void) { |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 157 | uint32_t a_inputs = GPIOA->IDR, b_inputs = GPIOB->IDR, c_inputs = GPIOC->IDR; |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 158 | uint32_t exti = __clz(EXTI->PR); |
| 159 | EXTI->PR = (1 << 31) >> exti; |
| 160 | switch (exti) { |
| 161 | case 31 - 10: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 162 | EXTI10_Handler(b_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 163 | break; |
| 164 | case 31 - 11: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 165 | EXTI11_Handler(a_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 166 | break; |
| 167 | case 31 - 12: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 168 | EXTI12_Handler(a_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 169 | break; |
| 170 | case 31 - 13: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 171 | EXTI13_Handler(c_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 172 | break; |
| 173 | case 31 - 14: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 174 | EXTI14_Handler(c_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 175 | break; |
| 176 | case 31 - 15: |
Brian Silverman | 5762111 | 2014-01-01 16:08:24 -0800 | [diff] [blame] | 177 | EXTI15_Handler(c_inputs); |
Brian Silverman | 25a06d9 | 2013-12-15 16:28:52 -0800 | [diff] [blame] | 178 | break; |
| 179 | } |
| 180 | } |
| 181 | |
| 182 | static void init_exti(int exti, int port) { |
| 183 | EXTI_set(exti, port); |
| 184 | EXTI->IMR |= 1 << exti; |
| 185 | EXTI->RTSR |= 1 << exti; |
| 186 | EXTI->FTSR |= 1 << exti; |
| 187 | } |
| 188 | |
| 189 | void digital_init(void) { |
| 190 | init_exti(2, 1); |
| 191 | init_exti(4, 2); |
| 192 | init_exti(5, 2); |
| 193 | init_exti(7, 0); |
| 194 | init_exti(8, 1); |
| 195 | init_exti(9, 1); |
| 196 | init_exti(10, 1); |
| 197 | init_exti(11, 0); |
| 198 | init_exti(12, 0); |
| 199 | init_exti(13, 2); |
| 200 | init_exti(14, 2); |
| 201 | init_exti(15, 2); |
| 202 | |
| 203 | NVIC_SetPriority(EXTI2_IRQn, 1); |
| 204 | NVIC_EnableIRQ(EXTI2_IRQn); |
| 205 | NVIC_SetPriority(EXTI4_IRQn, 1); |
| 206 | NVIC_EnableIRQ(EXTI4_IRQn); |
| 207 | NVIC_SetPriority(EXTI9_5_IRQn, 1); |
| 208 | NVIC_EnableIRQ(EXTI9_5_IRQn); |
| 209 | NVIC_SetPriority(EXTI15_10_IRQn, 1); |
| 210 | NVIC_EnableIRQ(EXTI15_10_IRQn); |
| 211 | } |