07dc09aea33a54d7e36a859fd0062ae70618393c
[android/external-libkmsxx.git] / tests / kmsview.cpp
1 #include <cstdio>
2 #include <fstream>
3 #include <unistd.h>
5 #include "kms++.h"
7 #include "test.h"
9 using namespace std;
10 using namespace kms;
12 static void read_frame(ifstream& is, DumbFramebuffer* fb, Crtc* crtc, Plane* plane)
13 {
14         for (unsigned i = 0; i < fb->num_planes(); ++i)
15                 is.read((char*)fb->map(i), fb->size(i));
17         int r = crtc->set_plane(plane, *fb,
18                                 0, 0, fb->width(), fb->height(),
19                                 0, 0, fb->width(), fb->height());
21         ASSERT(r == 0);
22 }
24 int main(int argc, char** argv)
25 {
26         if (argc != 5) {
27                 printf("Usage: %s <file> <width> <height> <fourcc>\n", argv[0]);
28                 return -1;
29         }
31         string filename = argv[1];
32         uint32_t w = stoi(argv[2]);
33         uint32_t h = stoi(argv[3]);
34         string modestr = argv[4];
36         auto pixfmt = FourCCToPixelFormat(modestr);
39         ifstream is(filename, ifstream::binary);
41         is.seekg(0, std::ios::end);
42         unsigned fsize = is.tellg();
43         is.seekg(0);
46         Card card;
48         auto conn = card.get_first_connected_connector();
49         auto crtc = conn->get_current_crtc();
51         auto fb = new DumbFramebuffer(card, w, h, pixfmt);
53         Plane* plane = 0;
55         for (Plane* p : crtc->get_possible_planes()) {
56                 if (p->plane_type() != PlaneType::Overlay)
57                         continue;
59                 if (!p->supports_format(pixfmt))
60                         continue;
62                 plane = p;
63                 break;
64         }
66         FAIL_IF(!plane, "available plane not found");
69         unsigned frame_size = 0;
70         for (unsigned i = 0; i < fb->num_planes(); ++i)
71                 frame_size += fb->size(i);
73         unsigned num_frames = fsize / frame_size;
74         printf("file size %u, frames %u\n", fsize, num_frames);
76         for (unsigned i = 0; i < num_frames; ++i) {
77                 printf("frame %d\n", i);
78                 read_frame(is, fb, crtc, plane);
79                 usleep(1000*50);
80         }
82         printf("press enter to exit\n");
84         is.close();
86         getchar();
88         delete fb;
89 }