summaryrefslogtreecommitdiff
path: root/ws2812
diff options
context:
space:
mode:
authorxengineering <mail2xengineering@protonmail.com>2020-10-25 13:07:54 +0100
committerxengineering <mail2xengineering@protonmail.com>2020-10-25 13:07:54 +0100
commit58d3787ca563b7d6a2cb4e0a1ab7fdde67fd5557 (patch)
tree42115a58b60bdd7fa027b8b37cac7e76e7b74fab /ws2812
parent9435a85605d7efc75642491c85b0942bd558fcec (diff)
downloadstm32f103c8-examples-58d3787ca563b7d6a2cb4e0a1ab7fdde67fd5557.tar
stm32f103c8-examples-58d3787ca563b7d6a2cb4e0a1ab7fdde67fd5557.tar.zst
stm32f103c8-examples-58d3787ca563b7d6a2cb4e0a1ab7fdde67fd5557.zip
Add ws2812 Code
Diffstat (limited to 'ws2812')
-rw-r--r--ws2812/Makefile34
-rw-r--r--ws2812/main.c76
2 files changed, 110 insertions, 0 deletions
diff --git a/ws2812/Makefile b/ws2812/Makefile
new file mode 100644
index 0000000..8973ef6
--- /dev/null
+++ b/ws2812/Makefile
@@ -0,0 +1,34 @@
+PROJECT = ws2812
+BUILD_DIR = bin
+
+SHARED_DIR = ../libraries
+CFILES = main.c
+CFILES += ws2812.c
+#AFILES += api-asm.S
+
+# TODO - you will need to edit these two lines!
+DEVICE=stm32f103c8
+#OOCD_FILE = board/stm32f4discovery.cfg
+
+# You shouldn't have to edit anything below here.
+VPATH += $(SHARED_DIR)
+INCLUDES += $(patsubst %,-I%, . $(SHARED_DIR))
+OPENCM3_DIR=../libopencm3
+
+include $(OPENCM3_DIR)/mk/genlink-config.mk
+include ../rules.mk
+include $(OPENCM3_DIR)/mk/genlink-rules.mk
+
+
+# Black Magic Probe:
+
+GDB=/usr/bin/arm-none-eabi-gdb
+BMP_DEVICE=/dev/ttyACM0
+
+bmp: $(PROJECT).elf
+ $(GDB) $(PROJECT).elf \
+ -ex 'set confirm off' \
+ -ex 'target extended-remote $(BMP_DEVICE)' \
+ -ex 'monitor swdp_scan' \
+ -ex 'attach 1'
+
diff --git a/ws2812/main.c b/ws2812/main.c
new file mode 100644
index 0000000..926cd68
--- /dev/null
+++ b/ws2812/main.c
@@ -0,0 +1,76 @@
+
+
+#include <libopencm3/stm32/rcc.h>
+#include <libopencm3/stm32/gpio.h>
+
+#include "ws2812.h"
+
+
+#define DELAY 30000 // 18,000,000 nops are one second
+#define BRIGHTNESS 100
+
+
+void clock_init(void);
+void gpio_init(void);
+void delay(void);
+
+
+ws2812_init_typedef ws2812;
+
+
+int main(void)
+{
+ clock_init();
+ gpio_init();
+ ws2812_init(&ws2812, GPIOB, GPIO13, 1, 1);
+
+ while(1){
+ /*ws2812_send_led(&ws2812, BRIGHTNESS, 0, 0);
+ delay();
+ ws2812_send_led(&ws2812, 0, BRIGHTNESS, 0);
+ delay();
+ ws2812_send_led(&ws2812, 0, 0, BRIGHTNESS);
+ delay();
+ ws2812_send_led(&ws2812, BRIGHTNESS, BRIGHTNESS, BRIGHTNESS);
+ delay();*/
+
+ for (uint16_t i=0; i<=255; i++){
+ ws2812_send_led(&ws2812, i, 0, 0);
+ delay();
+ }
+ for (uint16_t i=255; i>0; i--){
+ ws2812_send_led(&ws2812, i, 0, 0);
+ delay();
+ }
+ }
+
+ return 0;
+}
+
+
+void clock_init(void)
+{
+ rcc_clock_setup_in_hse_12mhz_out_72mhz();
+ rcc_periph_clock_enable(RCC_GPIOB); // for ws2812
+ rcc_periph_clock_enable(RCC_GPIOC); // for PC13 blinking
+}
+
+
+void gpio_init(void)
+{
+ // on board led blinking
+ gpio_set_mode(GPIOC, GPIO_MODE_OUTPUT_50_MHZ, GPIO_CNF_OUTPUT_PUSHPULL, GPIO13);
+ gpio_set(GPIOC, GPIO13);
+
+ // ws2812 output pin
+ gpio_set_mode(GPIOB, GPIO_MODE_OUTPUT_50_MHZ, GPIO_CNF_OUTPUT_PUSHPULL, GPIO13);
+ gpio_set(GPIOB, GPIO13);
+}
+
+
+void delay(void)
+{
+ for (int i = 0; i < DELAY; i++) {
+ __asm__("nop");
+ }
+}