1 /*---------------------------------------------------------------------------*
2   Project:  Horizon
3   File:     gx_MacroCommon.h
4 
5   Copyright (C)2009-2012 Nintendo Co., Ltd.  All rights reserved.
6 
7   These coded instructions, statements, and computer programs contain
8   proprietary information of Nintendo of America Inc. and/or Nintendo
9   Company Ltd., and are protected by Federal copyright law.  They may
10   not be disclosed to third parties or copied or duplicated in any form,
11   in whole or in part, without the prior written consent of Nintendo.
12 
13   $Rev: 46347 $
14  *---------------------------------------------------------------------------*/
15 
16 #ifndef NN_GX_CTR_GX_MACRO_COMMON_H_
17 #define NN_GX_CTR_GX_MACRO_COMMON_H_
18 
19 #include <GLES2/gl2.h>
20 #include <nn/gx/CTR/gx_MacroReg.h>
21 
22 #define CMD_PADDING_NAME2( x, name ) u32 padding_##name : x
23 #define CMD_PADDING_NAME1( x, name ) CMD_PADDING_NAME2( x, name )
24 #define CMD_PADDING( x )  CMD_PADDING_NAME1( x, __LINE__ )
25 //----------------------------------------------------------
26 
27 /*
28 struct CommandHeader
29 {
30     u32 addr    : 16;
31     u32 be      : 4;
32     u32 size    : 8;
33     CMD_PADDING(3);
34     u32 seq     : 1;
35 };
36 */
37 
38 /* Please see man pages for details
39 
40 
41 
42 
43 */
44 
45 #define PICA_CMD_HEADER( addr, size, be, seq )  ((addr) | (be) << 16 | (size) << 20 | ((seq) ? 0x80000000 : 0))
46 
47 #define PICA_CMD_HEADER_BURST( addr, size )            PICA_CMD_HEADER(addr, size - 1, 0xf, 0)
48 #define PICA_CMD_HEADER_BURST_BE( addr, size, be )     PICA_CMD_HEADER(addr, size - 1,  be, 0)
49 #define PICA_CMD_HEADER_BURSTSEQ( addr, size )         PICA_CMD_HEADER(addr, size - 1, 0xf, 1)
50 #define PICA_CMD_HEADER_BURSTSEQ_BE( addr, size, be )  PICA_CMD_HEADER(addr, size - 1,  be, 1)
51 
52 #define PICA_CMD_HEADER_SINGLE( addr )                 PICA_CMD_HEADER(addr, 0, 0xf, 0)
53 #define PICA_CMD_HEADER_SINGLE_BE( addr, be )          PICA_CMD_HEADER(addr, 0,  be, 0)
54 
55 // Command for writing to a floating point register.
56 // PICA_REG_VS_FLOAT0 0x2c1
57 #define PICA_CMD_HEADER_VS_F32( size )           PICA_CMD_HEADER(PICA_REG_VS_FLOAT0, (size) * 4 -1, 0xf, 0)
58 
59 // PICA_REG_GS_FLOAT0 0x291
60 #define PICA_CMD_HEADER_GS_F32( size )           PICA_CMD_HEADER(PICA_REG_GS_FLOAT0, (size) * 4 -1, 0xf, 0)
61 
62 //
63 #define PICA_CMD_DATA_ZERO() 0x00000000
64 
65 typedef struct _color8
66 {
67     GLubyte r;
68     GLubyte g;
69     GLubyte b;
70     GLubyte a;
71 } color8;
72 
73 #define PICA_CMD_DATA_COLOR_RGB8( r, g, b ) \
74     ( r | g << 8 | b << 16 )
75 
76 #define PICA_CMD_DATA_COLOR_RGBA8( r, g, b, a ) \
77     ( r | g << 8 | b << 16 | a << 24 )
78 
79 /*
80 
81 */
82 
83 #endif // NN_GX_CTR_GX_MACRO_COMMON_H_
84