annotate libvo/mga_common.c @ 290:f40a55208b76

Mode detect bugfix.
author se7encode
date Thu, 05 Apr 2001 20:42:24 +0000
parents 1ddac77b0d43
children f6b5c2dbc88e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
2 // mga_vid drawing functions
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
3
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
4 static int mga_next_frame=0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
5
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
6 static mga_vid_config_t mga_vid_config;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
7 static uint8_t *vid_data, *frames[4];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
8 static int f;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
9
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
10 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
11 int x,y;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
12 uint32_t bespitch = (mga_vid_config.src_width + 31) & ~31;
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
13
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
14 if (mga_vid_config.format==MGA_VID_FORMAT_YV12){
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
15
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
16 for(y=0;y<h;y++){
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
17 uint8_t *dst = vid_data + bespitch * (y0+y) + x0;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
18 for(x=0;x<w;x++){
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
19 // dst[x]=(dst[x]*srca[x]+src[x]*(srca[x]^255))>>8;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
20 if(srca[x])
249
2dadc379a934 OSD/SUB image quality & speed improvement
arpi_esp
parents: 202
diff changeset
21 dst[x]=((dst[x]*srca[x])>>8)+src[x];
2dadc379a934 OSD/SUB image quality & speed improvement
arpi_esp
parents: 202
diff changeset
22 //dst[x]=(dst[x]*(srca[x]^255)+src[x]*(srca[x]))>>8;
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
23 }
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
24 src+=stride;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
25 srca+=stride;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
26 }
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
27
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
28 } else {
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
29
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
30 for(y=0;y<h;y++){
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
31 uint8_t *dst = vid_data + 2*(bespitch * (y0+y) + x0);
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
32 for(x=0;x<w;x++){
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
33 // dst[x]=(dst[x]*srca[x]+src[x]*(srca[x]^255))>>8;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
34 if(srca[x])
249
2dadc379a934 OSD/SUB image quality & speed improvement
arpi_esp
parents: 202
diff changeset
35 dst[2*x]=((dst[2*x]*srca[x])>>8)+src[x];
2dadc379a934 OSD/SUB image quality & speed improvement
arpi_esp
parents: 202
diff changeset
36 //dst[2*x]=(dst[2*x]*(srca[x]^255)+src[x]*(srca[x]))>>8;
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
37 }
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
38 src+=stride;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
39 srca+=stride;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
40 }
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
41
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
42 }
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
43
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
44 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
45
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
46
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
47 //static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
48 //write_slice_g200(uint8_t *y,uint8_t *cr, uint8_t *cb,uint32_t slice_num)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
49
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
50 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
51 draw_slice_g200(uint8_t *image[], int stride[], int width,int height,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
52 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
53 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
54 uint8_t *src2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
55 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
56 uint32_t bespitch,h,w;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
57
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
58 bespitch = (mga_vid_config.src_width + 31) & ~31;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
59
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
60 dest = vid_data + bespitch*y + x;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
61 src = image[0];
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
62 for(h=0; h < height; h++)
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
63 {
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
64 memcpy(dest, src, width);
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
65 src += stride[0];
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
66 dest += bespitch;
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
67 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
68
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
69 width/=2;height/=2;x/=2;y/=2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
70
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
71 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch*y + 2*x;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
72 src = image[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
73 src2 = image[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
74 for(h=0; h < height; h++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
75 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
76 for(w=0; w < width; w++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
77 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
78 dest[2*w+0] = src[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
79 dest[2*w+1] = src2[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
80 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
81 dest += bespitch;
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
82 src += stride[1];
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
83 src2+= stride[2];
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
84 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
85 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
86
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
87 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
88 draw_slice_g400(uint8_t *image[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
89 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
90 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
91 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
92 uint32_t bespitch,bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
93 int i;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
94
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
95 bespitch = (mga_vid_config.src_width + 31) & ~31;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
96 bespitch2 = bespitch/2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
97
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
98 dest = vid_data + bespitch * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
99 src = image[0];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
100 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
101 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
102 src+=stride[0];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
103 dest += bespitch;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
104 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
105
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
106 w/=2;h/=2;x/=2;y/=2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
107
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
108 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch2 * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
109 src = image[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
110 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
111 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
112 src+=stride[1];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
113 dest += bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
114 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
115
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
116 dest = vid_data + bespitch*mga_vid_config.src_height
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
117 + bespitch*mga_vid_config.src_height / 4
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
118 + bespitch2 * y + x;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
119 src = image[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
120 for(i=0;i<h;i++){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
121 memcpy(dest,src,w);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
122 src+=stride[2];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
123 dest += bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
124 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
125
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
126 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
127
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
128 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
129 draw_slice(uint8_t *src[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
130 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
131 if (mga_vid_config.card_type == MGA_G200)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
132 draw_slice_g200(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
133 else
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
134 draw_slice_g400(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
135 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
136 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
137
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
138 static void
31
1fc618eba830 added check_events() interface
arpi_esp
parents: 1
diff changeset
139 vo_mga_flip_page(void)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
140 {
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
141
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
142 // printf("-- flip to %d --\n",mga_next_frame);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
143
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
144 #if 1
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
145 ioctl(f,MGA_VID_FSEL,&mga_next_frame);
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
146 mga_next_frame=(mga_next_frame+1)%mga_vid_config.num_frames;
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
147 vid_data=frames[mga_next_frame];
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
148 #endif
1
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 void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
154 write_frame_yuy2(uint8_t *y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
155 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
156 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
157 uint32_t bespitch,h;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
158 int len=2*mga_vid_config.src_width;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
159
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
160 dest = vid_data;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
161 bespitch = (mga_vid_config.src_width + 31) & ~31;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
162
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
163 // y+=2*mga_vid_config.src_width*mga_vid_config.src_height;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
164
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
165 for(h=0; h < mga_vid_config.src_height; h++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
166 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
167 // y -= 2*mga_vid_config.src_width;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
168 memcpy(dest, y, len);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
169 y += len;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
170 dest += 2*bespitch;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
171 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
172 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
173
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
174
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
175 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
176 draw_frame(uint8_t *src[])
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
177 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
178 if (mga_vid_config.format==MGA_VID_FORMAT_YUY2)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
179 write_frame_yuy2(src[0]);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
180 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
181 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
182
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
183 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
184 query_format(uint32_t format)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
185 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
186 switch(format){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
187 case IMGFMT_YV12:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
188 case IMGFMT_YUY2:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
189 // case IMGFMT_RGB|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
190 // case IMGFMT_BGR|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
191 return 1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
192 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
193 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
194 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
195
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
196 static int mga_init(){
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
197 char *frame_mem;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
198
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
199 mga_vid_config.num_frames=4;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
200 mga_vid_config.version=MGA_VID_VERSION;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
201 if (ioctl(f,MGA_VID_CONFIG,&mga_vid_config))
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
202 {
275
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
203 perror("Error in mga_vid_config ioctl()");
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
204 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
205 return -1;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
206 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
207 ioctl(f,MGA_VID_ON,0);
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
208
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
209 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
210 frames[1] = frames[0] + 1*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
211 frames[2] = frames[0] + 2*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
212 frames[3] = frames[0] + 3*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
213 mga_next_frame = 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
214 vid_data = frames[mga_next_frame];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
215
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
216 //clear the buffer
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
217 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
218
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
219 return 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
220
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
221 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
222