aboutsummaryrefslogtreecommitdiff
path: root/02-usart/src/spin.c
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2018-01-23 23:14:31 -0700
committerJosh Rahm <joshuarahm@gmail.com>2018-01-23 23:14:31 -0700
commit7aa10db46c13ad8adc88aadff39b8cf6b15db09d (patch)
treeb1e34a6703de33250b0bd97d34999b687a36a00f /02-usart/src/spin.c
parentacd8afd83da625d36ef39bc01717f29f3b689952 (diff)
downloadstm32l4-7aa10db46c13ad8adc88aadff39b8cf6b15db09d.tar.gz
stm32l4-7aa10db46c13ad8adc88aadff39b8cf6b15db09d.tar.bz2
stm32l4-7aa10db46c13ad8adc88aadff39b8cf6b15db09d.zip
rename folders to give notion of progression
Diffstat (limited to '02-usart/src/spin.c')
-rw-r--r--02-usart/src/spin.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/02-usart/src/spin.c b/02-usart/src/spin.c
new file mode 100644
index 0000000..fbd16b6
--- /dev/null
+++ b/02-usart/src/spin.c
@@ -0,0 +1,49 @@
+#include "spin.h"
+#include "delay.h"
+#include "gpio.h"
+
+#define SHORT_DELAY 200000
+#define LONG_DELAY (SHORT_DELAY * 2)
+
+static void flash_bit(
+ uint32_t base, gpio_output_pin_t out_pin,
+ uint8_t bit /* 0 => 0, non-zero => 1 */)
+{
+ pin_on(out_pin);
+ if (bit) {
+ delay(base * 2);
+ } else {
+ delay(base);
+ }
+ pin_off(out_pin);
+ delay(base);
+}
+
+void spin(uint32_t base, uint8_t c)
+{
+ uint8_t code;
+ __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 (;;) {
+ code = c;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+ code <<= 1;
+ flash_bit(base, pin3, code & 0x80);
+
+ delay(base * 4);
+ }
+}