You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
5.5 KiB
120 lines
5.5 KiB
//===== Copyright © 1996-2007, Valve Corporation, All rights reserved. ======//
|
|
//
|
|
// Purpose:
|
|
//
|
|
// $NoKeywords: $
|
|
//
|
|
// This file defines a number of constants and structured which are used to build up a command
|
|
// buffer to pass to ShaderAPI for state setting and other operations. Since the prupose of these
|
|
// command buffers is to minimize and optimize calls into shaderapi, their structure is not
|
|
// abstract - they are built out by the calling process.
|
|
//
|
|
//===========================================================================//
|
|
|
|
#ifndef COMMANDBUFFER_H
|
|
#define COMMANDBUFFER_H
|
|
|
|
#ifdef _WIN32
|
|
#pragma once
|
|
#endif
|
|
|
|
#ifdef _PS3
|
|
#define CBCMD_MAX_PS3TEX 8 // Max PS3 textures set in an ECB
|
|
#endif
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Commands used by the per-pass command buffers
|
|
//-----------------------------------------------------------------------------
|
|
enum CommandBufferCommand_t
|
|
{
|
|
// flow control commands.
|
|
CBCMD_END = 0, // end of stream
|
|
CBCMD_JUMP, // int cmd, void *adr. jump to another
|
|
// stream. Can be used to implement
|
|
// non-sequentially allocated storage
|
|
CBCMD_JSR, // int cmd, void *adr. subroutine call to another stream.
|
|
|
|
#ifdef _PS3
|
|
CBCMD_PS3TEX, // Textures. This command stores pointers to the BIND_TEXTURE commands
|
|
// Will fill in the Bind Texture commands just before issueing the ECB to the SPU
|
|
// This better emulates what happens on DX platforms, and so allows the weaponcache to function
|
|
// whilst still allowing the VRAM defrag feature om PS3
|
|
CBCMD_LENGTH, // Length of command buffer
|
|
#endif
|
|
// constant setting commands
|
|
CBCMD_SET_PIXEL_SHADER_FLOAT_CONST, // int cmd,int first_reg, int nregs, float values[nregs*4]
|
|
|
|
|
|
CBCMD_SET_VERTEX_SHADER_FLOAT_CONST, // int cmd,int first_reg, int nregs, float values[nregs*4]
|
|
CBCMD_SET_VERTEX_SHADER_FLOAT_CONST_REF, // int cmd,int first_reg, int nregs, &float values[nregs*4]
|
|
CBCMD_SETPIXELSHADERFOGPARAMS, // int cmd, int regdest
|
|
CBCMD_STORE_EYE_POS_IN_PSCONST, // int cmd, int regdest
|
|
CBCMD_SET_DEPTH_FEATHERING_CONST, // int cmd, int constant register, float blend scale
|
|
|
|
// texture binding. sampler indices have TEXTURECMD_BINDFLAGS_xxx flags OR'd into them.
|
|
|
|
CBCMD_BIND_STANDARD_TEXTURE, // cmd, sampler, texture id
|
|
CBCMD_BIND_SHADERAPI_TEXTURE_HANDLE, // cmd, sampler, texture handle
|
|
#ifdef _PS3
|
|
CBCMD_BIND_PS3_TEXTURE, // cmd, CPs3BindTexture_t
|
|
CBCMD_BIND_PS3_STANDARD_TEXTURE, // cmd, idx
|
|
#endif
|
|
|
|
// shaders
|
|
CBCMD_SET_PSHINDEX, // cmd, idx
|
|
CBCMD_SET_VSHINDEX, // cmd, idx
|
|
|
|
CBCMD_SET_VERTEX_SHADER_FLASHLIGHT_STATE, // cmd, int first_reg (for worldToTexture matrix)
|
|
CBCMD_SET_PIXEL_SHADER_FLASHLIGHT_STATE, // cmd, int color reg, int atten reg, int origin reg, sampler (for flashlight texture)
|
|
|
|
CBCMD_SET_PIXEL_SHADER_UBERLIGHT_STATE, // cmd
|
|
|
|
CBCMD_SET_VERTEX_SHADER_NEARZFARZ_STATE, // cmd
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Commands used by the per-instance command buffer
|
|
// NOTE: If you add commands, you probably want to change the size of
|
|
// CInstanceStorageBuffer and/or the choice of making it a fixed-size allocation
|
|
// see shaderlib/baseshader.*
|
|
//
|
|
// FIXME!! NOTE that this whole scheme here generates a dependency of the
|
|
// shaders on internal guts of shaderapidx8, since it's responsible for
|
|
// setting various pixel shader + vertex shader constants based on the
|
|
// commands below. We need to remove this dependency as it's way too restrictive
|
|
// and puts the smarts in the wrong place (see CBICMD_SETPIXELSHADERGLINTDAMPING
|
|
// as an example). Not going to solve this for l4d though, as I don't anticipate
|
|
// a large amount of new shader writing for that product.
|
|
//-----------------------------------------------------------------------------
|
|
enum CommandBufferInstanceCommand_t
|
|
{
|
|
CBICMD_END = 0, // end of stream
|
|
CBICMD_JUMP, // int cmd, void *adr. jump to another
|
|
// stream. Can be used to implement
|
|
// non-sequentially allocated storage
|
|
CBICMD_JSR, // int cmd, void *adr. subroutine call to another stream.
|
|
|
|
CBICMD_SETSKINNINGMATRICES, // int cmd
|
|
|
|
CBICMD_SETVERTEXSHADERLOCALLIGHTING, // int cmd
|
|
CBICMD_SETPIXELSHADERLOCALLIGHTING, // int cmd, int regdest
|
|
CBICMD_SETVERTEXSHADERAMBIENTLIGHTCUBE, // int cmd
|
|
CBICMD_SETPIXELSHADERAMBIENTLIGHTCUBE, // int cmd, int regdest
|
|
CBICMD_SETPIXELSHADERAMBIENTLIGHTCUBELUMINANCE, // int cmd, int regdest
|
|
CBICMD_SETPIXELSHADERGLINTDAMPING, // int cmd, int regdest
|
|
|
|
CBICMD_BIND_ENV_CUBEMAP_TEXTURE, // cmd, sampler
|
|
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE,
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE_LINEARCOLORSPACE_LINEARSCALE, // int cmd, int constant register, Vector color2, scale
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE_LINEARCOLORSPACE, // int cmd, int constant register, Vector4d( color2, 1.0 )
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE_LINEARSCALE, // int cmd, int constant register, Vector4d( color2, 1.0 ) float scale
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE_LINEARSCALE_SCALEINW, // int cmd, int constant register, Vector color2, float scale
|
|
CBICMD_SETMODULATIONVERTEXSHADERDYNAMICSTATE, // int cmd, int constant register, Vector color2
|
|
CBICMD_SETMODULATIONPIXELSHADERDYNAMICSTATE_IDENTITY, // int cmd, int constant register
|
|
CBICMD_SETMODULATIONVERTEXSHADERDYNAMICSTATE_LINEARSCALE, // int cmd, int constant register, Vector color2, float scale
|
|
// This must be last
|
|
CBICMD_COUNT,
|
|
};
|
|
|
|
#endif // COMMANDBUFFER_H
|