annotate libvo/mga_common.c @ 3571:ceaccd11b8ec

VP30 added - report by Mark Janssen <maniac@maniac.nl>
author arpi
date Mon, 17 Dec 2001 22:09:56 +0000
parents a8145a712f25
children 48bfd1d278d1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
413
7785656abf11 fastmemcpy added
arpi_esp
parents: 326
diff changeset
1
566
0375ced94bd7 ehh fixed ;)
arpi_esp
parents: 470
diff changeset
2 #include "fastmemcpy.h"
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
3 #include "../mmx_defs.h"
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
4
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
5 // mga_vid drawing functions
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
6
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
7 static int mga_next_frame=0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
8
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
9 static mga_vid_config_t mga_vid_config;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
10 static uint8_t *vid_data, *frames[4];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
11 static int f;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
12
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
13 static void draw_alpha(int x0,int y0, int w,int h, unsigned char* src, unsigned char *srca, int stride){
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
14 int x,y;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
15 uint32_t bespitch = (mga_vid_config.src_width + 31) & ~31;
466
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
16 switch(mga_vid_config.format){
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
17 case MGA_VID_FORMAT_YV12:
470
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
18 case MGA_VID_FORMAT_IYUV:
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
19 case MGA_VID_FORMAT_I420:
326
f6b5c2dbc88e OSD alpha renderers moved to osd.c
arpi_esp
parents: 284
diff changeset
20 vo_draw_alpha_yv12(w,h,src,srca,stride,vid_data+bespitch*y0+x0,bespitch);
466
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
21 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
22 case MGA_VID_FORMAT_YUY2:
326
f6b5c2dbc88e OSD alpha renderers moved to osd.c
arpi_esp
parents: 284
diff changeset
23 vo_draw_alpha_yuy2(w,h,src,srca,stride,vid_data+2*(bespitch*y0+x0),2*bespitch);
466
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
24 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
25 case MGA_VID_FORMAT_UYVY:
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
26 vo_draw_alpha_yuy2(w,h,src,srca,stride,vid_data+2*(bespitch*y0+x0)+1,2*bespitch);
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
27 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
28 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
29 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
30
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
31
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
32 //static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
33 //write_slice_g200(uint8_t *y,uint8_t *cr, uint8_t *cb,uint32_t slice_num)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
34
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
35 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
36 draw_slice_g200(uint8_t *image[], int stride[], int width,int height,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
37 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
38 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
39 uint8_t *src2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
40 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
41 uint32_t bespitch,h,w;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
42
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
43 bespitch = (mga_vid_config.src_width + 31) & ~31;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
44
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
45 dest = vid_data + bespitch*y + x;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
46 src = image[0];
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
47 for(h=0; h < height; h++)
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
48 {
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
49 memcpy(dest, src, width);
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
50 src += stride[0];
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
51 dest += bespitch;
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
52 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
53
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
54 width/=2;height/=2;x/=2;y/=2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
55
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
56 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch*y + 2*x;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
57 src = image[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
58 src2 = image[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
59 for(h=0; h < height; h++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
60 {
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
61 #ifdef HAVE_MMX
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
62 asm(
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
63 "xorl %%eax, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
64 "1: \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
65 PREFETCH" 64(%1, %%eax) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
66 PREFETCH" 64(%2, %%eax) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
67 "movq (%1, %%eax), %%mm0 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
68 "movq 8(%1, %%eax), %%mm2 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
69 "movq %%mm0, %%mm1 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
70 "movq %%mm2, %%mm3 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
71 "movq (%2, %%eax), %%mm4 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
72 "movq 8(%2, %%eax), %%mm5 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
73 "punpcklbw %%mm4, %%mm0 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
74 "punpckhbw %%mm4, %%mm1 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
75 "punpcklbw %%mm5, %%mm2 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
76 "punpckhbw %%mm5, %%mm3 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
77 MOVNTQ" %%mm0, (%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
78 MOVNTQ" %%mm1, 8(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
79 MOVNTQ" %%mm2, 16(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
80 MOVNTQ" %%mm3, 24(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
81 "addl $16, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
82 "cmpl %3, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
83 " jb 1b \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
84 ::"r"(dest), "r"(src), "r"(src2), "r" (width-15)
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
85 : "memory", "%eax"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
86 );
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
87 for(w= (width&(~15)); w < width; w++)
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
88 {
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
89 dest[2*w+0] = src[w];
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
90 dest[2*w+1] = src2[w];
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
91 }
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
92 #else
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
93 for(w=0; w < width; w++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
94 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
95 dest[2*w+0] = src[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
96 dest[2*w+1] = src2[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
97 }
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
98 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
99 dest += bespitch;
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
100 src += stride[1];
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
101 src2+= stride[2];
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
102 }
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
103 #ifdef HAVE_MMX
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
104 asm(
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
105 EMMS" \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
106 SFENCE" \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
107 ::: "memory"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
108 );
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
109 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
110 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
111
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
112 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
113 draw_slice_g400(uint8_t *image[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
114 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
115 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
116 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
117 uint32_t bespitch,bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
118 int i;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
119
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
120 bespitch = (mga_vid_config.src_width + 31) & ~31;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
121 bespitch2 = bespitch/2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
122
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
123 dest = vid_data + bespitch * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
124 src = image[0];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
125 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
126 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
127 src+=stride[0];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
128 dest += bespitch;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
129 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
130
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
131 w/=2;h/=2;x/=2;y/=2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
132
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
133 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch2 * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
134 src = image[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
135 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
136 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
137 src+=stride[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
138 dest += bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
139 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
140
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
141 dest = vid_data + bespitch*mga_vid_config.src_height
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
142 + bespitch*mga_vid_config.src_height / 4
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
143 + bespitch2 * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
144 src = image[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
145 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
146 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
147 src+=stride[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
148 dest += bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
149 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
150
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
151 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
152
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
153 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
154 draw_slice(uint8_t *src[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
155 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
156 if (mga_vid_config.card_type == MGA_G200)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
157 draw_slice_g200(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
158 else
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
159 draw_slice_g400(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
160 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
161 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
162
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
163 static void
31
1fc618eba830 added check_events() interface
arpi_esp
parents: 1
diff changeset
164 vo_mga_flip_page(void)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
165 {
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
166
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
167 // printf("-- flip to %d --\n",mga_next_frame);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
168
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
169 #if 1
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
170 ioctl(f,MGA_VID_FSEL,&mga_next_frame);
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
171 mga_next_frame=(mga_next_frame+1)%mga_vid_config.num_frames;
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
172 vid_data=frames[mga_next_frame];
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
173 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
174
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
175 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
176
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
177
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
178 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
179 write_frame_yuy2(uint8_t *y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
180 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
181 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
182 uint32_t bespitch,h;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
183 int len=2*mga_vid_config.src_width;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
184
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
185 dest = vid_data;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
186 bespitch = (mga_vid_config.src_width + 31) & ~31;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
187
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
188 // y+=2*mga_vid_config.src_width*mga_vid_config.src_height;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
189
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
190 for(h=0; h < mga_vid_config.src_height; h++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
191 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
192 // y -= 2*mga_vid_config.src_width;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
193 memcpy(dest, y, len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
194 y += len;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
195 dest += 2*bespitch;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
196 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
197 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
198
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
199
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
200 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
201 draw_frame(uint8_t *src[])
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
202 {
448
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
203 switch(mga_vid_config.format){
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
204 case MGA_VID_FORMAT_YUY2:
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
205 write_frame_yuy2(src[0]);break;
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
206 case MGA_VID_FORMAT_UYVY:
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
207 write_frame_yuy2(src[0]);break;
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
208 }
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
209 return 0;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
210 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
211
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
212 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
213 query_format(uint32_t format)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
214 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
215 switch(format){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
216 case IMGFMT_YV12:
470
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
217 case IMGFMT_I420:
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
218 case IMGFMT_IYUV:
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
219 case IMGFMT_YUY2:
448
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
220 case IMGFMT_UYVY:
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
221 // case IMGFMT_RGB|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
222 // case IMGFMT_BGR|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
223 return 1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
224 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
225 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
226 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
227
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
228 static int mga_init(){
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
229 char *frame_mem;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
230
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
231 mga_vid_config.num_frames=4;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
232 mga_vid_config.version=MGA_VID_VERSION;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
233 if (ioctl(f,MGA_VID_CONFIG,&mga_vid_config))
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
234 {
275
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
235 perror("Error in mga_vid_config ioctl()");
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
236 printf("Your mga_vid driver version is incompatible with this MPlayer version!\n");
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
237 return -1;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
238 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
239 ioctl(f,MGA_VID_ON,0);
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
240
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
241 frames[0] = (char*)mmap(0,mga_vid_config.frame_size*mga_vid_config.num_frames,PROT_WRITE,MAP_SHARED,f,0);
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
242 frames[1] = frames[0] + 1*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
243 frames[2] = frames[0] + 2*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
244 frames[3] = frames[0] + 3*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
245 mga_next_frame = 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
246 vid_data = frames[mga_next_frame];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
247
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
248 //clear the buffer
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
249 memset(frames[0],0x80,mga_vid_config.frame_size*mga_vid_config.num_frames);
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
250
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
251 return 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
252
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
253 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
254
1637
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
255 static int mga_uninit(){
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
256 ioctl( f,MGA_VID_OFF,0 );
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
257 munmap(frames[0],mga_vid_config.frame_size*mga_vid_config.num_frames);
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
258 close(f);
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
259 }