From 06d7074474af00ed4b697318dbc526847744365c Mon Sep 17 00:00:00 2001 From: Tomi Valkeinen Date: Sun, 7 Feb 2016 10:29:20 +0200 Subject: add fbtestpat --- tests/CMakeLists.txt | 3 +++ tests/fbtestpat.cpp | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 tests/fbtestpat.cpp diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index e18081a..181ff78 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -12,3 +12,6 @@ target_link_libraries(kmsview kms++ kmstest ${LIBDRM_LIBRARIES}) add_executable (kmsprint kmsprint.cpp) target_link_libraries(kmsprint kms++ kmstest ${LIBDRM_LIBRARIES}) + +add_executable (fbtestpat fbtestpat.cpp) +target_link_libraries(fbtestpat kmstest) diff --git a/tests/fbtestpat.cpp b/tests/fbtestpat.cpp new file mode 100644 index 0000000..9607757 --- /dev/null +++ b/tests/fbtestpat.cpp @@ -0,0 +1,59 @@ +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include + +#include "test.h" +#include "mappedbuffer.h" + +using namespace kms; + +int main(int argc, char** argv) +{ + const char* fbdev = "/dev/fb0"; + int r; + + int fd = open(fbdev, O_RDWR); + FAIL_IF(fd < 0, "open %s failed\n", fbdev); + + struct fb_var_screeninfo var; + + r = ioctl(fd, FBIOGET_VSCREENINFO, &var); + FAIL_IF(r, "FBIOGET_VSCREENINFO failed"); + + struct fb_fix_screeninfo fix; + + r = ioctl(fd, FBIOGET_FSCREENINFO, &fix); + FAIL_IF(r, "FBIOGET_FSCREENINFO failed"); + + void* ptr = mmap(NULL, + var.yres_virtual * fix.line_length, + PROT_WRITE | PROT_READ, + MAP_SHARED, fd, 0); + + FAIL_IF(ptr == MAP_FAILED, "mmap failed"); + + MappedCPUBuffer buf(var.xres_virtual, var.yres_virtual, PixelFormat::XRGB8888); + + printf("%s: res %dx%d, virtual %dx%d, line_len %d\n", + fbdev, + var.xres, var.yres, + var.xres_virtual, var.yres_virtual, + fix.line_length); + + draw_test_pattern(buf); + + memcpy(ptr, buf.map(0), buf.size(0)); + + close(fd); + + return 0; +} -- cgit v1.2.3