summaryrefslogtreecommitdiff
path: root/i965_drv_video/shaders/post_processing/Common/PL8x4_Save_IMC3.inc
blob: 3b1df1732dfc166dc5505b5937918b746e75a641 (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
56
57
58
59
60
61
62
/*
 * 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: PL8x4_Save_IMC3.inc
//
// Setup for storing planar data
//

#include "undefall.inc"                 //Undefine the SRC and DEST sysmbols

// For saving
#define nDPW_BLOCK_SIZE_Y        nBLOCK_WIDTH_16+nBLOCK_HEIGHT_8    // Y block size 16x8
#define nDPW_MSG_SIZE_Y          nMSGLEN_4                          // # of MRF's to hold Y block data (4)
#define nDPW_BLOCK_SIZE_UV       nBLOCK_WIDTH_8+nBLOCK_HEIGHT_4     // U/V block size 8x4
#define nDPW_MSG_SIZE_UV         nMSGLEN_1                          // # of MRF's to hold U/V block data (1)

// For masking
#undef  nDPR_MSG_SIZE_Y
#define nDPR_MSG_SIZE_Y      nRESLEN_4        // # of MRF's to hold Y block data (4)
#undef  nDPR_MSG_SIZE_UV
#define nDPR_MSG_SIZE_UV     nRESLEN_1        // # of MRF's to hold U/V block data (1)
#define     rMASK_TEMP     REG(r,nTEMP0)
.declare    uwMASK_TEMP    Base=rMASK_TEMP    ElementSize=2    SrcRegion=<8;8,1>    Type=uw        //1 GRF

#if (nSRC_REGION==nREGION_1)
    // For saving
    #define ub2DEST_Y        ub2TOP_Y
    #define ub2DEST_U        ub2TOP_U
    #define ub2DEST_V        ub2TOP_V
    //For masking operation
    #define udSRC_Y          udBOT_Y_IO
    #define udSRC_U          udBOT_U_IO
    #define udSRC_V          udBOT_V_IO
    #define ubSRC_Y          ubBOT_Y
    #define ubSRC_U          ubBOT_U
    #define ubSRC_V          ubBOT_V
    #define uwSRC_U          uwBOT_U
    #define uwSRC_V          uwBOT_V

#elif (nSRC_REGION==nREGION_2)
    // For saving
    #define ub2DEST_Y        ub2BOT_Y
    #define ub2DEST_U        ub2BOT_U
    #define ub2DEST_V        ub2BOT_V
    //For masking operation
    #define udSRC_Y          udTOP_Y_IO
    #define udSRC_U          udTOP_U_IO
    #define udSRC_V          udTOP_V_IO
    #define ubSRC_Y          ubTOP_Y
    #define ubSRC_U          ubTOP_U
    #define ubSRC_V          ubTOP_V
    #define uwSRC_U          uwTOP_U
    #define uwSRC_V          uwTOP_V

#endif