summary refs log tree commit diff
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2018-02-03 14:53:06 -0500
committerJune McEnroe <june@causal.agency>2018-02-03 14:53:06 -0500
commitf918ec37ffb7f8c8498f4478ec783ca8c495b864 (patch)
tree939365fc90df255d2108a1a88d7ad05ff14ebd75
parentAdd gfxx palette loading (diff)
downloadsrc-f918ec37ffb7f8c8498f4478ec783ca8c495b864.tar.gz
src-f918ec37ffb7f8c8498f4478ec783ca8c495b864.zip
Separate gfxx and its framebuffer frontend
-rw-r--r--bin/.gitignore1
-rw-r--r--bin/Makefile4
-rw-r--r--bin/gfb.c88
-rw-r--r--bin/gfxx.c98
4 files changed, 97 insertions, 94 deletions
diff --git a/bin/.gitignore b/bin/.gitignore
index c193de65..24c3bf6c 100644
--- a/bin/.gitignore
+++ b/bin/.gitignore
@@ -1,3 +1,4 @@
+*.o
 atch
 dtch
 hnel
diff --git a/bin/Makefile b/bin/Makefile
index 52bca4d4..c7e44d87 100644
--- a/bin/Makefile
+++ b/bin/Makefile
@@ -15,6 +15,8 @@ linux: $(ANY_BINS) $(LIN_BINS) .gitignore
 atch: dtch
 	ln -f dtch atch
 
+gfxx: gfxx.o gfb.o
+
 pbcopy pbpaste: pbd
 	ln -f pbd $@
 
@@ -32,6 +34,6 @@ unlink:
 	rm -f $(ALL_BINS:%=~/.bin/%)
 
 .gitignore: Makefile
-	echo $(ALL_BINS) | tr ' ' '\n' > .gitignore
+	echo '*.o' $(ALL_BINS) | tr ' ' '\n' > .gitignore
 
 .PHONY: bsd linux any setuid clean link unlink
diff --git a/bin/gfb.c b/bin/gfb.c
new file mode 100644
index 00000000..e64efee5
--- /dev/null
+++ b/bin/gfb.c
@@ -0,0 +1,88 @@
+/* Copyright (c) 2018, June McEnroe <programble@gmail.com>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <err.h>
+#include <fcntl.h>
+#include <linux/fb.h>
+#include <stdint.h>
+#include <stdlib.h>
+#include <sys/ioctl.h>
+#include <sys/mman.h>
+#include <sysexits.h>
+#include <termios.h>
+#include <unistd.h>
+
+extern int init(int argc, char *argv[]);
+extern void draw(uint32_t *buf, size_t xres, size_t yres);
+extern void input(char in);
+
+static uint32_t *buf;
+static struct fb_var_screeninfo info;
+
+static uint32_t saveBg;
+static void restoreBg(void) {
+    for (size_t i = 0; i < info.xres * info.yres; ++i) {
+        buf[i] = saveBg;
+    }
+}
+
+static struct termios saveTerm;
+static void restoreTerm(void) {
+    tcsetattr(STDERR_FILENO, TCSADRAIN, &saveTerm);
+}
+
+int main(int argc, char *argv[]) {
+    int error;
+
+    error = init(argc, argv);
+    if (error) return error;
+
+    const char *path = getenv("FRAMEBUFFER");
+    if (!path) path = "/dev/fb0";
+
+    int fb = open(path, O_RDWR);
+    if (fb < 0) err(EX_OSFILE, "%s", path);
+
+    error = ioctl(fb, FBIOGET_VSCREENINFO, &info);
+    if (error) err(EX_IOERR, "%s", path);
+
+    size_t size = 4 * info.xres * info.yres;
+    buf = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fb, 0);
+    if (buf == MAP_FAILED) err(EX_IOERR, "%s", path);
+
+    saveBg = buf[0];
+    atexit(restoreBg);
+
+    error = tcgetattr(STDERR_FILENO, &saveTerm);
+    if (error) err(EX_IOERR, "tcgetattr");
+    atexit(restoreTerm);
+
+    struct termios term = saveTerm;
+    term.c_lflag &= ~(ICANON | ECHO);
+    error = tcsetattr(STDERR_FILENO, TCSADRAIN, &term);
+    if (error) err(EX_IOERR, "tcsetattr");
+
+    for (;;) {
+        draw(buf, info.xres, info.yres);
+
+        char in;
+        ssize_t len = read(STDERR_FILENO, &in, 1);
+        if (len < 0) err(EX_IOERR, "read");
+        if (!len) return EX_DATAERR;
+
+        input(in);
+    }
+}
diff --git a/bin/gfxx.c b/bin/gfxx.c
index 2b2f803c..7a3f24df 100644
--- a/bin/gfxx.c
+++ b/bin/gfxx.c
@@ -15,102 +15,14 @@
  */
 
 #include <err.h>
-#include <fcntl.h>
-#include <linux/fb.h>
-#include <stdint.h>
-#include <stdlib.h>
-#include <sys/ioctl.h>
-#include <sys/mman.h>
-#include <sysexits.h>
-#include <termios.h>
-#include <unistd.h>
-
-static int init(int argc, char *argv[]);
-static void draw(uint32_t *buf, size_t xres, size_t yres);
-static void input(char in);
-
-static uint32_t *buf;
-static struct fb_var_screeninfo info;
-
-static uint32_t saveBg;
-static void restoreBg(void) {
-    for (size_t i = 0; i < info.xres * info.yres; ++i) {
-        buf[i] = saveBg;
-    }
-}
-
-static struct termios saveTerm;
-static void restoreTerm(void) {
-    tcsetattr(STDERR_FILENO, TCSADRAIN, &saveTerm);
-}
-
-int main(int argc, char *argv[]) {
-    int error;
-
-    error = init(argc, argv);
-    if (error) return error;
-
-    const char *path = getenv("FRAMEBUFFER");
-    if (!path) path = "/dev/fb0";
-
-    int fb = open(path, O_RDWR);
-    if (fb < 0) err(EX_OSFILE, "%s", path);
-
-    error = ioctl(fb, FBIOGET_VSCREENINFO, &info);
-    if (error) err(EX_IOERR, "%s", path);
-
-    size_t size = 4 * info.xres * info.yres;
-    buf = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fb, 0);
-    if (buf == MAP_FAILED) err(EX_IOERR, "%s", path);
-
-    saveBg = buf[0];
-    atexit(restoreBg);
-
-    error = tcgetattr(STDERR_FILENO, &saveTerm);
-    if (error) err(EX_IOERR, "tcgetattr");
-    atexit(restoreTerm);
-
-    struct termios term = saveTerm;
-    term.c_lflag &= ~(ICANON | ECHO);
-    error = tcsetattr(STDERR_FILENO, TCSADRAIN, &term);
-    if (error) err(EX_IOERR, "tcsetattr");
-
-    for (;;) {
-        draw(buf, info.xres, info.yres);
-
-        char in;
-        ssize_t len = read(STDERR_FILENO, &in, 1);
-        if (len < 0) err(EX_IOERR, "read");
-        if (!len) return EX_DATAERR;
-
-        input(in);
-    }
-}
-
-// ABSTRACTION LINE
-
-/* Copyright (c) 2018, June McEnroe <programble@gmail.com>
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program.  If not, see <http://www.gnu.org/licenses/>.
- */
-
 #include <stdbool.h>
 #include <stdint.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <sys/stat.h>
+#include <sysexits.h>
+#include <unistd.h>
 
 #define RGB(r,g,b) ((uint32_t)(r) << 16 | (uint32_t)(g) << 8 | (uint32_t)(b))
 #define GRAY(n)    RGB(n, n, n)
@@ -150,7 +62,7 @@ static uint8_t get(size_t i) {
     }
 }
 
-static /**/ int init(int argc, char *argv[]) {
+extern int init(int argc, char *argv[]) {
     const char *path = NULL;
     const char *palPath = NULL;
 
@@ -334,7 +246,7 @@ static void draw32(struct Pos *pos) {
     }
 }
 
-static /**/ void draw(uint32_t *buf, size_t xres, size_t yres) {
+extern void draw(uint32_t *buf, size_t xres, size_t yres) {
     memset(buf, 0, 4 * xres * yres);
     struct Pos pos = {
         .buf = buf,
@@ -351,7 +263,7 @@ static /**/ void draw(uint32_t *buf, size_t xres, size_t yres) {
     }
 }
 
-static /**/ void input(char in) {
+extern void input(char in) {
     size_t pixel = (bits + 7) / 8;
     size_t row = width * bits / 8;
     switch (in) {