summaryrefslogtreecommitdiff
path: root/i965_drv_video/shaders/post_processing/Common/readSampler16x1.asm
blob: 36c4be68ca98b49f1b83087ccb5e494d44062df1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 * All Video Processing kernels 
 * Copyright © <2010>, Intel Corporation.
 *
 * This program is licensed under the terms and conditions of the
 * Eclipse Public License (EPL), version 1.0.  The full text of the EPL is at
 * http://www.opensource.org/licenses/eclipse-1.0.php.
 *
 */

// Module name: readSampler16x1.asm
//
// Read one row of pix through sampler
//



//#define SAMPLER_MSG_DSC		0x166A0000	// ILK Sampler Message Descriptor



// Send Message [DevILK]                                Message Descriptor
//  MBZ MsgL=5 MsgR=8                            H MBZ   SIMD     MsgType   SmplrIndx BindTab
//  000 0 101 0 1000                             1  0     10     0000         0000    00000000
//    0     A    8                                     A             0             0     0     0

//     MsgL=1+2*2(u,v)=5 MsgR=8
 
#define SAMPLER_MSG_DSC		0x0A8A0000	// ILK Sampler Message Descriptor





                                                                                

	// Assume MSGSRC is set already in the caller
        //mov (8)		rMSGSRC.0<1>:ud			0:ud	// Unused fileds



	// Read 16 sampled pixels and stored them in float32 in 8 GRFs
	// 422 data is expanded to 444, return 8 GRF in the order of RGB- (UYV-).
	// 420 data has three surfaces, return 8 GRF. Valid is always in the 1st GRF when in R8.  Make sure no overwrite the following 3 GRFs.
	// alpha data is expanded to 4444, return 8 GRF in the order of RGBA (UYVA).

    mov(16)     mMSGHDR<1>:uw   rMSGSRC<16;16,1>:uw
    send (16)	DATABUF(0)<1>	mMSGHDR		udDUMMY_NULL	0x2 SAMPLER_MSG_DSC+SAMPLER_IDX+BINDING_IDX:ud