annotate libvo/vo_fbdev.c @ 288:abe56b2561b1

bpp fix
author arpi_esp
date Thu, 05 Apr 2001 19:44:54 +0000
parents 604b37178b3d
children 6c3a6322f81c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
1 #include <stdio.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
2 #include <stdlib.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
3 #include <string.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
4 #include <fcntl.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
5 #include <unistd.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
6 #include <errno.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
7
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
8 #include <sys/mman.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
9 #include <sys/ioctl.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
10 #include <linux/fb.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
11 #include <linux/vt.h>
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
12
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
13 #include "config.h"
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
14 #include "video_out.h"
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
15 #include "video_out_internal.h"
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
16
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
17 #include "yuv2rgb.h"
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
18
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
19 LIBVO_EXTERN(fbdev)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
20
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
21 //#include "yuv2rgb.h"
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
22
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
23 static vo_info_t vo_info = {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
24 "Framebuffer Device",
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
25 "fbdev",
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
26 "Szabolcs Berecz <szabi@inf.elte.hu>",
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
27 ""
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
28 };
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
29
230
2605bca34a96 works with .avi (for me :) )
szabii
parents: 229
diff changeset
30 static int vt_active = -1;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
31 static int vt_fd;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
32
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
33 char *fb_dev_name = NULL;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
34 static int fb_dev_fd;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
35 static size_t fb_size;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
36 static uint8_t *frame_buffer;
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
37 static int fb_pixel_size;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
38 static int fb_bpp;
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
39 struct fb_fix_screeninfo fb_fix_info;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
40 struct fb_var_screeninfo fb_var_info;
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
41 static uint32_t fb_xres_virtual;
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
42 static uint32_t fb_yres_virtual;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
43
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
44 static int in_width;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
45 static int in_height;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
46 static int out_width;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
47 static int out_height;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
48 static uint8_t *next_frame;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
49 static int screen_width;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
50 static uint32_t pixel_format;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
51
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
52 static int fb_init_done = 0;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
53
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
54 static int fb_init(void)
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
55 {
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
56 int fd;
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
57 #if 0
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
58 int vt;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
59 char vt_name[11];
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
60 struct vt_stat vt_state;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
61 struct vt_mode vt_mode;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
62
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
63 /* get a free vt */
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
64 if ((fd = open("/dev/tty0", O_WRONLY, 0)) == -1) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
65 printf("Can't open /dev/tty0: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
66 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
67 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
68 if (ioctl(fd, VT_OPENQRY, &vt) < 0 || vt == -1) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
69 printf("Can't open a free VT: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
70 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
71 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
72 close(fd);
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
73
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
74 /* open the vt */
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
75 snprintf(vt_name, 10, "/dev/tty%d", vt);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
76 if ((vt_fd = open(vt_name, O_RDWR | O_NONBLOCK, 0)) == -1) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
77 printf("Can't open %s: %s\n", vt_name, strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
78 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
79 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
80
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
81 /* save the current vtnum */
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
82 if (!ioctl(vt_fd, VT_GETSTATE, &vt_state))
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
83 vt_active = vt_state.v_active;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
84
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
85 /* detach the controlling tty */
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
86 if ((fd = open("/dev/tty", O_RDWR)) >= 0) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
87 ioctl(fd, TIOCNOTTY, 0);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
88 close(fd);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
89 }
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
90
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
91 /* switch to the new vt */
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
92 if (ioctl(vt_fd, VT_ACTIVATE, vt_active))
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
93 printf("ioctl VT_ACTIVATE: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
94 if (ioctl(vt_fd, VT_WAITACTIVE, vt_active))
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
95 printf("ioctl VT_WAITACTIVE: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
96 if (ioctl(vt_fd, VT_GETMODE, &vt_mode) < 0) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
97 printf("ioctl VT_GETMODE: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
98 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
99 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
100 signal(SIGUSR1, vt_request);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
101 vt_mode.mode = VT_PROCESS;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
102 vt_mode.relsig = SIGUSR1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
103 vt_mode.acqsig = SIGUSR1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
104 if (ioctl(vt_fd, VT_SETMODE, &vt_mode) < 0) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
105 printf("ioctl VT_SETMODE: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
106 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
107 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
108 #endif
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
109 if (!fb_dev_name && !(fb_dev_name = getenv("FRAMEBUFFER")))
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
110 fb_dev_name = "/dev/fb0";
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
111 printf("fb_init: using %s\n", fb_dev_name);
245
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
112
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
113 if ((fb_dev_fd = open(fb_dev_name, O_RDWR)) == -1) {
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
114 printf("fb_init: Can't open %s: %s\n", fb_dev_name, strerror(errno));
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
115 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
116 }
245
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
117
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
118 if (ioctl(fb_dev_fd, FBIOGET_VSCREENINFO, &fb_var_info)) {
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
119 printf("fb_init: Can't get VSCREENINFO: %s\n", strerror(errno));
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
120 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
121 }
245
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
122
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
123 /* disable scrolling */
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
124 fb_xres_virtual = fb_var_info.xres_virtual;
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
125 fb_yres_virtual = fb_var_info.yres_virtual;
245
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
126 fb_var_info.xres_virtual = fb_var_info.xres;
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
127 fb_var_info.yres_virtual = fb_var_info.yres;
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
128
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
129 if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_var_info)) {
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
130 printf("fb_init: Can't put VSCREENINFO: %s\n", strerror(errno));
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
131 return 1;
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
132 }
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
133
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
134 if (ioctl(fb_dev_fd, FBIOGET_FSCREENINFO, &fb_fix_info)) {
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
135 printf("fb_init: Can't get VSCREENINFO: %s\n", strerror(errno));
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
136 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
137 }
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
138 switch (fb_fix_info.type) {
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
139 case FB_TYPE_VGA_PLANES:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
140 printf("fb_init: FB_TYPE_VGA_PLANES not supported.\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
141 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
142 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
143 case FB_TYPE_PLANES:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
144 printf("fb_init: FB_TYPE_PLANES not supported.\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
145 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
146 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
147 case FB_TYPE_INTERLEAVED_PLANES:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
148 printf("fb_init: FB_TYPE_INTERLEAVED_PLANES not supported.\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
149 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
150 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
151 #ifdef FB_TYPE_TEXT
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
152 case FB_TYPE_TEXT:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
153 printf("fb_init: FB_TYPE_TEXT not supported.\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
154 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
155 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
156 #endif
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
157 case FB_TYPE_PACKED_PIXELS:
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
158 /* OK */
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
159 printf("fb_init: FB_TYPE_PACKED_PIXELS: OK\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
160 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
161 default:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
162 printf("fb_init: unknown FB_TYPE: %d\n", fb_fix_info.type);
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
163 return 1;
245
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
164 }
cb4c682746c0 disabled scrollback buffer (virtual fb size set to real screen size)
szabii
parents: 231
diff changeset
165
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
166 fb_pixel_size = fb_var_info.bits_per_pixel / 8;
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
167 fb_bpp = fb_var_info.red.length + fb_var_info.green.length +
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
168 fb_var_info.blue.length;
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
169 screen_width = fb_fix_info.line_length;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
170 fb_size = fb_fix_info.smem_len;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
171 if ((frame_buffer = (uint8_t *) mmap(0, fb_size, PROT_READ | PROT_WRITE,
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
172 MAP_SHARED, fb_dev_fd, 0)) == (uint8_t *) -1) {
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
173 printf("fb_init: Can't mmap %s: %s\n", fb_dev_name, strerror(errno));
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
174 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
175 }
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
176
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
177 printf("fb_init: framebuffer @ %p\n", frame_buffer);
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
178 printf("fb_init: framebuffer size: %d bytes\n", fb_size);
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
179 printf("fb_init: bpp: %d\n", fb_bpp);
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
180 printf("fb_init: pixel size: %d\n", fb_pixel_size);
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
181 printf("fb_init: pixel per line: %d\n", screen_width / fb_pixel_size);
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
182 printf("fb_init: visual: %d\n", fb_fix_info.visual);
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
183 printf("fb_init: red: %d %d %d\n", fb_var_info.red.offset,
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
184 fb_var_info.red.length, fb_var_info.red.msb_right);
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
185 printf("fb_init: green: %d %d %d\n", fb_var_info.green.offset,
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
186 fb_var_info.green.length, fb_var_info.green.msb_right);
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
187 printf("fb_init: blue: %d %d %d\n", fb_var_info.blue.offset,
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
188 fb_var_info.blue.length, fb_var_info.blue.msb_right);
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
189
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
190 fb_init_done = 1;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
191 return 0;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
192 }
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
193
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
194 static uint32_t init(uint32_t width, uint32_t height, uint32_t d_width,
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
195 uint32_t d_height, uint32_t fullscreen, char *title,
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
196 uint32_t format)
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
197 {
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
198 if (!fb_init_done)
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
199 if (fb_init())
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
200 return 1;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
201
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
202 in_width = width;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
203 in_height = height;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
204 out_width = width;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
205 out_height = height;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
206 pixel_format = format;
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
207 if (!(next_frame = (uint8_t *) malloc(in_width * in_height * fb_pixel_size))) {
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
208 printf("Can't malloc next_frame: %s\n", strerror(errno));
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
209 return 1;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
210 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
211
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
212 if (format == IMGFMT_YV12)
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
213 // yuv2rgb_init(fb_pixel_size * 8, MODE_RGB);
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
214 yuv2rgb_init((fb_pixel_size == 4) ? 32 : fb_bpp, MODE_RGB);
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
215 return 0;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
216 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
217
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
218 static uint32_t query_format(uint32_t format)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
219 {
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
220 if (!fb_init_done)
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
221 if (fb_init())
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
222 return 0;
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
223 printf("vo_fbdev: query_format(%#x(%.4s)): ", format, &format);
230
2605bca34a96 works with .avi (for me :) )
szabii
parents: 229
diff changeset
224 // if (format & IMGFMT_BGR_MASK == IMGFMT_BGR)
2605bca34a96 works with .avi (for me :) )
szabii
parents: 229
diff changeset
225 // goto not_supported;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
226 switch (format) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
227 case IMGFMT_YV12:
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
228 goto supported;
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
229 /*
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
230 case IMGFMT_RGB32:
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
231 if (fb_bpp == 32)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
232 goto supported;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
233 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
234 case IMGFMT_RGB24:
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
235 if (fb_bpp == 24)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
236 goto supported;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
237 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
238 case IMGFMT_RGB16:
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
239 if (fb_bpp == 16)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
240 goto supported;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
241 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
242 case IMGFMT_RGB15:
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
243 if (fb_bpp == 15)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
244 goto supported;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
245 break;
277
8d526cf59ffe report more info on fb
szabii
parents: 251
diff changeset
246 */
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
247 case IMGFMT_BGR|32:
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
248 if (fb_bpp == 24 && fb_pixel_size == 4)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
249 goto supported;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
250 break;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
251 case IMGFMT_BGR|24:
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
252 if (fb_bpp == 24 && fb_pixel_size == 3)
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
253 goto supported;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
254 break;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
255 case IMGFMT_BGR|16:
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
256 if (fb_bpp == 16)
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
257 goto supported;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
258 break;
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
259 case IMGFMT_BGR|15:
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
260 if (fb_bpp == 15)
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
261 goto supported;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
262 break;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
263 }
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
264 not_supported:
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
265 printf("not_supported\n");
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
266 return 0;
229
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
267 supported:
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
268 printf("supported\n");
a8170ba5496f maybe it can play avi :)
szabii
parents: 225
diff changeset
269 return 1;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
270 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
271
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
272 static const vo_info_t *get_info(void)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
273 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
274 return &vo_info;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
275 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
276
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
277 static void draw_alpha(int x0, int y0, int w, int h, unsigned char *src,
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
278 unsigned char *srca, int stride)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
279 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
280 int x, y;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
281 uint8_t *dst;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
282
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
283 if (pixel_format == IMGFMT_YV12) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
284 for (y = 0; y < h; y++){
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
285 dst = next_frame + (in_width * (y0 + y) + x0) * fb_pixel_size;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
286 for (x = 0; x < w; x++) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
287 if (srca[x]) {
251
ea2dcb082185 alpha rendering, virtual screensize reset fix
szabii
parents: 246
diff changeset
288 dst[0]=((dst[0]*srca[x])>>8)+src[x];
ea2dcb082185 alpha rendering, virtual screensize reset fix
szabii
parents: 246
diff changeset
289 dst[1]=((dst[1]*srca[x])>>8)+src[x];
ea2dcb082185 alpha rendering, virtual screensize reset fix
szabii
parents: 246
diff changeset
290 dst[2]=((dst[2]*srca[x])>>8)+src[x];
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
291 }
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
292 dst += fb_pixel_size;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
293 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
294 src += stride;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
295 srca += stride;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
296 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
297 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
298 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
299
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
300 static uint32_t draw_frame(uint8_t *src[])
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
301 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
302 if (pixel_format == IMGFMT_YV12) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
303 yuv2rgb(next_frame, src[0], src[1], src[2], in_width,
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
304 in_height, in_width * fb_pixel_size,
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
305 in_width, in_width / 2);
230
2605bca34a96 works with .avi (for me :) )
szabii
parents: 229
diff changeset
306 } else if ((pixel_format & IMGFMT_BGR_MASK) == IMGFMT_BGR) {
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
307 memcpy(next_frame, src[0], in_width * in_height * fb_pixel_size);
230
2605bca34a96 works with .avi (for me :) )
szabii
parents: 229
diff changeset
308 } else if ((pixel_format & IMGFMT_RGB_MASK) == IMGFMT_RGB) {
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
309 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
310 return 0;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
311 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
312
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
313 static uint32_t draw_slice(uint8_t *src[], int stride[], int w, int h, int x,
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
314 int y)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
315 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
316 uint8_t *dest;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
317
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
318 dest = next_frame + (in_width * y + x) * fb_pixel_size;
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
319 yuv2rgb(dest, src[0], src[1], src[2], w, h, in_width * fb_pixel_size,
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
320 stride[0], stride[1]);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
321 return 0;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
322 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
323
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
324 static void check_events(void)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
325 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
326 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
327
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
328 static void put_frame(void)
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
329 {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
330 int i, out_offset = 0, in_offset = 0;
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
331
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
332 for (i = 0; i < in_height; i++) {
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
333 memcpy(frame_buffer + out_offset, next_frame + in_offset,
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
334 in_width * fb_pixel_size);
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
335 out_offset += screen_width;
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
336 in_offset += in_width * fb_pixel_size;
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
337 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
338 }
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
339
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
340 static void flip_page(void)
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
341 {
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
342 vo_draw_text(in_width, in_height, draw_alpha);
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
343 check_events();
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
344 put_frame();
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
345 }
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
346
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
347 static void uninit(void)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
348 {
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
349 printf("vo_fbdev: uninit\n");
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
350 fb_var_info.xres_virtual = fb_xres_virtual;
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
351 fb_var_info.yres_virtual = fb_yres_virtual;
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
352 if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_var_info))
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
353 printf("vo_fbdev: Can't set virtual screensize to original value: %s\n", strerror(errno));
251
ea2dcb082185 alpha rendering, virtual screensize reset fix
szabii
parents: 246
diff changeset
354 close(fb_dev_fd);
278
604b37178b3d now it works in 15bpp mode
szabii
parents: 277
diff changeset
355 memset(next_frame, '\0', in_height * in_width * fb_pixel_size);
246
5673f9146c54 clear the frame on uninit
szabii
parents: 245
diff changeset
356 put_frame();
225
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
357 if (vt_active >= 0)
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
358 ioctl(vt_fd, VT_ACTIVATE, vt_active);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
359 free(next_frame);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
360 munmap(frame_buffer, fb_size);
62ec84961b27 vo_fbdev added
szabii
parents:
diff changeset
361 }