summaryrefslogtreecommitdiff
path: root/src/app/bad-apple-msp430fr-ssd1306-128x64
diff options
context:
space:
mode:
authorBirte Kristina Friesel <derf@finalrewind.org>2024-02-10 22:11:25 +0100
committerBirte Kristina Friesel <derf@finalrewind.org>2024-02-10 22:11:25 +0100
commit467b1b587811a2091d04a5faab20d6430313cd51 (patch)
tree496f43b1b3ca16a1e0995267623914db4136e70c /src/app/bad-apple-msp430fr-ssd1306-128x64
parentb5b506c97469f1917de4e7b7bd291f68b6d8d897 (diff)
rename ssd1306-bad-apple to bad-apple-msp430fr-ssd1306-128x64
Diffstat (limited to 'src/app/bad-apple-msp430fr-ssd1306-128x64')
-rw-r--r--src/app/bad-apple-msp430fr-ssd1306-128x64/Kconfig6
-rw-r--r--src/app/bad-apple-msp430fr-ssd1306-128x64/Makefile.inc16
-rwxr-xr-xsrc/app/bad-apple-msp430fr-ssd1306-128x64/convert16
-rwxr-xr-xsrc/app/bad-apple-msp430fr-ssd1306-128x64/frames-to-cc42
-rw-r--r--src/app/bad-apple-msp430fr-ssd1306-128x64/main.cc74
5 files changed, 154 insertions, 0 deletions
diff --git a/src/app/bad-apple-msp430fr-ssd1306-128x64/Kconfig b/src/app/bad-apple-msp430fr-ssd1306-128x64/Kconfig
new file mode 100644
index 0000000..575e11b
--- /dev/null
+++ b/src/app/bad-apple-msp430fr-ssd1306-128x64/Kconfig
@@ -0,0 +1,6 @@
+# Copyright 2020 Birte Kristina Friesel
+#
+# SPDX-License-Identifier: CC0-1.0
+
+prompt "SSD1306 Bad Apple"
+depends on driver_ssd1306 && !wakeup
diff --git a/src/app/bad-apple-msp430fr-ssd1306-128x64/Makefile.inc b/src/app/bad-apple-msp430fr-ssd1306-128x64/Makefile.inc
new file mode 100644
index 0000000..4d1b6d3
--- /dev/null
+++ b/src/app/bad-apple-msp430fr-ssd1306-128x64/Makefile.inc
@@ -0,0 +1,16 @@
+# vim:ft=make
+#
+# Copyright 2020 Birte Kristina Friesel
+#
+# SPDX-License-Identifier: CC0-1.0
+
+ifdef app
+ override arch_drivers += i2c,timer
+ CONFIG_driver_ssd1306 = y
+ COMMON_FLAGS += -DCONFIG_driver_ssd1306
+ CONFIG_driver_ssd1306_width = 128
+ CONFIG_driver_ssd1306_height = 64
+ CONFIG_lib_inflate = y
+ CONFIG_lib_inflate_lut = y
+ CONFIG_arch_msp430fr5994lp_large_mode = y
+endif
diff --git a/src/app/bad-apple-msp430fr-ssd1306-128x64/convert b/src/app/bad-apple-msp430fr-ssd1306-128x64/convert
new file mode 100755
index 0000000..7d2ca0e
--- /dev/null
+++ b/src/app/bad-apple-msp430fr-ssd1306-128x64/convert
@@ -0,0 +1,16 @@
+#!/bin/sh
+
+# [size=WxH] ./convert.sh <file> -r <frame rate> [additional ffmpeg args]
+
+set -eu
+
+mkdir -p tmp
+
+ffmpeg -i "$@" tmp/frame%4d.png
+
+parallel mogrify -resize "${size:-128x64}" -threshold 50% -- tmp/*.png
+
+echo "const unsigned char frame_rate = $3;" > frames.cc
+./frames-to-cc tmp/*.png >> frames.cc
+
+rm -rf tmp
diff --git a/src/app/bad-apple-msp430fr-ssd1306-128x64/frames-to-cc b/src/app/bad-apple-msp430fr-ssd1306-128x64/frames-to-cc
new file mode 100755
index 0000000..bcbabf7
--- /dev/null
+++ b/src/app/bad-apple-msp430fr-ssd1306-128x64/frames-to-cc
@@ -0,0 +1,42 @@
+#!/usr/bin/env python3
+
+from PIL import Image
+import os
+import sys
+import zlib
+
+buf_w, buf_h = map(int, os.getenv("size", "128x64").split("x"))
+
+def load_image(filename):
+ im = Image.open(filename)
+ w, h = im.size
+ buf = [0 for i in range(buf_w * buf_h // 8)]
+ for y in range(min(h, buf_h)):
+ for x in range(min(w, buf_w)):
+ if im.getpixel((x, y)):
+ buf[(y // 8) * buf_w + x] |= 1 << (y % 8)
+ return buf
+
+
+for i in range(1, len(sys.argv) - 2, 3):
+ buf = (
+ load_image(sys.argv[i])
+ + load_image(sys.argv[i + 1])
+ + load_image(sys.argv[i + 2])
+ )
+ c_buf = ",".join(map(str, buf))
+ z_buf = zlib.compress(bytes(buf), 9)
+ z_buf = z_buf[2:-4]
+ out_buf = ",".join(map(str, z_buf))
+ print(
+ f'__attribute__((section(".text"))) unsigned char const frame{i:04d}[] = {{ {out_buf} }};'
+ )
+
+frames = list()
+for i in range(1, len(sys.argv) - 2, 3):
+ frames.append(f"(unsigned char*)frame{i:04d}")
+
+prefix = "unsigned char* const frames[] = {"
+postfix = "};"
+
+print(prefix + ", ".join(frames) + postfix)
diff --git a/src/app/bad-apple-msp430fr-ssd1306-128x64/main.cc b/src/app/bad-apple-msp430fr-ssd1306-128x64/main.cc
new file mode 100644
index 0000000..d8d1b6f
--- /dev/null
+++ b/src/app/bad-apple-msp430fr-ssd1306-128x64/main.cc
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2020 Birte Kristina Friesel
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+#include "arch.h"
+#include "driver/gpio.h"
+#include "driver/stdout.h"
+#include "driver/i2c.h"
+#include "driver/ssd1306.h"
+#include "lib/inflate.h"
+
+#include "driver/timer.h"
+volatile unsigned char timer_done = 0;
+
+#include "frames.cc"
+
+__attribute__((section(".leaRAM"))) unsigned char img_buf[(SSD1306_WIDTH * SSD1306_HEIGHT / 8) * 3];
+
+int main(void)
+{
+ unsigned int i = 0;
+ unsigned char line;
+ arch.setup();
+ gpio.setup();
+ kout.setup();
+ i2c.setup();
+ ssd1306.init();
+
+ timer.setup_hz_low(frame_rate);
+
+ while (1) {
+ for (i = 0; i < (sizeof(frames) / sizeof(frames[0])); i++) {
+
+ timer_done = 0;
+ timer.start(1);
+
+ ssd1306.showImage(img_buf + (SSD1306_WIDTH * SSD1306_HEIGHT / 8 * 2), SSD1306_WIDTH * SSD1306_HEIGHT / 8);
+
+ inflate(frames[i], sizeof(img_buf), img_buf, sizeof(img_buf));
+
+ while (!timer_done) {
+ arch.idle();
+ }
+ timer.stop();
+
+ timer_done = 0;
+ timer.start(1);
+
+ ssd1306.showImage(img_buf + (SSD1306_WIDTH * SSD1306_HEIGHT / 8 * 0), SSD1306_WIDTH * SSD1306_HEIGHT / 8);
+
+ while (!timer_done) {
+ arch.idle();
+ }
+ timer.stop();
+
+ timer_done = 0;
+ timer.start(1);
+
+ ssd1306.showImage(img_buf + (SSD1306_WIDTH * SSD1306_HEIGHT / 8 * 1), SSD1306_WIDTH * SSD1306_HEIGHT / 8);
+
+ while (!timer_done) {
+ arch.idle();
+ }
+ timer.stop();
+ }
+ }
+
+ return 0;
+}
+
+ON_TIMER_INTERRUPT_head
+ timer_done = 1;
+ON_TIMER_INTERRUPT_tail