1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
#include <cstdio>
#include <fstream>
#include <unistd.h>
#include <kms++/kms++.h>
#include <kms++util/kms++util.h>
using namespace std;
using namespace kms;
static void read_frame(ifstream& is, DumbFramebuffer* fb, Crtc* crtc, Plane* plane)
{
for (unsigned i = 0; i < fb->num_planes(); ++i)
is.read((char*)fb->map(i), fb->size(i));
unsigned w = min(crtc->width(), fb->width());
unsigned h = min(crtc->height(), fb->height());
int r = crtc->set_plane(plane, *fb,
0, 0, w, h,
0, 0, fb->width(), fb->height());
ASSERT(r == 0);
}
static const char* usage_str =
"Usage: kmsview [options] <file> <width> <height> <fourcc>\n\n"
"Options:\n"
" -c, --connector <name> Output connector\n"
" -t, --time <ms> Milliseconds to sleep between frames\n";
static void usage()
{
puts(usage_str);
}
int main(int argc, char** argv)
{
uint32_t time = 0;
string dev_path;
string conn_name;
OptionSet optionset = {
Option("c|connector=", [&conn_name](string s) {
conn_name = s;
}),
Option("|device=", [&dev_path](string s) {
dev_path = s;
}),
Option("t|time=", [&time](const string& str) {
time = stoul(str);
}),
Option("h|help", []() {
usage();
exit(-1);
}),
};
optionset.parse(argc, argv);
vector<string> params = optionset.params();
if (params.size() != 4) {
usage();
exit(-1);
}
string filename = params[0];
uint32_t w = stoi(params[1]);
uint32_t h = stoi(params[2]);
string modestr = params[3];
auto pixfmt = FourCCToPixelFormat(modestr);
ifstream is(filename, ifstream::binary);
is.seekg(0, std::ios::end);
unsigned fsize = is.tellg();
is.seekg(0);
Card card(dev_path);
ResourceManager res(card);
auto conn = res.reserve_connector(conn_name);
auto crtc = res.reserve_crtc(conn);
auto plane = res.reserve_overlay_plane(crtc, pixfmt);
FAIL_IF(!plane, "available plane not found");
auto fb = new DumbFramebuffer(card, w, h, pixfmt);
unsigned frame_size = 0;
for (unsigned i = 0; i < fb->num_planes(); ++i)
frame_size += fb->size(i);
unsigned num_frames = fsize / frame_size;
printf("file size %u, frame size %u, frames %u\n", fsize, frame_size, num_frames);
for (unsigned i = 0; i < num_frames; ++i) {
printf("frame %d", i);
fflush(stdout);
read_frame(is, fb, crtc, plane);
if (!time) {
getchar();
} else {
usleep(time * 1000);
printf("\n");
}
}
is.close();
if (time) {
printf("press enter to exit\n");
getchar();
}
delete fb;
}
|