From 0e5960d6120dc94f01e45f36bcc578ab9ad012c9 Mon Sep 17 00:00:00 2001 From: Curtis McEnroe Date: Sat, 3 Feb 2018 14:53:06 -0500 Subject: Separate gfxx and its framebuffer frontend --- bin/.gitignore | 1 + bin/Makefile | 4 ++- bin/gfb.c | 88 ++++++++++++++++++++++++++++++++++++++++++++++++++++ bin/gfxx.c | 98 +++------------------------------------------------------- 4 files changed, 97 insertions(+), 94 deletions(-) create mode 100644 bin/gfb.c 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..1cd56ac8 --- /dev/null +++ b/bin/gfb.c @@ -0,0 +1,88 @@ +/* Copyright (c) 2018, Curtis McEnroe + * + * 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 . + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +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 f0b8aa9a..f742149c 100644 --- a/bin/gfxx.c +++ b/bin/gfxx.c @@ -15,102 +15,14 @@ */ #include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -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, Curtis McEnroe - * - * 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 . - */ - #include #include #include #include #include #include +#include +#include #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) { -- cgit 1.4.1