aboutsummaryrefslogtreecommitdiff
path: root/usart/src/spin.c
diff options
context:
space:
mode:
authorJosh Rahm <joshuarahm@gmail.com>2018-01-22 00:14:20 -0700
committerJosh Rahm <joshuarahm@gmail.com>2018-01-22 00:14:20 -0700
commitaf0244fb51ccb608440128d0f3303ccce77c14c2 (patch)
tree4b6057fe3c3029ee4b4602e690917859c6011599 /usart/src/spin.c
parent2dcbbea5fe1e2342ce4700b3ee8dce44a360a888 (diff)
downloadstm32l4-af0244fb51ccb608440128d0f3303ccce77c14c2.tar.gz
stm32l4-af0244fb51ccb608440128d0f3303ccce77c14c2.tar.bz2
stm32l4-af0244fb51ccb608440128d0f3303ccce77c14c2.zip
VERY simple USART set up on USART2.
Diffstat (limited to 'usart/src/spin.c')
-rw-r--r--usart/src/spin.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/usart/src/spin.c b/usart/src/spin.c
new file mode 100644
index 0000000..fbd16b6
--- /dev/null
+++ b/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);
+ }
+}