OSDN Git Service

ca77b4846e911d14efb757b424eed860364024af
[android-x86/hardware-intel-common-libva.git] / i965_drv_video / shaders / render / exa_wm_src_sample_planar.g4a
1 /*
2  * Copyright © 2006 Intel Corporation
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21  * IN THE SOFTWARE.
22  *
23  * Authors:
24  *    Wang Zhenyu <zhenyu.z.wang@intel.com>
25  *    Keith Packard <keithp@keithp.com>
26  */
27
28 /* Sample the src surface in planar format */
29
30 include(`exa_wm.g4i')
31
32 /* prepare sampler read back gX register, which would be written back to output */
33
34 /* use simd16 sampler, param 0 is u, param 1 is v. */
35 /* 'payload' loading, assuming tex coord start from g4 */
36
37 /* load r */
38 mov (1) g0.8<1>UD       0x0000e000UD { align1 mask_disable };
39
40 /* src_msg will be copied with g0, as it contains send desc */
41 /* emit sampler 'send' cmd */
42
43 /* sample Y */
44 send (16) src_msg_ind           /* msg reg index */
45         src_sample_g<1>UW       /* readback */
46         g0<8,8,1>UW             /* copy to msg start reg*/
47         sampler (1,0,F)         /* sampler message description, (binding_table,sampler_index,datatype)
48                                 /* here(src->dst) we should use src_sampler and src_surface */
49         mlen 5 rlen 2 { align1 };   /* required message len 5, readback len 8 */
50         
51 /* sample U (Cr) */
52 send (16) src_msg_ind           /* msg reg index */
53         src_sample_r<1>UW       /* readback */
54         g0<8,8,1>UW             /* copy to msg start reg*/
55         sampler (3,2,F)         /* sampler message description, (binding_table,sampler_index,datatype)
56                                 /* here(src->dst) we should use src_sampler and src_surface */
57         mlen 5 rlen 2 { align1 };   /* required message len 5, readback len 8 */
58         
59 /* sample V (Cb) */
60 send (16) src_msg_ind           /* msg reg index */
61         src_sample_b<1>UW       /* readback */
62         g0<8,8,1>UW             /* copy to msg start reg*/
63         sampler (5,4,F)         /* sampler message description, (binding_table,sampler_index,datatype)
64                                 /* here(src->dst) we should use src_sampler and src_surface */
65         mlen 5 rlen 2 { align1 };   /* required message len 5, readback len 8 */