annotate libvo/mga_common.c @ 5317:80fbb03b385a

U,V plane odrer fixed
author arpi
date Sun, 24 Mar 2002 20:45:30 +0000
parents 4458e43871d3
children da218aa7f9db
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"
4971
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
4 #include "../mp_image.h"
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
5
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
6 // mga_vid drawing functions
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
7
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
8 static int mga_next_frame=0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
9
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
10 static mga_vid_config_t mga_vid_config;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
11 static uint8_t *vid_data, *frames[4];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
12 static int f;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
13
202
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
14 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
15 int x,y;
6ad0715dfac8 grey+alpha rendering support (for .sub)
arpi_esp
parents: 56
diff changeset
16 uint32_t bespitch = (mga_vid_config.src_width + 31) & ~31;
466
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
17 switch(mga_vid_config.format){
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
18 case MGA_VID_FORMAT_YV12:
470
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
19 case MGA_VID_FORMAT_IYUV:
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
20 case MGA_VID_FORMAT_I420:
326
f6b5c2dbc88e OSD alpha renderers moved to osd.c
arpi_esp
parents: 284
diff changeset
21 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
22 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
23 case MGA_VID_FORMAT_YUY2:
326
f6b5c2dbc88e OSD alpha renderers moved to osd.c
arpi_esp
parents: 284
diff changeset
24 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
25 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
26 case MGA_VID_FORMAT_UYVY:
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
27 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
28 break;
c7c03bf70bb7 UYVY support
arpi_esp
parents: 448
diff changeset
29 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
30 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
31
5014
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
32 static int mga_set_video_eq( const vidix_video_eq_t *info)
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
33 {
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
34
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
35 uint32_t luma;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
36 float factor = 256.0 / 2000;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
37
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
38 luma = ((int)(info->brightness * factor) << 16) +
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
39 ((int)(info->contrast * factor) & 0xFFFF);
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
40 if (ioctl(f,MGA_VID_SET_LUMA,luma)) {
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
41 perror("Error in mga_vid_config ioctl()");
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
42 printf("Could not set luma values in the kernel module!\n");
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
43 return -1;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
44 }
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
45 return 0;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
46
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
47 }
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
48
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
49 static int mga_get_video_eq( vidix_video_eq_t *info)
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
50 {
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
51
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
52 uint32_t luma;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
53 float factor = 2000.0 / 256;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
54
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
55 if (ioctl(f,MGA_VID_GET_LUMA,&luma)) {
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
56 perror("Error in mga_vid_config ioctl()");
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
57 printf("Could not get luma values from the kernel module!\n");
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
58 return -1;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
59 }
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
60 info->brightness = (luma >> 16) * factor;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
61 info->cap |= VEQ_CAP_BRIGHTNESS;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
62
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
63 info->contrast = (luma & 0xFFFF) * factor;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
64 info->cap |= VEQ_CAP_CONTRAST;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
65
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
66 return 0;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
67 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
68
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
69 //static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
70 //write_slice_g200(uint8_t *y,uint8_t *cr, uint8_t *cb,uint32_t slice_num)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
71
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
72 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
73 draw_slice_g200(uint8_t *image[], int stride[], int width,int height,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
74 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
75 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
76 uint8_t *src2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
77 uint8_t *dest;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
78 uint32_t bespitch,h,w;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
79
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
80 bespitch = (mga_vid_config.src_width + 31) & ~31;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
81
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
82 dest = vid_data + bespitch*y + x;
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
83 mem2agpcpy_pic(dest, image[0], width, height, bespitch, stride[0]);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
84
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
85 width/=2;height/=2;x/=2;y/=2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
86
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
87 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch*y + 2*x;
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
88 if(mga_vid_config.format==MGA_VID_FORMAT_YV12){
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
89 src = image[1];
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
90 src2 = image[2];
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
91 } else {
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
92 src = image[2];
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
93 src2 = image[1];
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
94 }
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
95
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
96 for(h=0; h < height; h++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
97 {
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
98 #ifdef HAVE_MMX
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
99 asm(
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
100 "xorl %%eax, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
101 "1: \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
102 PREFETCH" 64(%1, %%eax) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
103 PREFETCH" 64(%2, %%eax) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
104 "movq (%1, %%eax), %%mm0 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
105 "movq 8(%1, %%eax), %%mm2 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
106 "movq %%mm0, %%mm1 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
107 "movq %%mm2, %%mm3 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
108 "movq (%2, %%eax), %%mm4 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
109 "movq 8(%2, %%eax), %%mm5 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
110 "punpcklbw %%mm4, %%mm0 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
111 "punpckhbw %%mm4, %%mm1 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
112 "punpcklbw %%mm5, %%mm2 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
113 "punpckhbw %%mm5, %%mm3 \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
114 MOVNTQ" %%mm0, (%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
115 MOVNTQ" %%mm1, 8(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
116 MOVNTQ" %%mm2, 16(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
117 MOVNTQ" %%mm3, 24(%0, %%eax, 2) \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
118 "addl $16, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
119 "cmpl %3, %%eax \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
120 " jb 1b \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
121 ::"r"(dest), "r"(src), "r"(src2), "r" (width-15)
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
122 : "memory", "%eax"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
123 );
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
124 for(w= (width&(~15)); w < width; w++)
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
125 {
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
126 dest[2*w+0] = src[w];
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
127 dest[2*w+1] = src2[w];
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
128 }
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
129 #else
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
130 for(w=0; w < width; w++)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
131 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
132 dest[2*w+0] = src[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
133 dest[2*w+1] = src2[w];
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
134 }
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
135 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
136 dest += bespitch;
284
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
137 src += stride[1];
1ddac77b0d43 fixed the bespitch*y*x bug
arpi_esp
parents: 275
diff changeset
138 src2+= stride[2];
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
139 }
2625
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
140 #ifdef HAVE_MMX
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
141 asm(
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
142 EMMS" \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
143 SFENCE" \n\t"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
144 ::: "memory"
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
145 );
a8145a712f25 mmx opt ,untested, i have no mga
michael
parents: 1637
diff changeset
146 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
147 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
148
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
149 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
150 draw_slice_g400(uint8_t *image[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
151 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
152 uint8_t *src;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
153 uint8_t *dest;
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
154 uint8_t *dest2;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
155 uint32_t bespitch,bespitch2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
156 int i;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
157
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
158 bespitch = (mga_vid_config.src_width + 31) & ~31;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
159 bespitch2 = bespitch/2;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
160
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
161 dest = vid_data + bespitch * y + x;
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
162 mem2agpcpy_pic(dest, image[0], w, h, bespitch, stride[0]);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
163
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
164 w/=2;h/=2;x/=2;y/=2;
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
165
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
166 dest = vid_data + bespitch*mga_vid_config.src_height + bespitch2 * y + x;
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
167 dest2= dest + bespitch2*mga_vid_config.src_height / 2;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
168
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
169 if(mga_vid_config.format==MGA_VID_FORMAT_YV12){
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
170 // mga_vid's YV12 assumes Y,U,V order (insteda of Y,V,U) :(
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
171 mem2agpcpy_pic(dest, image[1], w, h, bespitch2, stride[1]);
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
172 mem2agpcpy_pic(dest2,image[2], w, h, bespitch2, stride[2]);
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
173 } else {
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
174 mem2agpcpy_pic(dest, image[2], w, h, bespitch2, stride[2]);
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
175 mem2agpcpy_pic(dest2,image[1], w, h, bespitch2, stride[1]);
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
176 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
177
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
178 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
179
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
180 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
181 draw_slice(uint8_t *src[], int stride[], int w,int h,int x,int y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
182 {
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
183
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
184 #if 0
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
185 printf("vo: %p/%d %p/%d %p/%d %dx%d/%d;%d \n",
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
186 src[0],stride[0],
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
187 src[1],stride[1],
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
188 src[2],stride[2],
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
189 w,h,x,y);
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
190 #endif
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
191
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
192 if (mga_vid_config.card_type == MGA_G200)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
193 draw_slice_g200(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
194 else
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
195 draw_slice_g400(src,stride,w,h,x,y);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
196 return 0;
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 static void
31
1fc618eba830 added check_events() interface
arpi_esp
parents: 1
diff changeset
200 vo_mga_flip_page(void)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
201 {
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
202
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
203 // printf("-- flip to %d --\n",mga_next_frame);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
204
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
205 #if 1
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
206 ioctl(f,MGA_VID_FSEL,&mga_next_frame);
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
207 mga_next_frame=(mga_next_frame+1)%mga_vid_config.num_frames;
47
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
208 vid_data=frames[mga_next_frame];
9d68da5d8a9a vsync in mga/xmga
arpi_esp
parents: 31
diff changeset
209 #endif
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
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
213
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
214 static void
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
215 write_frame_yuy2(uint8_t *y)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
216 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
217 int len=2*mga_vid_config.src_width;
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
218 uint32_t bespitch = (mga_vid_config.src_width + 31) & ~31;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
219
4949
48bfd1d278d1 using mem2agpcpy_pic()
arpi
parents: 2625
diff changeset
220 mem2agpcpy_pic(vid_data, y, len, mga_vid_config.src_height, 2*bespitch, len);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
221 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
222
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
223 static uint32_t
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
224 draw_frame(uint8_t *src[])
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
225 {
448
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
226 switch(mga_vid_config.format){
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
227 case MGA_VID_FORMAT_YUY2:
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
228 case MGA_VID_FORMAT_UYVY:
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
229 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
230 }
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
231 return 0;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
232 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
233
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
234 static uint32_t
4971
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
235 get_image(mp_image_t *mpi){
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
236 uint32_t bespitch = (mga_vid_config.src_width + 31) & ~31;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
237 uint32_t bespitch2 = bespitch/2;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
238 // printf("mga: get_image() called\n");
4975
877f0f643fef accept STATIC buffers if num_buffers==1
arpi
parents: 4971
diff changeset
239 if(mpi->type==MP_IMGTYPE_STATIC && mga_vid_config.num_frames>1) return VO_FALSE; // it is not static
4971
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
240 if(mpi->flags&MP_IMGFLAG_READABLE) return VO_FALSE; // slow video ram
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
241 // printf("width=%d vs. bespitch=%d, flags=0x%X \n",mpi->width,bespitch,mpi->flags);
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
242 if((mpi->width==bespitch) ||
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
243 (mpi->flags&(MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_ACCEPT_WIDTH))){
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
244 // we're lucky or codec accepts stride => ok, let's go!
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
245 if(mpi->flags&MP_IMGFLAG_PLANAR){
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
246 mpi->planes[0]=vid_data;
5317
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
247 if(mpi->flags&MP_IMGFLAG_SWAPPED){
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
248 mpi->planes[1]=vid_data + bespitch*mga_vid_config.src_height;
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
249 mpi->planes[2]=mpi->planes[1] + bespitch2*mga_vid_config.src_height/2;
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
250 } else {
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
251 mpi->planes[2]=vid_data + bespitch*mga_vid_config.src_height;
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
252 mpi->planes[1]=mpi->planes[2] + bespitch2*mga_vid_config.src_height/2;
80fbb03b385a U,V plane odrer fixed
arpi
parents: 5014
diff changeset
253 }
4971
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
254 mpi->width=mpi->stride[0]=bespitch;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
255 mpi->stride[1]=mpi->stride[2]=bespitch2;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
256 } else {
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
257 mpi->planes[0]=vid_data;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
258 mpi->width=bespitch;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
259 mpi->stride[0]=mpi->width*(mpi->bpp/8);
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
260 }
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
261 mpi->flags|=MP_IMGFLAG_DIRECT;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
262 // printf("mga: get_image() SUCCESS -> Direct Rendering ENABLED\n");
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
263 return VO_TRUE;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
264 }
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
265 return VO_FALSE;
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
266 }
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
267
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
268 static uint32_t
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
269 query_format(uint32_t format)
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
270 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
271 switch(format){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
272 case IMGFMT_YV12:
470
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
273 case IMGFMT_I420:
8e101a5d9dc2 I420/IYUV support
arpi_esp
parents: 466
diff changeset
274 case IMGFMT_IYUV:
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
275 case IMGFMT_YUY2:
448
198b46b739d8 qrva eletbe nem kene cvs-t elbaszni inkabb ne nyuljatok hozza baz+
arpi_esp
parents: 413
diff changeset
276 case IMGFMT_UYVY:
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
277 // case IMGFMT_RGB|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
278 // case IMGFMT_BGR|24:
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
279 return 1;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
280 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
281 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
282 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
283
5014
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
284 static void query_vaa(vo_vaa_t *vaa)
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
285 {
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
286 memset(vaa,0,sizeof(vo_vaa_t));
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
287 vaa->get_video_eq = mga_get_video_eq;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
288 vaa->set_video_eq = mga_set_video_eq;
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
289 }
4970
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
290 static uint32_t control(uint32_t request, void *data, ...)
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
291 {
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
292 switch (request) {
5014
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
293 case VOCTRL_QUERY_VAA:
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
294 query_vaa((vo_vaa_t*)data);
4458e43871d3 video_eq support - applied brightness/contrast patch by Brian J. Murrell
arpi
parents: 4981
diff changeset
295 return VO_TRUE;
4970
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
296 case VOCTRL_QUERY_FORMAT:
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
297 return query_format(*((uint32_t*)data));
4971
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
298 case VOCTRL_GET_IMAGE:
fa002f25631e direct rendering support
arpi
parents: 4970
diff changeset
299 return get_image(data);
4981
bfc652fc7f43 rewrite fullscreen support in some libvo driver
pontscho
parents: 4975
diff changeset
300 #ifdef VO_XMGA
bfc652fc7f43 rewrite fullscreen support in some libvo driver
pontscho
parents: 4975
diff changeset
301 case VOCTRL_FULLSCREEN:
bfc652fc7f43 rewrite fullscreen support in some libvo driver
pontscho
parents: 4975
diff changeset
302 vo_x11_fullscreen();
bfc652fc7f43 rewrite fullscreen support in some libvo driver
pontscho
parents: 4975
diff changeset
303 return VO_TRUE;
bfc652fc7f43 rewrite fullscreen support in some libvo driver
pontscho
parents: 4975
diff changeset
304 #endif
4970
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
305 }
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
306 return VO_NOTIMPL;
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
307 }
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
308
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
309
56
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
310 static int mga_init(){
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
311 char *frame_mem;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
312
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
313 mga_vid_config.num_frames=4;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
314 mga_vid_config.version=MGA_VID_VERSION;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
315 if (ioctl(f,MGA_VID_CONFIG,&mga_vid_config))
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
316 {
275
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
317 perror("Error in mga_vid_config ioctl()");
edd442cd99f0 lamer_protection++
arpi_esp
parents: 249
diff changeset
318 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
319 return -1;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
320 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
321 ioctl(f,MGA_VID_ON,0);
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
322
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
323 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
324 frames[1] = frames[0] + 1*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
325 frames[2] = frames[0] + 2*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
326 frames[3] = frames[0] + 3*mga_vid_config.frame_size;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
327 mga_next_frame = 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
328 vid_data = frames[mga_next_frame];
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
329
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
330 //clear the buffer
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
331 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
332
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
333 return 0;
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
334
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
335 }
cdb2e30be421 mga_vid fixes, code cleanup
arpi_esp
parents: 47
diff changeset
336
1637
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
337 static int mga_uninit(){
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
338 ioctl( f,MGA_VID_OFF,0 );
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
339 munmap(frames[0],mga_vid_config.frame_size*mga_vid_config.num_frames);
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
340 close(f);
248972c26eee fixed mga uninit
arpi
parents: 566
diff changeset
341 }
4970
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
342
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
343 static uint32_t preinit(const char *arg)
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
344 {
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
345 return 0;
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
346 }
f21d15f0cba6 control+preinit moved to mga_common.c
arpi
parents: 4949
diff changeset
347