diff options
author | gman@chromium.org <gman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-02-25 03:20:50 +0000 |
---|---|---|
committer | gman@chromium.org <gman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-02-25 03:20:50 +0000 |
commit | 3916c97e1bb1ef3fecfdcaf9d80f239016756c06 (patch) | |
tree | 5c756aa2feec17d4a5609bcf2a16a06a12b828e8 /gpu/command_buffer | |
parent | 84aebedeaa91c3fadf523260c12afa136420c7d3 (diff) | |
download | chromium_src-3916c97e1bb1ef3fecfdcaf9d80f239016756c06.zip chromium_src-3916c97e1bb1ef3fecfdcaf9d80f239016756c06.tar.gz chromium_src-3916c97e1bb1ef3fecfdcaf9d80f239016756c06.tar.bz2 |
Reorangizing the GLES2 code to handle shared
resources and non-renderable texture situations.
I haven't written enough unit tests for this
but the CL is already too big.
TEST=none
BUG=none
Review URL: http://codereview.chromium.org/646070
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@39984 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'gpu/command_buffer')
32 files changed, 4653 insertions, 3689 deletions
diff --git a/gpu/command_buffer/build_gles2_cmd_buffer.py b/gpu/command_buffer/build_gles2_cmd_buffer.py index a1010ec..5cf8375 100755 --- a/gpu/command_buffer/build_gles2_cmd_buffer.py +++ b/gpu/command_buffer/build_gles2_cmd_buffer.py @@ -822,7 +822,7 @@ _ENUM_LISTS = { # # cmd_comment: A comment added to the cmd format. # type: defines which handler will be used to generate code. -# DecoderFunc: defines which function to call in the decoder to execute the +# decoder_func: defines which function to call in the decoder to execute the # corresponding GL command. If not specified the GL command will # be called directly. # gl_test_func: GL function that is expected to be called when testing. @@ -841,16 +841,17 @@ _ENUM_LISTS = { # unit_test: If False no unit test will be generated. _FUNCTION_INFO = { + 'ActiveTexture': {'decoder_func': 'DoActiveTexture'}, 'BindAttribLocation': {'type': 'GLchar'}, - 'BindBuffer': {'DecoderFunc': 'DoBindBuffer'}, - 'BindFramebuffer': {'DecoderFunc': 'glBindFramebufferEXT'}, - 'BindRenderbuffer': {'DecoderFunc': 'glBindRenderbufferEXT'}, - 'BindTexture': {'DecoderFunc': 'DoBindTexture'}, + 'BindBuffer': {'decoder_func': 'DoBindBuffer'}, + 'BindFramebuffer': {'decoder_func': 'glBindFramebufferEXT'}, + 'BindRenderbuffer': {'decoder_func': 'glBindRenderbufferEXT'}, + 'BindTexture': {'decoder_func': 'DoBindTexture'}, 'BufferData': {'type': 'Manual', 'immediate': True}, 'BufferSubData': {'type': 'Data'}, - 'CheckFramebufferStatus': {'DecoderFunc': 'glCheckFramebufferStatusEXT'}, - 'ClearDepthf': {'DecoderFunc': 'glClearDepth'}, - 'CompileShader': {'DecoderFunc': 'DoCompileShader', 'unit_test': False}, + 'CheckFramebufferStatus': {'decoder_func': 'glCheckFramebufferStatusEXT'}, + 'ClearDepthf': {'decoder_func': 'glClearDepth'}, + 'CompileShader': {'decoder_func': 'DoCompileShader', 'unit_test': False}, 'CompressedTexImage2D': {'type': 'Manual','immediate': True}, 'CompressedTexSubImage2D': {'type': 'Data'}, 'CreateProgram': {'type': 'Create'}, @@ -860,27 +861,27 @@ _FUNCTION_INFO = { 'type': 'DELn', 'gl_test_func': 'glDeleteFramebuffersEXT', }, - 'DeleteProgram': {'type': 'Custom', 'DecoderFunc': 'DoDeleteProgram'}, + 'DeleteProgram': {'type': 'Custom', 'decoder_func': 'DoDeleteProgram'}, 'DeleteRenderbuffers': { 'type': 'DELn', 'gl_test_func': 'glDeleteRenderbuffersEXT', }, - 'DeleteShader': {'type': 'Custom', 'DecoderFunc': 'DoDeleteShader'}, + 'DeleteShader': {'type': 'Custom', 'decoder_func': 'DoDeleteShader'}, 'DeleteTextures': {'type': 'DELn'}, - 'DepthRangef': {'DecoderFunc': 'glDepthRange'}, - 'DisableVertexAttribArray': {'DecoderFunc': 'DoDisableVertexAttribArray'}, - 'DrawArrays': { 'DecoderFunc': 'DoDrawArrays', 'unit_test': False}, + 'DepthRangef': {'decoder_func': 'glDepthRange'}, + 'DisableVertexAttribArray': {'decoder_func': 'DoDisableVertexAttribArray'}, + 'DrawArrays': { 'decoder_func': 'DoDrawArrays', 'unit_test': False}, 'DrawElements': { 'type': 'Manual', 'cmd_args': 'GLenum mode, GLsizei count, GLenum type, GLuint index_offset', }, - 'EnableVertexAttribArray': {'DecoderFunc': 'DoEnableVertexAttribArray'}, + 'EnableVertexAttribArray': {'decoder_func': 'DoEnableVertexAttribArray'}, 'Finish': {'impl_func': False}, 'Flush': {'impl_func': False}, - 'FramebufferRenderbuffer': {'DecoderFunc': 'glFramebufferRenderbufferEXT'}, - 'FramebufferTexture2D': {'DecoderFunc': 'glFramebufferTexture2DEXT'}, + 'FramebufferRenderbuffer': {'decoder_func': 'glFramebufferRenderbufferEXT'}, + 'FramebufferTexture2D': {'decoder_func': 'glFramebufferTexture2DEXT'}, 'GenerateMipmap': { - 'DecoderFunc': 'DoGenerateMipmap', + 'decoder_func': 'DoGenerateMipmap', 'gl_test_func': 'glGenerateMipmapEXT', }, 'GenBuffers': {'type': 'GENn', 'gl_test_func': 'glGenBuffersARB'}, @@ -926,18 +927,18 @@ _FUNCTION_INFO = { }, 'GetBooleanv': {'type': 'GETn'}, 'GetBufferParameteriv': {'type': 'GETn'}, - 'GetError': {'type': 'Is', 'DecoderFunc': 'GetGLError'}, + 'GetError': {'type': 'Is', 'decoder_func': 'GetGLError'}, 'GetFloatv': {'type': 'GETn'}, 'GetFramebufferAttachmentParameteriv': { 'type': 'GETn', - 'DecoderFunc': 'glGetFramebufferAttachmentParameterivEXT', + 'decoder_func': 'glGetFramebufferAttachmentParameterivEXT', }, 'GetIntegerv': {'type': 'GETn'}, 'GetProgramiv': {'type': 'GETn'}, 'GetProgramInfoLog': {'type': 'STRn'}, 'GetRenderbufferParameteriv': { 'type': 'GETn', - 'DecoderFunc': 'glGetRenderbufferParameterivEXT', + 'decoder_func': 'glGetRenderbufferParameterivEXT', }, 'GetShaderiv': {'type': 'GETn'}, 'GetShaderInfoLog': {'type': 'STRn'}, @@ -954,7 +955,7 @@ _FUNCTION_INFO = { 'int32 precision', ], }, - 'GetShaderSource': {'type': 'STRn', 'DecoderFunc': 'DoGetShaderSource'}, + 'GetShaderSource': {'type': 'STRn', 'decoder_func': 'DoGetShaderSource'}, 'GetTexParameterfv': {'type': 'GETn'}, 'GetTexParameteriv': {'type': 'GETn'}, 'GetUniformfv': { @@ -983,14 +984,14 @@ _FUNCTION_INFO = { }, 'IsBuffer': {'type': 'Is'}, 'IsEnabled': {'type': 'Is'}, - 'IsFramebuffer': {'type': 'Is', 'DecoderFunc': 'glIsFramebufferEXT'}, + 'IsFramebuffer': {'type': 'Is', 'decoder_func': 'glIsFramebufferEXT'}, 'IsProgram': {'type': 'Is'}, - 'IsRenderbuffer': {'type': 'Is', 'DecoderFunc': 'glIsRenderbufferEXT'}, + 'IsRenderbuffer': {'type': 'Is', 'decoder_func': 'glIsRenderbufferEXT'}, 'IsShader': {'type': 'Is'}, 'IsTexture': {'type': 'Is'}, - 'LinkProgram': {'DecoderFunc': 'DoLinkProgram'}, + 'LinkProgram': {'decoder_func': 'DoLinkProgram'}, 'PixelStorei': {'type': 'Manual'}, - 'RenderbufferStorage': {'DecoderFunc': 'glRenderbufferStorageEXT'}, + 'RenderbufferStorage': {'decoder_func': 'glRenderbufferStorageEXT'}, 'ReadPixels': { 'cmd_comment': '// ReadPixels has the result separated from the pixel buffer so that\n' @@ -1015,11 +1016,30 @@ _FUNCTION_INFO = { 'GLuint shader, const char* data', }, 'TexImage2D': {'type': 'Manual', 'immediate': True}, - 'TexParameterfv': {'type': 'PUT', 'data_type': 'GLfloat', 'count': 1}, - 'TexParameteriv': {'type': 'PUT', 'data_type': 'GLint', 'count': 1}, + 'TexParameterf': {'decoder_func': 'DoTexParameterf'}, + 'TexParameteri': {'decoder_func': 'DoTexParameteri'}, + 'TexParameterfv': { + 'type': 'PUT', + 'data_type': 'GLfloat', + 'count': 1, + 'decoder_func': 'DoTexParameterfv', + }, + 'TexParameteriv': { + 'type': 'PUT', + 'data_type': 'GLint', + 'count': 1, + 'decoder_func': 'DoTexParameteriv', + }, 'TexSubImage2D': {'type': 'Data'}, 'Uniform1fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 1}, - 'Uniform1iv': {'type': 'PUTn', 'data_type': 'GLint', 'count': 1}, + 'Uniform1i': {'decoder_func': 'DoUniform1i', 'unit_test': False}, + 'Uniform1iv': { + 'type': 'PUTn', + 'data_type': 'GLint', + 'count': 1, + 'decoder_func': 'DoUniform1iv', + 'unit_test': False, + }, 'Uniform2fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 2}, 'Uniform2iv': {'type': 'PUTn', 'data_type': 'GLint', 'count': 2}, 'Uniform3fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 3}, @@ -1029,7 +1049,7 @@ _FUNCTION_INFO = { 'UniformMatrix2fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 4}, 'UniformMatrix3fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 9}, 'UniformMatrix4fv': {'type': 'PUTn', 'data_type': 'GLfloat', 'count': 16}, - 'UseProgram': {'DecoderFunc': 'DoUseProgram', 'unit_test': False}, + 'UseProgram': {'decoder_func': 'DoUseProgram', 'unit_test': False}, 'VertexAttrib1fv': {'type': 'PUT', 'data_type': 'GLfloat', 'count': 1}, 'VertexAttrib2fv': {'type': 'PUT', 'data_type': 'GLfloat', 'count': 2}, 'VertexAttrib3fv': {'type': 'PUT', 'data_type': 'GLfloat', 'count': 3}, @@ -1041,7 +1061,7 @@ _FUNCTION_INFO = { }, 'SwapBuffers': { 'impl_func': False, - 'DecoderFunc': 'DoSwapBuffers', + 'decoder_func': 'DoSwapBuffers', 'unit_test': False, }, } @@ -1053,6 +1073,11 @@ class CWriter(object): def __init__(self, filename): self.filename = filename self.file = open(filename, "wb") + self.file_num = 0 + + def SetFileNum(self, num): + """Used to help write number files and tests.""" + self.file_num = num def Write(self, string): """Writes a string to a file spliting if it's > 80 characters.""" @@ -1351,6 +1376,7 @@ COMPILE_ASSERT(offsetof(%(cmd_name)s::Result, %(field_name)s) == %(offset)d, count += 1 gl_func_name = func.GetGLTestFunctionName() vars = { + 'test_name': 'GLES2DecoderTest%d' % file.file_num, 'name':name, 'gl_func_name': gl_func_name, 'args': ", ".join(arg_strings), @@ -1382,14 +1408,15 @@ COMPILE_ASSERT(offsetof(%(cmd_name)s::Result, %(field_name)s) == %(offset)d, count += 1 gl_func_name = func.GetGLTestFunctionName() vars = { - 'name': func.name, - 'arg_index': arg_index, - 'value_index': value_index, - 'gl_func_name': gl_func_name, - 'args': ", ".join(arg_strings), - 'all_but_last_args': ", ".join(arg_strings[:-1]), - 'gl_args': ", ".join(gl_arg_strings), - 'parse_result': parse_result, + 'test_name': 'GLES2DecoderTest%d' % file.file_num , + 'name': func.name, + 'arg_index': arg_index, + 'value_index': value_index, + 'gl_func_name': gl_func_name, + 'args': ", ".join(arg_strings), + 'all_but_last_args': ", ".join(arg_strings[:-1]), + 'gl_args': ", ".join(gl_arg_strings), + 'parse_result': parse_result, } vars.update(extra) file.Write(test % vars) @@ -1397,11 +1424,8 @@ COMPILE_ASSERT(offsetof(%(cmd_name)s::Result, %(field_name)s) == %(offset)d, def WriteServiceUnitTest(self, func, file): """Writes the service unit test for a command.""" - if func.GetInfo('unit_test') == False: - file.Write("// TODO(gman): %s\n" % func.name) - return valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)); SpecializedSetup<%(name)s, 0>(); %(name)s cmd; @@ -1412,7 +1436,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { self.WriteValidUnitTest(func, file, valid_test) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { +TEST_F(%(test_name)s, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)).Times(0); SpecializedSetup<%(name)s, 0>(); %(name)s cmd; @@ -1781,7 +1805,7 @@ class GENnHandler(TypeHandler): def WriteServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(1, _)) .WillOnce(SetArgumentPointee<1>(kNewServiceId)); GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; @@ -1794,7 +1818,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { """ self.WriteValidUnitTest(func, file, valid_test) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { +TEST_F(%(test_name)s, %(name)sInvalidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(_, _)).Times(0); GetSharedMemoryAs<GLuint*>()[0] = client_%(resource_name)s_id_; SpecializedSetup<%(name)s, 0>(); @@ -1810,7 +1834,7 @@ TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { def WriteImmediateServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(1, _)) .WillOnce(SetArgumentPointee<1>(kNewServiceId)); %(name)s& cmd = *GetImmediateAs<%(name)s>(); @@ -1824,7 +1848,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { """ self.WriteValidUnitTest(func, file, valid_test) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { +TEST_F(%(test_name)s, %(name)sInvalidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(_, _)).Times(0); %(name)s& cmd = *GetImmediateAs<%(name)s>(); SpecializedSetup<%(name)s, 0>(); @@ -1947,7 +1971,7 @@ class CreateHandler(TypeHandler): def WriteServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)) .WillOnce(Return(kNewServiceId)); SpecializedSetup<%(name)s, 0>(); @@ -1964,7 +1988,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { 'comma': comma, }) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { +TEST_F(%(test_name)s, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)).Times(0); SpecializedSetup<%(name)s, 0>(); %(name)s cmd; @@ -2009,7 +2033,7 @@ class DELnHandler(TypeHandler): def WriteServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL( *gl_, %(gl_func_name)s(1, Pointee(kService%(upper_resource_name)sId))) @@ -2028,7 +2052,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { func.GetOriginalArgs()[1].name[0:-1].capitalize(), }) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { +TEST_F(%(test_name)s, %(name)sInvalidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(1, Pointee(0))) .Times(1); GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; @@ -2043,7 +2067,7 @@ TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { def WriteImmediateServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL( *gl_, %(gl_func_name)s(1, Pointee(kService%(upper_resource_name)sId))) @@ -2062,7 +2086,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { func.GetOriginalArgs()[1].name[0:-1].capitalize(), }) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs) { +TEST_F(%(test_name)s, %(name)sInvalidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(1, Pointee(0))) .Times(1); %(name)s& cmd = *GetImmediateAs<%(name)s>(); @@ -2255,7 +2279,7 @@ class PUTHandler(TypeHandler): def WriteImmediateServiceUnitTest(self, func, file): """Writes the service unit test for a command.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { %(name)s& cmd = *GetImmediateAs<%(name)s>(); EXPECT_CALL( *gl_, @@ -2284,7 +2308,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { self.WriteValidUnitTest(func, file, valid_test, extra) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { +TEST_F(%(test_name)s, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { %(name)s& cmd = *GetImmediateAs<%(name)s>(); EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_any_args)s, _)).Times(0); SpecializedSetup<%(name)s, 0>(); @@ -2426,7 +2450,7 @@ class PUTnHandler(TypeHandler): def WriteImmediateServiceUnitTest(self, func, file): """Writes the service unit test for a command.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { %(name)s& cmd = *GetImmediateAs<%(name)s>(); EXPECT_CALL( *gl_, @@ -2455,7 +2479,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { self.WriteValidUnitTest(func, file, valid_test, extra) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { +TEST_F(%(test_name)s, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { %(name)s& cmd = *GetImmediateAs<%(name)s>(); EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_any_args)s, _)).Times(0); SpecializedSetup<%(name)s, 0>(); @@ -2962,7 +2986,7 @@ class IsHandler(TypeHandler): def WriteServiceUnitTest(self, func, file): """Overrriden from TypeHandler.""" valid_test = """ -TEST_F(GLES2DecoderTest, %(name)sValidArgs) { +TEST_F(%(test_name)s, %(name)sValidArgs) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)); SpecializedSetup<%(name)s, 0>(); %(name)s cmd; @@ -2978,7 +3002,7 @@ TEST_F(GLES2DecoderTest, %(name)sValidArgs) { }) invalid_test = """ -TEST_F(GLES2DecoderTest, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { +TEST_F(%(test_name)s, %(name)sInvalidArgs%(arg_index)d_%(value_index)d) { EXPECT_CALL(*gl_, %(gl_func_name)s(%(gl_args)s)).Times(0); SpecializedSetup<%(name)s, 0>(); %(name)s cmd; @@ -3361,7 +3385,7 @@ class ResourceIdArgument(Argument): def WriteGetCode(self, file): """Overridden from Argument.""" file.Write(" %s %s;\n" % (self.type, self.name)) - file.Write(" if (!id_manager_->GetServiceId(c.%s, &%s)) {\n" % + file.Write(" if (!id_manager()->GetServiceId(c.%s, &%s)) {\n" % (self.name, self.name)) file.Write(" SetGLError(GL_INVALID_VALUE);\n") file.Write(" return error::kNoError;\n") @@ -3376,10 +3400,10 @@ class ResourceIdArgument(Argument): class Function(object): """A class that represents a function.""" - def __init__(self, name, info, return_type, original_args, args_for_cmds, - cmd_args, init_args, num_pointer_args): + def __init__(self, original_name, name, info, return_type, original_args, + args_for_cmds, cmd_args, init_args, num_pointer_args): self.name = name - self.original_name = name + self.original_name = original_name self.info = info self.type_handler = info.type_handler self.return_type = return_type @@ -3403,8 +3427,8 @@ class Function(object): def GetGLFunctionName(self): """Gets the function to call to execute GL for this command.""" - if self.GetInfo('DecoderFunc'): - return self.GetInfo('DecoderFunc') + if self.GetInfo('decoder_func'): + return self.GetInfo('decoder_func') return "gl%s" % self.original_name def GetGLTestFunctionName(self): @@ -3414,7 +3438,7 @@ class Function(object): if gl_func_name.startswith("gl"): gl_func_name = gl_func_name[2:] else: - gl_func_name = self.name + gl_func_name = self.original_name return gl_func_name def AddCmdArg(self, arg): @@ -3587,6 +3611,7 @@ class ImmediateFunction(Function): Function.__init__( self, + func.original_name, "%sImmediate" % func.name, func.info, func.return_type, @@ -3595,7 +3620,6 @@ class ImmediateFunction(Function): cmd_args, new_init_args, 0) - self.original_name = func.name def WriteServiceImplementation(self, file): """Overridden from Function""" @@ -3795,8 +3819,8 @@ class GLGenerator(object): return_arg = CreateArg(return_type + " result") if return_arg: init_args.append(return_arg) - f = Function(func_name, func_info, return_type, args, args_for_cmds, - cmd_args, init_args, num_pointer_args) + f = Function(func_name, func_name, func_info, return_type, args, + args_for_cmds, cmd_args, init_args, num_pointer_args) self.original_functions.append(f) self.AddFunction(f) f.type_handler.AddImmediateFunction(self, f) @@ -3898,14 +3922,27 @@ class GLGenerator(object): def WriteServiceUnitTests(self, filename): """Writes the service decorder unit tests.""" - file = CHeaderWriter( - filename, - "// It is included by gles2_cmd_decoder_unittest.cc\n") - - for func in self.functions: - func.WriteServiceUnitTest(file) - - file.Close() + num_tests = len(self.functions) + step = (num_tests + 1) / 2 + count = 0 + for test_num in range(0, num_tests, step): + count += 1 + name = filename % count + file = CHeaderWriter( + name, + "// It is included by gles2_cmd_decoder_unittest_%d.cc\n" % count) + file.SetFileNum(count) + end = test_num + step + if end > num_tests: + end = num_tests + for idx in range(test_num, end): + func = self.functions[idx] + if func.GetInfo('unit_test') == False: + file.Write("// TODO(gman): %s\n" % func.name) + else: + func.WriteServiceUnitTest(file) + + file.Close() def WriteGLES2CLibImplementation(self, filename): @@ -3989,7 +4026,7 @@ def main(argv): gen.WriteGLES2CLibImplementation("client/gles2_c_lib_autogen.h") gen.WriteCmdHelperHeader("client/gles2_cmd_helper_autogen.h") gen.WriteServiceImplementation("service/gles2_cmd_decoder_autogen.h") - gen.WriteServiceUnitTests("service/gles2_cmd_decoder_unittest_autogen.h") + gen.WriteServiceUnitTests("service/gles2_cmd_decoder_unittest_%d_autogen.h") gen.WriteServiceUtilsHeader("service/gles2_cmd_validation_autogen.h") gen.WriteServiceUtilsImplementation( "service/gles2_cmd_validation_implementation_autogen.h") diff --git a/gpu/command_buffer/common/gles2_cmd_utils.cc b/gpu/command_buffer/common/gles2_cmd_utils.cc index aac4b84..9e376270 100644 --- a/gpu/command_buffer/common/gles2_cmd_utils.cc +++ b/gpu/command_buffer/common/gles2_cmd_utils.cc @@ -343,7 +343,7 @@ uint32 GLES2Util::ComputeImageDataSize( return height * row_size; } -uint32 GLES2Util::GetGLDataTypeSize(int type) { +uint32 GLES2Util::GetGLDataTypeSizeForUniforms(int type) { switch (type) { case GL_FLOAT: return sizeof(GLfloat); // NOLINT @@ -384,6 +384,24 @@ uint32 GLES2Util::GetGLDataTypeSize(int type) { } } +size_t GLES2Util::GetGLTypeSizeForTexturesAndBuffers(uint32 type) { + switch (type) { + case GL_BYTE: + return sizeof(GLbyte); // NOLINT + case GL_UNSIGNED_BYTE: + return sizeof(GLubyte); // NOLINT + case GL_SHORT: + return sizeof(GLshort); // NOLINT + case GL_UNSIGNED_SHORT: + return sizeof(GLushort); // NOLINT + case GL_FLOAT: + return sizeof(GLfloat); // NOLINT + default: + return 0; + } +} + + } // namespace gles2 } // namespace gpu diff --git a/gpu/command_buffer/common/gles2_cmd_utils.h b/gpu/command_buffer/common/gles2_cmd_utils.h index 1d2139d..b2da669 100644 --- a/gpu/command_buffer/common/gles2_cmd_utils.h +++ b/gpu/command_buffer/common/gles2_cmd_utils.h @@ -30,7 +30,9 @@ class GLES2Util { static uint32 ComputeImageDataSize( int width, int height, int format, int type, int unpack_alignment); - static uint32 GetGLDataTypeSize(int type); + static uint32 GetGLDataTypeSizeForUniforms(int type); + + static size_t GetGLTypeSizeForTexturesAndBuffers(uint32 type); private: int num_compressed_texture_formats_; diff --git a/gpu/command_buffer/service/buffer_manager.cc b/gpu/command_buffer/service/buffer_manager.cc index 3509b86..2dfbc15 100644 --- a/gpu/command_buffer/service/buffer_manager.cc +++ b/gpu/command_buffer/service/buffer_manager.cc @@ -4,24 +4,31 @@ #include "gpu/command_buffer/service/buffer_manager.h" #include "base/logging.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" namespace gpu { namespace gles2 { -void BufferManager::CreateBufferInfo(GLuint buffer) { +void BufferManager::CreateBufferInfo(GLuint buffer_id) { std::pair<BufferInfoMap::iterator, bool> result = - buffer_infos_.insert(std::make_pair(buffer, BufferInfo())); + buffer_infos_.insert( + std::make_pair(buffer_id, + BufferInfo::Ref(new BufferInfo(buffer_id)))); DCHECK(result.second); } BufferManager::BufferInfo* BufferManager::GetBufferInfo( - GLuint buffer) { - BufferInfoMap::iterator it = buffer_infos_.find(buffer); - return it != buffer_infos_.end() ? &it->second : NULL; + GLuint buffer_id) { + BufferInfoMap::iterator it = buffer_infos_.find(buffer_id); + return it != buffer_infos_.end() ? it->second : NULL; } void BufferManager::RemoveBufferInfo(GLuint buffer_id) { - buffer_infos_.erase(buffer_id); + BufferInfoMap::iterator it = buffer_infos_.find(buffer_id); + if (it != buffer_infos_.end()) { + it->second->MarkAsDeleted(); + buffer_infos_.erase(buffer_id); + } } GLuint BufferManager::BufferInfo::GetMaxValueForRange( diff --git a/gpu/command_buffer/service/buffer_manager.h b/gpu/command_buffer/service/buffer_manager.h index b4dcda1..e278a85 100644 --- a/gpu/command_buffer/service/buffer_manager.h +++ b/gpu/command_buffer/service/buffer_manager.h @@ -7,6 +7,7 @@ #include <map> #include "base/basictypes.h" +#include "base/ref_counted.h" #include "gpu/command_buffer/service/gl_utils.h" namespace gpu { @@ -20,10 +21,17 @@ namespace gles2 { class BufferManager { public: // Info about Buffers currently in the system. - class BufferInfo { + class BufferInfo : public base::RefCounted<BufferInfo> { public: - BufferInfo() - : size_(0) { + typedef scoped_refptr<BufferInfo> Ref; + + explicit BufferInfo(GLuint buffer_id) + : buffer_id_(buffer_id), + size_(0) { + } + + GLuint buffer_id() const { + return buffer_id_; } GLsizeiptr size() const { @@ -38,17 +46,31 @@ class BufferManager { // interpreted as the given type. GLuint GetMaxValueForRange(GLuint offset, GLsizei count, GLenum type); + bool IsDeleted() { + return buffer_id_ == 0; + } + private: + friend class BufferManager; + friend class base::RefCounted<BufferInfo>; + + ~BufferInfo() { } + + void MarkAsDeleted() { + buffer_id_ = 0; + } + + GLuint buffer_id_; GLsizeiptr size_; }; - BufferManager() { }; + BufferManager() { } // Creates a BufferInfo for the given buffer. - void CreateBufferInfo(GLuint buffer); + void CreateBufferInfo(GLuint buffer_id); // Gets the buffer info for the given buffer. - BufferInfo* GetBufferInfo(GLuint buffer); + BufferInfo* GetBufferInfo(GLuint buffer_id); // Removes a buffer info for the given buffer. void RemoveBufferInfo(GLuint buffer_id); @@ -56,7 +78,7 @@ class BufferManager { private: // Info for each buffer in the system. // TODO(gman): Choose a faster container. - typedef std::map<GLuint, BufferInfo> BufferInfoMap; + typedef std::map<GLuint, BufferInfo::Ref> BufferInfoMap; BufferInfoMap buffer_infos_; DISALLOW_COPY_AND_ASSIGN(BufferManager); diff --git a/gpu/command_buffer/service/context_group.cc b/gpu/command_buffer/service/context_group.cc new file mode 100644 index 0000000..5bc0ae41 --- /dev/null +++ b/gpu/command_buffer/service/context_group.cc @@ -0,0 +1,59 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/buffer_manager.h" +#include "gpu/command_buffer/service/id_manager.h" +#include "gpu/command_buffer/service/program_manager.h" +#include "gpu/command_buffer/service/shader_manager.h" +#include "gpu/command_buffer/service/texture_manager.h" + +namespace gpu { +namespace gles2 { + +ContextGroup::ContextGroup() + : initialized_(false), + max_vertex_attribs_(0u), + max_texture_units_(0u) { +} + +ContextGroup::~ContextGroup() { +} + +bool ContextGroup::Initialize() { + if (initialized_) { + return true; + } + + id_manager_.reset(new IdManager()); + buffer_manager_.reset(new BufferManager()); + shader_manager_.reset(new ShaderManager()); + program_manager_.reset(new ProgramManager()); + + // Lookup GL things we need to know. + GLint value; + glGetIntegerv(GL_MAX_VERTEX_ATTRIBS, &value); + max_vertex_attribs_ = value; + const GLuint kGLES2RequiredMiniumumVertexAttribs = 8u; + DCHECK_GE(max_vertex_attribs_, kGLES2RequiredMiniumumVertexAttribs); + + glGetIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS, &value); + max_texture_units_ = value; + const GLuint kGLES2RequiredMiniumumTextureUnits = 8u; + DCHECK_GE(max_texture_units_, kGLES2RequiredMiniumumTextureUnits); + + GLint max_texture_size; + GLint max_cube_map_texture_size; + glGetIntegerv(GL_MAX_TEXTURE_SIZE, &max_texture_size); + glGetIntegerv(GL_MAX_CUBE_MAP_TEXTURE_SIZE, &max_cube_map_texture_size); + texture_manager_.reset(new TextureManager(max_texture_size, + max_cube_map_texture_size)); + initialized_ = true; + return true; +} + +} // namespace gles2 +} // namespace gpu + + diff --git a/gpu/command_buffer/service/context_group.h b/gpu/command_buffer/service/context_group.h new file mode 100644 index 0000000..362be16 --- /dev/null +++ b/gpu/command_buffer/service/context_group.h @@ -0,0 +1,88 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef GPU_COMMAND_BUFFER_SERVICE_CONTEXT_GROUP_H_ +#define GPU_COMMAND_BUFFER_SERVICE_CONTEXT_GROUP_H_ + +#include <vector> +#include "base/basictypes.h" +#include "base/scoped_ptr.h" + +namespace gpu { +namespace gles2 { + +class GLES2Decoder; +class BufferManager; +class IdManager; +class ProgramManager; +class ShaderManager; +class TextureManager; + +// A Context Group helps manage multiple GLES2Decoders that share +// resources. +class ContextGroup { + public: + ContextGroup(); + ~ContextGroup(); + + // This should only be called by GLES2Decoder. + bool Initialize(); + + uint32 max_vertex_attribs() const { + return max_vertex_attribs_; + } + + uint32 max_texture_units() const { + return max_texture_units_; + } + + // Map of client ids to GL ids. + IdManager* id_manager() const { + return id_manager_.get(); + } + + BufferManager* buffer_manager() const { + return buffer_manager_.get(); + } + + TextureManager* texture_manager() const { + return texture_manager_.get(); + } + + ProgramManager* program_manager() const { + return program_manager_.get(); + } + + ShaderManager* shader_manager() const { + return shader_manager_.get(); + } + + private: + // Whether or not this context is initialized. + bool initialized_; + + uint32 max_vertex_attribs_; + + uint32 max_texture_units_; + + // Map of client ids to GL ids. + scoped_ptr<IdManager> id_manager_; + + scoped_ptr<BufferManager> buffer_manager_; + + scoped_ptr<TextureManager> texture_manager_; + + scoped_ptr<ProgramManager> program_manager_; + + scoped_ptr<ShaderManager> shader_manager_; + + DISALLOW_COPY_AND_ASSIGN(ContextGroup); +}; + +} // namespace gles2 +} // namespace gpu + +#endif // GPU_COMMAND_BUFFER_SERVICE_CONTEXT_GROUP_H_ + + diff --git a/gpu/command_buffer/service/context_group_unittest.cc b/gpu/command_buffer/service/context_group_unittest.cc new file mode 100644 index 0000000..a61077b --- /dev/null +++ b/gpu/command_buffer/service/context_group_unittest.cc @@ -0,0 +1,40 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "gpu/command_buffer/service/context_group.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace gpu { +namespace gles2 { + +class ContextGroupTest : public testing::Test { + public: + ContextGroupTest() { + } + + protected: + virtual void SetUp() { + } + + virtual void TearDown() { + } + + ContextGroup group_; +}; + +TEST_F(ContextGroupTest, Basic) { + // Test it starts off uninitialized. + EXPECT_EQ(0u, group_.max_vertex_attribs()); + EXPECT_EQ(0u, group_.max_texture_units()); + EXPECT_TRUE(group_.id_manager() == NULL); + EXPECT_TRUE(group_.buffer_manager() == NULL); + EXPECT_TRUE(group_.texture_manager() == NULL); + EXPECT_TRUE(group_.program_manager() == NULL); + EXPECT_TRUE(group_.shader_manager() == NULL); +} + +} // namespace gles2 +} // namespace gpu + + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder.cc b/gpu/command_buffer/service/gles2_cmd_decoder.cc index c018356..77bfc3c 100644 --- a/gpu/command_buffer/service/gles2_cmd_decoder.cc +++ b/gpu/command_buffer/service/gles2_cmd_decoder.cc @@ -15,10 +15,11 @@ #include "base/linked_ptr.h" #include "base/scoped_ptr.h" #define GLES2_GPU_SERVICE 1 -#include "gpu/command_buffer/service/buffer_manager.h" #include "gpu/command_buffer/common/gles2_cmd_format.h" #include "gpu/command_buffer/common/gles2_cmd_utils.h" +#include "gpu/command_buffer/service/buffer_manager.h" #include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" #include "gpu/command_buffer/service/gl_utils.h" #include "gpu/command_buffer/service/gles2_cmd_validation.h" #include "gpu/command_buffer/service/id_manager.h" @@ -59,23 +60,6 @@ COMPILE_ASSERT(sizeof(GLfloat) == sizeof(float), // NOLINT // linker on Mac OS X 10.6 when the symbol ordering file is used // namespace { -static size_t GetGLTypeSize(GLenum type) { - switch (type) { - case GL_BYTE: - return sizeof(GLbyte); // NOLINT - case GL_UNSIGNED_BYTE: - return sizeof(GLubyte); // NOLINT - case GL_SHORT: - return sizeof(GLshort); // NOLINT - case GL_UNSIGNED_SHORT: - return sizeof(GLushort); // NOLINT - case GL_FLOAT: - return sizeof(GLfloat); // NOLINT - default: - return 0; - } -} - // Returns the address of the first byte after a struct. template <typename T> const void* AddressAfterStruct(const T& pod) { @@ -168,27 +152,30 @@ GLenum GLErrorBitToGLError(uint32 error_bit) { // } // anonymous namespace. +GLES2Decoder::GLES2Decoder(ContextGroup* group) + : group_(group), #if defined(UNIT_TEST) -GLES2Decoder::GLES2Decoder() - : debug_(false) { + debug_(false) { #elif defined(OS_LINUX) -GLES2Decoder::GLES2Decoder() - : debug_(false), + debug_(false), window_(NULL) { #elif defined(OS_WIN) -GLES2Decoder::GLES2Decoder() - : debug_(false), + debug_(false), hwnd_(NULL) { #else -GLES2Decoder::GLES2Decoder() - : debug_(false) { + debug_(false) { #endif } +GLES2Decoder::~GLES2Decoder() { +} + // This class implements GLES2Decoder so we don't have to expose all the GLES2 // cmd stuff to outside this class. class GLES2DecoderImpl : public GLES2Decoder { public: + explicit GLES2DecoderImpl(ContextGroup* group); + // Info about Vertex Attributes. This is used to track what the user currently // has bound on each Vertex Attribute so that checking can be done at // glDrawXXX time. @@ -199,11 +186,9 @@ class GLES2DecoderImpl : public GLES2Decoder { size_(0), type_(0), offset_(0), - real_stride_(0), - buffer_(0), - buffer_size_(0), - num_elements_(0) { + real_stride_(0) { } + // Returns true if this VertexAttrib can access index. bool CanAccess(GLuint index); @@ -211,7 +196,7 @@ class GLES2DecoderImpl : public GLES2Decoder { enabled_ = enabled; } - GLuint buffer() const { + BufferManager::BufferInfo* buffer() const { return buffer_; } @@ -219,26 +204,8 @@ class GLES2DecoderImpl : public GLES2Decoder { return offset_; } - void Clear() { - buffer_ = 0; - SetBufferSize(0); - } - - void SetBufferSize(GLsizeiptr buffer_size) { - buffer_size_ = buffer_size; - if (offset_ > buffer_size || real_stride_ == 0) { - num_elements_ = 0; - } else { - uint32 usable_size = buffer_size - offset_; - num_elements_ = usable_size / real_stride_ + - ((usable_size % real_stride_) >= - (GetGLTypeSize(type_) * size_) ? 1 : 0); - } - } - void SetInfo( - GLuint buffer, - GLsizeiptr buffer_size, + BufferManager::BufferInfo* buffer, GLint size, GLenum type, GLsizei real_stride, @@ -249,7 +216,10 @@ class GLES2DecoderImpl : public GLES2Decoder { type_ = type; real_stride_ = real_stride; offset_ = offset; - SetBufferSize(buffer_size); + } + + void ClearBuffer() { + buffer_ = NULL; } private: @@ -270,22 +240,14 @@ class GLES2DecoderImpl : public GLES2Decoder { // of 0. GLsizei real_stride_; - // The service side name of the buffer bound to this attribute. 0 = invalid - GLuint buffer_; - - // The size of the buffer. - GLsizeiptr buffer_size_; - - // The number of elements that can be accessed. - GLuint num_elements_; + // The buffer bound to this attribute. + BufferManager::BufferInfo::Ref buffer_; }; - GLES2DecoderImpl(); - // Overridden from AsyncAPIInterface. virtual Error DoCommand(unsigned int command, - unsigned int arg_count, - const void* args); + unsigned int arg_count, + const void* args); // Overridden from AsyncAPIInterface. virtual const char* GetCommandName(unsigned int command_id) const; @@ -319,6 +281,21 @@ class GLES2DecoderImpl : public GLES2Decoder { virtual void SetSwapBuffersCallback(Callback0::Type* callback); private: + // State associated with each texture unit. + struct TextureUnit { + TextureUnit() : bind_target(GL_TEXTURE_2D) { } + + // The last target that was bound to this texture unit. + GLenum bind_target; + + // texture currently bound to this unit's GL_TEXTURE_2D with glBindTexture + TextureManager::TextureInfo::Ref bound_texture_2d; + + // texture currently bound to this unit's GL_TEXTURE_CUBE_MAP with + // glBindTexture + TextureManager::TextureInfo::Ref bound_texture_cube_map; + }; + friend void GLGenTexturesHelper( GLES2DecoderImpl* decoder, GLsizei n, GLuint* ids); friend void GLDeleteTexturesHelper( @@ -328,6 +305,27 @@ class GLES2DecoderImpl : public GLES2Decoder { friend void GLDeleteBuffersHelper( GLES2DecoderImpl* decoder, GLsizei n, GLuint* ids); + // TODO(gman): Cache these pointers? + IdManager* id_manager() { + return group_->id_manager(); + } + + BufferManager* buffer_manager() { + return group_->buffer_manager(); + } + + ProgramManager* program_manager() { + return group_->program_manager(); + } + + ShaderManager* shader_manager() { + return group_->shader_manager(); + } + + TextureManager* texture_manager() { + return group_->texture_manager(); + } + bool InitPlatformSpecific(); bool InitGlew(); @@ -368,16 +366,20 @@ class GLES2DecoderImpl : public GLES2Decoder { // Creates a TextureInfo for the given texture. void CreateTextureInfo(GLuint texture) { - texture_manager_->CreateTextureInfo(texture); + texture_manager()->CreateTextureInfo(texture); } // Gets the texture info for the given texture. Returns NULL if none exists. TextureManager::TextureInfo* GetTextureInfo(GLuint texture) { - return texture_manager_->GetTextureInfo(texture); + TextureManager::TextureInfo* info = + texture_manager()->GetTextureInfo(texture); + return (info && !info->IsDeleted()) ? info : NULL; } // Deletes the texture info for the given texture. - void RemoveTextureInfo(GLuint texture); + void RemoveTextureInfo(GLuint texture) { + texture_manager()->RemoveTextureInfo(texture); + } // Wrapper for CompressedTexImage2D commands. error::Error DoCompressedTexImage2D( @@ -405,48 +407,48 @@ class GLES2DecoderImpl : public GLES2Decoder { // Creates a ProgramInfo for the given program. void CreateProgramInfo(GLuint program) { - program_manager_->CreateProgramInfo(program); + program_manager()->CreateProgramInfo(program); } // Gets the program info for the given program. Returns NULL if none exists. // Programs that have no had glLinkProgram succesfully called on them will // not exist. ProgramManager::ProgramInfo* GetProgramInfo(GLuint program) { - return program_manager_->GetProgramInfo(program); + ProgramManager::ProgramInfo* info = + program_manager()->GetProgramInfo(program); + return (info && !info->IsDeleted()) ? info : NULL; } // Deletes the program info for the given program. void RemoveProgramInfo(GLuint program) { - program_manager_->RemoveProgramInfo(program); + program_manager()->RemoveProgramInfo(program); } // Creates a ShaderInfo for the given shader. void CreateShaderInfo(GLuint shader) { - shader_manager_->CreateShaderInfo(shader); + shader_manager()->CreateShaderInfo(shader); } // Gets the shader info for the given shader. Returns NULL if none exists. ShaderManager::ShaderInfo* GetShaderInfo(GLuint shader) { - return shader_manager_->GetShaderInfo(shader); + ShaderManager::ShaderInfo* info = shader_manager()->GetShaderInfo(shader); + return (info && !info->IsDeleted()) ? info : NULL; } // Deletes the shader info for the given shader. void RemoveShaderInfo(GLuint shader) { - shader_manager_->RemoveShaderInfo(shader); + shader_manager()->RemoveShaderInfo(shader); } // Creates a buffer info for the given buffer. void CreateBufferInfo(GLuint buffer) { - return buffer_manager_->CreateBufferInfo(buffer); + return buffer_manager()->CreateBufferInfo(buffer); } - // Helper for glShaderSource. - error::Error ShaderSourceHelper( - GLuint shader, const char* data, uint32 data_size); - // Gets the buffer info for the given buffer. BufferManager::BufferInfo* GetBufferInfo(GLuint buffer) { - return buffer_manager_->GetBufferInfo(buffer); + BufferManager::BufferInfo* info = buffer_manager()->GetBufferInfo(buffer); + return (info && !info->IsDeleted()) ? info : NULL; } // Removes any buffers in the VertexAtrribInfos and BufferInfos. This is used @@ -454,8 +456,9 @@ class GLES2DecoderImpl : public GLES2Decoder { // with deleted buffers. void RemoveBufferInfo(GLuint buffer_id); - // Update VertexAttribInfo. - void UpdateVertexAttribInfo(GLuint buffer, GLsizeiptr size); + // Helper for glShaderSource. + error::Error ShaderSourceHelper( + GLuint shader, const char* data, uint32 data_size); // Wrapper for glCreateProgram void CreateProgramHelper(GLuint client_id); @@ -463,6 +466,9 @@ class GLES2DecoderImpl : public GLES2Decoder { // Wrapper for glCreateShader void CreateShaderHelper(GLenum type, GLuint client_id); + // Wrapper for glActiveTexture + void DoActiveTexture(GLenum texture_unit); + // Wrapper for glBindBuffer since we need to track the current targets. void DoBindBuffer(GLenum target, GLuint buffer); @@ -494,6 +500,17 @@ class GLES2DecoderImpl : public GLES2Decoder { // Swaps the buffers (copies/renders to the current window). void DoSwapBuffers(); + // Wrappers for glTexParameter functions. + void DoTexParameterf(GLenum target, GLenum pname, GLfloat param); + void DoTexParameteri(GLenum target, GLenum pname, GLint param); + void DoTexParameterfv(GLenum target, GLenum pname, const GLfloat* params); + void DoTexParameteriv(GLenum target, GLenum pname, const GLint* params); + + // Wrappers for glUniform1i and glUniform1iv as according to the GLES2 + // spec only these 2 functions can be used to set sampler uniforms. + void DoUniform1i(GLint location, GLint v0); + void DoUniform1iv(GLint location, GLsizei count, const GLint *value); + // Wrapper for glUseProgram void DoUseProgram(GLuint program); @@ -512,18 +529,26 @@ class GLES2DecoderImpl : public GLES2Decoder { // Checks if the current program and vertex attributes are valid for drawing. bool IsDrawValid(GLuint max_vertex_accessed); + void SetBlackTextureForNonRenderableTextures( + bool* has_non_renderable_textures); + void RestoreStateForNonRenderableTextures(); + // Gets the buffer id for a given target. - GLuint GetBufferForTarget(GLenum target) { + BufferManager::BufferInfo* GetBufferInfoForTarget(GLenum target) { DCHECK(target == GL_ARRAY_BUFFER || target == GL_ELEMENT_ARRAY_BUFFER); - return target == GL_ARRAY_BUFFER ? bound_array_buffer_ : - bound_element_array_buffer_; + BufferManager::BufferInfo* info = target == GL_ARRAY_BUFFER ? + bound_array_buffer_ : bound_element_array_buffer_; + return (info && !info->IsDeleted()) ? info : NULL; } // Gets the texture id for a given target. - GLuint GetTextureForTarget(GLenum target) { + TextureManager::TextureInfo* GetTextureInfoForTarget(GLenum target) { + TextureUnit& unit = texture_units_[active_texture_unit_]; + TextureManager::TextureInfo* info = NULL; switch (target) { case GL_TEXTURE_2D: - return bound_texture_2d_; + info = unit.bound_texture_2d; + break; case GL_TEXTURE_CUBE_MAP: case GL_TEXTURE_CUBE_MAP_POSITIVE_X: case GL_TEXTURE_CUBE_MAP_NEGATIVE_X: @@ -531,15 +556,17 @@ class GLES2DecoderImpl : public GLES2Decoder { case GL_TEXTURE_CUBE_MAP_NEGATIVE_Y: case GL_TEXTURE_CUBE_MAP_POSITIVE_Z: case GL_TEXTURE_CUBE_MAP_NEGATIVE_Z: - return bound_texture_cube_map_; + info = unit.bound_texture_cube_map; + break; // Note: If we ever support TEXTURE_RECTANGLE as a target, be sure to // track |texture_| with the currently bound TEXTURE_RECTANGLE texture, // because |texture_| is used by the FBO rendering mechanism for readback // to the bits that get sent to the browser. default: NOTREACHED(); - return 0; + return NULL; } + return (info && !info->IsDeleted()) ? info : NULL; } // Validates the program and location for a glGetUniform call and returns @@ -578,9 +605,6 @@ class GLES2DecoderImpl : public GLES2Decoder { // Current GL error bits. uint32 error_bits_; - // Map of client ids to GL ids. - scoped_ptr<IdManager> id_manager_; - // Util to help with GL. GLES2Util util_; @@ -592,35 +616,32 @@ class GLES2DecoderImpl : public GLES2Decoder { // The currently bound array buffer. If this is 0 it is illegal to call // glVertexAttribPointer. - GLuint bound_array_buffer_; + BufferManager::BufferInfo::Ref bound_array_buffer_; // The currently bound element array buffer. If this is 0 it is illegal // to call glDrawElements. - GLuint bound_element_array_buffer_; - - // texture currently bound to GL_TEXTURE_2D with glBindTexture - GLuint bound_texture_2d_; - - // texture currently bound to GL_TEXTURE_CUBE_MAP with glBindTexture - GLuint bound_texture_cube_map_; - - // The maximum vertex attributes. - GLuint max_vertex_attribs_; + BufferManager::BufferInfo::Ref bound_element_array_buffer_; // Info for each vertex attribute saved so we can check at glDrawXXX time // if it is safe to draw. scoped_array<VertexAttribInfo> vertex_attrib_infos_; - scoped_ptr<BufferManager> buffer_manager_; - - scoped_ptr<TextureManager> texture_manager_; + // Current active texture by 0 - n index. + // In other words, if we call glActiveTexture(GL_TEXTURE2) this value would + // be 2. + GLuint active_texture_unit_; - scoped_ptr<ProgramManager> program_manager_; + // Which textures are bound to texture units through glActiveTexture. + scoped_array<TextureUnit> texture_units_; - scoped_ptr<ShaderManager> shader_manager_; + // Black (0,0,0,0) textures for when non-renderable textures are used. + // NOTE: There is no corresponding TextureInfo for these textures. + // TextureInfos are only for textures the client side can access. + GLuint black_2d_texture_id_; + GLuint black_cube_texture_id_; // The program in use by glUseProgram - GLuint current_program_; + ProgramManager::ProgramInfo::Ref current_program_; #if defined(UNIT_TEST) #elif defined(OS_WIN) @@ -662,22 +683,19 @@ class GLES2DecoderImpl : public GLES2Decoder { DISALLOW_COPY_AND_ASSIGN(GLES2DecoderImpl); }; -GLES2Decoder* GLES2Decoder::Create() { - return new GLES2DecoderImpl(); +GLES2Decoder* GLES2Decoder::Create(ContextGroup* group) { + return new GLES2DecoderImpl(group); } -GLES2DecoderImpl::GLES2DecoderImpl() - : GLES2Decoder(), +GLES2DecoderImpl::GLES2DecoderImpl(ContextGroup* group) + : GLES2Decoder(group), error_bits_(0), util_(0), // TODO(gman): Set to actual num compress texture formats. pack_alignment_(4), unpack_alignment_(4), - bound_array_buffer_(0), - bound_element_array_buffer_(0), - bound_texture_2d_(0), - bound_texture_cube_map_(0), - max_vertex_attribs_(0), - current_program_(0), + active_texture_unit_(0), + black_2d_texture_id_(0), + black_cube_texture_id_(0), #if defined(UNIT_TEST) #elif defined(OS_WIN) device_context_(NULL), @@ -699,35 +717,42 @@ GLES2DecoderImpl::GLES2DecoderImpl() bool GLES2DecoderImpl::Initialize() { bool success = false; - id_manager_.reset(new IdManager()); - buffer_manager_.reset(new BufferManager()); - shader_manager_.reset(new ShaderManager()); - program_manager_.reset(new ProgramManager()); - if (InitPlatformSpecific()) { if (MakeCurrent()) { if (InitGlew()) { CHECK_GL_ERROR(); - - // Lookup GL things we need to know. - GLint value; - glGetIntegerv(GL_MAX_VERTEX_ATTRIBS, &value); - max_vertex_attribs_ = value; - - GLint max_texture_size; - GLint max_cube_map_texture_size; - glGetIntegerv(GL_MAX_TEXTURE_SIZE, &max_texture_size); - glGetIntegerv(GL_MAX_CUBE_MAP_TEXTURE_SIZE, &max_cube_map_texture_size); - texture_manager_.reset(new TextureManager(max_texture_size, - max_cube_map_texture_size)); - DCHECK_GE(max_vertex_attribs_, 8u); - - vertex_attrib_infos_.reset(new VertexAttribInfo[max_vertex_attribs_]); - memset(vertex_attrib_infos_.get(), 0, - sizeof(vertex_attrib_infos_[0]) * max_vertex_attribs_); - - // glBindFramebuffer(0, 0); - success = true; + success = group_->Initialize(); + if (success) { + vertex_attrib_infos_.reset( + new VertexAttribInfo[group_->max_vertex_attribs()]); + texture_units_.reset( + new TextureUnit[group_->max_texture_units()]); + GLuint ids[2]; + glGenTextures(2, ids); + // Make black textures for replacing non-renderable textures. + black_2d_texture_id_ = ids[0]; + black_cube_texture_id_ = ids[1]; + static int8 black[] = {0, 0, 0, 0}; + glBindTexture(GL_TEXTURE_2D, black_2d_texture_id_); + glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, + GL_UNSIGNED_BYTE, black); + glBindTexture(GL_TEXTURE_2D, 0); + glBindTexture(GL_TEXTURE_CUBE_MAP, black_cube_texture_id_); + static GLenum faces[] = { + GL_TEXTURE_CUBE_MAP_POSITIVE_X, + GL_TEXTURE_CUBE_MAP_NEGATIVE_X, + GL_TEXTURE_CUBE_MAP_POSITIVE_Y, + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, + GL_TEXTURE_CUBE_MAP_POSITIVE_Z, + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, + }; + for (size_t ii = 0; ii < arraysize(faces); ++ii) { + glTexImage2D(faces[ii], 0, GL_RGBA, 1, 1, 0, GL_RGBA, + GL_UNSIGNED_BYTE, black); + } + glBindTexture(GL_TEXTURE_CUBE_MAP, 0); + CHECK_GL_ERROR(); + } } } } @@ -1001,7 +1026,7 @@ bool GLES2DecoderImpl::MakeCurrent() { uint32 GLES2DecoderImpl::GetServiceIdForTesting(uint32 client_id) { #if defined(UNIT_TEST) GLuint service_id; - bool result = id_manager_->GetServiceId(client_id, &service_id); + bool result = id_manager()->GetServiceId(client_id, &service_id); return result ? service_id : 0u; #else DCHECK(false); @@ -1013,7 +1038,7 @@ bool GLES2DecoderImpl::ValidateIdsAreUnused( GLsizei n, const GLuint* client_ids) { for (GLsizei ii = 0; ii < n; ++ii) { GLuint service_id; - if (id_manager_->GetServiceId(client_ids[ii], &service_id)) { + if (id_manager()->GetServiceId(client_ids[ii], &service_id)) { return false; } } @@ -1023,7 +1048,7 @@ bool GLES2DecoderImpl::ValidateIdsAreUnused( bool GLES2DecoderImpl::RegisterObjects( GLsizei n, const GLuint* client_ids, const GLuint* service_ids) { for (GLsizei ii = 0; ii < n; ++ii) { - if (!id_manager_->AddMapping(client_ids[ii], service_ids[ii])) { + if (!id_manager()->AddMapping(client_ids[ii], service_ids[ii])) { NOTREACHED(); return false; } @@ -1034,8 +1059,8 @@ bool GLES2DecoderImpl::RegisterObjects( void GLES2DecoderImpl::UnregisterObjects( GLsizei n, const GLuint* client_ids, GLuint* service_ids) { for (GLsizei ii = 0; ii < n; ++ii) { - if (id_manager_->GetServiceId(client_ids[ii], &service_ids[ii])) { - id_manager_->RemoveMapping(client_ids[ii], service_ids[ii]); + if (id_manager()->GetServiceId(client_ids[ii], &service_ids[ii])) { + id_manager()->RemoveMapping(client_ids[ii], service_ids[ii]); } else { service_ids[ii] = 0; } @@ -1465,11 +1490,32 @@ error::Error GLES2DecoderImpl::DoCommand( return result; } +void GLES2DecoderImpl::RemoveBufferInfo(GLuint buffer_id) { + buffer_manager()->RemoveBufferInfo(buffer_id); + // TODO(gman): See if we can remove the rest of this function as + // buffers are now reference counted and have a "IsDeleted" function. + if (bound_array_buffer_ && bound_array_buffer_->buffer_id() == buffer_id) { + bound_array_buffer_ = NULL; + } + if (bound_element_array_buffer_ && + bound_element_array_buffer_->buffer_id() == buffer_id) { + bound_element_array_buffer_ = NULL; + } + + // go through VertexAttribInfo and update any info that references the buffer. + for (GLuint ii = 0; ii < group_->max_vertex_attribs(); ++ii) { + VertexAttribInfo& info = vertex_attrib_infos_[ii]; + if (info.buffer() && info.buffer()->buffer_id() == buffer_id) { + info.ClearBuffer(); + } + } +} + void GLES2DecoderImpl::CreateProgramHelper(GLuint client_id) { // TODO(gman): verify client_id is unused. GLuint service_id = glCreateProgram(); if (service_id) { - id_manager_->AddMapping(client_id, service_id); + id_manager()->AddMapping(client_id, service_id); CreateProgramInfo(service_id); } } @@ -1478,14 +1524,23 @@ void GLES2DecoderImpl::CreateShaderHelper(GLenum type, GLuint client_id) { // TODO(gman): verify client_id is unused. GLuint service_id = glCreateShader(type); if (service_id) { - id_manager_->AddMapping(client_id, service_id); + id_manager()->AddMapping(client_id, service_id); CreateShaderInfo(service_id); } } +void GLES2DecoderImpl::DoActiveTexture(GLenum texture_unit) { + if (texture_unit > group_->max_texture_units()) { + SetGLError(GL_INVALID_ENUM); + return; + } + active_texture_unit_ = texture_unit - GL_TEXTURE0; +} + void GLES2DecoderImpl::DoBindBuffer(GLenum target, GLuint buffer) { + BufferManager::BufferInfo* info = NULL; if (buffer) { - BufferManager::BufferInfo* info = GetBufferInfo(buffer); + info = GetBufferInfo(buffer); if (!info) { SetGLError(GL_INVALID_OPERATION); return; @@ -1493,10 +1548,10 @@ void GLES2DecoderImpl::DoBindBuffer(GLenum target, GLuint buffer) { } switch (target) { case GL_ARRAY_BUFFER: - bound_array_buffer_ = buffer; + bound_array_buffer_ = info; break; case GL_ELEMENT_ARRAY_BUFFER: - bound_element_array_buffer_ = buffer; + bound_element_array_buffer_ = info; break; default: NOTREACHED(); // Validation should prevent us getting here. @@ -1506,23 +1561,28 @@ void GLES2DecoderImpl::DoBindBuffer(GLenum target, GLuint buffer) { } void GLES2DecoderImpl::DoBindTexture(GLenum target, GLuint texture) { + TextureManager::TextureInfo* info = NULL; if (texture) { - TextureManager::TextureInfo* info = GetTextureInfo(texture); + info = GetTextureInfo(texture); + // Check the texture exists + // Check that we are not trying to bind it to a different target. if (!info || (info->target() != 0 && info->target() != target)) { SetGLError(GL_INVALID_OPERATION); return; } if (info->target() == 0) { - texture_manager_->SetInfoTarget(info, target); + texture_manager()->SetInfoTarget(info, target); } } glBindTexture(target, texture); + TextureUnit& unit = texture_units_[active_texture_unit_]; + unit.bind_target = target; switch (target) { case GL_TEXTURE_2D: - bound_texture_2d_ = texture; + unit.bound_texture_2d = info; break; case GL_TEXTURE_CUBE_MAP: - bound_texture_cube_map_ = texture; + unit.bound_texture_cube_map = info; break; default: NOTREACHED(); // Validation should prevent us getting here. @@ -1531,7 +1591,7 @@ void GLES2DecoderImpl::DoBindTexture(GLenum target, GLuint texture) { } void GLES2DecoderImpl::DoDisableVertexAttribArray(GLuint index) { - if (index < max_vertex_attribs_) { + if (index < group_->max_vertex_attribs()) { vertex_attrib_infos_[index].set_enabled(false); glDisableVertexAttribArray(index); } else { @@ -1540,7 +1600,7 @@ void GLES2DecoderImpl::DoDisableVertexAttribArray(GLuint index) { } void GLES2DecoderImpl::DoEnableVertexAttribArray(GLuint index) { - if (index < max_vertex_attribs_) { + if (index < group_->max_vertex_attribs()) { vertex_attrib_infos_[index].set_enabled(true); glEnableVertexAttribArray(index); } else { @@ -1549,27 +1609,25 @@ void GLES2DecoderImpl::DoEnableVertexAttribArray(GLuint index) { } void GLES2DecoderImpl::DoGenerateMipmap(GLenum target) { - GLuint texture = GetTextureForTarget(target); - TextureManager::TextureInfo* info = GetTextureInfo(texture); - if (!info || !info->CanGenerateMipmaps()) { + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); + if (!info || !info->MarkMipmapsGenerated()) { SetGLError(GL_INVALID_OPERATION); return; } glGenerateMipmapEXT(target); - info->MarkMipmapsGenerated(); } error::Error GLES2DecoderImpl::HandleDeleteShader( uint32 immediate_data_size, const gles2::DeleteShader& c) { GLuint shader = c.shader; GLuint service_id; - if (!id_manager_->GetServiceId(shader, &service_id)) { + if (!id_manager()->GetServiceId(shader, &service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } RemoveShaderInfo(service_id); glDeleteShader(service_id); - id_manager_->RemoveMapping(shader, service_id); + id_manager()->RemoveMapping(shader, service_id); return error::kNoError; } @@ -1577,20 +1635,25 @@ error::Error GLES2DecoderImpl::HandleDeleteProgram( uint32 immediate_data_size, const gles2::DeleteProgram& c) { GLuint program = c.program; GLuint service_id; - if (!id_manager_->GetServiceId(program, &service_id)) { + if (!id_manager()->GetServiceId(program, &service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } RemoveProgramInfo(service_id); glDeleteProgram(service_id); - id_manager_->RemoveMapping(program, service_id); + id_manager()->RemoveMapping(program, service_id); return error::kNoError; } void GLES2DecoderImpl::DoDrawArrays( GLenum mode, GLint first, GLsizei count) { if (IsDrawValid(first + count - 1)) { + bool has_non_renderable_textures; + SetBlackTextureForNonRenderableTextures(&has_non_renderable_textures); glDrawArrays(mode, first, count); + if (has_non_renderable_textures) { + RestoreStateForNonRenderableTextures(); + } } } @@ -1656,15 +1719,83 @@ void GLES2DecoderImpl::DoSwapBuffers() { } } -void GLES2DecoderImpl::DoUseProgram(GLuint program) { - ProgramManager::ProgramInfo* info = GetProgramInfo(program); +void GLES2DecoderImpl::DoTexParameterf( + GLenum target, GLenum pname, GLfloat param) { + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); if (!info) { - // Program was not linked successfully. (ie, glLinkProgram) - SetGLError(GL_INVALID_OPERATION); + SetGLError(GL_INVALID_VALUE); + } else { + info->SetParameter(pname, static_cast<GLint>(param)); + glTexParameterf(target, pname, param); + } +} + +void GLES2DecoderImpl::DoTexParameteri( + GLenum target, GLenum pname, GLint param) { + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); + if (!info) { + SetGLError(GL_INVALID_VALUE); + } else { + info->SetParameter(pname, param); + glTexParameteri(target, pname, param); + } +} + +void GLES2DecoderImpl::DoTexParameterfv( + GLenum target, GLenum pname, const GLfloat* params) { + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); + if (!info) { + SetGLError(GL_INVALID_VALUE); + } else { + info->SetParameter(pname, *reinterpret_cast<const GLint*>(params)); + glTexParameterfv(target, pname, params); + } +} + +void GLES2DecoderImpl::DoTexParameteriv( + GLenum target, GLenum pname, const GLint* params) { + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); + if (!info) { + SetGLError(GL_INVALID_VALUE); } else { - current_program_ = program; - glUseProgram(program); + info->SetParameter(pname, *params); + glTexParameteriv(target, pname, params); + } +} + +void GLES2DecoderImpl::DoUniform1i(GLint location, GLint v0) { + if (!current_program_ || current_program_->IsDeleted()) { + // The program does not exist. + SetGLError(GL_INVALID_OPERATION); + return; } + current_program_->SetSamplers(location, 1, &v0); + glUniform1i(location, v0); +} + +void GLES2DecoderImpl::DoUniform1iv( + GLint location, GLsizei count, const GLint *value) { + if (!current_program_ || current_program_->IsDeleted()) { + // The program does not exist. + SetGLError(GL_INVALID_OPERATION); + return; + } + current_program_->SetSamplers(location, count, value); + glUniform1iv(location, count, value); +} + +void GLES2DecoderImpl::DoUseProgram(GLuint program) { + ProgramManager::ProgramInfo* info = NULL; + if (program) { + info = GetProgramInfo(program); + if (!info) { + // Program was not linked successfully. (ie, glLinkProgram) + SetGLError(GL_INVALID_OPERATION); + return; + } + } + current_program_ = info; + glUseProgram(program); } GLenum GLES2DecoderImpl::GetGLError() { @@ -1697,81 +1828,125 @@ void GLES2DecoderImpl::CopyRealGLErrorsToWrapper() { } } -void GLES2DecoderImpl::RemoveTextureInfo(GLuint texture_id) { - // TODO(gman): This code needs to change for shared resources. It needs to - // handle a different decoder deleting the texture. (or, the code that gets - // a texture always needs to check that it still exists). - if (bound_texture_2d_ == texture_id) { - bound_texture_2d_ = 0; +bool GLES2DecoderImpl::VertexAttribInfo::CanAccess(GLuint index) { + if (!enabled_) { + return true; } - if (bound_texture_cube_map_ == texture_id) { - bound_texture_cube_map_ = 0; + + if (!buffer_ || buffer_->IsDeleted()) { + return false; } - texture_manager_->RemoveTextureInfo(texture_id); -} -void GLES2DecoderImpl::UpdateVertexAttribInfo(GLuint buffer, GLsizeiptr size) { - // go through VertexAttribInfo and update any info that references the buffer. - // TODO(gman): This code needs to change for shared resources. - for (GLuint ii = 0; ii < max_vertex_attribs_; ++ii) { - if (vertex_attrib_infos_[ii].buffer() == buffer) { - vertex_attrib_infos_[ii].SetBufferSize(size); - } + // The number of elements that can be accessed. + GLsizeiptr buffer_size = buffer_->size(); + if (offset_ > buffer_size || real_stride_ == 0) { + return false; } -} -void GLES2DecoderImpl::RemoveBufferInfo(GLuint buffer_id) { - // TODO(gman): This code needs to change for shared resources. - for (GLuint ii = 0; ii < max_vertex_attribs_; ++ii) { - if (vertex_attrib_infos_[ii].buffer() == buffer_id) { - vertex_attrib_infos_[ii].Clear(); + uint32 usable_size = buffer_size - offset_; + GLuint num_elements = usable_size / real_stride_ + + ((usable_size % real_stride_) >= + (GLES2Util::GetGLTypeSizeForTexturesAndBuffers(type_) * size_) ? 1 : 0); + return index < num_elements; +} + +void GLES2DecoderImpl::SetBlackTextureForNonRenderableTextures( + bool* has_non_renderable_textures) { + DCHECK(has_non_renderable_textures); + DCHECK(current_program_); + DCHECK(!current_program_->IsDeleted()); + *has_non_renderable_textures = false; + const ProgramManager::ProgramInfo::SamplerIndices& sampler_indices = + current_program_->sampler_indices(); + for (size_t ii = 0; ii < sampler_indices.size(); ++ii) { + const ProgramManager::ProgramInfo::UniformInfo* uniform_info = + current_program_->GetUniformInfo(sampler_indices[ii]); + DCHECK(uniform_info); + for (size_t jj = 0; jj < uniform_info->texture_units.size(); ++jj) { + GLuint texture_unit_index = uniform_info->texture_units[jj]; + if (texture_unit_index < group_->max_texture_units()) { + TextureUnit& texture_unit = texture_units_[texture_unit_index]; + TextureManager::TextureInfo* texture_info = + uniform_info->type == GL_SAMPLER_2D ? + texture_unit.bound_texture_2d : + texture_unit.bound_texture_cube_map; + if (!texture_info || !texture_info->CanRender()) { + *has_non_renderable_textures = true; + glActiveTexture(GL_TEXTURE0 + texture_unit_index); + glBindTexture( + uniform_info->type == GL_SAMPLER_2D ? GL_TEXTURE_2D : + GL_TEXTURE_CUBE_MAP, + uniform_info->type == GL_SAMPLER_2D ? black_2d_texture_id_ : + black_cube_texture_id_); + } + } + // else: should this be an error? } } - if (bound_array_buffer_ == buffer_id) { - bound_array_buffer_ = 0; - } - if (bound_element_array_buffer_ == buffer_id) { - bound_element_array_buffer_ = 0; - } - buffer_manager_->RemoveBufferInfo(buffer_id); } -bool GLES2DecoderImpl::VertexAttribInfo::CanAccess(GLuint index) { - return !enabled_ || (buffer_ != 0 && index < num_elements_); +void GLES2DecoderImpl::RestoreStateForNonRenderableTextures() { + DCHECK(current_program_); + DCHECK(!current_program_->IsDeleted()); + const ProgramManager::ProgramInfo::SamplerIndices& sampler_indices = + current_program_->sampler_indices(); + for (size_t ii = 0; ii < sampler_indices.size(); ++ii) { + const ProgramManager::ProgramInfo::UniformInfo* uniform_info = + current_program_->GetUniformInfo(sampler_indices[ii]); + DCHECK(uniform_info); + for (size_t jj = 0; jj < uniform_info->texture_units.size(); ++jj) { + GLuint texture_unit_index = uniform_info->texture_units[jj]; + if (texture_unit_index < group_->max_texture_units()) { + TextureUnit& texture_unit = texture_units_[texture_unit_index]; + TextureManager::TextureInfo* texture_info = + uniform_info->type == GL_SAMPLER_2D ? + texture_unit.bound_texture_2d : + texture_unit.bound_texture_cube_map; + if (!texture_info || !texture_info->CanRender()) { + glActiveTexture(GL_TEXTURE0 + texture_unit_index); + // Get the texture info that was previously bound here. + texture_info = texture_unit.bind_target == GL_TEXTURE_2D ? + texture_unit.bound_texture_2d : + texture_unit.bound_texture_cube_map; + glBindTexture(texture_unit.bind_target, + texture_info ? texture_info->texture_id() : 0); + } + } + } + } + // Set the active texture back to whatever the user had it as. + glActiveTexture(GL_TEXTURE0 + active_texture_unit_); } bool GLES2DecoderImpl::IsDrawValid(GLuint max_vertex_accessed) { - if (current_program_) { - ProgramManager::ProgramInfo* info = GetProgramInfo(current_program_); - if (!info) { - // The program does not exist. - SetGLError(GL_INVALID_OPERATION); + if (!current_program_ || current_program_->IsDeleted()) { + // The program does not exist. + // But GL says no ERROR. + return false; + } + // Validate that all attribs current program needs are setup correctly. + const ProgramManager::ProgramInfo::AttribInfoVector& infos = + current_program_->GetAttribInfos(); + for (size_t ii = 0; ii < infos.size(); ++ii) { + GLint location = infos[ii].location; + if (location < 0) { return false; } - // Validate that all attribs current program needs are setup correctly. - const ProgramManager::ProgramInfo::AttribInfoVector& infos = - info->GetAttribInfos(); - for (size_t ii = 0; ii < infos.size(); ++ii) { - GLint location = infos[ii].location; - if (location < 0) { - return false; - } - DCHECK_LT(static_cast<GLuint>(location), max_vertex_attribs_); - if (!vertex_attrib_infos_[location].CanAccess(max_vertex_accessed)) { - SetGLError(GL_INVALID_OPERATION); - return false; - } + DCHECK_LT(static_cast<GLuint>(location), group_->max_vertex_attribs()); + if (!vertex_attrib_infos_[location].CanAccess(max_vertex_accessed)) { + SetGLError(GL_INVALID_OPERATION); + return false; } - return true; } - // We do not set a GL error here because the GL spec says no error if the - // program is invalid. - return false; + return true; }; error::Error GLES2DecoderImpl::HandleDrawElements( uint32 immediate_data_size, const gles2::DrawElements& c) { - if (bound_element_array_buffer_ != 0) { + if (!bound_element_array_buffer_ || + bound_element_array_buffer_->IsDeleted()) { + SetGLError(GL_INVALID_OPERATION); + } else { GLenum mode = c.mode; GLsizei count = c.count; GLenum type = c.type; @@ -1780,38 +1955,32 @@ error::Error GLES2DecoderImpl::HandleDrawElements( !ValidateGLenumIndexType(type)) { SetGLError(GL_INVALID_ENUM); } else { - // TODO(gman): We could cache this lookup in glBindBuffer. - BufferManager::BufferInfo* info = - GetBufferInfo(bound_element_array_buffer_); - if (!info) { + GLsizeiptr buffer_size = bound_element_array_buffer_->size(); + if (offset > buffer_size) { SetGLError(GL_INVALID_OPERATION); } else { - GLsizeiptr buffer_size = info->size(); - if (offset > buffer_size) { + GLsizei usable_size = buffer_size - offset; + GLsizei num_elements = + usable_size / GLES2Util::GetGLTypeSizeForTexturesAndBuffers(type); + if (count > num_elements) { SetGLError(GL_INVALID_OPERATION); } else { - GLsizei usable_size = buffer_size - offset; - GLsizei num_elements = usable_size / GetGLTypeSize(type); - if (count > num_elements) { - SetGLError(GL_INVALID_OPERATION); - } else { - const GLvoid* indices = reinterpret_cast<const GLvoid*>(offset); - // TODO(gman): Validate indices. Get maximum index. - // - // This value should be computed by walking the index buffer from 0 - // to count and finding the maximum vertex accessed. For now we'll - // pass 0 so it should always pass. - GLuint max_vertex_accessed = info->GetMaxValueForRange( - offset, count, type); - if (IsDrawValid(max_vertex_accessed)) { - glDrawElements(mode, count, type, indices); + const GLvoid* indices = reinterpret_cast<const GLvoid*>(offset); + GLuint max_vertex_accessed = + bound_element_array_buffer_->GetMaxValueForRange( + offset, count, type); + if (IsDrawValid(max_vertex_accessed)) { + bool has_non_renderable_textures; + SetBlackTextureForNonRenderableTextures( + &has_non_renderable_textures); + glDrawElements(mode, count, type, indices); + if (has_non_renderable_textures) { + RestoreStateForNonRenderableTextures(); } } } } } - } else { - SetGLError(GL_INVALID_OPERATION); } return error::kNoError; } @@ -1836,7 +2005,7 @@ error::Error GLES2DecoderImpl::ShaderSourceHelper( error::Error GLES2DecoderImpl::HandleShaderSource( uint32 immediate_data_size, const gles2::ShaderSource& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1852,7 +2021,7 @@ error::Error GLES2DecoderImpl::HandleShaderSource( error::Error GLES2DecoderImpl::HandleShaderSourceImmediate( uint32 immediate_data_size, const gles2::ShaderSourceImmediate& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1897,7 +2066,7 @@ void GLES2DecoderImpl::DoGetShaderSource( error::Error GLES2DecoderImpl::HandleVertexAttribPointer( uint32 immediate_data_size, const gles2::VertexAttribPointer& c) { - if (bound_array_buffer_ != 0) { + if (bound_array_buffer_ && !bound_array_buffer_->IsDeleted()) { GLuint indx = c.indx; GLint size = c.size; GLenum type = c.type; @@ -1907,14 +2076,13 @@ error::Error GLES2DecoderImpl::HandleVertexAttribPointer( const void* ptr = reinterpret_cast<const void*>(offset); if (!ValidateGLenumVertexAttribType(type) || !ValidateGLintVertexAttribSize(size) || - indx >= max_vertex_attribs_ || + indx >= group_->max_vertex_attribs() || stride < 0) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } - const BufferManager::BufferInfo* buffer_info = - GetBufferInfo(bound_array_buffer_); - GLsizei component_size = GetGLTypeSize(type); + GLsizei component_size = + GLES2Util::GetGLTypeSizeForTexturesAndBuffers(type); GLsizei real_stride = stride != 0 ? stride : component_size * size; if (offset % component_size > 0) { SetGLError(GL_INVALID_VALUE); @@ -1922,7 +2090,6 @@ error::Error GLES2DecoderImpl::HandleVertexAttribPointer( } vertex_attrib_infos_[indx].SetInfo( bound_array_buffer_, - buffer_info ? buffer_info->size() : 0, size, type, real_stride, @@ -1998,7 +2165,7 @@ error::Error GLES2DecoderImpl::HandlePixelStorei( error::Error GLES2DecoderImpl::HandleGetAttribLocation( uint32 immediate_data_size, const gles2::GetAttribLocation& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2024,7 +2191,7 @@ error::Error GLES2DecoderImpl::HandleGetAttribLocation( error::Error GLES2DecoderImpl::HandleGetAttribLocationImmediate( uint32 immediate_data_size, const gles2::GetAttribLocationImmediate& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2050,7 +2217,7 @@ error::Error GLES2DecoderImpl::HandleGetAttribLocationImmediate( error::Error GLES2DecoderImpl::HandleGetUniformLocation( uint32 immediate_data_size, const gles2::GetUniformLocation& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2076,7 +2243,7 @@ error::Error GLES2DecoderImpl::HandleGetUniformLocation( error::Error GLES2DecoderImpl::HandleGetUniformLocationImmediate( uint32 immediate_data_size, const gles2::GetUniformLocationImmediate& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2118,8 +2285,7 @@ error::Error GLES2DecoderImpl::HandleBufferData( SetGLError(GL_INVALID_VALUE); return error::kNoError; } - GLuint buffer = GetBufferForTarget(target); - BufferManager::BufferInfo* info = GetBufferInfo(buffer); + BufferManager::BufferInfo* info = GetBufferInfoForTarget(target); if (!info) { SetGLError(GL_INVALID_OPERATION); return error::kNoError; @@ -2138,7 +2304,6 @@ error::Error GLES2DecoderImpl::HandleBufferData( SetGLError(error); } else { info->set_size(size); - UpdateVertexAttribInfo(buffer, size); } return error::kNoError; } @@ -2158,8 +2323,7 @@ error::Error GLES2DecoderImpl::HandleBufferDataImmediate( SetGLError(GL_INVALID_VALUE); return error::kNoError; } - GLuint buffer = GetBufferForTarget(target); - BufferManager::BufferInfo* info = GetBufferInfo(buffer); + BufferManager::BufferInfo* info = GetBufferInfoForTarget(target); if (!info) { SetGLError(GL_INVALID_OPERATION); return error::kNoError; @@ -2171,7 +2335,6 @@ error::Error GLES2DecoderImpl::HandleBufferDataImmediate( SetGLError(error); } else { info->set_size(size); - UpdateVertexAttribInfo(buffer, size); } return error::kNoError; } @@ -2191,13 +2354,12 @@ error::Error GLES2DecoderImpl::DoCompressedTexImage2D( SetGLError(GL_INVALID_ENUM); return error::kNoError; } - if (!texture_manager_->ValidForTarget(target, level, width, height, 1) || + if (!texture_manager()->ValidForTarget(target, level, width, height, 1) || border != 0) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } - GLuint texture = GetTextureForTarget(target); - TextureManager::TextureInfo* info = GetTextureInfo(texture); + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); if (!info) { SetGLError(GL_INVALID_OPERATION); return error::kNoError; @@ -2276,13 +2438,12 @@ error::Error GLES2DecoderImpl::DoTexImage2D( SetGLError(GL_INVALID_ENUM); return error::kNoError; } - if (!texture_manager_->ValidForTarget(target, level, width, height, 1) || + if (!texture_manager()->ValidForTarget(target, level, width, height, 1) || border != 0) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } - GLuint texture = GetTextureForTarget(target); - TextureManager::TextureInfo* info = GetTextureInfo(texture); + TextureManager::TextureInfo* info = GetTextureInfoForTarget(target); if (!info) { SetGLError(GL_INVALID_OPERATION); return error::kNoError; @@ -2369,7 +2530,7 @@ error::Error GLES2DecoderImpl::HandleGetVertexAttribPointerv( SetGLError(GL_INVALID_ENUM); return error::kNoError; } - if (index >= max_vertex_attribs_) { + if (index >= group_->max_vertex_attribs()) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2394,7 +2555,7 @@ bool GLES2DecoderImpl::GetUniformSetup( *result_pointer = result; // Set the result size to 0 so the client does not have to check for success. result->SetNumResults(0); - if (!id_manager_->GetServiceId(program, service_id)) { + if (!id_manager()->GetServiceId(program, service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2410,7 +2571,7 @@ bool GLES2DecoderImpl::GetUniformSetup( SetGLError(GL_INVALID_OPERATION); return false; } - GLsizei size = GLES2Util::GetGLDataTypeSize(type); + GLsizei size = GLES2Util::GetGLDataTypeSizeForUniforms(type); if (size == 0) { SetGLError(GL_INVALID_OPERATION); return false; @@ -2506,7 +2667,7 @@ error::Error GLES2DecoderImpl::HandleGetAttachedShaders( uint32 immediate_data_size, const gles2::GetAttachedShaders& c) { GLuint service_id; uint32 result_size = c.result_size; - if (!id_manager_->GetServiceId(c.program, &service_id)) { + if (!id_manager()->GetServiceId(c.program, &service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2524,7 +2685,7 @@ error::Error GLES2DecoderImpl::HandleGetAttachedShaders( GLsizei count = 0; glGetAttachedShaders(service_id, max_count, &count, result->GetData()); for (GLsizei ii = 0; ii < count; ++ii) { - if (!id_manager_->GetClientId(result->GetData()[ii], + if (!id_manager()->GetClientId(result->GetData()[ii], &result->GetData()[ii])) { NOTREACHED(); return error::kGenericError; @@ -2550,7 +2711,7 @@ error::Error GLES2DecoderImpl::HandleGetActiveUniform( if (result->success != 0) { return error::kInvalidArguments; } - if (!id_manager_->GetServiceId(program, &service_id)) { + if (!id_manager()->GetServiceId(program, &service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2590,7 +2751,7 @@ error::Error GLES2DecoderImpl::HandleGetActiveAttrib( if (result->success != 0) { return error::kInvalidArguments; } - if (!id_manager_->GetServiceId(program, &service_id)) { + if (!id_manager()->GetServiceId(program, &service_id)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } diff --git a/gpu/command_buffer/service/gles2_cmd_decoder.h b/gpu/command_buffer/service/gles2_cmd_decoder.h index 2b6f4e0..cfa4c66 100644 --- a/gpu/command_buffer/service/gles2_cmd_decoder.h +++ b/gpu/command_buffer/service/gles2_cmd_decoder.h @@ -25,6 +25,8 @@ class XWindowWrapper; namespace gles2 { +class ContextGroup; + // This class implements the AsyncAPIInterface interface, decoding GLES2 // commands and calling GL. class GLES2Decoder : public CommonDecoder { @@ -32,10 +34,9 @@ class GLES2Decoder : public CommonDecoder { typedef error::Error Error; // Creates a decoder. - static GLES2Decoder* Create(); + static GLES2Decoder* Create(ContextGroup* group); - virtual ~GLES2Decoder() { - } + virtual ~GLES2Decoder(); bool debug() const { return debug_; @@ -87,7 +88,9 @@ class GLES2Decoder : public CommonDecoder { virtual void SetSwapBuffersCallback(Callback0::Type* callback) = 0; protected: - GLES2Decoder(); + explicit GLES2Decoder(ContextGroup* group); + + ContextGroup* group_; private: bool debug_; diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h index a57b644..12d387f 100644 --- a/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h +++ b/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h @@ -18,12 +18,12 @@ error::Error GLES2DecoderImpl::HandleActiveTexture( error::Error GLES2DecoderImpl::HandleAttachShader( uint32 immediate_data_size, const gles2::AttachShader& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -34,7 +34,7 @@ error::Error GLES2DecoderImpl::HandleAttachShader( error::Error GLES2DecoderImpl::HandleBindAttribLocation( uint32 immediate_data_size, const gles2::BindAttribLocation& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -53,7 +53,7 @@ error::Error GLES2DecoderImpl::HandleBindAttribLocation( error::Error GLES2DecoderImpl::HandleBindAttribLocationImmediate( uint32 immediate_data_size, const gles2::BindAttribLocationImmediate& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -73,7 +73,7 @@ error::Error GLES2DecoderImpl::HandleBindBuffer( uint32 immediate_data_size, const gles2::BindBuffer& c) { GLenum target = static_cast<GLenum>(c.target); GLuint buffer; - if (!id_manager_->GetServiceId(c.buffer, &buffer)) { + if (!id_manager()->GetServiceId(c.buffer, &buffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -89,7 +89,7 @@ error::Error GLES2DecoderImpl::HandleBindFramebuffer( uint32 immediate_data_size, const gles2::BindFramebuffer& c) { GLenum target = static_cast<GLenum>(c.target); GLuint framebuffer; - if (!id_manager_->GetServiceId(c.framebuffer, &framebuffer)) { + if (!id_manager()->GetServiceId(c.framebuffer, &framebuffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -105,7 +105,7 @@ error::Error GLES2DecoderImpl::HandleBindRenderbuffer( uint32 immediate_data_size, const gles2::BindRenderbuffer& c) { GLenum target = static_cast<GLenum>(c.target); GLuint renderbuffer; - if (!id_manager_->GetServiceId(c.renderbuffer, &renderbuffer)) { + if (!id_manager()->GetServiceId(c.renderbuffer, &renderbuffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -121,7 +121,7 @@ error::Error GLES2DecoderImpl::HandleBindTexture( uint32 immediate_data_size, const gles2::BindTexture& c) { GLenum target = static_cast<GLenum>(c.target); GLuint texture; - if (!id_manager_->GetServiceId(c.texture, &texture)) { + if (!id_manager()->GetServiceId(c.texture, &texture)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -305,7 +305,7 @@ error::Error GLES2DecoderImpl::HandleColorMask( error::Error GLES2DecoderImpl::HandleCompileShader( uint32 immediate_data_size, const gles2::CompileShader& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -563,12 +563,12 @@ error::Error GLES2DecoderImpl::HandleDepthRangef( error::Error GLES2DecoderImpl::HandleDetachShader( uint32 immediate_data_size, const gles2::DetachShader& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -643,7 +643,7 @@ error::Error GLES2DecoderImpl::HandleFramebufferRenderbuffer( GLenum attachment = static_cast<GLenum>(c.attachment); GLenum renderbuffertarget = static_cast<GLenum>(c.renderbuffertarget); GLuint renderbuffer; - if (!id_manager_->GetServiceId(c.renderbuffer, &renderbuffer)) { + if (!id_manager()->GetServiceId(c.renderbuffer, &renderbuffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -670,7 +670,7 @@ error::Error GLES2DecoderImpl::HandleFramebufferTexture2D( GLenum attachment = static_cast<GLenum>(c.attachment); GLenum textarget = static_cast<GLenum>(c.textarget); GLuint texture; - if (!id_manager_->GetServiceId(c.texture, &texture)) { + if (!id_manager()->GetServiceId(c.texture, &texture)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -943,7 +943,7 @@ error::Error GLES2DecoderImpl::HandleGetIntegerv( error::Error GLES2DecoderImpl::HandleGetProgramiv( uint32 immediate_data_size, const gles2::GetProgramiv& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -967,7 +967,7 @@ error::Error GLES2DecoderImpl::HandleGetProgramiv( error::Error GLES2DecoderImpl::HandleGetProgramInfoLog( uint32 immediate_data_size, const gles2::GetProgramInfoLog& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1018,7 +1018,7 @@ error::Error GLES2DecoderImpl::HandleGetRenderbufferParameteriv( error::Error GLES2DecoderImpl::HandleGetShaderiv( uint32 immediate_data_size, const gles2::GetShaderiv& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1042,7 +1042,7 @@ error::Error GLES2DecoderImpl::HandleGetShaderiv( error::Error GLES2DecoderImpl::HandleGetShaderInfoLog( uint32 immediate_data_size, const gles2::GetShaderInfoLog& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1069,7 +1069,7 @@ error::Error GLES2DecoderImpl::HandleGetShaderInfoLog( error::Error GLES2DecoderImpl::HandleGetShaderSource( uint32 immediate_data_size, const gles2::GetShaderSource& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1211,7 +1211,7 @@ error::Error GLES2DecoderImpl::HandleHint( error::Error GLES2DecoderImpl::HandleIsBuffer( uint32 immediate_data_size, const gles2::IsBuffer& c) { GLuint buffer; - if (!id_manager_->GetServiceId(c.buffer, &buffer)) { + if (!id_manager()->GetServiceId(c.buffer, &buffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1237,7 +1237,7 @@ error::Error GLES2DecoderImpl::HandleIsEnabled( error::Error GLES2DecoderImpl::HandleIsFramebuffer( uint32 immediate_data_size, const gles2::IsFramebuffer& c) { GLuint framebuffer; - if (!id_manager_->GetServiceId(c.framebuffer, &framebuffer)) { + if (!id_manager()->GetServiceId(c.framebuffer, &framebuffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1250,7 +1250,7 @@ error::Error GLES2DecoderImpl::HandleIsFramebuffer( error::Error GLES2DecoderImpl::HandleIsProgram( uint32 immediate_data_size, const gles2::IsProgram& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1263,7 +1263,7 @@ error::Error GLES2DecoderImpl::HandleIsProgram( error::Error GLES2DecoderImpl::HandleIsRenderbuffer( uint32 immediate_data_size, const gles2::IsRenderbuffer& c) { GLuint renderbuffer; - if (!id_manager_->GetServiceId(c.renderbuffer, &renderbuffer)) { + if (!id_manager()->GetServiceId(c.renderbuffer, &renderbuffer)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1276,7 +1276,7 @@ error::Error GLES2DecoderImpl::HandleIsRenderbuffer( error::Error GLES2DecoderImpl::HandleIsShader( uint32 immediate_data_size, const gles2::IsShader& c) { GLuint shader; - if (!id_manager_->GetServiceId(c.shader, &shader)) { + if (!id_manager()->GetServiceId(c.shader, &shader)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1289,7 +1289,7 @@ error::Error GLES2DecoderImpl::HandleIsShader( error::Error GLES2DecoderImpl::HandleIsTexture( uint32 immediate_data_size, const gles2::IsTexture& c) { GLuint texture; - if (!id_manager_->GetServiceId(c.texture, &texture)) { + if (!id_manager()->GetServiceId(c.texture, &texture)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1309,7 +1309,7 @@ error::Error GLES2DecoderImpl::HandleLineWidth( error::Error GLES2DecoderImpl::HandleLinkProgram( uint32 immediate_data_size, const gles2::LinkProgram& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -1471,7 +1471,7 @@ error::Error GLES2DecoderImpl::HandleTexParameterf( SetGLError(GL_INVALID_ENUM); return error::kNoError; } - glTexParameterf(target, pname, param); + DoTexParameterf(target, pname, param); return error::kNoError; } @@ -1494,7 +1494,7 @@ error::Error GLES2DecoderImpl::HandleTexParameterfv( if (params == NULL) { return error::kOutOfBounds; } - glTexParameterfv(target, pname, params); + DoTexParameterfv(target, pname, params); return error::kNoError; } @@ -1517,7 +1517,7 @@ error::Error GLES2DecoderImpl::HandleTexParameterfvImmediate( if (params == NULL) { return error::kOutOfBounds; } - glTexParameterfv(target, pname, params); + DoTexParameterfv(target, pname, params); return error::kNoError; } @@ -1534,7 +1534,7 @@ error::Error GLES2DecoderImpl::HandleTexParameteri( SetGLError(GL_INVALID_ENUM); return error::kNoError; } - glTexParameteri(target, pname, param); + DoTexParameteri(target, pname, param); return error::kNoError; } @@ -1557,7 +1557,7 @@ error::Error GLES2DecoderImpl::HandleTexParameteriv( if (params == NULL) { return error::kOutOfBounds; } - glTexParameteriv(target, pname, params); + DoTexParameteriv(target, pname, params); return error::kNoError; } @@ -1580,7 +1580,7 @@ error::Error GLES2DecoderImpl::HandleTexParameterivImmediate( if (params == NULL) { return error::kOutOfBounds; } - glTexParameteriv(target, pname, params); + DoTexParameteriv(target, pname, params); return error::kNoError; } @@ -1694,7 +1694,7 @@ error::Error GLES2DecoderImpl::HandleUniform1i( uint32 immediate_data_size, const gles2::Uniform1i& c) { GLint location = static_cast<GLint>(c.location); GLint x = static_cast<GLint>(c.x); - glUniform1i(location, x); + DoUniform1i(location, x); return error::kNoError; } @@ -1709,7 +1709,7 @@ error::Error GLES2DecoderImpl::HandleUniform1iv( if (v == NULL) { return error::kOutOfBounds; } - glUniform1iv(location, count, v); + DoUniform1iv(location, count, v); return error::kNoError; } @@ -1724,7 +1724,7 @@ error::Error GLES2DecoderImpl::HandleUniform1ivImmediate( if (v == NULL) { return error::kOutOfBounds; } - glUniform1iv(location, count, v); + DoUniform1iv(location, count, v); return error::kNoError; } @@ -2091,7 +2091,7 @@ error::Error GLES2DecoderImpl::HandleUniformMatrix4fvImmediate( error::Error GLES2DecoderImpl::HandleUseProgram( uint32 immediate_data_size, const gles2::UseProgram& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } @@ -2102,7 +2102,7 @@ error::Error GLES2DecoderImpl::HandleUseProgram( error::Error GLES2DecoderImpl::HandleValidateProgram( uint32 immediate_data_size, const gles2::ValidateProgram& c) { GLuint program; - if (!id_manager_->GetServiceId(c.program, &program)) { + if (!id_manager()->GetServiceId(c.program, &program)) { SetGLError(GL_INVALID_VALUE); return error::kNoError; } diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_mock.h b/gpu/command_buffer/service/gles2_cmd_decoder_mock.h index f782be4..2beff5a 100644 --- a/gpu/command_buffer/service/gles2_cmd_decoder_mock.h +++ b/gpu/command_buffer/service/gles2_cmd_decoder_mock.h @@ -14,9 +14,11 @@ namespace gpu { namespace gles2 { +class ContextGroup; class MockGLES2Decoder : public GLES2Decoder { public: - MockGLES2Decoder() { + explicit MockGLES2Decoder(ContextGroup* group) + : GLES2Decoder(group) { ON_CALL(*this, GetCommandName(testing::_)) .WillByDefault(testing::Return("")); ON_CALL(*this, MakeCurrent()) diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest.cc b/gpu/command_buffer/service/gles2_cmd_decoder_unittest.cc index a656d13..09ddc14 100644 --- a/gpu/command_buffer/service/gles2_cmd_decoder_unittest.cc +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest.cc @@ -3,11 +3,12 @@ // found in the LICENSE file. #include "gpu/command_buffer/service/gles2_cmd_decoder.h" -#include "base/string_util.h" #include "gpu/command_buffer/common/gles2_cmd_format.h" #include "gpu/command_buffer/common/gles2_cmd_utils.h" #include "gpu/command_buffer/service/gl_mock.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h" #include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" #include "gpu/command_buffer/service/program_manager.h" #include "testing/gtest/include/gtest/gtest.h" @@ -26,650 +27,56 @@ using ::testing::StrictMock; namespace gpu { namespace gles2 { -class GLES2DecoderTest : public testing::Test { +class GLES2DecoderTest : public GLES2DecoderTestBase { public: - GLES2DecoderTest() - : client_buffer_id_(100), - client_framebuffer_id_(101), - client_program_id_(102), - client_renderbuffer_id_(103), - client_shader_id_(104), - client_texture_id_(105), - client_element_buffer_id_(106) { - memset(immediate_buffer_, 0xEE, sizeof(immediate_buffer_)); - } - - protected: - static const GLint kMaxTextureSize = 2048; - static const GLint kMaxCubeMapTextureSize = 256; - static const GLint kNumVertexAttribs = 16; - - static const GLuint kServiceBufferId = 301; - static const GLuint kServiceFramebufferId = 302; - static const GLuint kServiceRenderbufferId = 303; - static const GLuint kServiceTextureId = 304; - static const GLuint kServiceProgramId = 305; - static const GLuint kServiceShaderId = 306; - static const GLuint kServiceElementBufferId = 307; - - static const int32 kSharedMemoryId = 401; - static const size_t kSharedBufferSize = 2048; - static const uint32 kSharedMemoryOffset = 132; - static const int32 kInvalidSharedMemoryId = 402; - static const uint32 kInvalidSharedMemoryOffset = kSharedBufferSize + 1; - static const uint32 kInitialResult = 0xBDBDBDBDu; - static const uint8 kInitialMemoryValue = 0xBDu; - - static const uint32 kNewClientId = 501; - static const uint32 kNewServiceId = 502; - static const uint32 kInvalidClientId = 601; - - // Template to call glGenXXX functions. - template <typename T> - void GenHelper(GLuint client_id) { - int8 buffer[sizeof(T) + sizeof(client_id)]; - T& cmd = *reinterpret_cast<T*>(&buffer); - cmd.Init(1, &client_id); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(client_id))); - } - - // This template exists solely so we can specialize it for - // certain commands. - template <typename T, int id> - void SpecializedSetup() { - } - - template <typename T> - T* GetImmediateAs() { - return reinterpret_cast<T*>(immediate_buffer_); - } - - template <typename T, typename Command> - T GetImmediateDataAs(Command* cmd) { - return reinterpret_cast<T>(ImmediateDataAddress(cmd)); - } - - void ClearSharedMemory() { - engine_->ClearSharedMemory(); - } - - virtual void SetUp() { - gl_.reset(new StrictMock<MockGLInterface>()); - ::gles2::GLInterface::SetGLInterface(gl_.get()); - - EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_VERTEX_ATTRIBS, _)) - .WillOnce(SetArgumentPointee<1>(kNumVertexAttribs)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_TEXTURE_SIZE, _)) - .WillOnce(SetArgumentPointee<1>(kMaxTextureSize)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_CUBE_MAP_TEXTURE_SIZE, _)) - .WillOnce(SetArgumentPointee<1>(kMaxCubeMapTextureSize)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, GetError()) - .WillRepeatedly(Return(GL_NO_ERROR)); - - engine_.reset(new StrictMock<MockCommandBufferEngine>()); - Buffer buffer = engine_->GetSharedMemoryBuffer(kSharedMemoryId); - shared_memory_offset_ = kSharedMemoryOffset; - shared_memory_address_ = reinterpret_cast<int8*>(buffer.ptr) + - shared_memory_offset_; - shared_memory_id_ = kSharedMemoryId; - - decoder_.reset(GLES2Decoder::Create()); - decoder_->Initialize(); - decoder_->set_engine(engine_.get()); - - EXPECT_CALL(*gl_, GenBuffersARB(_, _)) - .WillOnce(SetArgumentPointee<1>(kServiceBufferId)) - .RetiresOnSaturation(); - GenHelper<GenBuffersImmediate>(client_buffer_id_); - EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)) - .WillOnce(SetArgumentPointee<1>(kServiceFramebufferId)) - .RetiresOnSaturation(); - GenHelper<GenFramebuffersImmediate>(client_framebuffer_id_); - EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)) - .WillOnce(SetArgumentPointee<1>(kServiceRenderbufferId)) - .RetiresOnSaturation(); - GenHelper<GenRenderbuffersImmediate>(client_renderbuffer_id_); - EXPECT_CALL(*gl_, GenTextures(_, _)) - .WillOnce(SetArgumentPointee<1>(kServiceTextureId)) - .RetiresOnSaturation(); - GenHelper<GenTexturesImmediate>(client_texture_id_); - EXPECT_CALL(*gl_, GenBuffersARB(_, _)) - .WillOnce(SetArgumentPointee<1>(kServiceElementBufferId)) - .RetiresOnSaturation(); - GenHelper<GenBuffersImmediate>(client_element_buffer_id_); - - { - EXPECT_CALL(*gl_, CreateProgram()) - .Times(1) - .WillOnce(Return(kServiceProgramId)) - .RetiresOnSaturation(); - CreateProgram cmd; - cmd.Init(client_program_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - { - EXPECT_CALL(*gl_, CreateShader(_)) - .Times(1) - .WillOnce(Return(kServiceShaderId)) - .RetiresOnSaturation(); - CreateShader cmd; - cmd.Init(GL_VERTEX_SHADER, client_shader_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - EXPECT_EQ(GL_NO_ERROR, GetGLError()); - } - - virtual void TearDown() { - decoder_->Destroy(); - decoder_.reset(); - engine_.reset(); - ::gles2::GLInterface::SetGLInterface(NULL); - gl_.reset(); - } - - template <typename T> - error::Error ExecuteCmd(const T& cmd) { - COMPILE_ASSERT(T::kArgFlags == cmd::kFixed, Cmd_kArgFlags_not_kFixed); - return decoder_->DoCommand(cmd.kCmdId, - ComputeNumEntries(sizeof(cmd)) - 1, - &cmd); - } - - template <typename T> - error::Error ExecuteImmediateCmd(const T& cmd, size_t data_size) { - COMPILE_ASSERT(T::kArgFlags == cmd::kAtLeastN, Cmd_kArgFlags_not_kAtLeastN); - return decoder_->DoCommand(cmd.kCmdId, - ComputeNumEntries(sizeof(cmd) + data_size) - 1, - &cmd); - } - - template <typename T> - T GetSharedMemoryAs() { - return reinterpret_cast<T>(shared_memory_address_); - } - - template <typename T> - T GetSharedMemoryAsWithOffset(uint32 offset) { - void* ptr = reinterpret_cast<int8*>(shared_memory_address_) + offset; - return reinterpret_cast<T>(ptr); - } - - uint32 GetServiceId(uint32 client_id) { - return decoder_->GetServiceIdForTesting(client_id); - } - - // Note that the error is returned as GLint instead of GLenum. - // This is because there is a mismatch in the types of GLenum and - // the error values GL_NO_ERROR, GL_INVALID_ENUM, etc. GLenum is - // typedef'd as unsigned int while the error values are defined as - // integers. This is problematic for template functions such as - // EXPECT_EQ that expect both types to be the same. - GLint GetGLError() { - EXPECT_CALL(*gl_, GetError()) - .WillOnce(Return(GL_NO_ERROR)) - .RetiresOnSaturation(); - GetError cmd; - cmd.Init(shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - return static_cast<GLint>(*GetSharedMemoryAs<GLenum*>()); - } - - void DoBindTexture(GLenum target, GLuint client_id, GLuint service_id) { - EXPECT_CALL(*gl_, BindTexture(target, service_id)) - .Times(1) - .RetiresOnSaturation(); - BindTexture cmd; - cmd.Init(target, client_id); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoTexImage2D(GLenum target, GLint level, GLenum internal_format, - GLsizei width, GLsizei height, GLint border, - GLenum format, GLenum type, - uint32 shared_memory_id, uint32 shared_memory_offset) { - EXPECT_CALL(*gl_, TexImage2D(target, level, internal_format, - width, height, border, format, type, _)) - .Times(1) - .RetiresOnSaturation(); - TexImage2D cmd; - cmd.Init(target, level, internal_format, width, height, border, format, - type, shared_memory_id, shared_memory_offset); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - // Use StrictMock to make 100% sure we know how GL will be called. - scoped_ptr<StrictMock<MockGLInterface> > gl_; - scoped_ptr<GLES2Decoder> decoder_; - - GLuint client_buffer_id_; - GLuint client_framebuffer_id_; - GLuint client_program_id_; - GLuint client_renderbuffer_id_; - GLuint client_shader_id_; - GLuint client_texture_id_; - GLuint client_element_buffer_id_; - - uint32 shared_memory_id_; - uint32 shared_memory_offset_; - void* shared_memory_address_; - - int8 immediate_buffer_[256]; - - private: - class MockCommandBufferEngine : public CommandBufferEngine { - public: - MockCommandBufferEngine() { - data_.reset(new int8[kSharedBufferSize]); - ClearSharedMemory(); - valid_buffer_.ptr = data_.get(); - valid_buffer_.size = kSharedBufferSize; - } - - virtual ~MockCommandBufferEngine() { - } - - Buffer GetSharedMemoryBuffer(int32 shm_id) { - return shm_id == kSharedMemoryId ? valid_buffer_ : invalid_buffer_; - } - - void ClearSharedMemory() { - memset(data_.get(), kInitialMemoryValue, kSharedBufferSize); - } - - void set_token(int32 token) { - DCHECK(false); - } - - // Overridden from CommandBufferEngine. - virtual bool SetGetOffset(int32 offset) { - DCHECK(false); - return false; - } - - // Overridden from CommandBufferEngine. - virtual int32 GetGetOffset() { - DCHECK(false); - return 0; - } - - private: - scoped_array<int8> data_; - Buffer valid_buffer_; - Buffer invalid_buffer_; - }; - - scoped_ptr<StrictMock<MockCommandBufferEngine> > engine_; + GLES2DecoderTest() { } }; -const GLint GLES2DecoderTest::kNumVertexAttribs; -const GLuint GLES2DecoderTest::kServiceBufferId; -const GLuint GLES2DecoderTest::kServiceFramebufferId; -const GLuint GLES2DecoderTest::kServiceRenderbufferId; -const GLuint GLES2DecoderTest::kServiceTextureId; -const GLuint GLES2DecoderTest::kServiceProgramId; -const GLuint GLES2DecoderTest::kServiceShaderId; -const GLuint GLES2DecoderTest::kServiceElementBufferId; -const int32 GLES2DecoderTest::kSharedMemoryId; -const size_t GLES2DecoderTest::kSharedBufferSize; -const uint32 GLES2DecoderTest::kSharedMemoryOffset; -const int32 GLES2DecoderTest::kInvalidSharedMemoryId; -const uint32 GLES2DecoderTest::kInvalidSharedMemoryOffset; -const uint32 GLES2DecoderTest::kInitialResult; -const uint32 GLES2DecoderTest::kNewClientId; -const uint32 GLES2DecoderTest::kNewServiceId; -const uint32 GLES2DecoderTest::kInvalidClientId; - -template <> -void GLES2DecoderTest::SpecializedSetup<LinkProgram, 0>() { - InSequence dummy; - EXPECT_CALL(*gl_, GetProgramiv(kServiceProgramId, GL_ACTIVE_ATTRIBUTES, _)) - .WillOnce(SetArgumentPointee<2>(0)); - EXPECT_CALL( - *gl_, - GetProgramiv(kServiceProgramId, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, _)) - .WillOnce(SetArgumentPointee<2>(0)); - EXPECT_CALL(*gl_, GetProgramiv(kServiceProgramId, GL_ACTIVE_UNIFORMS, _)) - .WillOnce(SetArgumentPointee<2>(0)); - EXPECT_CALL( - *gl_, - GetProgramiv(kServiceProgramId, GL_ACTIVE_UNIFORM_MAX_LENGTH, _)) - .WillOnce(SetArgumentPointee<2>(0)); -}; - -template <> -void GLES2DecoderTest::SpecializedSetup<GenerateMipmap, 0>() { - DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); - DoTexImage2D( - GL_TEXTURE_2D, 0, GL_RGBA, 16, 16, 0, GL_RGBA, GL_UNSIGNED_BYTE, - 0, 0); -}; - -class GLES2DecoderWithShaderTest : public GLES2DecoderTest { +class GLES2DecoderWithShaderTest : public GLES2DecoderWithShaderTestBase { public: GLES2DecoderWithShaderTest() - : GLES2DecoderTest() { - } - - static const GLsizei kNumVertices = 100; - static const GLsizei kNumIndices = 10; - static const int kValidIndexRangeStart = 1; - static const int kValidIndexRangeCount = 7; - static const int kInvalidIndexRangeStart = 0; - static const int kInvalidIndexRangeCount = 7; - static const int kOutOfRangeIndexRangeEnd = 10; - - static const GLint kMaxAttribLength = 10; - static const char* kAttrib1Name; - static const char* kAttrib2Name; - static const char* kAttrib3Name; - static const GLint kAttrib1Size = 1; - static const GLint kAttrib2Size = 1; - static const GLint kAttrib3Size = 1; - static const GLint kAttrib1Location = 0; - static const GLint kAttrib2Location = 1; - static const GLint kAttrib3Location = 2; - static const GLenum kAttrib1Type = GL_FLOAT_VEC4; - static const GLenum kAttrib2Type = GL_FLOAT_VEC2; - static const GLenum kAttrib3Type = GL_FLOAT_VEC3; - static const GLint kInvalidAttribLocation = 30; - static const GLint kBadAttribIndex = kNumVertexAttribs; - - static const GLint kMaxUniformLength = 10; - static const char* kUniform1Name; - static const char* kUniform2Name; - static const char* kUniform3Name; - static const GLint kUniform1Size = 1; - static const GLint kUniform2Size = 3; - static const GLint kUniform3Size = 2; - static const GLint kUniform1Location = 3; - static const GLint kUniform2Location = 10; - static const GLint kUniform2ElementLocation = 12; - static const GLint kUniform3Location = 20; - static const GLenum kUniform1Type = GL_FLOAT_VEC4; - static const GLenum kUniform2Type = GL_INT_VEC2; - static const GLenum kUniform3Type = GL_FLOAT_VEC3; - static const GLint kInvalidUniformLocation = 30; - static const GLint kBadUniformIndex = 1000; - - protected: - struct AttribInfo { - const char* name; - GLint size; - GLenum type; - GLint location; - }; - - struct UniformInfo { - const char* name; - GLint size; - GLenum type; - GLint location; - }; - - virtual void SetUp() { - GLES2DecoderTest::SetUp(); - - { - static AttribInfo attribs[] = { - { kAttrib1Name, kAttrib1Size, kAttrib1Type, kAttrib1Location, }, - { kAttrib2Name, kAttrib2Size, kAttrib2Type, kAttrib2Location, }, - { kAttrib3Name, kAttrib3Size, kAttrib3Type, kAttrib3Location, }, - }; - static UniformInfo uniforms[] = { - { kUniform1Name, kUniform1Size, kUniform1Type, kUniform1Location, }, - { kUniform2Name, kUniform2Size, kUniform2Type, kUniform2Location, }, - { kUniform3Name, kUniform3Size, kUniform3Type, kUniform3Location, }, - }; - SetupShader(attribs, arraysize(attribs), uniforms, arraysize(uniforms), - client_program_id_, kServiceProgramId); - } - - { - EXPECT_CALL(*gl_, UseProgram(kServiceProgramId)) - .Times(1) - .RetiresOnSaturation(); - UseProgram cmd; - cmd.Init(client_program_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - } - - virtual void TearDown() { - GLES2DecoderTest::TearDown(); - } - - void SetupShader(AttribInfo* attribs, size_t num_attribs, - UniformInfo* uniforms, size_t num_uniforms, - GLuint client_id, GLuint service_id) { - LinkProgram cmd; - cmd.Init(client_id); - - { - InSequence s; - EXPECT_CALL(*gl_, LinkProgram(service_id)) - .Times(1) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, GetError()) - .WillOnce(Return(GL_NO_ERROR)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, - GetProgramiv(service_id, GL_ACTIVE_ATTRIBUTES, _)) - .WillOnce(SetArgumentPointee<2>(num_attribs)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, - GetProgramiv(service_id, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, _)) - .WillOnce(SetArgumentPointee<2>(kMaxAttribLength)) - .RetiresOnSaturation(); - for (size_t ii = 0; ii < num_attribs; ++ii) { - const AttribInfo& info = attribs[ii]; - EXPECT_CALL(*gl_, - GetActiveAttrib(service_id, ii, - kMaxAttribLength, _, _, _, _)) - .WillOnce(DoAll( - SetArgumentPointee<3>(strlen(info.name)), - SetArgumentPointee<4>(info.size), - SetArgumentPointee<5>(info.type), - SetArrayArgument<6>(info.name, - info.name + strlen(info.name) + 1))) - .RetiresOnSaturation(); - if (!ProgramManager::IsInvalidPrefix(info.name, strlen(info.name))) { - EXPECT_CALL(*gl_, GetAttribLocation(service_id, - StrEq(info.name))) - .WillOnce(Return(info.location)) - .RetiresOnSaturation(); - } - } - EXPECT_CALL(*gl_, - GetProgramiv(service_id, GL_ACTIVE_UNIFORMS, _)) - .WillOnce(SetArgumentPointee<2>(num_uniforms)) - .RetiresOnSaturation(); - EXPECT_CALL(*gl_, - GetProgramiv(service_id, GL_ACTIVE_UNIFORM_MAX_LENGTH, _)) - .WillOnce(SetArgumentPointee<2>(kMaxUniformLength)) - .RetiresOnSaturation(); - for (size_t ii = 0; ii < num_uniforms; ++ii) { - const UniformInfo& info = uniforms[ii]; - EXPECT_CALL(*gl_, - GetActiveUniform(service_id, ii, - kMaxUniformLength, _, _, _, _)) - .WillOnce(DoAll( - SetArgumentPointee<3>(strlen(info.name)), - SetArgumentPointee<4>(info.size), - SetArgumentPointee<5>(info.type), - SetArrayArgument<6>(info.name, - info.name + strlen(info.name) + 1))) - .RetiresOnSaturation(); - if (!ProgramManager::IsInvalidPrefix(info.name, strlen(info.name))) { - EXPECT_CALL(*gl_, GetUniformLocation(service_id, - StrEq(info.name))) - .WillOnce(Return(info.location)) - .RetiresOnSaturation(); - if (info.size > 1) { - for (GLsizei jj = 1; jj < info.size; ++jj) { - std::string element_name( - std::string(info.name) + "[" + IntToString(jj) + "]"); - EXPECT_CALL(*gl_, GetUniformLocation(service_id, - StrEq(element_name))) - .WillOnce(Return(info.location + jj)) - .RetiresOnSaturation(); - } - } - } - } - } - - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - inline GLvoid* BufferOffset(unsigned i) { - return static_cast<int8 *>(NULL)+(i); + : GLES2DecoderWithShaderTestBase() { } +}; - void DoEnableVertexAttribArray(GLint index) { - EXPECT_CALL(*gl_, EnableVertexAttribArray(index)) - .Times(1) - .RetiresOnSaturation(); - EnableVertexAttribArray cmd; - cmd.Init(index); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } +TEST_F(GLES2DecoderWithShaderTest, DrawArraysNoAttributesSucceeds) { + SetupTexture(); + EXPECT_CALL(*gl_, DrawArrays(GL_TRIANGLES, 0, kNumVertices)) + .Times(1) + .RetiresOnSaturation(); + DrawArrays cmd; + cmd.Init(GL_TRIANGLES, 0, kNumVertices); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GL_NO_ERROR, GetGLError()); +} - void DoBindBuffer(GLenum target, GLuint client_id, GLuint service_id) { - EXPECT_CALL(*gl_, BindBuffer(target, service_id)) +TEST_F(GLES2DecoderWithShaderTest, DrawArraysBadTextureUsesBlack) { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); + // This is an NPOT texture. As the default filtering requires mips + // this should trigger replacing with black textures before rendering. + DoTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 3, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE, + 0, 0); + { + InSequence sequence; + EXPECT_CALL(*gl_, ActiveTexture(GL_TEXTURE0)) .Times(1) .RetiresOnSaturation(); - BindBuffer cmd; - cmd.Init(target, client_id); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoBufferData(GLenum target, GLsizei size) { - EXPECT_CALL(*gl_, BufferData(target, size, _, GL_STREAM_DRAW)) + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, kServiceBlackTexture2dId)) .Times(1) .RetiresOnSaturation(); - BufferData cmd; - cmd.Init(target, size, 0, 0, GL_STREAM_DRAW); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoBufferSubData( - GLenum target, GLint offset, GLsizei size, const void* data) { - EXPECT_CALL(*gl_, BufferSubData(target, offset, size, - shared_memory_address_)) + EXPECT_CALL(*gl_, DrawArrays(GL_TRIANGLES, 0, kNumVertices)) .Times(1) .RetiresOnSaturation(); - memcpy(shared_memory_address_, data, size); - BufferSubData cmd; - cmd.Init(target, offset, size, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoDeleteBuffer(GLuint client_id, GLuint service_id) { - EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(service_id))) + EXPECT_CALL(*gl_, ActiveTexture(GL_TEXTURE0)) .Times(1) .RetiresOnSaturation(); - DeleteBuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - memcpy(shared_memory_address_, &client_id, sizeof(client_id)); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoDeleteProgram(GLuint client_id, GLuint service_id) { - EXPECT_CALL(*gl_, DeleteProgram(service_id)) + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, kServiceTextureId)) .Times(1) .RetiresOnSaturation(); - DeleteProgram cmd; - cmd.Init(client_id); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void DoVertexAttribPointer( - GLuint index, GLint size, GLenum type, GLsizei stride, GLuint offset) { - EXPECT_CALL(*gl_, - VertexAttribPointer(index, size, type, GL_FALSE, stride, - BufferOffset(offset))) + EXPECT_CALL(*gl_, ActiveTexture(GL_TEXTURE0)) .Times(1) .RetiresOnSaturation(); - VertexAttribPointer cmd; - cmd.Init(index, size, GL_FLOAT, GL_FALSE, stride, offset); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - } - - void SetupVertexBuffer() { - DoEnableVertexAttribArray(1); - DoBindBuffer(GL_ARRAY_BUFFER, client_buffer_id_, kServiceBufferId); - GLfloat f = 0; - DoBufferData(GL_ARRAY_BUFFER, kNumVertices * 2 * sizeof(f)); - } - - void SetupIndexBuffer() { - DoBindBuffer(GL_ELEMENT_ARRAY_BUFFER, - client_element_buffer_id_, - kServiceElementBufferId); - static const GLshort indices[] = {100, 1, 2, 3, 4, 5, 6, 7, 100, 9}; - COMPILE_ASSERT(arraysize(indices) == kNumIndices, Indices_is_not_10); - DoBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices)); - DoBufferSubData(GL_ELEMENT_ARRAY_BUFFER, 0, sizeof(indices), indices); - } - - void DeleteVertexBuffer() { - DoDeleteBuffer(client_buffer_id_, kServiceBufferId); } - - void DeleteIndexBuffer() { - DoDeleteBuffer(client_element_buffer_id_, kServiceElementBufferId); - } -}; - -const GLint GLES2DecoderWithShaderTest::kMaxAttribLength; -const GLsizei GLES2DecoderWithShaderTest::kNumVertices; -const GLsizei GLES2DecoderWithShaderTest::kNumIndices; -const int GLES2DecoderWithShaderTest::kValidIndexRangeStart; -const int GLES2DecoderWithShaderTest::kValidIndexRangeCount; -const int GLES2DecoderWithShaderTest::kInvalidIndexRangeStart; -const int GLES2DecoderWithShaderTest::kInvalidIndexRangeCount; -const int GLES2DecoderWithShaderTest::kOutOfRangeIndexRangeEnd; -const char* GLES2DecoderWithShaderTest::kAttrib1Name = "attrib1"; -const char* GLES2DecoderWithShaderTest::kAttrib2Name = "attrib2"; -const char* GLES2DecoderWithShaderTest::kAttrib3Name = "attrib3"; -const GLint GLES2DecoderWithShaderTest::kAttrib1Size; -const GLint GLES2DecoderWithShaderTest::kAttrib2Size; -const GLint GLES2DecoderWithShaderTest::kAttrib3Size; -const GLint GLES2DecoderWithShaderTest::kAttrib1Location; -const GLint GLES2DecoderWithShaderTest::kAttrib2Location; -const GLint GLES2DecoderWithShaderTest::kAttrib3Location; -const GLenum GLES2DecoderWithShaderTest::kAttrib1Type; -const GLenum GLES2DecoderWithShaderTest::kAttrib2Type; -const GLenum GLES2DecoderWithShaderTest::kAttrib3Type; -const GLint GLES2DecoderWithShaderTest::kInvalidAttribLocation; -const GLint GLES2DecoderWithShaderTest::kBadAttribIndex; -const GLint GLES2DecoderWithShaderTest::kMaxUniformLength; -const char* GLES2DecoderWithShaderTest::kUniform1Name = "uniform1"; -const char* GLES2DecoderWithShaderTest::kUniform2Name = "uniform2"; -const char* GLES2DecoderWithShaderTest::kUniform3Name = "uniform3"; -const GLint GLES2DecoderWithShaderTest::kUniform1Size; -const GLint GLES2DecoderWithShaderTest::kUniform2Size; -const GLint GLES2DecoderWithShaderTest::kUniform3Size; -const GLint GLES2DecoderWithShaderTest::kUniform1Location; -const GLint GLES2DecoderWithShaderTest::kUniform2Location; -const GLint GLES2DecoderWithShaderTest::kUniform2ElementLocation; -const GLint GLES2DecoderWithShaderTest::kUniform3Location; -const GLenum GLES2DecoderWithShaderTest::kUniform1Type; -const GLenum GLES2DecoderWithShaderTest::kUniform2Type; -const GLenum GLES2DecoderWithShaderTest::kUniform3Type; -const GLint GLES2DecoderWithShaderTest::kInvalidUniformLocation; -const GLint GLES2DecoderWithShaderTest::kBadUniformIndex; - -TEST_F(GLES2DecoderWithShaderTest, DrawArraysNoAttributesSucceeds) { - EXPECT_CALL(*gl_, DrawArrays(GL_TRIANGLES, 0, kNumVertices)) - .Times(1) - .RetiresOnSaturation(); DrawArrays cmd; cmd.Init(GL_TRIANGLES, 0, kNumVertices); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); @@ -688,6 +95,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawArraysMissingAttributesFails) { } TEST_F(GLES2DecoderWithShaderTest, DrawArraysValidAttributesSucceeds) { + SetupTexture(); SetupVertexBuffer(); DoVertexAttribPointer(1, 2, GL_FLOAT, 0, 0); @@ -713,7 +121,8 @@ TEST_F(GLES2DecoderWithShaderTest, DrawArraysDeletedBufferFails) { EXPECT_EQ(GL_INVALID_OPERATION, GetGLError()); } -TEST_F(GLES2DecoderWithShaderTest, DrawArraysDeletedProgramFails) { +TEST_F(GLES2DecoderWithShaderTest, + DrawArraysDeletedProgramSucceedsWithoutGLCall) { SetupVertexBuffer(); DoVertexAttribPointer(1, 2, GL_FLOAT, 0, 0); DoDeleteProgram(client_program_id_, kServiceProgramId); @@ -723,7 +132,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawArraysDeletedProgramFails) { DrawArrays cmd; cmd.Init(GL_TRIANGLES, 0, kNumVertices); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GL_INVALID_OPERATION, GetGLError()); + EXPECT_EQ(GL_NO_ERROR, GetGLError()); } TEST_F(GLES2DecoderWithShaderTest, DrawArraysWithInvalidModeFails) { @@ -781,6 +190,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawArraysInvalidCountFails) { } TEST_F(GLES2DecoderWithShaderTest, DrawElementsNoAttributesSucceeds) { + SetupTexture(); SetupIndexBuffer(); EXPECT_CALL(*gl_, DrawElements(GL_TRIANGLES, kValidIndexRangeCount, GL_UNSIGNED_SHORT, @@ -808,6 +218,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawElementsMissingAttributesFails) { } TEST_F(GLES2DecoderWithShaderTest, DrawElementsValidAttributesSucceeds) { + SetupTexture(); SetupVertexBuffer(); SetupIndexBuffer(); DoVertexAttribPointer(1, 2, GL_FLOAT, 0, 0); @@ -839,7 +250,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawElementsDeletedBufferFails) { EXPECT_EQ(GL_INVALID_OPERATION, GetGLError()); } -TEST_F(GLES2DecoderWithShaderTest, DrawElementsDeleteProgramFails) { +TEST_F(GLES2DecoderWithShaderTest, DrawElementsDeletedProgramSucceedsNoGLCall) { SetupVertexBuffer(); SetupIndexBuffer(); DoVertexAttribPointer(1, 2, GL_FLOAT, 0, 0); @@ -851,7 +262,7 @@ TEST_F(GLES2DecoderWithShaderTest, DrawElementsDeleteProgramFails) { cmd.Init(GL_TRIANGLES, kValidIndexRangeCount, GL_UNSIGNED_SHORT, kValidIndexRangeStart); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GL_INVALID_OPERATION, GetGLError()); + EXPECT_EQ(GL_NO_ERROR, GetGLError()); } TEST_F(GLES2DecoderWithShaderTest, DrawElementsWithInvalidModeFails) { @@ -980,7 +391,8 @@ TEST_F(GLES2DecoderWithShaderTest, GetUniformivSucceeds) { EXPECT_CALL(*gl_, GetUniformiv(kServiceProgramId, kUniform2Location, _)) .Times(1); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GLES2Util::GetGLDataTypeSize(kUniform2Type), result->size); + EXPECT_EQ(GLES2Util::GetGLDataTypeSizeForUniforms(kUniform2Type), + result->size); } TEST_F(GLES2DecoderWithShaderTest, GetUniformivArrayElementSucceeds) { @@ -994,7 +406,8 @@ TEST_F(GLES2DecoderWithShaderTest, GetUniformivArrayElementSucceeds) { GetUniformiv(kServiceProgramId, kUniform2ElementLocation, _)) .Times(1); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GLES2Util::GetGLDataTypeSize(kUniform2Type), result->size); + EXPECT_EQ(GLES2Util::GetGLDataTypeSizeForUniforms(kUniform2Type), + result->size); } TEST_F(GLES2DecoderWithShaderTest, GetUniformivBadProgramFails) { @@ -1071,7 +484,8 @@ TEST_F(GLES2DecoderWithShaderTest, GetUniformfvSucceeds) { EXPECT_CALL(*gl_, GetUniformfv(kServiceProgramId, kUniform2Location, _)) .Times(1); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GLES2Util::GetGLDataTypeSize(kUniform2Type), result->size); + EXPECT_EQ(GLES2Util::GetGLDataTypeSizeForUniforms(kUniform2Type), + result->size); } TEST_F(GLES2DecoderWithShaderTest, GetUniformfvArrayElementSucceeds) { @@ -1085,7 +499,8 @@ TEST_F(GLES2DecoderWithShaderTest, GetUniformfvArrayElementSucceeds) { GetUniformfv(kServiceProgramId, kUniform2ElementLocation, _)) .Times(1); EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GLES2Util::GetGLDataTypeSize(kUniform2Type), result->size); + EXPECT_EQ(GLES2Util::GetGLDataTypeSizeForUniforms(kUniform2Type), + result->size); } TEST_F(GLES2DecoderWithShaderTest, GetUniformfvBadProgramFails) { @@ -1526,6 +941,55 @@ TEST_F(GLES2DecoderTest, GenerateMipmapWrongFormatsFails) { EXPECT_EQ(GL_INVALID_OPERATION, GetGLError()); } +TEST_F(GLES2DecoderWithShaderTest, Uniform1iValidArgs) { + EXPECT_CALL(*gl_, Uniform1i(kUniform1Location, 2)); + SpecializedSetup<Uniform1i, 0>(); + Uniform1i cmd; + cmd.Init(kUniform1Location, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderWithShaderTest, Uniform1ivValidArgs) { + EXPECT_CALL( + *gl_, Uniform1iv( + kUniform1Location, 2, + reinterpret_cast<const GLint*>(shared_memory_address_))); + SpecializedSetup<Uniform1iv, 0>(); + Uniform1iv cmd; + cmd.Init(kUniform1Location, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderWithShaderTest, Uniform1ivInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform1iv(_, _, _)).Times(0); + SpecializedSetup<Uniform1iv, 0>(); + Uniform1iv cmd; + cmd.Init(kUniform1Location, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderWithShaderTest, Uniform1ivInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform1iv(_, _, _)).Times(0); + SpecializedSetup<Uniform1iv, 0>(); + Uniform1iv cmd; + cmd.Init(kUniform1Location, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderWithShaderTest, Uniform1ivImmediateValidArgs) { + Uniform1ivImmediate& cmd = *GetImmediateAs<Uniform1ivImmediate>(); + EXPECT_CALL( + *gl_, + Uniform1iv(kUniform1Location, 2, + reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform1ivImmediate, 0>(); + GLint temp[1 * 2] = { 0, }; + cmd.Init(kUniform1Location, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + + // TODO(gman): BindAttribLocation // TODO(gman): BindAttribLocationImmediate @@ -1576,8 +1040,6 @@ TEST_F(GLES2DecoderTest, GenerateMipmapWrongFormatsFails) { // TODO(gman): VertexAttribPointer -#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_autogen.h" - } // namespace gles2 } // namespace gpu diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1.cc b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1.cc new file mode 100644 index 0000000..05f9b8a --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1.cc @@ -0,0 +1,47 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" + +#include "gpu/command_buffer/common/gles2_cmd_format.h" +#include "gpu/command_buffer/common/gles2_cmd_utils.h" +#include "gpu/command_buffer/service/gl_mock.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h" +#include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/program_manager.h" +#include "testing/gtest/include/gtest/gtest.h" + +using ::gles2::MockGLInterface; +using ::testing::_; +using ::testing::DoAll; +using ::testing::InSequence; +using ::testing::MatcherCast; +using ::testing::Pointee; +using ::testing::Return; +using ::testing::SetArrayArgument; +using ::testing::SetArgumentPointee; +using ::testing::StrEq; + +namespace gpu { +namespace gles2 { + +class GLES2DecoderTest1 : public GLES2DecoderTestBase { + public: + GLES2DecoderTest1() { } +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<GenerateMipmap, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); + DoTexImage2D( + GL_TEXTURE_2D, 0, GL_RGBA, 16, 16, 0, GL_RGBA, GL_UNSIGNED_BYTE, + 0, 0); +}; + +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_1_autogen.h" + +} // namespace gles2 +} // namespace gpu + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1_autogen.h new file mode 100644 index 0000000..bfbbd25 --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_1_autogen.h @@ -0,0 +1,1241 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// This file is auto-generated. DO NOT EDIT! + +// It is included by gles2_cmd_decoder_unittest_1.cc +#ifndef GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_1_AUTOGEN_H_ +#define GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_1_AUTOGEN_H_ + + +TEST_F(GLES2DecoderTest1, ActiveTextureValidArgs) { + EXPECT_CALL(*gl_, ActiveTexture(1)); + SpecializedSetup<ActiveTexture, 0>(); + ActiveTexture cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, AttachShaderValidArgs) { + EXPECT_CALL(*gl_, AttachShader(kServiceProgramId, kServiceShaderId)); + SpecializedSetup<AttachShader, 0>(); + AttachShader cmd; + cmd.Init(client_program_id_, client_shader_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): BindAttribLocation + +// TODO(gman): BindAttribLocationImmediate + + +TEST_F(GLES2DecoderTest1, BindBufferValidArgs) { + EXPECT_CALL(*gl_, BindBuffer(GL_ARRAY_BUFFER, kServiceBufferId)); + SpecializedSetup<BindBuffer, 0>(); + BindBuffer cmd; + cmd.Init(GL_ARRAY_BUFFER, client_buffer_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindBufferInvalidArgs0_0) { + EXPECT_CALL(*gl_, BindBuffer(_, _)).Times(0); + SpecializedSetup<BindBuffer, 0>(); + BindBuffer cmd; + cmd.Init(GL_RENDERBUFFER, client_buffer_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindFramebufferValidArgs) { + EXPECT_CALL(*gl_, BindFramebufferEXT(GL_FRAMEBUFFER, kServiceFramebufferId)); + SpecializedSetup<BindFramebuffer, 0>(); + BindFramebuffer cmd; + cmd.Init(GL_FRAMEBUFFER, client_framebuffer_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindRenderbufferValidArgs) { + EXPECT_CALL( + *gl_, BindRenderbufferEXT(GL_RENDERBUFFER, kServiceRenderbufferId)); + SpecializedSetup<BindRenderbuffer, 0>(); + BindRenderbuffer cmd; + cmd.Init(GL_RENDERBUFFER, client_renderbuffer_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindTextureValidArgs) { + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, kServiceTextureId)); + SpecializedSetup<BindTexture, 0>(); + BindTexture cmd; + cmd.Init(GL_TEXTURE_2D, client_texture_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindTextureInvalidArgs0_0) { + EXPECT_CALL(*gl_, BindTexture(_, _)).Times(0); + SpecializedSetup<BindTexture, 0>(); + BindTexture cmd; + cmd.Init(GL_TEXTURE_1D, client_texture_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BindTextureInvalidArgs0_1) { + EXPECT_CALL(*gl_, BindTexture(_, _)).Times(0); + SpecializedSetup<BindTexture, 0>(); + BindTexture cmd; + cmd.Init(GL_TEXTURE_3D, client_texture_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendColorValidArgs) { + EXPECT_CALL(*gl_, BlendColor(1, 2, 3, 4)); + SpecializedSetup<BlendColor, 0>(); + BlendColor cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationValidArgs) { + EXPECT_CALL(*gl_, BlendEquation(GL_FUNC_ADD)); + SpecializedSetup<BlendEquation, 0>(); + BlendEquation cmd; + cmd.Init(GL_FUNC_ADD); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationInvalidArgs0_0) { + EXPECT_CALL(*gl_, BlendEquation(_)).Times(0); + SpecializedSetup<BlendEquation, 0>(); + BlendEquation cmd; + cmd.Init(GL_MIN); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationInvalidArgs0_1) { + EXPECT_CALL(*gl_, BlendEquation(_)).Times(0); + SpecializedSetup<BlendEquation, 0>(); + BlendEquation cmd; + cmd.Init(GL_MAX); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationSeparateValidArgs) { + EXPECT_CALL(*gl_, BlendEquationSeparate(GL_FUNC_ADD, GL_FUNC_ADD)); + SpecializedSetup<BlendEquationSeparate, 0>(); + BlendEquationSeparate cmd; + cmd.Init(GL_FUNC_ADD, GL_FUNC_ADD); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationSeparateInvalidArgs0_0) { + EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); + SpecializedSetup<BlendEquationSeparate, 0>(); + BlendEquationSeparate cmd; + cmd.Init(GL_MIN, GL_FUNC_ADD); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationSeparateInvalidArgs0_1) { + EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); + SpecializedSetup<BlendEquationSeparate, 0>(); + BlendEquationSeparate cmd; + cmd.Init(GL_MAX, GL_FUNC_ADD); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationSeparateInvalidArgs1_0) { + EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); + SpecializedSetup<BlendEquationSeparate, 0>(); + BlendEquationSeparate cmd; + cmd.Init(GL_FUNC_ADD, GL_MIN); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendEquationSeparateInvalidArgs1_1) { + EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); + SpecializedSetup<BlendEquationSeparate, 0>(); + BlendEquationSeparate cmd; + cmd.Init(GL_FUNC_ADD, GL_MAX); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendFuncValidArgs) { + EXPECT_CALL(*gl_, BlendFunc(GL_ZERO, GL_ZERO)); + SpecializedSetup<BlendFunc, 0>(); + BlendFunc cmd; + cmd.Init(GL_ZERO, GL_ZERO); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, BlendFuncSeparateValidArgs) { + EXPECT_CALL(*gl_, BlendFuncSeparate(GL_ZERO, GL_ZERO, GL_ZERO, GL_ZERO)); + SpecializedSetup<BlendFuncSeparate, 0>(); + BlendFuncSeparate cmd; + cmd.Init(GL_ZERO, GL_ZERO, GL_ZERO, GL_ZERO); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): BufferData + +// TODO(gman): BufferDataImmediate + +// TODO(gman): BufferSubData + +// TODO(gman): BufferSubDataImmediate + + +TEST_F(GLES2DecoderTest1, CheckFramebufferStatusValidArgs) { + EXPECT_CALL(*gl_, CheckFramebufferStatusEXT(GL_FRAMEBUFFER)); + SpecializedSetup<CheckFramebufferStatus, 0>(); + CheckFramebufferStatus cmd; + cmd.Init(GL_FRAMEBUFFER); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, ClearValidArgs) { + EXPECT_CALL(*gl_, Clear(1)); + SpecializedSetup<Clear, 0>(); + Clear cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, ClearColorValidArgs) { + EXPECT_CALL(*gl_, ClearColor(1, 2, 3, 4)); + SpecializedSetup<ClearColor, 0>(); + ClearColor cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, ClearDepthfValidArgs) { + EXPECT_CALL(*gl_, ClearDepth(1)); + SpecializedSetup<ClearDepthf, 0>(); + ClearDepthf cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, ClearStencilValidArgs) { + EXPECT_CALL(*gl_, ClearStencil(1)); + SpecializedSetup<ClearStencil, 0>(); + ClearStencil cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, ColorMaskValidArgs) { + EXPECT_CALL(*gl_, ColorMask(1, 2, 3, 4)); + SpecializedSetup<ColorMask, 0>(); + ColorMask cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): CompileShader +// TODO(gman): CompressedTexImage2D + +// TODO(gman): CompressedTexImage2DImmediate + +// TODO(gman): CompressedTexSubImage2D + +// TODO(gman): CompressedTexSubImage2DImmediate + + +TEST_F(GLES2DecoderTest1, CopyTexImage2DValidArgs) { + EXPECT_CALL(*gl_, CopyTexImage2D(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8)); + SpecializedSetup<CopyTexImage2D, 0>(); + CopyTexImage2D cmd; + cmd.Init(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, CopyTexImage2DInvalidArgs0_0) { + EXPECT_CALL(*gl_, CopyTexImage2D(_, _, _, _, _, _, _, _)).Times(0); + SpecializedSetup<CopyTexImage2D, 0>(); + CopyTexImage2D cmd; + cmd.Init(GL_PROXY_TEXTURE_CUBE_MAP, 2, 3, 4, 5, 6, 7, 8); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, CopyTexSubImage2DValidArgs) { + EXPECT_CALL(*gl_, CopyTexSubImage2D(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8)); + SpecializedSetup<CopyTexSubImage2D, 0>(); + CopyTexSubImage2D cmd; + cmd.Init(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, CopyTexSubImage2DInvalidArgs0_0) { + EXPECT_CALL(*gl_, CopyTexSubImage2D(_, _, _, _, _, _, _, _)).Times(0); + SpecializedSetup<CopyTexSubImage2D, 0>(); + CopyTexSubImage2D cmd; + cmd.Init(GL_PROXY_TEXTURE_CUBE_MAP, 2, 3, 4, 5, 6, 7, 8); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, CreateProgramValidArgs) { + EXPECT_CALL(*gl_, CreateProgram()) + .WillOnce(Return(kNewServiceId)); + SpecializedSetup<CreateProgram, 0>(); + CreateProgram cmd; + cmd.Init(kNewClientId); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, CreateShaderValidArgs) { + EXPECT_CALL(*gl_, CreateShader(GL_VERTEX_SHADER)) + .WillOnce(Return(kNewServiceId)); + SpecializedSetup<CreateShader, 0>(); + CreateShader cmd; + cmd.Init(GL_VERTEX_SHADER, kNewClientId); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, CullFaceValidArgs) { + EXPECT_CALL(*gl_, CullFace(GL_FRONT)); + SpecializedSetup<CullFace, 0>(); + CullFace cmd; + cmd.Init(GL_FRONT); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DeleteBuffersValidArgs) { + EXPECT_CALL( + *gl_, + DeleteBuffersARB(1, Pointee(kServiceBufferId))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = client_buffer_id_; + SpecializedSetup<DeleteBuffers, 0>(); + DeleteBuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteBuffersInvalidArgs) { + EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(0))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; + SpecializedSetup<DeleteBuffers, 0>(); + DeleteBuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DeleteBuffersImmediateValidArgs) { + EXPECT_CALL( + *gl_, + DeleteBuffersARB(1, Pointee(kServiceBufferId))) + .Times(1); + DeleteBuffersImmediate& cmd = *GetImmediateAs<DeleteBuffersImmediate>(); + SpecializedSetup<DeleteBuffersImmediate, 0>(); + cmd.Init(1, &client_buffer_id_); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(client_buffer_id_))); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteBuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(0))) + .Times(1); + DeleteBuffersImmediate& cmd = *GetImmediateAs<DeleteBuffersImmediate>(); + SpecializedSetup<DeleteBuffersImmediate, 0>(); + GLuint temp = kInvalidClientId; + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest1, DeleteFramebuffersValidArgs) { + EXPECT_CALL( + *gl_, + DeleteFramebuffersEXT(1, Pointee(kServiceFramebufferId))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = client_framebuffer_id_; + SpecializedSetup<DeleteFramebuffers, 0>(); + DeleteFramebuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteFramebuffersInvalidArgs) { + EXPECT_CALL(*gl_, DeleteFramebuffersEXT(1, Pointee(0))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; + SpecializedSetup<DeleteFramebuffers, 0>(); + DeleteFramebuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DeleteFramebuffersImmediateValidArgs) { + EXPECT_CALL( + *gl_, + DeleteFramebuffersEXT(1, Pointee(kServiceFramebufferId))) + .Times(1); + DeleteFramebuffersImmediate& cmd = + *GetImmediateAs<DeleteFramebuffersImmediate>(); + SpecializedSetup<DeleteFramebuffersImmediate, 0>(); + cmd.Init(1, &client_framebuffer_id_); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(client_framebuffer_id_))); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteFramebuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, DeleteFramebuffersEXT(1, Pointee(0))) + .Times(1); + DeleteFramebuffersImmediate& cmd = + *GetImmediateAs<DeleteFramebuffersImmediate>(); + SpecializedSetup<DeleteFramebuffersImmediate, 0>(); + GLuint temp = kInvalidClientId; + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): DeleteProgram + + +TEST_F(GLES2DecoderTest1, DeleteRenderbuffersValidArgs) { + EXPECT_CALL( + *gl_, + DeleteRenderbuffersEXT(1, Pointee(kServiceRenderbufferId))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = client_renderbuffer_id_; + SpecializedSetup<DeleteRenderbuffers, 0>(); + DeleteRenderbuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteRenderbuffersInvalidArgs) { + EXPECT_CALL(*gl_, DeleteRenderbuffersEXT(1, Pointee(0))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; + SpecializedSetup<DeleteRenderbuffers, 0>(); + DeleteRenderbuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DeleteRenderbuffersImmediateValidArgs) { + EXPECT_CALL( + *gl_, + DeleteRenderbuffersEXT(1, Pointee(kServiceRenderbufferId))) + .Times(1); + DeleteRenderbuffersImmediate& cmd = + *GetImmediateAs<DeleteRenderbuffersImmediate>(); + SpecializedSetup<DeleteRenderbuffersImmediate, 0>(); + cmd.Init(1, &client_renderbuffer_id_); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(client_renderbuffer_id_))); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteRenderbuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, DeleteRenderbuffersEXT(1, Pointee(0))) + .Times(1); + DeleteRenderbuffersImmediate& cmd = + *GetImmediateAs<DeleteRenderbuffersImmediate>(); + SpecializedSetup<DeleteRenderbuffersImmediate, 0>(); + GLuint temp = kInvalidClientId; + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): DeleteShader + + +TEST_F(GLES2DecoderTest1, DeleteTexturesValidArgs) { + EXPECT_CALL( + *gl_, + DeleteTextures(1, Pointee(kServiceTextureId))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = client_texture_id_; + SpecializedSetup<DeleteTextures, 0>(); + DeleteTextures cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteTexturesInvalidArgs) { + EXPECT_CALL(*gl_, DeleteTextures(1, Pointee(0))) + .Times(1); + GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; + SpecializedSetup<DeleteTextures, 0>(); + DeleteTextures cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DeleteTexturesImmediateValidArgs) { + EXPECT_CALL( + *gl_, + DeleteTextures(1, Pointee(kServiceTextureId))) + .Times(1); + DeleteTexturesImmediate& cmd = *GetImmediateAs<DeleteTexturesImmediate>(); + SpecializedSetup<DeleteTexturesImmediate, 0>(); + cmd.Init(1, &client_texture_id_); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(client_texture_id_))); + EXPECT_EQ(GetServiceId(kNewClientId), 0u); +} + +TEST_F(GLES2DecoderTest1, DeleteTexturesImmediateInvalidArgs) { + EXPECT_CALL(*gl_, DeleteTextures(1, Pointee(0))) + .Times(1); + DeleteTexturesImmediate& cmd = *GetImmediateAs<DeleteTexturesImmediate>(); + SpecializedSetup<DeleteTexturesImmediate, 0>(); + GLuint temp = kInvalidClientId; + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest1, DepthFuncValidArgs) { + EXPECT_CALL(*gl_, DepthFunc(GL_NEVER)); + SpecializedSetup<DepthFunc, 0>(); + DepthFunc cmd; + cmd.Init(GL_NEVER); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DepthMaskValidArgs) { + EXPECT_CALL(*gl_, DepthMask(1)); + SpecializedSetup<DepthMask, 0>(); + DepthMask cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DepthRangefValidArgs) { + EXPECT_CALL(*gl_, DepthRange(1, 2)); + SpecializedSetup<DepthRangef, 0>(); + DepthRangef cmd; + cmd.Init(1, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DetachShaderValidArgs) { + EXPECT_CALL(*gl_, DetachShader(kServiceProgramId, kServiceShaderId)); + SpecializedSetup<DetachShader, 0>(); + DetachShader cmd; + cmd.Init(client_program_id_, client_shader_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DisableValidArgs) { + EXPECT_CALL(*gl_, Disable(GL_BLEND)); + SpecializedSetup<Disable, 0>(); + Disable cmd; + cmd.Init(GL_BLEND); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DisableInvalidArgs0_0) { + EXPECT_CALL(*gl_, Disable(_)).Times(0); + SpecializedSetup<Disable, 0>(); + Disable cmd; + cmd.Init(GL_CLIP_PLANE0); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DisableInvalidArgs0_1) { + EXPECT_CALL(*gl_, Disable(_)).Times(0); + SpecializedSetup<Disable, 0>(); + Disable cmd; + cmd.Init(GL_POINT_SPRITE); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, DisableVertexAttribArrayValidArgs) { + EXPECT_CALL(*gl_, DisableVertexAttribArray(1)); + SpecializedSetup<DisableVertexAttribArray, 0>(); + DisableVertexAttribArray cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): DrawArrays +// TODO(gman): DrawElements + + +TEST_F(GLES2DecoderTest1, EnableValidArgs) { + EXPECT_CALL(*gl_, Enable(GL_BLEND)); + SpecializedSetup<Enable, 0>(); + Enable cmd; + cmd.Init(GL_BLEND); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, EnableInvalidArgs0_0) { + EXPECT_CALL(*gl_, Enable(_)).Times(0); + SpecializedSetup<Enable, 0>(); + Enable cmd; + cmd.Init(GL_CLIP_PLANE0); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, EnableInvalidArgs0_1) { + EXPECT_CALL(*gl_, Enable(_)).Times(0); + SpecializedSetup<Enable, 0>(); + Enable cmd; + cmd.Init(GL_POINT_SPRITE); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, EnableVertexAttribArrayValidArgs) { + EXPECT_CALL(*gl_, EnableVertexAttribArray(1)); + SpecializedSetup<EnableVertexAttribArray, 0>(); + EnableVertexAttribArray cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FinishValidArgs) { + EXPECT_CALL(*gl_, Finish()); + SpecializedSetup<Finish, 0>(); + Finish cmd; + cmd.Init(); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FlushValidArgs) { + EXPECT_CALL(*gl_, Flush()); + SpecializedSetup<Flush, 0>(); + Flush cmd; + cmd.Init(); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FramebufferRenderbufferValidArgs) { + EXPECT_CALL( + *gl_, FramebufferRenderbufferEXT( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_RENDERBUFFER, + kServiceRenderbufferId)); + SpecializedSetup<FramebufferRenderbuffer, 0>(); + FramebufferRenderbuffer cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_RENDERBUFFER, + client_renderbuffer_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FramebufferTexture2DValidArgs) { + EXPECT_CALL( + *gl_, FramebufferTexture2DEXT( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, + kServiceTextureId, 5)); + SpecializedSetup<FramebufferTexture2D, 0>(); + FramebufferTexture2D cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, client_texture_id_, + 5); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FramebufferTexture2DInvalidArgs2_0) { + EXPECT_CALL(*gl_, FramebufferTexture2DEXT(_, _, _, _, _)).Times(0); + SpecializedSetup<FramebufferTexture2D, 0>(); + FramebufferTexture2D cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_PROXY_TEXTURE_CUBE_MAP, + client_texture_id_, 5); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, FrontFaceValidArgs) { + EXPECT_CALL(*gl_, FrontFace(GL_CW)); + SpecializedSetup<FrontFace, 0>(); + FrontFace cmd; + cmd.Init(GL_CW); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenBuffersValidArgs) { + EXPECT_CALL(*gl_, GenBuffersARB(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; + SpecializedSetup<GenBuffers, 0>(); + GenBuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenBuffersInvalidArgs) { + EXPECT_CALL(*gl_, GenBuffersARB(_, _)).Times(0); + GetSharedMemoryAs<GLuint*>()[0] = client_buffer_id_; + SpecializedSetup<GenBuffers, 0>(); + GenBuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenBuffersImmediateValidArgs) { + EXPECT_CALL(*gl_, GenBuffersARB(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GenBuffersImmediate& cmd = *GetImmediateAs<GenBuffersImmediate>(); + GLuint temp = kNewClientId; + SpecializedSetup<GenBuffersImmediate, 0>(); + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenBuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, GenBuffersARB(_, _)).Times(0); + GenBuffersImmediate& cmd = *GetImmediateAs<GenBuffersImmediate>(); + SpecializedSetup<GenBuffersImmediate, 0>(); + cmd.Init(1, &client_buffer_id_); + EXPECT_EQ(error::kInvalidArguments, + ExecuteImmediateCmd(cmd, sizeof(&client_buffer_id_))); +} + +TEST_F(GLES2DecoderTest1, GenerateMipmapValidArgs) { + EXPECT_CALL(*gl_, GenerateMipmapEXT(GL_TEXTURE_2D)); + SpecializedSetup<GenerateMipmap, 0>(); + GenerateMipmap cmd; + cmd.Init(GL_TEXTURE_2D); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenerateMipmapInvalidArgs0_0) { + EXPECT_CALL(*gl_, GenerateMipmapEXT(_)).Times(0); + SpecializedSetup<GenerateMipmap, 0>(); + GenerateMipmap cmd; + cmd.Init(GL_TEXTURE_1D); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenerateMipmapInvalidArgs0_1) { + EXPECT_CALL(*gl_, GenerateMipmapEXT(_)).Times(0); + SpecializedSetup<GenerateMipmap, 0>(); + GenerateMipmap cmd; + cmd.Init(GL_TEXTURE_3D); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenFramebuffersValidArgs) { + EXPECT_CALL(*gl_, GenFramebuffersEXT(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; + SpecializedSetup<GenFramebuffers, 0>(); + GenFramebuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenFramebuffersInvalidArgs) { + EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)).Times(0); + GetSharedMemoryAs<GLuint*>()[0] = client_framebuffer_id_; + SpecializedSetup<GenFramebuffers, 0>(); + GenFramebuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenFramebuffersImmediateValidArgs) { + EXPECT_CALL(*gl_, GenFramebuffersEXT(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GenFramebuffersImmediate& cmd = *GetImmediateAs<GenFramebuffersImmediate>(); + GLuint temp = kNewClientId; + SpecializedSetup<GenFramebuffersImmediate, 0>(); + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenFramebuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)).Times(0); + GenFramebuffersImmediate& cmd = *GetImmediateAs<GenFramebuffersImmediate>(); + SpecializedSetup<GenFramebuffersImmediate, 0>(); + cmd.Init(1, &client_framebuffer_id_); + EXPECT_EQ(error::kInvalidArguments, + ExecuteImmediateCmd(cmd, sizeof(&client_framebuffer_id_))); +} + +TEST_F(GLES2DecoderTest1, GenRenderbuffersValidArgs) { + EXPECT_CALL(*gl_, GenRenderbuffersEXT(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; + SpecializedSetup<GenRenderbuffers, 0>(); + GenRenderbuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenRenderbuffersInvalidArgs) { + EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)).Times(0); + GetSharedMemoryAs<GLuint*>()[0] = client_renderbuffer_id_; + SpecializedSetup<GenRenderbuffers, 0>(); + GenRenderbuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenRenderbuffersImmediateValidArgs) { + EXPECT_CALL(*gl_, GenRenderbuffersEXT(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GenRenderbuffersImmediate& cmd = + *GetImmediateAs<GenRenderbuffersImmediate>(); + GLuint temp = kNewClientId; + SpecializedSetup<GenRenderbuffersImmediate, 0>(); + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenRenderbuffersImmediateInvalidArgs) { + EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)).Times(0); + GenRenderbuffersImmediate& cmd = + *GetImmediateAs<GenRenderbuffersImmediate>(); + SpecializedSetup<GenRenderbuffersImmediate, 0>(); + cmd.Init(1, &client_renderbuffer_id_); + EXPECT_EQ(error::kInvalidArguments, + ExecuteImmediateCmd(cmd, sizeof(&client_renderbuffer_id_))); +} + +TEST_F(GLES2DecoderTest1, GenTexturesValidArgs) { + EXPECT_CALL(*gl_, GenTextures(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; + SpecializedSetup<GenTextures, 0>(); + GenTextures cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenTexturesInvalidArgs) { + EXPECT_CALL(*gl_, GenTextures(_, _)).Times(0); + GetSharedMemoryAs<GLuint*>()[0] = client_texture_id_; + SpecializedSetup<GenTextures, 0>(); + GenTextures cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GenTexturesImmediateValidArgs) { + EXPECT_CALL(*gl_, GenTextures(1, _)) + .WillOnce(SetArgumentPointee<1>(kNewServiceId)); + GenTexturesImmediate& cmd = *GetImmediateAs<GenTexturesImmediate>(); + GLuint temp = kNewClientId; + SpecializedSetup<GenTexturesImmediate, 0>(); + cmd.Init(1, &temp); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); + EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); +} + +TEST_F(GLES2DecoderTest1, GenTexturesImmediateInvalidArgs) { + EXPECT_CALL(*gl_, GenTextures(_, _)).Times(0); + GenTexturesImmediate& cmd = *GetImmediateAs<GenTexturesImmediate>(); + SpecializedSetup<GenTexturesImmediate, 0>(); + cmd.Init(1, &client_texture_id_); + EXPECT_EQ(error::kInvalidArguments, + ExecuteImmediateCmd(cmd, sizeof(&client_texture_id_))); +} +// TODO(gman): GetActiveAttrib + +// TODO(gman): GetActiveUniform + +// TODO(gman): GetAttachedShaders + +// TODO(gman): GetAttribLocation + +// TODO(gman): GetAttribLocationImmediate + + +TEST_F(GLES2DecoderTest1, GetBooleanvValidArgs) { + EXPECT_CALL( + *gl_, GetBooleanv( + 1, reinterpret_cast<GLboolean*>(shared_memory_address_))); + SpecializedSetup<GetBooleanv, 0>(); + GetBooleanv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBooleanvInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetBooleanv(_, _)).Times(0); + SpecializedSetup<GetBooleanv, 0>(); + GetBooleanv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBooleanvInvalidArgs1_1) { + EXPECT_CALL(*gl_, GetBooleanv(_, _)).Times(0); + SpecializedSetup<GetBooleanv, 0>(); + GetBooleanv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBufferParameterivValidArgs) { + EXPECT_CALL( + *gl_, GetBufferParameteriv( + GL_ARRAY_BUFFER, GL_BUFFER_SIZE, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetBufferParameteriv, 0>(); + GetBufferParameteriv cmd; + cmd.Init( + GL_ARRAY_BUFFER, GL_BUFFER_SIZE, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBufferParameterivInvalidArgs0_0) { + EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetBufferParameteriv, 0>(); + GetBufferParameteriv cmd; + cmd.Init( + GL_RENDERBUFFER, GL_BUFFER_SIZE, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBufferParameterivInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetBufferParameteriv, 0>(); + GetBufferParameteriv cmd; + cmd.Init( + GL_ARRAY_BUFFER, GL_PIXEL_PACK_BUFFER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBufferParameterivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetBufferParameteriv, 0>(); + GetBufferParameteriv cmd; + cmd.Init(GL_ARRAY_BUFFER, GL_BUFFER_SIZE, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetBufferParameterivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetBufferParameteriv, 0>(); + GetBufferParameteriv cmd; + cmd.Init( + GL_ARRAY_BUFFER, GL_BUFFER_SIZE, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetErrorValidArgs) { + EXPECT_CALL(*gl_, GetError()); + SpecializedSetup<GetError, 0>(); + GetError cmd; + cmd.Init(shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFloatvValidArgs) { + EXPECT_CALL( + *gl_, GetFloatv(1, reinterpret_cast<GLfloat*>(shared_memory_address_))); + SpecializedSetup<GetFloatv, 0>(); + GetFloatv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFloatvInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetFloatv(_, _)).Times(0); + SpecializedSetup<GetFloatv, 0>(); + GetFloatv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFloatvInvalidArgs1_1) { + EXPECT_CALL(*gl_, GetFloatv(_, _)).Times(0); + SpecializedSetup<GetFloatv, 0>(); + GetFloatv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFramebufferAttachmentParameterivValidArgs) { + EXPECT_CALL( + *gl_, GetFramebufferAttachmentParameterivEXT( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); + GetFramebufferAttachmentParameteriv cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFramebufferAttachmentParameterivInvalidArgs3_0) { + EXPECT_CALL( + *gl_, GetFramebufferAttachmentParameterivEXT(_, _, _, _)).Times(0); + SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); + GetFramebufferAttachmentParameteriv cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetFramebufferAttachmentParameterivInvalidArgs3_1) { + EXPECT_CALL( + *gl_, GetFramebufferAttachmentParameterivEXT(_, _, _, _)).Times(0); + SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); + GetFramebufferAttachmentParameteriv cmd; + cmd.Init( + GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, + GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetIntegervValidArgs) { + EXPECT_CALL( + *gl_, GetIntegerv(1, reinterpret_cast<GLint*>(shared_memory_address_))); + SpecializedSetup<GetIntegerv, 0>(); + GetIntegerv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetIntegervInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetIntegerv(_, _)).Times(0); + SpecializedSetup<GetIntegerv, 0>(); + GetIntegerv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetIntegervInvalidArgs1_1) { + EXPECT_CALL(*gl_, GetIntegerv(_, _)).Times(0); + SpecializedSetup<GetIntegerv, 0>(); + GetIntegerv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetProgramivValidArgs) { + EXPECT_CALL( + *gl_, GetProgramiv( + kServiceProgramId, GL_DELETE_STATUS, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetProgramiv, 0>(); + GetProgramiv cmd; + cmd.Init( + client_program_id_, GL_DELETE_STATUS, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetProgramivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetProgramiv(_, _, _)).Times(0); + SpecializedSetup<GetProgramiv, 0>(); + GetProgramiv cmd; + cmd.Init(client_program_id_, GL_DELETE_STATUS, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetProgramivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetProgramiv(_, _, _)).Times(0); + SpecializedSetup<GetProgramiv, 0>(); + GetProgramiv cmd; + cmd.Init( + client_program_id_, GL_DELETE_STATUS, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} +// TODO(gman): GetProgramInfoLog + + +TEST_F(GLES2DecoderTest1, GetRenderbufferParameterivValidArgs) { + EXPECT_CALL( + *gl_, GetRenderbufferParameterivEXT( + GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetRenderbufferParameteriv, 0>(); + GetRenderbufferParameteriv cmd; + cmd.Init( + GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetRenderbufferParameterivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetRenderbufferParameterivEXT(_, _, _)).Times(0); + SpecializedSetup<GetRenderbufferParameteriv, 0>(); + GetRenderbufferParameteriv cmd; + cmd.Init(GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetRenderbufferParameterivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetRenderbufferParameterivEXT(_, _, _)).Times(0); + SpecializedSetup<GetRenderbufferParameteriv, 0>(); + GetRenderbufferParameteriv cmd; + cmd.Init( + GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetShaderivValidArgs) { + EXPECT_CALL( + *gl_, GetShaderiv( + kServiceShaderId, GL_SHADER_TYPE, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetShaderiv, 0>(); + GetShaderiv cmd; + cmd.Init( + client_shader_id_, GL_SHADER_TYPE, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetShaderivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetShaderiv(_, _, _)).Times(0); + SpecializedSetup<GetShaderiv, 0>(); + GetShaderiv cmd; + cmd.Init(client_shader_id_, GL_SHADER_TYPE, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetShaderivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetShaderiv(_, _, _)).Times(0); + SpecializedSetup<GetShaderiv, 0>(); + GetShaderiv cmd; + cmd.Init( + client_shader_id_, GL_SHADER_TYPE, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} +// TODO(gman): GetShaderInfoLog + +// TODO(gman): GetShaderPrecisionFormat + +// TODO(gman): GetShaderSource + + +TEST_F(GLES2DecoderTest1, GetStringValidArgs) { + EXPECT_CALL(*gl_, GetString(GL_VENDOR)); + SpecializedSetup<GetString, 0>(); + GetString cmd; + cmd.Init(GL_VENDOR); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterfvValidArgs) { + EXPECT_CALL( + *gl_, GetTexParameterfv( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<GLfloat*>( + shared_memory_address_))); + SpecializedSetup<GetTexParameterfv, 0>(); + GetTexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterfvInvalidArgs0_0) { + EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameterfv, 0>(); + GetTexParameterfv cmd; + cmd.Init( + GL_PROXY_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterfvInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameterfv, 0>(); + GetTexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterfvInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameterfv, 0>(); + GetTexParameterfv cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterfvInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameterfv, 0>(); + GetTexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterivValidArgs) { + EXPECT_CALL( + *gl_, GetTexParameteriv( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetTexParameteriv, 0>(); + GetTexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterivInvalidArgs0_0) { + EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameteriv, 0>(); + GetTexParameteriv cmd; + cmd.Init( + GL_PROXY_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterivInvalidArgs1_0) { + EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameteriv, 0>(); + GetTexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameteriv, 0>(); + GetTexParameteriv cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest1, GetTexParameterivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); + SpecializedSetup<GetTexParameteriv, 0>(); + GetTexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} +#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_1_AUTOGEN_H_ + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2.cc b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2.cc new file mode 100644 index 0000000..89cada4 --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2.cc @@ -0,0 +1,90 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" + +#include "gpu/command_buffer/common/gles2_cmd_format.h" +#include "gpu/command_buffer/common/gles2_cmd_utils.h" +#include "gpu/command_buffer/service/gl_mock.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h" +#include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/program_manager.h" +#include "testing/gtest/include/gtest/gtest.h" + +using ::gles2::MockGLInterface; +using ::testing::_; +using ::testing::DoAll; +using ::testing::InSequence; +using ::testing::MatcherCast; +using ::testing::Pointee; +using ::testing::Return; +using ::testing::SetArrayArgument; +using ::testing::SetArgumentPointee; +using ::testing::StrEq; + +namespace gpu { +namespace gles2 { + +class GLES2DecoderTest2 : public GLES2DecoderTestBase { + public: + GLES2DecoderTest2() { } +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<LinkProgram, 0>() { + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + InSequence dummy; + EXPECT_CALL(*gl_, GetProgramiv(kServiceProgramId, GL_ACTIVE_ATTRIBUTES, _)) + .WillOnce(SetArgumentPointee<2>(0)); + EXPECT_CALL( + *gl_, + GetProgramiv(kServiceProgramId, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, _)) + .WillOnce(SetArgumentPointee<2>(0)); + EXPECT_CALL(*gl_, GetProgramiv(kServiceProgramId, GL_ACTIVE_UNIFORMS, _)) + .WillOnce(SetArgumentPointee<2>(0)); + EXPECT_CALL( + *gl_, + GetProgramiv(kServiceProgramId, GL_ACTIVE_UNIFORM_MAX_LENGTH, _)) + .WillOnce(SetArgumentPointee<2>(0)); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameterf, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameteri, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameterfv, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameterfvImmediate, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameteriv, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +template <> +void GLES2DecoderTestBase::SpecializedSetup<TexParameterivImmediate, 0>() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); +}; + +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_2_autogen.h" + +} // namespace gles2 +} // namespace gpu + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2_autogen.h new file mode 100644 index 0000000..e9215e7 --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_2_autogen.h @@ -0,0 +1,1278 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// This file is auto-generated. DO NOT EDIT! + +// It is included by gles2_cmd_decoder_unittest_2.cc +#ifndef GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_2_AUTOGEN_H_ +#define GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_2_AUTOGEN_H_ + +// TODO(gman): GetUniformfv + +// TODO(gman): GetUniformiv + +// TODO(gman): GetUniformLocation + +// TODO(gman): GetUniformLocationImmediate + + +TEST_F(GLES2DecoderTest2, GetVertexAttribfvValidArgs) { + EXPECT_CALL( + *gl_, GetVertexAttribfv( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, reinterpret_cast<GLfloat*>( + shared_memory_address_))); + SpecializedSetup<GetVertexAttribfv, 0>(); + GetVertexAttribfv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, GetVertexAttribfvInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetVertexAttribfv(_, _, _)).Times(0); + SpecializedSetup<GetVertexAttribfv, 0>(); + GetVertexAttribfv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, GetVertexAttribfvInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetVertexAttribfv(_, _, _)).Times(0); + SpecializedSetup<GetVertexAttribfv, 0>(); + GetVertexAttribfv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, GetVertexAttribivValidArgs) { + EXPECT_CALL( + *gl_, GetVertexAttribiv( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, reinterpret_cast<GLint*>( + shared_memory_address_))); + SpecializedSetup<GetVertexAttribiv, 0>(); + GetVertexAttribiv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, GetVertexAttribivInvalidArgs2_0) { + EXPECT_CALL(*gl_, GetVertexAttribiv(_, _, _)).Times(0); + SpecializedSetup<GetVertexAttribiv, 0>(); + GetVertexAttribiv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, GetVertexAttribivInvalidArgs2_1) { + EXPECT_CALL(*gl_, GetVertexAttribiv(_, _, _)).Times(0); + SpecializedSetup<GetVertexAttribiv, 0>(); + GetVertexAttribiv cmd; + cmd.Init( + 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} +// TODO(gman): GetVertexAttribPointerv + + +TEST_F(GLES2DecoderTest2, HintValidArgs) { + EXPECT_CALL(*gl_, Hint(GL_GENERATE_MIPMAP_HINT, GL_FASTEST)); + SpecializedSetup<Hint, 0>(); + Hint cmd; + cmd.Init(GL_GENERATE_MIPMAP_HINT, GL_FASTEST); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, HintInvalidArgs0_0) { + EXPECT_CALL(*gl_, Hint(_, _)).Times(0); + SpecializedSetup<Hint, 0>(); + Hint cmd; + cmd.Init(GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsBufferValidArgs) { + EXPECT_CALL(*gl_, IsBuffer(kServiceBufferId)); + SpecializedSetup<IsBuffer, 0>(); + IsBuffer cmd; + cmd.Init(client_buffer_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsEnabledValidArgs) { + EXPECT_CALL(*gl_, IsEnabled(GL_BLEND)); + SpecializedSetup<IsEnabled, 0>(); + IsEnabled cmd; + cmd.Init(GL_BLEND, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsEnabledInvalidArgs0_0) { + EXPECT_CALL(*gl_, IsEnabled(_)).Times(0); + SpecializedSetup<IsEnabled, 0>(); + IsEnabled cmd; + cmd.Init(GL_CLIP_PLANE0, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsEnabledInvalidArgs0_1) { + EXPECT_CALL(*gl_, IsEnabled(_)).Times(0); + SpecializedSetup<IsEnabled, 0>(); + IsEnabled cmd; + cmd.Init(GL_POINT_SPRITE, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsFramebufferValidArgs) { + EXPECT_CALL(*gl_, IsFramebufferEXT(kServiceFramebufferId)); + SpecializedSetup<IsFramebuffer, 0>(); + IsFramebuffer cmd; + cmd.Init(client_framebuffer_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsProgramValidArgs) { + EXPECT_CALL(*gl_, IsProgram(kServiceProgramId)); + SpecializedSetup<IsProgram, 0>(); + IsProgram cmd; + cmd.Init(client_program_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsRenderbufferValidArgs) { + EXPECT_CALL(*gl_, IsRenderbufferEXT(kServiceRenderbufferId)); + SpecializedSetup<IsRenderbuffer, 0>(); + IsRenderbuffer cmd; + cmd.Init(client_renderbuffer_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsShaderValidArgs) { + EXPECT_CALL(*gl_, IsShader(kServiceShaderId)); + SpecializedSetup<IsShader, 0>(); + IsShader cmd; + cmd.Init(client_shader_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, IsTextureValidArgs) { + EXPECT_CALL(*gl_, IsTexture(kServiceTextureId)); + SpecializedSetup<IsTexture, 0>(); + IsTexture cmd; + cmd.Init(client_texture_id_, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, LineWidthValidArgs) { + EXPECT_CALL(*gl_, LineWidth(1)); + SpecializedSetup<LineWidth, 0>(); + LineWidth cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, LinkProgramValidArgs) { + EXPECT_CALL(*gl_, LinkProgram(kServiceProgramId)); + SpecializedSetup<LinkProgram, 0>(); + LinkProgram cmd; + cmd.Init(client_program_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): PixelStorei + + +TEST_F(GLES2DecoderTest2, PolygonOffsetValidArgs) { + EXPECT_CALL(*gl_, PolygonOffset(1, 2)); + SpecializedSetup<PolygonOffset, 0>(); + PolygonOffset cmd; + cmd.Init(1, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): ReadPixels + + +TEST_F(GLES2DecoderTest2, RenderbufferStorageValidArgs) { + EXPECT_CALL(*gl_, RenderbufferStorageEXT(GL_RENDERBUFFER, GL_RGBA4, 3, 4)); + SpecializedSetup<RenderbufferStorage, 0>(); + RenderbufferStorage cmd; + cmd.Init(GL_RENDERBUFFER, GL_RGBA4, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, SampleCoverageValidArgs) { + EXPECT_CALL(*gl_, SampleCoverage(1, 2)); + SpecializedSetup<SampleCoverage, 0>(); + SampleCoverage cmd; + cmd.Init(1, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, ScissorValidArgs) { + EXPECT_CALL(*gl_, Scissor(1, 2, 3, 4)); + SpecializedSetup<Scissor, 0>(); + Scissor cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): ShaderSource + +// TODO(gman): ShaderSourceImmediate + + +TEST_F(GLES2DecoderTest2, StencilFuncValidArgs) { + EXPECT_CALL(*gl_, StencilFunc(GL_NEVER, 2, 3)); + SpecializedSetup<StencilFunc, 0>(); + StencilFunc cmd; + cmd.Init(GL_NEVER, 2, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, StencilFuncSeparateValidArgs) { + EXPECT_CALL(*gl_, StencilFuncSeparate(GL_FRONT, GL_NEVER, 3, 4)); + SpecializedSetup<StencilFuncSeparate, 0>(); + StencilFuncSeparate cmd; + cmd.Init(GL_FRONT, GL_NEVER, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, StencilMaskValidArgs) { + EXPECT_CALL(*gl_, StencilMask(1)); + SpecializedSetup<StencilMask, 0>(); + StencilMask cmd; + cmd.Init(1); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, StencilMaskSeparateValidArgs) { + EXPECT_CALL(*gl_, StencilMaskSeparate(GL_FRONT, 2)); + SpecializedSetup<StencilMaskSeparate, 0>(); + StencilMaskSeparate cmd; + cmd.Init(GL_FRONT, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, StencilOpValidArgs) { + EXPECT_CALL(*gl_, StencilOp(GL_KEEP, GL_KEEP, GL_KEEP)); + SpecializedSetup<StencilOp, 0>(); + StencilOp cmd; + cmd.Init(GL_KEEP, GL_KEEP, GL_KEEP); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, StencilOpSeparateValidArgs) { + EXPECT_CALL(*gl_, StencilOpSeparate(GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP)); + SpecializedSetup<StencilOpSeparate, 0>(); + StencilOpSeparate cmd; + cmd.Init(GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): TexImage2D + +// TODO(gman): TexImage2DImmediate + + +TEST_F(GLES2DecoderTest2, TexParameterfValidArgs) { + EXPECT_CALL(*gl_, TexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3)); + SpecializedSetup<TexParameterf, 0>(); + TexParameterf cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfInvalidArgs0_0) { + EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); + SpecializedSetup<TexParameterf, 0>(); + TexParameterf cmd; + cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfInvalidArgs0_1) { + EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); + SpecializedSetup<TexParameterf, 0>(); + TexParameterf cmd; + cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfInvalidArgs1_0) { + EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); + SpecializedSetup<TexParameterf, 0>(); + TexParameterf cmd; + cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvValidArgs) { + EXPECT_CALL( + *gl_, TexParameterfv( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, + reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvInvalidArgs0_0) { + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init( + GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvInvalidArgs0_1) { + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init( + GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvInvalidArgs1_0) { + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvInvalidArgs2_0) { + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvInvalidArgs2_1) { + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfv, 0>(); + TexParameterfv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvImmediateValidArgs) { + TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); + EXPECT_CALL( + *gl_, + TexParameterfv(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<TexParameterfvImmediate, 0>(); + GLfloat temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvImmediateInvalidArgs0_0) { + TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfvImmediate, 0>(); + GLfloat temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvImmediateInvalidArgs0_1) { + TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfvImmediate, 0>(); + GLfloat temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterfvImmediateInvalidArgs1_0) { + TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); + EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); + SpecializedSetup<TexParameterfvImmediate, 0>(); + GLfloat temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameteriValidArgs) { + EXPECT_CALL(*gl_, TexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3)); + SpecializedSetup<TexParameteri, 0>(); + TexParameteri cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameteriInvalidArgs0_0) { + EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); + SpecializedSetup<TexParameteri, 0>(); + TexParameteri cmd; + cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameteriInvalidArgs0_1) { + EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); + SpecializedSetup<TexParameteri, 0>(); + TexParameteri cmd; + cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameteriInvalidArgs1_0) { + EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); + SpecializedSetup<TexParameteri, 0>(); + TexParameteri cmd; + cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivValidArgs) { + EXPECT_CALL( + *gl_, TexParameteriv( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<const GLint*>( + shared_memory_address_))); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivInvalidArgs0_0) { + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init( + GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivInvalidArgs0_1) { + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init( + GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivInvalidArgs1_0) { + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, + shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivInvalidArgs2_0) { + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivInvalidArgs2_1) { + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameteriv, 0>(); + TexParameteriv cmd; + cmd.Init( + GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, + kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, TexParameterivImmediateValidArgs) { + TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); + EXPECT_CALL( + *gl_, + TexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, + reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<TexParameterivImmediate, 0>(); + GLint temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterivImmediateInvalidArgs0_0) { + TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameterivImmediate, 0>(); + GLint temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterivImmediateInvalidArgs0_1) { + TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameterivImmediate, 0>(); + GLint temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, TexParameterivImmediateInvalidArgs1_0) { + TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); + EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); + SpecializedSetup<TexParameterivImmediate, 0>(); + GLint temp[1] = { 0, }; + cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): TexSubImage2D + +// TODO(gman): TexSubImage2DImmediate + + +TEST_F(GLES2DecoderTest2, Uniform1fValidArgs) { + EXPECT_CALL(*gl_, Uniform1f(1, 2)); + SpecializedSetup<Uniform1f, 0>(); + Uniform1f cmd; + cmd.Init(1, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform1fvValidArgs) { + EXPECT_CALL( + *gl_, Uniform1fv( + 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<Uniform1fv, 0>(); + Uniform1fv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform1fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform1fv(_, _, _)).Times(0); + SpecializedSetup<Uniform1fv, 0>(); + Uniform1fv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform1fvInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform1fv(_, _, _)).Times(0); + SpecializedSetup<Uniform1fv, 0>(); + Uniform1fv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform1fvImmediateValidArgs) { + Uniform1fvImmediate& cmd = *GetImmediateAs<Uniform1fvImmediate>(); + EXPECT_CALL( + *gl_, + Uniform1fv(1, 2, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform1fvImmediate, 0>(); + GLfloat temp[1 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): Uniform1i +// TODO(gman): Uniform1iv +// TODO(gman): Uniform1ivImmediate + +TEST_F(GLES2DecoderTest2, Uniform2fValidArgs) { + EXPECT_CALL(*gl_, Uniform2f(1, 2, 3)); + SpecializedSetup<Uniform2f, 0>(); + Uniform2f cmd; + cmd.Init(1, 2, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2fvValidArgs) { + EXPECT_CALL( + *gl_, Uniform2fv( + 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<Uniform2fv, 0>(); + Uniform2fv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform2fv(_, _, _)).Times(0); + SpecializedSetup<Uniform2fv, 0>(); + Uniform2fv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2fvInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform2fv(_, _, _)).Times(0); + SpecializedSetup<Uniform2fv, 0>(); + Uniform2fv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2fvImmediateValidArgs) { + Uniform2fvImmediate& cmd = *GetImmediateAs<Uniform2fvImmediate>(); + EXPECT_CALL( + *gl_, + Uniform2fv(1, 2, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform2fvImmediate, 0>(); + GLfloat temp[2 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, Uniform2iValidArgs) { + EXPECT_CALL(*gl_, Uniform2i(1, 2, 3)); + SpecializedSetup<Uniform2i, 0>(); + Uniform2i cmd; + cmd.Init(1, 2, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2ivValidArgs) { + EXPECT_CALL( + *gl_, Uniform2iv( + 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); + SpecializedSetup<Uniform2iv, 0>(); + Uniform2iv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2ivInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform2iv(_, _, _)).Times(0); + SpecializedSetup<Uniform2iv, 0>(); + Uniform2iv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2ivInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform2iv(_, _, _)).Times(0); + SpecializedSetup<Uniform2iv, 0>(); + Uniform2iv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform2ivImmediateValidArgs) { + Uniform2ivImmediate& cmd = *GetImmediateAs<Uniform2ivImmediate>(); + EXPECT_CALL( + *gl_, + Uniform2iv(1, 2, + reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform2ivImmediate, 0>(); + GLint temp[2 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, Uniform3fValidArgs) { + EXPECT_CALL(*gl_, Uniform3f(1, 2, 3, 4)); + SpecializedSetup<Uniform3f, 0>(); + Uniform3f cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3fvValidArgs) { + EXPECT_CALL( + *gl_, Uniform3fv( + 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<Uniform3fv, 0>(); + Uniform3fv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform3fv(_, _, _)).Times(0); + SpecializedSetup<Uniform3fv, 0>(); + Uniform3fv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3fvInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform3fv(_, _, _)).Times(0); + SpecializedSetup<Uniform3fv, 0>(); + Uniform3fv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3fvImmediateValidArgs) { + Uniform3fvImmediate& cmd = *GetImmediateAs<Uniform3fvImmediate>(); + EXPECT_CALL( + *gl_, + Uniform3fv(1, 2, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform3fvImmediate, 0>(); + GLfloat temp[3 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, Uniform3iValidArgs) { + EXPECT_CALL(*gl_, Uniform3i(1, 2, 3, 4)); + SpecializedSetup<Uniform3i, 0>(); + Uniform3i cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3ivValidArgs) { + EXPECT_CALL( + *gl_, Uniform3iv( + 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); + SpecializedSetup<Uniform3iv, 0>(); + Uniform3iv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3ivInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform3iv(_, _, _)).Times(0); + SpecializedSetup<Uniform3iv, 0>(); + Uniform3iv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3ivInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform3iv(_, _, _)).Times(0); + SpecializedSetup<Uniform3iv, 0>(); + Uniform3iv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform3ivImmediateValidArgs) { + Uniform3ivImmediate& cmd = *GetImmediateAs<Uniform3ivImmediate>(); + EXPECT_CALL( + *gl_, + Uniform3iv(1, 2, + reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform3ivImmediate, 0>(); + GLint temp[3 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, Uniform4fValidArgs) { + EXPECT_CALL(*gl_, Uniform4f(1, 2, 3, 4, 5)); + SpecializedSetup<Uniform4f, 0>(); + Uniform4f cmd; + cmd.Init(1, 2, 3, 4, 5); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4fvValidArgs) { + EXPECT_CALL( + *gl_, Uniform4fv( + 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<Uniform4fv, 0>(); + Uniform4fv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform4fv(_, _, _)).Times(0); + SpecializedSetup<Uniform4fv, 0>(); + Uniform4fv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4fvInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform4fv(_, _, _)).Times(0); + SpecializedSetup<Uniform4fv, 0>(); + Uniform4fv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4fvImmediateValidArgs) { + Uniform4fvImmediate& cmd = *GetImmediateAs<Uniform4fvImmediate>(); + EXPECT_CALL( + *gl_, + Uniform4fv(1, 2, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform4fvImmediate, 0>(); + GLfloat temp[4 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, Uniform4iValidArgs) { + EXPECT_CALL(*gl_, Uniform4i(1, 2, 3, 4, 5)); + SpecializedSetup<Uniform4i, 0>(); + Uniform4i cmd; + cmd.Init(1, 2, 3, 4, 5); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4ivValidArgs) { + EXPECT_CALL( + *gl_, Uniform4iv( + 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); + SpecializedSetup<Uniform4iv, 0>(); + Uniform4iv cmd; + cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4ivInvalidArgs2_0) { + EXPECT_CALL(*gl_, Uniform4iv(_, _, _)).Times(0); + SpecializedSetup<Uniform4iv, 0>(); + Uniform4iv cmd; + cmd.Init(1, 2, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4ivInvalidArgs2_1) { + EXPECT_CALL(*gl_, Uniform4iv(_, _, _)).Times(0); + SpecializedSetup<Uniform4iv, 0>(); + Uniform4iv cmd; + cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, Uniform4ivImmediateValidArgs) { + Uniform4ivImmediate& cmd = *GetImmediateAs<Uniform4ivImmediate>(); + EXPECT_CALL( + *gl_, + Uniform4iv(1, 2, + reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<Uniform4ivImmediate, 0>(); + GLint temp[4 * 2] = { 0, }; + cmd.Init(1, 2, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvValidArgs) { + EXPECT_CALL( + *gl_, UniformMatrix2fv( + 1, 2, false, reinterpret_cast<const GLfloat*>( + shared_memory_address_))); + SpecializedSetup<UniformMatrix2fv, 0>(); + UniformMatrix2fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix2fv, 0>(); + UniformMatrix2fv cmd; + cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvInvalidArgs3_0) { + EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix2fv, 0>(); + UniformMatrix2fv cmd; + cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvInvalidArgs3_1) { + EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix2fv, 0>(); + UniformMatrix2fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvImmediateValidArgs) { + UniformMatrix2fvImmediate& cmd = + *GetImmediateAs<UniformMatrix2fvImmediate>(); + EXPECT_CALL( + *gl_, + UniformMatrix2fv(1, 2, false, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<UniformMatrix2fvImmediate, 0>(); + GLfloat temp[4 * 2] = { 0, }; + cmd.Init(1, 2, false, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix2fvImmediateInvalidArgs2_0) { + UniformMatrix2fvImmediate& cmd = + *GetImmediateAs<UniformMatrix2fvImmediate>(); + EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix2fvImmediate, 0>(); + GLfloat temp[4 * 2] = { 0, }; + cmd.Init(1, 2, true, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvValidArgs) { + EXPECT_CALL( + *gl_, UniformMatrix3fv( + 1, 2, false, reinterpret_cast<const GLfloat*>( + shared_memory_address_))); + SpecializedSetup<UniformMatrix3fv, 0>(); + UniformMatrix3fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix3fv, 0>(); + UniformMatrix3fv cmd; + cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvInvalidArgs3_0) { + EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix3fv, 0>(); + UniformMatrix3fv cmd; + cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvInvalidArgs3_1) { + EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix3fv, 0>(); + UniformMatrix3fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvImmediateValidArgs) { + UniformMatrix3fvImmediate& cmd = + *GetImmediateAs<UniformMatrix3fvImmediate>(); + EXPECT_CALL( + *gl_, + UniformMatrix3fv(1, 2, false, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<UniformMatrix3fvImmediate, 0>(); + GLfloat temp[9 * 2] = { 0, }; + cmd.Init(1, 2, false, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix3fvImmediateInvalidArgs2_0) { + UniformMatrix3fvImmediate& cmd = + *GetImmediateAs<UniformMatrix3fvImmediate>(); + EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix3fvImmediate, 0>(); + GLfloat temp[9 * 2] = { 0, }; + cmd.Init(1, 2, true, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvValidArgs) { + EXPECT_CALL( + *gl_, UniformMatrix4fv( + 1, 2, false, reinterpret_cast<const GLfloat*>( + shared_memory_address_))); + SpecializedSetup<UniformMatrix4fv, 0>(); + UniformMatrix4fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvInvalidArgs2_0) { + EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix4fv, 0>(); + UniformMatrix4fv cmd; + cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvInvalidArgs3_0) { + EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix4fv, 0>(); + UniformMatrix4fv cmd; + cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvInvalidArgs3_1) { + EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix4fv, 0>(); + UniformMatrix4fv cmd; + cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvImmediateValidArgs) { + UniformMatrix4fvImmediate& cmd = + *GetImmediateAs<UniformMatrix4fvImmediate>(); + EXPECT_CALL( + *gl_, + UniformMatrix4fv(1, 2, false, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<UniformMatrix4fvImmediate, 0>(); + GLfloat temp[16 * 2] = { 0, }; + cmd.Init(1, 2, false, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, UniformMatrix4fvImmediateInvalidArgs2_0) { + UniformMatrix4fvImmediate& cmd = + *GetImmediateAs<UniformMatrix4fvImmediate>(); + EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); + SpecializedSetup<UniformMatrix4fvImmediate, 0>(); + GLfloat temp[16 * 2] = { 0, }; + cmd.Init(1, 2, true, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): UseProgram + +TEST_F(GLES2DecoderTest2, ValidateProgramValidArgs) { + EXPECT_CALL(*gl_, ValidateProgram(kServiceProgramId)); + SpecializedSetup<ValidateProgram, 0>(); + ValidateProgram cmd; + cmd.Init(client_program_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib1fValidArgs) { + EXPECT_CALL(*gl_, VertexAttrib1f(1, 2)); + SpecializedSetup<VertexAttrib1f, 0>(); + VertexAttrib1f cmd; + cmd.Init(1, 2); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib1fvValidArgs) { + EXPECT_CALL( + *gl_, VertexAttrib1fv( + 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<VertexAttrib1fv, 0>(); + VertexAttrib1fv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib1fvInvalidArgs1_0) { + EXPECT_CALL(*gl_, VertexAttrib1fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib1fv, 0>(); + VertexAttrib1fv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib1fvInvalidArgs1_1) { + EXPECT_CALL(*gl_, VertexAttrib1fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib1fv, 0>(); + VertexAttrib1fv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib1fvImmediateValidArgs) { + VertexAttrib1fvImmediate& cmd = *GetImmediateAs<VertexAttrib1fvImmediate>(); + EXPECT_CALL( + *gl_, + VertexAttrib1fv(1, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<VertexAttrib1fvImmediate, 0>(); + GLfloat temp[1] = { 0, }; + cmd.Init(1, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib2fValidArgs) { + EXPECT_CALL(*gl_, VertexAttrib2f(1, 2, 3)); + SpecializedSetup<VertexAttrib2f, 0>(); + VertexAttrib2f cmd; + cmd.Init(1, 2, 3); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib2fvValidArgs) { + EXPECT_CALL( + *gl_, VertexAttrib2fv( + 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<VertexAttrib2fv, 0>(); + VertexAttrib2fv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib2fvInvalidArgs1_0) { + EXPECT_CALL(*gl_, VertexAttrib2fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib2fv, 0>(); + VertexAttrib2fv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib2fvInvalidArgs1_1) { + EXPECT_CALL(*gl_, VertexAttrib2fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib2fv, 0>(); + VertexAttrib2fv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib2fvImmediateValidArgs) { + VertexAttrib2fvImmediate& cmd = *GetImmediateAs<VertexAttrib2fvImmediate>(); + EXPECT_CALL( + *gl_, + VertexAttrib2fv(1, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<VertexAttrib2fvImmediate, 0>(); + GLfloat temp[2] = { 0, }; + cmd.Init(1, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib3fValidArgs) { + EXPECT_CALL(*gl_, VertexAttrib3f(1, 2, 3, 4)); + SpecializedSetup<VertexAttrib3f, 0>(); + VertexAttrib3f cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib3fvValidArgs) { + EXPECT_CALL( + *gl_, VertexAttrib3fv( + 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<VertexAttrib3fv, 0>(); + VertexAttrib3fv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib3fvInvalidArgs1_0) { + EXPECT_CALL(*gl_, VertexAttrib3fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib3fv, 0>(); + VertexAttrib3fv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib3fvInvalidArgs1_1) { + EXPECT_CALL(*gl_, VertexAttrib3fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib3fv, 0>(); + VertexAttrib3fv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib3fvImmediateValidArgs) { + VertexAttrib3fvImmediate& cmd = *GetImmediateAs<VertexAttrib3fvImmediate>(); + EXPECT_CALL( + *gl_, + VertexAttrib3fv(1, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<VertexAttrib3fvImmediate, 0>(); + GLfloat temp[3] = { 0, }; + cmd.Init(1, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib4fValidArgs) { + EXPECT_CALL(*gl_, VertexAttrib4f(1, 2, 3, 4, 5)); + SpecializedSetup<VertexAttrib4f, 0>(); + VertexAttrib4f cmd; + cmd.Init(1, 2, 3, 4, 5); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib4fvValidArgs) { + EXPECT_CALL( + *gl_, VertexAttrib4fv( + 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); + SpecializedSetup<VertexAttrib4fv, 0>(); + VertexAttrib4fv cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib4fvInvalidArgs1_0) { + EXPECT_CALL(*gl_, VertexAttrib4fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib4fv, 0>(); + VertexAttrib4fv cmd; + cmd.Init(1, kInvalidSharedMemoryId, 0); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib4fvInvalidArgs1_1) { + EXPECT_CALL(*gl_, VertexAttrib4fv(_, _)).Times(0); + SpecializedSetup<VertexAttrib4fv, 0>(); + VertexAttrib4fv cmd; + cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); + EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); +} + +TEST_F(GLES2DecoderTest2, VertexAttrib4fvImmediateValidArgs) { + VertexAttrib4fvImmediate& cmd = *GetImmediateAs<VertexAttrib4fvImmediate>(); + EXPECT_CALL( + *gl_, + VertexAttrib4fv(1, + reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); + SpecializedSetup<VertexAttrib4fvImmediate, 0>(); + GLfloat temp[4] = { 0, }; + cmd.Init(1, &temp[0]); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(temp))); +} +// TODO(gman): VertexAttribPointer + + +TEST_F(GLES2DecoderTest2, ViewportValidArgs) { + EXPECT_CALL(*gl_, Viewport(1, 2, 3, 4)); + SpecializedSetup<Viewport, 0>(); + Viewport cmd; + cmd.Init(1, 2, 3, 4); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} +// TODO(gman): SwapBuffers +#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_2_AUTOGEN_H_ + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_autogen.h deleted file mode 100644 index 905a451..0000000 --- a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_autogen.h +++ /dev/null @@ -1,2551 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -// This file is auto-generated. DO NOT EDIT! - -// It is included by gles2_cmd_decoder_unittest.cc -#ifndef GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_AUTOGEN_H_ -#define GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_AUTOGEN_H_ - - -TEST_F(GLES2DecoderTest, ActiveTextureValidArgs) { - EXPECT_CALL(*gl_, ActiveTexture(1)); - SpecializedSetup<ActiveTexture, 0>(); - ActiveTexture cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, AttachShaderValidArgs) { - EXPECT_CALL(*gl_, AttachShader(kServiceProgramId, kServiceShaderId)); - SpecializedSetup<AttachShader, 0>(); - AttachShader cmd; - cmd.Init(client_program_id_, client_shader_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): BindAttribLocation - -// TODO(gman): BindAttribLocationImmediate - - -TEST_F(GLES2DecoderTest, BindBufferValidArgs) { - EXPECT_CALL(*gl_, BindBuffer(GL_ARRAY_BUFFER, kServiceBufferId)); - SpecializedSetup<BindBuffer, 0>(); - BindBuffer cmd; - cmd.Init(GL_ARRAY_BUFFER, client_buffer_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindBufferInvalidArgs0_0) { - EXPECT_CALL(*gl_, BindBuffer(_, _)).Times(0); - SpecializedSetup<BindBuffer, 0>(); - BindBuffer cmd; - cmd.Init(GL_RENDERBUFFER, client_buffer_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindFramebufferValidArgs) { - EXPECT_CALL(*gl_, BindFramebufferEXT(GL_FRAMEBUFFER, kServiceFramebufferId)); - SpecializedSetup<BindFramebuffer, 0>(); - BindFramebuffer cmd; - cmd.Init(GL_FRAMEBUFFER, client_framebuffer_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindRenderbufferValidArgs) { - EXPECT_CALL( - *gl_, BindRenderbufferEXT(GL_RENDERBUFFER, kServiceRenderbufferId)); - SpecializedSetup<BindRenderbuffer, 0>(); - BindRenderbuffer cmd; - cmd.Init(GL_RENDERBUFFER, client_renderbuffer_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindTextureValidArgs) { - EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, kServiceTextureId)); - SpecializedSetup<BindTexture, 0>(); - BindTexture cmd; - cmd.Init(GL_TEXTURE_2D, client_texture_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindTextureInvalidArgs0_0) { - EXPECT_CALL(*gl_, BindTexture(_, _)).Times(0); - SpecializedSetup<BindTexture, 0>(); - BindTexture cmd; - cmd.Init(GL_TEXTURE_1D, client_texture_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BindTextureInvalidArgs0_1) { - EXPECT_CALL(*gl_, BindTexture(_, _)).Times(0); - SpecializedSetup<BindTexture, 0>(); - BindTexture cmd; - cmd.Init(GL_TEXTURE_3D, client_texture_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendColorValidArgs) { - EXPECT_CALL(*gl_, BlendColor(1, 2, 3, 4)); - SpecializedSetup<BlendColor, 0>(); - BlendColor cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationValidArgs) { - EXPECT_CALL(*gl_, BlendEquation(GL_FUNC_ADD)); - SpecializedSetup<BlendEquation, 0>(); - BlendEquation cmd; - cmd.Init(GL_FUNC_ADD); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationInvalidArgs0_0) { - EXPECT_CALL(*gl_, BlendEquation(_)).Times(0); - SpecializedSetup<BlendEquation, 0>(); - BlendEquation cmd; - cmd.Init(GL_MIN); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationInvalidArgs0_1) { - EXPECT_CALL(*gl_, BlendEquation(_)).Times(0); - SpecializedSetup<BlendEquation, 0>(); - BlendEquation cmd; - cmd.Init(GL_MAX); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationSeparateValidArgs) { - EXPECT_CALL(*gl_, BlendEquationSeparate(GL_FUNC_ADD, GL_FUNC_ADD)); - SpecializedSetup<BlendEquationSeparate, 0>(); - BlendEquationSeparate cmd; - cmd.Init(GL_FUNC_ADD, GL_FUNC_ADD); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationSeparateInvalidArgs0_0) { - EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); - SpecializedSetup<BlendEquationSeparate, 0>(); - BlendEquationSeparate cmd; - cmd.Init(GL_MIN, GL_FUNC_ADD); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationSeparateInvalidArgs0_1) { - EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); - SpecializedSetup<BlendEquationSeparate, 0>(); - BlendEquationSeparate cmd; - cmd.Init(GL_MAX, GL_FUNC_ADD); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationSeparateInvalidArgs1_0) { - EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); - SpecializedSetup<BlendEquationSeparate, 0>(); - BlendEquationSeparate cmd; - cmd.Init(GL_FUNC_ADD, GL_MIN); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendEquationSeparateInvalidArgs1_1) { - EXPECT_CALL(*gl_, BlendEquationSeparate(_, _)).Times(0); - SpecializedSetup<BlendEquationSeparate, 0>(); - BlendEquationSeparate cmd; - cmd.Init(GL_FUNC_ADD, GL_MAX); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendFuncValidArgs) { - EXPECT_CALL(*gl_, BlendFunc(GL_ZERO, GL_ZERO)); - SpecializedSetup<BlendFunc, 0>(); - BlendFunc cmd; - cmd.Init(GL_ZERO, GL_ZERO); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, BlendFuncSeparateValidArgs) { - EXPECT_CALL(*gl_, BlendFuncSeparate(GL_ZERO, GL_ZERO, GL_ZERO, GL_ZERO)); - SpecializedSetup<BlendFuncSeparate, 0>(); - BlendFuncSeparate cmd; - cmd.Init(GL_ZERO, GL_ZERO, GL_ZERO, GL_ZERO); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): BufferData - -// TODO(gman): BufferDataImmediate - -// TODO(gman): BufferSubData - -// TODO(gman): BufferSubDataImmediate - - -TEST_F(GLES2DecoderTest, CheckFramebufferStatusValidArgs) { - EXPECT_CALL(*gl_, CheckFramebufferStatusEXT(GL_FRAMEBUFFER)); - SpecializedSetup<CheckFramebufferStatus, 0>(); - CheckFramebufferStatus cmd; - cmd.Init(GL_FRAMEBUFFER); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ClearValidArgs) { - EXPECT_CALL(*gl_, Clear(1)); - SpecializedSetup<Clear, 0>(); - Clear cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ClearColorValidArgs) { - EXPECT_CALL(*gl_, ClearColor(1, 2, 3, 4)); - SpecializedSetup<ClearColor, 0>(); - ClearColor cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ClearDepthfValidArgs) { - EXPECT_CALL(*gl_, ClearDepth(1)); - SpecializedSetup<ClearDepthf, 0>(); - ClearDepthf cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ClearStencilValidArgs) { - EXPECT_CALL(*gl_, ClearStencil(1)); - SpecializedSetup<ClearStencil, 0>(); - ClearStencil cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ColorMaskValidArgs) { - EXPECT_CALL(*gl_, ColorMask(1, 2, 3, 4)); - SpecializedSetup<ColorMask, 0>(); - ColorMask cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): CompileShader -// TODO(gman): CompressedTexImage2D - -// TODO(gman): CompressedTexImage2DImmediate - -// TODO(gman): CompressedTexSubImage2D - -// TODO(gman): CompressedTexSubImage2DImmediate - - -TEST_F(GLES2DecoderTest, CopyTexImage2DValidArgs) { - EXPECT_CALL(*gl_, CopyTexImage2D(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8)); - SpecializedSetup<CopyTexImage2D, 0>(); - CopyTexImage2D cmd; - cmd.Init(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, CopyTexImage2DInvalidArgs0_0) { - EXPECT_CALL(*gl_, CopyTexImage2D(_, _, _, _, _, _, _, _)).Times(0); - SpecializedSetup<CopyTexImage2D, 0>(); - CopyTexImage2D cmd; - cmd.Init(GL_PROXY_TEXTURE_CUBE_MAP, 2, 3, 4, 5, 6, 7, 8); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, CopyTexSubImage2DValidArgs) { - EXPECT_CALL(*gl_, CopyTexSubImage2D(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8)); - SpecializedSetup<CopyTexSubImage2D, 0>(); - CopyTexSubImage2D cmd; - cmd.Init(GL_TEXTURE_2D, 2, 3, 4, 5, 6, 7, 8); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, CopyTexSubImage2DInvalidArgs0_0) { - EXPECT_CALL(*gl_, CopyTexSubImage2D(_, _, _, _, _, _, _, _)).Times(0); - SpecializedSetup<CopyTexSubImage2D, 0>(); - CopyTexSubImage2D cmd; - cmd.Init(GL_PROXY_TEXTURE_CUBE_MAP, 2, 3, 4, 5, 6, 7, 8); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, CreateProgramValidArgs) { - EXPECT_CALL(*gl_, CreateProgram()) - .WillOnce(Return(kNewServiceId)); - SpecializedSetup<CreateProgram, 0>(); - CreateProgram cmd; - cmd.Init(kNewClientId); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, CreateShaderValidArgs) { - EXPECT_CALL(*gl_, CreateShader(GL_VERTEX_SHADER)) - .WillOnce(Return(kNewServiceId)); - SpecializedSetup<CreateShader, 0>(); - CreateShader cmd; - cmd.Init(GL_VERTEX_SHADER, kNewClientId); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, CullFaceValidArgs) { - EXPECT_CALL(*gl_, CullFace(GL_FRONT)); - SpecializedSetup<CullFace, 0>(); - CullFace cmd; - cmd.Init(GL_FRONT); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DeleteBuffersValidArgs) { - EXPECT_CALL( - *gl_, - DeleteBuffersARB(1, Pointee(kServiceBufferId))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = client_buffer_id_; - SpecializedSetup<DeleteBuffers, 0>(); - DeleteBuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteBuffersInvalidArgs) { - EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(0))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; - SpecializedSetup<DeleteBuffers, 0>(); - DeleteBuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DeleteBuffersImmediateValidArgs) { - EXPECT_CALL( - *gl_, - DeleteBuffersARB(1, Pointee(kServiceBufferId))) - .Times(1); - DeleteBuffersImmediate& cmd = *GetImmediateAs<DeleteBuffersImmediate>(); - SpecializedSetup<DeleteBuffersImmediate, 0>(); - cmd.Init(1, &client_buffer_id_); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(client_buffer_id_))); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteBuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(0))) - .Times(1); - DeleteBuffersImmediate& cmd = *GetImmediateAs<DeleteBuffersImmediate>(); - SpecializedSetup<DeleteBuffersImmediate, 0>(); - GLuint temp = kInvalidClientId; - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, DeleteFramebuffersValidArgs) { - EXPECT_CALL( - *gl_, - DeleteFramebuffersEXT(1, Pointee(kServiceFramebufferId))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = client_framebuffer_id_; - SpecializedSetup<DeleteFramebuffers, 0>(); - DeleteFramebuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteFramebuffersInvalidArgs) { - EXPECT_CALL(*gl_, DeleteFramebuffersEXT(1, Pointee(0))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; - SpecializedSetup<DeleteFramebuffers, 0>(); - DeleteFramebuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DeleteFramebuffersImmediateValidArgs) { - EXPECT_CALL( - *gl_, - DeleteFramebuffersEXT(1, Pointee(kServiceFramebufferId))) - .Times(1); - DeleteFramebuffersImmediate& cmd = - *GetImmediateAs<DeleteFramebuffersImmediate>(); - SpecializedSetup<DeleteFramebuffersImmediate, 0>(); - cmd.Init(1, &client_framebuffer_id_); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(client_framebuffer_id_))); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteFramebuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, DeleteFramebuffersEXT(1, Pointee(0))) - .Times(1); - DeleteFramebuffersImmediate& cmd = - *GetImmediateAs<DeleteFramebuffersImmediate>(); - SpecializedSetup<DeleteFramebuffersImmediate, 0>(); - GLuint temp = kInvalidClientId; - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} -// TODO(gman): DeleteProgram - - -TEST_F(GLES2DecoderTest, DeleteRenderbuffersValidArgs) { - EXPECT_CALL( - *gl_, - DeleteRenderbuffersEXT(1, Pointee(kServiceRenderbufferId))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = client_renderbuffer_id_; - SpecializedSetup<DeleteRenderbuffers, 0>(); - DeleteRenderbuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteRenderbuffersInvalidArgs) { - EXPECT_CALL(*gl_, DeleteRenderbuffersEXT(1, Pointee(0))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; - SpecializedSetup<DeleteRenderbuffers, 0>(); - DeleteRenderbuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DeleteRenderbuffersImmediateValidArgs) { - EXPECT_CALL( - *gl_, - DeleteRenderbuffersEXT(1, Pointee(kServiceRenderbufferId))) - .Times(1); - DeleteRenderbuffersImmediate& cmd = - *GetImmediateAs<DeleteRenderbuffersImmediate>(); - SpecializedSetup<DeleteRenderbuffersImmediate, 0>(); - cmd.Init(1, &client_renderbuffer_id_); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(client_renderbuffer_id_))); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteRenderbuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, DeleteRenderbuffersEXT(1, Pointee(0))) - .Times(1); - DeleteRenderbuffersImmediate& cmd = - *GetImmediateAs<DeleteRenderbuffersImmediate>(); - SpecializedSetup<DeleteRenderbuffersImmediate, 0>(); - GLuint temp = kInvalidClientId; - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} -// TODO(gman): DeleteShader - - -TEST_F(GLES2DecoderTest, DeleteTexturesValidArgs) { - EXPECT_CALL( - *gl_, - DeleteTextures(1, Pointee(kServiceTextureId))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = client_texture_id_; - SpecializedSetup<DeleteTextures, 0>(); - DeleteTextures cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteTexturesInvalidArgs) { - EXPECT_CALL(*gl_, DeleteTextures(1, Pointee(0))) - .Times(1); - GetSharedMemoryAs<GLuint*>()[0] = kInvalidClientId; - SpecializedSetup<DeleteTextures, 0>(); - DeleteTextures cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DeleteTexturesImmediateValidArgs) { - EXPECT_CALL( - *gl_, - DeleteTextures(1, Pointee(kServiceTextureId))) - .Times(1); - DeleteTexturesImmediate& cmd = *GetImmediateAs<DeleteTexturesImmediate>(); - SpecializedSetup<DeleteTexturesImmediate, 0>(); - cmd.Init(1, &client_texture_id_); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(client_texture_id_))); - EXPECT_EQ(GetServiceId(kNewClientId), 0u); -} - -TEST_F(GLES2DecoderTest, DeleteTexturesImmediateInvalidArgs) { - EXPECT_CALL(*gl_, DeleteTextures(1, Pointee(0))) - .Times(1); - DeleteTexturesImmediate& cmd = *GetImmediateAs<DeleteTexturesImmediate>(); - SpecializedSetup<DeleteTexturesImmediate, 0>(); - GLuint temp = kInvalidClientId; - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, DepthFuncValidArgs) { - EXPECT_CALL(*gl_, DepthFunc(GL_NEVER)); - SpecializedSetup<DepthFunc, 0>(); - DepthFunc cmd; - cmd.Init(GL_NEVER); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DepthMaskValidArgs) { - EXPECT_CALL(*gl_, DepthMask(1)); - SpecializedSetup<DepthMask, 0>(); - DepthMask cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DepthRangefValidArgs) { - EXPECT_CALL(*gl_, DepthRange(1, 2)); - SpecializedSetup<DepthRangef, 0>(); - DepthRangef cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DetachShaderValidArgs) { - EXPECT_CALL(*gl_, DetachShader(kServiceProgramId, kServiceShaderId)); - SpecializedSetup<DetachShader, 0>(); - DetachShader cmd; - cmd.Init(client_program_id_, client_shader_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DisableValidArgs) { - EXPECT_CALL(*gl_, Disable(GL_BLEND)); - SpecializedSetup<Disable, 0>(); - Disable cmd; - cmd.Init(GL_BLEND); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DisableInvalidArgs0_0) { - EXPECT_CALL(*gl_, Disable(_)).Times(0); - SpecializedSetup<Disable, 0>(); - Disable cmd; - cmd.Init(GL_CLIP_PLANE0); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DisableInvalidArgs0_1) { - EXPECT_CALL(*gl_, Disable(_)).Times(0); - SpecializedSetup<Disable, 0>(); - Disable cmd; - cmd.Init(GL_POINT_SPRITE); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, DisableVertexAttribArrayValidArgs) { - EXPECT_CALL(*gl_, DisableVertexAttribArray(1)); - SpecializedSetup<DisableVertexAttribArray, 0>(); - DisableVertexAttribArray cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): DrawArrays -// TODO(gman): DrawElements - - -TEST_F(GLES2DecoderTest, EnableValidArgs) { - EXPECT_CALL(*gl_, Enable(GL_BLEND)); - SpecializedSetup<Enable, 0>(); - Enable cmd; - cmd.Init(GL_BLEND); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, EnableInvalidArgs0_0) { - EXPECT_CALL(*gl_, Enable(_)).Times(0); - SpecializedSetup<Enable, 0>(); - Enable cmd; - cmd.Init(GL_CLIP_PLANE0); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, EnableInvalidArgs0_1) { - EXPECT_CALL(*gl_, Enable(_)).Times(0); - SpecializedSetup<Enable, 0>(); - Enable cmd; - cmd.Init(GL_POINT_SPRITE); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, EnableVertexAttribArrayValidArgs) { - EXPECT_CALL(*gl_, EnableVertexAttribArray(1)); - SpecializedSetup<EnableVertexAttribArray, 0>(); - EnableVertexAttribArray cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FinishValidArgs) { - EXPECT_CALL(*gl_, Finish()); - SpecializedSetup<Finish, 0>(); - Finish cmd; - cmd.Init(); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FlushValidArgs) { - EXPECT_CALL(*gl_, Flush()); - SpecializedSetup<Flush, 0>(); - Flush cmd; - cmd.Init(); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FramebufferRenderbufferValidArgs) { - EXPECT_CALL( - *gl_, FramebufferRenderbufferEXT( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_RENDERBUFFER, - kServiceRenderbufferId)); - SpecializedSetup<FramebufferRenderbuffer, 0>(); - FramebufferRenderbuffer cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_RENDERBUFFER, - client_renderbuffer_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FramebufferTexture2DValidArgs) { - EXPECT_CALL( - *gl_, FramebufferTexture2DEXT( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, - kServiceTextureId, 5)); - SpecializedSetup<FramebufferTexture2D, 0>(); - FramebufferTexture2D cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, client_texture_id_, - 5); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FramebufferTexture2DInvalidArgs2_0) { - EXPECT_CALL(*gl_, FramebufferTexture2DEXT(_, _, _, _, _)).Times(0); - SpecializedSetup<FramebufferTexture2D, 0>(); - FramebufferTexture2D cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_PROXY_TEXTURE_CUBE_MAP, - client_texture_id_, 5); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, FrontFaceValidArgs) { - EXPECT_CALL(*gl_, FrontFace(GL_CW)); - SpecializedSetup<FrontFace, 0>(); - FrontFace cmd; - cmd.Init(GL_CW); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenBuffersValidArgs) { - EXPECT_CALL(*gl_, GenBuffersARB(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; - SpecializedSetup<GenBuffers, 0>(); - GenBuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenBuffersInvalidArgs) { - EXPECT_CALL(*gl_, GenBuffersARB(_, _)).Times(0); - GetSharedMemoryAs<GLuint*>()[0] = client_buffer_id_; - SpecializedSetup<GenBuffers, 0>(); - GenBuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenBuffersImmediateValidArgs) { - EXPECT_CALL(*gl_, GenBuffersARB(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GenBuffersImmediate& cmd = *GetImmediateAs<GenBuffersImmediate>(); - GLuint temp = kNewClientId; - SpecializedSetup<GenBuffersImmediate, 0>(); - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenBuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, GenBuffersARB(_, _)).Times(0); - GenBuffersImmediate& cmd = *GetImmediateAs<GenBuffersImmediate>(); - SpecializedSetup<GenBuffersImmediate, 0>(); - cmd.Init(1, &client_buffer_id_); - EXPECT_EQ(error::kInvalidArguments, - ExecuteImmediateCmd(cmd, sizeof(&client_buffer_id_))); -} - -TEST_F(GLES2DecoderTest, GenerateMipmapValidArgs) { - EXPECT_CALL(*gl_, GenerateMipmapEXT(GL_TEXTURE_2D)); - SpecializedSetup<GenerateMipmap, 0>(); - GenerateMipmap cmd; - cmd.Init(GL_TEXTURE_2D); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenerateMipmapInvalidArgs0_0) { - EXPECT_CALL(*gl_, GenerateMipmapEXT(_)).Times(0); - SpecializedSetup<GenerateMipmap, 0>(); - GenerateMipmap cmd; - cmd.Init(GL_TEXTURE_1D); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenerateMipmapInvalidArgs0_1) { - EXPECT_CALL(*gl_, GenerateMipmapEXT(_)).Times(0); - SpecializedSetup<GenerateMipmap, 0>(); - GenerateMipmap cmd; - cmd.Init(GL_TEXTURE_3D); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenFramebuffersValidArgs) { - EXPECT_CALL(*gl_, GenFramebuffersEXT(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; - SpecializedSetup<GenFramebuffers, 0>(); - GenFramebuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenFramebuffersInvalidArgs) { - EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)).Times(0); - GetSharedMemoryAs<GLuint*>()[0] = client_framebuffer_id_; - SpecializedSetup<GenFramebuffers, 0>(); - GenFramebuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenFramebuffersImmediateValidArgs) { - EXPECT_CALL(*gl_, GenFramebuffersEXT(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GenFramebuffersImmediate& cmd = *GetImmediateAs<GenFramebuffersImmediate>(); - GLuint temp = kNewClientId; - SpecializedSetup<GenFramebuffersImmediate, 0>(); - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenFramebuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)).Times(0); - GenFramebuffersImmediate& cmd = *GetImmediateAs<GenFramebuffersImmediate>(); - SpecializedSetup<GenFramebuffersImmediate, 0>(); - cmd.Init(1, &client_framebuffer_id_); - EXPECT_EQ(error::kInvalidArguments, - ExecuteImmediateCmd(cmd, sizeof(&client_framebuffer_id_))); -} - -TEST_F(GLES2DecoderTest, GenRenderbuffersValidArgs) { - EXPECT_CALL(*gl_, GenRenderbuffersEXT(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; - SpecializedSetup<GenRenderbuffers, 0>(); - GenRenderbuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenRenderbuffersInvalidArgs) { - EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)).Times(0); - GetSharedMemoryAs<GLuint*>()[0] = client_renderbuffer_id_; - SpecializedSetup<GenRenderbuffers, 0>(); - GenRenderbuffers cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenRenderbuffersImmediateValidArgs) { - EXPECT_CALL(*gl_, GenRenderbuffersEXT(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GenRenderbuffersImmediate& cmd = - *GetImmediateAs<GenRenderbuffersImmediate>(); - GLuint temp = kNewClientId; - SpecializedSetup<GenRenderbuffersImmediate, 0>(); - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenRenderbuffersImmediateInvalidArgs) { - EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)).Times(0); - GenRenderbuffersImmediate& cmd = - *GetImmediateAs<GenRenderbuffersImmediate>(); - SpecializedSetup<GenRenderbuffersImmediate, 0>(); - cmd.Init(1, &client_renderbuffer_id_); - EXPECT_EQ(error::kInvalidArguments, - ExecuteImmediateCmd(cmd, sizeof(&client_renderbuffer_id_))); -} - -TEST_F(GLES2DecoderTest, GenTexturesValidArgs) { - EXPECT_CALL(*gl_, GenTextures(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GetSharedMemoryAs<GLuint*>()[0] = kNewClientId; - SpecializedSetup<GenTextures, 0>(); - GenTextures cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenTexturesInvalidArgs) { - EXPECT_CALL(*gl_, GenTextures(_, _)).Times(0); - GetSharedMemoryAs<GLuint*>()[0] = client_texture_id_; - SpecializedSetup<GenTextures, 0>(); - GenTextures cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kInvalidArguments, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GenTexturesImmediateValidArgs) { - EXPECT_CALL(*gl_, GenTextures(1, _)) - .WillOnce(SetArgumentPointee<1>(kNewServiceId)); - GenTexturesImmediate& cmd = *GetImmediateAs<GenTexturesImmediate>(); - GLuint temp = kNewClientId; - SpecializedSetup<GenTexturesImmediate, 0>(); - cmd.Init(1, &temp); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); - EXPECT_EQ(GetServiceId(kNewClientId), kNewServiceId); -} - -TEST_F(GLES2DecoderTest, GenTexturesImmediateInvalidArgs) { - EXPECT_CALL(*gl_, GenTextures(_, _)).Times(0); - GenTexturesImmediate& cmd = *GetImmediateAs<GenTexturesImmediate>(); - SpecializedSetup<GenTexturesImmediate, 0>(); - cmd.Init(1, &client_texture_id_); - EXPECT_EQ(error::kInvalidArguments, - ExecuteImmediateCmd(cmd, sizeof(&client_texture_id_))); -} -// TODO(gman): GetActiveAttrib - -// TODO(gman): GetActiveUniform - -// TODO(gman): GetAttachedShaders - -// TODO(gman): GetAttribLocation - -// TODO(gman): GetAttribLocationImmediate - - -TEST_F(GLES2DecoderTest, GetBooleanvValidArgs) { - EXPECT_CALL( - *gl_, GetBooleanv( - 1, reinterpret_cast<GLboolean*>(shared_memory_address_))); - SpecializedSetup<GetBooleanv, 0>(); - GetBooleanv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBooleanvInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetBooleanv(_, _)).Times(0); - SpecializedSetup<GetBooleanv, 0>(); - GetBooleanv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBooleanvInvalidArgs1_1) { - EXPECT_CALL(*gl_, GetBooleanv(_, _)).Times(0); - SpecializedSetup<GetBooleanv, 0>(); - GetBooleanv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBufferParameterivValidArgs) { - EXPECT_CALL( - *gl_, GetBufferParameteriv( - GL_ARRAY_BUFFER, GL_BUFFER_SIZE, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetBufferParameteriv, 0>(); - GetBufferParameteriv cmd; - cmd.Init( - GL_ARRAY_BUFFER, GL_BUFFER_SIZE, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBufferParameterivInvalidArgs0_0) { - EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetBufferParameteriv, 0>(); - GetBufferParameteriv cmd; - cmd.Init( - GL_RENDERBUFFER, GL_BUFFER_SIZE, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBufferParameterivInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetBufferParameteriv, 0>(); - GetBufferParameteriv cmd; - cmd.Init( - GL_ARRAY_BUFFER, GL_PIXEL_PACK_BUFFER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBufferParameterivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetBufferParameteriv, 0>(); - GetBufferParameteriv cmd; - cmd.Init(GL_ARRAY_BUFFER, GL_BUFFER_SIZE, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetBufferParameterivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetBufferParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetBufferParameteriv, 0>(); - GetBufferParameteriv cmd; - cmd.Init( - GL_ARRAY_BUFFER, GL_BUFFER_SIZE, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetErrorValidArgs) { - EXPECT_CALL(*gl_, GetError()); - SpecializedSetup<GetError, 0>(); - GetError cmd; - cmd.Init(shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFloatvValidArgs) { - EXPECT_CALL( - *gl_, GetFloatv(1, reinterpret_cast<GLfloat*>(shared_memory_address_))); - SpecializedSetup<GetFloatv, 0>(); - GetFloatv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFloatvInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetFloatv(_, _)).Times(0); - SpecializedSetup<GetFloatv, 0>(); - GetFloatv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFloatvInvalidArgs1_1) { - EXPECT_CALL(*gl_, GetFloatv(_, _)).Times(0); - SpecializedSetup<GetFloatv, 0>(); - GetFloatv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFramebufferAttachmentParameterivValidArgs) { - EXPECT_CALL( - *gl_, GetFramebufferAttachmentParameterivEXT( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, - GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); - GetFramebufferAttachmentParameteriv cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, - GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFramebufferAttachmentParameterivInvalidArgs3_0) { - EXPECT_CALL( - *gl_, GetFramebufferAttachmentParameterivEXT(_, _, _, _)).Times(0); - SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); - GetFramebufferAttachmentParameteriv cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, - GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetFramebufferAttachmentParameterivInvalidArgs3_1) { - EXPECT_CALL( - *gl_, GetFramebufferAttachmentParameterivEXT(_, _, _, _)).Times(0); - SpecializedSetup<GetFramebufferAttachmentParameteriv, 0>(); - GetFramebufferAttachmentParameteriv cmd; - cmd.Init( - GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, - GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetIntegervValidArgs) { - EXPECT_CALL( - *gl_, GetIntegerv(1, reinterpret_cast<GLint*>(shared_memory_address_))); - SpecializedSetup<GetIntegerv, 0>(); - GetIntegerv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetIntegervInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetIntegerv(_, _)).Times(0); - SpecializedSetup<GetIntegerv, 0>(); - GetIntegerv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetIntegervInvalidArgs1_1) { - EXPECT_CALL(*gl_, GetIntegerv(_, _)).Times(0); - SpecializedSetup<GetIntegerv, 0>(); - GetIntegerv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetProgramivValidArgs) { - EXPECT_CALL( - *gl_, GetProgramiv( - kServiceProgramId, GL_DELETE_STATUS, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetProgramiv, 0>(); - GetProgramiv cmd; - cmd.Init( - client_program_id_, GL_DELETE_STATUS, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetProgramivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetProgramiv(_, _, _)).Times(0); - SpecializedSetup<GetProgramiv, 0>(); - GetProgramiv cmd; - cmd.Init(client_program_id_, GL_DELETE_STATUS, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetProgramivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetProgramiv(_, _, _)).Times(0); - SpecializedSetup<GetProgramiv, 0>(); - GetProgramiv cmd; - cmd.Init( - client_program_id_, GL_DELETE_STATUS, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} -// TODO(gman): GetProgramInfoLog - - -TEST_F(GLES2DecoderTest, GetRenderbufferParameterivValidArgs) { - EXPECT_CALL( - *gl_, GetRenderbufferParameterivEXT( - GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetRenderbufferParameteriv, 0>(); - GetRenderbufferParameteriv cmd; - cmd.Init( - GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetRenderbufferParameterivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetRenderbufferParameterivEXT(_, _, _)).Times(0); - SpecializedSetup<GetRenderbufferParameteriv, 0>(); - GetRenderbufferParameteriv cmd; - cmd.Init(GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetRenderbufferParameterivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetRenderbufferParameterivEXT(_, _, _)).Times(0); - SpecializedSetup<GetRenderbufferParameteriv, 0>(); - GetRenderbufferParameteriv cmd; - cmd.Init( - GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetShaderivValidArgs) { - EXPECT_CALL( - *gl_, GetShaderiv( - kServiceShaderId, GL_SHADER_TYPE, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetShaderiv, 0>(); - GetShaderiv cmd; - cmd.Init( - client_shader_id_, GL_SHADER_TYPE, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetShaderivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetShaderiv(_, _, _)).Times(0); - SpecializedSetup<GetShaderiv, 0>(); - GetShaderiv cmd; - cmd.Init(client_shader_id_, GL_SHADER_TYPE, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetShaderivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetShaderiv(_, _, _)).Times(0); - SpecializedSetup<GetShaderiv, 0>(); - GetShaderiv cmd; - cmd.Init( - client_shader_id_, GL_SHADER_TYPE, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} -// TODO(gman): GetShaderInfoLog - -// TODO(gman): GetShaderPrecisionFormat - -// TODO(gman): GetShaderSource - - -TEST_F(GLES2DecoderTest, GetStringValidArgs) { - EXPECT_CALL(*gl_, GetString(GL_VENDOR)); - SpecializedSetup<GetString, 0>(); - GetString cmd; - cmd.Init(GL_VENDOR); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterfvValidArgs) { - EXPECT_CALL( - *gl_, GetTexParameterfv( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<GLfloat*>( - shared_memory_address_))); - SpecializedSetup<GetTexParameterfv, 0>(); - GetTexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterfvInvalidArgs0_0) { - EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameterfv, 0>(); - GetTexParameterfv cmd; - cmd.Init( - GL_PROXY_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterfvInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameterfv, 0>(); - GetTexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterfvInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameterfv, 0>(); - GetTexParameterfv cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterfvInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetTexParameterfv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameterfv, 0>(); - GetTexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterivValidArgs) { - EXPECT_CALL( - *gl_, GetTexParameteriv( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetTexParameteriv, 0>(); - GetTexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterivInvalidArgs0_0) { - EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameteriv, 0>(); - GetTexParameteriv cmd; - cmd.Init( - GL_PROXY_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterivInvalidArgs1_0) { - EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameteriv, 0>(); - GetTexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameteriv, 0>(); - GetTexParameteriv cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetTexParameterivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetTexParameteriv(_, _, _)).Times(0); - SpecializedSetup<GetTexParameteriv, 0>(); - GetTexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} -// TODO(gman): GetUniformfv - -// TODO(gman): GetUniformiv - -// TODO(gman): GetUniformLocation - -// TODO(gman): GetUniformLocationImmediate - - -TEST_F(GLES2DecoderTest, GetVertexAttribfvValidArgs) { - EXPECT_CALL( - *gl_, GetVertexAttribfv( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, reinterpret_cast<GLfloat*>( - shared_memory_address_))); - SpecializedSetup<GetVertexAttribfv, 0>(); - GetVertexAttribfv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetVertexAttribfvInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetVertexAttribfv(_, _, _)).Times(0); - SpecializedSetup<GetVertexAttribfv, 0>(); - GetVertexAttribfv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetVertexAttribfvInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetVertexAttribfv(_, _, _)).Times(0); - SpecializedSetup<GetVertexAttribfv, 0>(); - GetVertexAttribfv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetVertexAttribivValidArgs) { - EXPECT_CALL( - *gl_, GetVertexAttribiv( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, reinterpret_cast<GLint*>( - shared_memory_address_))); - SpecializedSetup<GetVertexAttribiv, 0>(); - GetVertexAttribiv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetVertexAttribivInvalidArgs2_0) { - EXPECT_CALL(*gl_, GetVertexAttribiv(_, _, _)).Times(0); - SpecializedSetup<GetVertexAttribiv, 0>(); - GetVertexAttribiv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, GetVertexAttribivInvalidArgs2_1) { - EXPECT_CALL(*gl_, GetVertexAttribiv(_, _, _)).Times(0); - SpecializedSetup<GetVertexAttribiv, 0>(); - GetVertexAttribiv cmd; - cmd.Init( - 1, GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} -// TODO(gman): GetVertexAttribPointerv - - -TEST_F(GLES2DecoderTest, HintValidArgs) { - EXPECT_CALL(*gl_, Hint(GL_GENERATE_MIPMAP_HINT, GL_FASTEST)); - SpecializedSetup<Hint, 0>(); - Hint cmd; - cmd.Init(GL_GENERATE_MIPMAP_HINT, GL_FASTEST); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, HintInvalidArgs0_0) { - EXPECT_CALL(*gl_, Hint(_, _)).Times(0); - SpecializedSetup<Hint, 0>(); - Hint cmd; - cmd.Init(GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsBufferValidArgs) { - EXPECT_CALL(*gl_, IsBuffer(kServiceBufferId)); - SpecializedSetup<IsBuffer, 0>(); - IsBuffer cmd; - cmd.Init(client_buffer_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsEnabledValidArgs) { - EXPECT_CALL(*gl_, IsEnabled(GL_BLEND)); - SpecializedSetup<IsEnabled, 0>(); - IsEnabled cmd; - cmd.Init(GL_BLEND, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsEnabledInvalidArgs0_0) { - EXPECT_CALL(*gl_, IsEnabled(_)).Times(0); - SpecializedSetup<IsEnabled, 0>(); - IsEnabled cmd; - cmd.Init(GL_CLIP_PLANE0, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsEnabledInvalidArgs0_1) { - EXPECT_CALL(*gl_, IsEnabled(_)).Times(0); - SpecializedSetup<IsEnabled, 0>(); - IsEnabled cmd; - cmd.Init(GL_POINT_SPRITE, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsFramebufferValidArgs) { - EXPECT_CALL(*gl_, IsFramebufferEXT(kServiceFramebufferId)); - SpecializedSetup<IsFramebuffer, 0>(); - IsFramebuffer cmd; - cmd.Init(client_framebuffer_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsProgramValidArgs) { - EXPECT_CALL(*gl_, IsProgram(kServiceProgramId)); - SpecializedSetup<IsProgram, 0>(); - IsProgram cmd; - cmd.Init(client_program_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsRenderbufferValidArgs) { - EXPECT_CALL(*gl_, IsRenderbufferEXT(kServiceRenderbufferId)); - SpecializedSetup<IsRenderbuffer, 0>(); - IsRenderbuffer cmd; - cmd.Init(client_renderbuffer_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsShaderValidArgs) { - EXPECT_CALL(*gl_, IsShader(kServiceShaderId)); - SpecializedSetup<IsShader, 0>(); - IsShader cmd; - cmd.Init(client_shader_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, IsTextureValidArgs) { - EXPECT_CALL(*gl_, IsTexture(kServiceTextureId)); - SpecializedSetup<IsTexture, 0>(); - IsTexture cmd; - cmd.Init(client_texture_id_, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, LineWidthValidArgs) { - EXPECT_CALL(*gl_, LineWidth(1)); - SpecializedSetup<LineWidth, 0>(); - LineWidth cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, LinkProgramValidArgs) { - EXPECT_CALL(*gl_, LinkProgram(kServiceProgramId)); - SpecializedSetup<LinkProgram, 0>(); - LinkProgram cmd; - cmd.Init(client_program_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): PixelStorei - - -TEST_F(GLES2DecoderTest, PolygonOffsetValidArgs) { - EXPECT_CALL(*gl_, PolygonOffset(1, 2)); - SpecializedSetup<PolygonOffset, 0>(); - PolygonOffset cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): ReadPixels - - -TEST_F(GLES2DecoderTest, RenderbufferStorageValidArgs) { - EXPECT_CALL(*gl_, RenderbufferStorageEXT(GL_RENDERBUFFER, GL_RGBA4, 3, 4)); - SpecializedSetup<RenderbufferStorage, 0>(); - RenderbufferStorage cmd; - cmd.Init(GL_RENDERBUFFER, GL_RGBA4, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, SampleCoverageValidArgs) { - EXPECT_CALL(*gl_, SampleCoverage(1, 2)); - SpecializedSetup<SampleCoverage, 0>(); - SampleCoverage cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, ScissorValidArgs) { - EXPECT_CALL(*gl_, Scissor(1, 2, 3, 4)); - SpecializedSetup<Scissor, 0>(); - Scissor cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): ShaderSource - -// TODO(gman): ShaderSourceImmediate - - -TEST_F(GLES2DecoderTest, StencilFuncValidArgs) { - EXPECT_CALL(*gl_, StencilFunc(GL_NEVER, 2, 3)); - SpecializedSetup<StencilFunc, 0>(); - StencilFunc cmd; - cmd.Init(GL_NEVER, 2, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, StencilFuncSeparateValidArgs) { - EXPECT_CALL(*gl_, StencilFuncSeparate(GL_FRONT, GL_NEVER, 3, 4)); - SpecializedSetup<StencilFuncSeparate, 0>(); - StencilFuncSeparate cmd; - cmd.Init(GL_FRONT, GL_NEVER, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, StencilMaskValidArgs) { - EXPECT_CALL(*gl_, StencilMask(1)); - SpecializedSetup<StencilMask, 0>(); - StencilMask cmd; - cmd.Init(1); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, StencilMaskSeparateValidArgs) { - EXPECT_CALL(*gl_, StencilMaskSeparate(GL_FRONT, 2)); - SpecializedSetup<StencilMaskSeparate, 0>(); - StencilMaskSeparate cmd; - cmd.Init(GL_FRONT, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, StencilOpValidArgs) { - EXPECT_CALL(*gl_, StencilOp(GL_KEEP, GL_KEEP, GL_KEEP)); - SpecializedSetup<StencilOp, 0>(); - StencilOp cmd; - cmd.Init(GL_KEEP, GL_KEEP, GL_KEEP); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, StencilOpSeparateValidArgs) { - EXPECT_CALL(*gl_, StencilOpSeparate(GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP)); - SpecializedSetup<StencilOpSeparate, 0>(); - StencilOpSeparate cmd; - cmd.Init(GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): TexImage2D - -// TODO(gman): TexImage2DImmediate - - -TEST_F(GLES2DecoderTest, TexParameterfValidArgs) { - EXPECT_CALL(*gl_, TexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3)); - SpecializedSetup<TexParameterf, 0>(); - TexParameterf cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfInvalidArgs0_0) { - EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); - SpecializedSetup<TexParameterf, 0>(); - TexParameterf cmd; - cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfInvalidArgs0_1) { - EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); - SpecializedSetup<TexParameterf, 0>(); - TexParameterf cmd; - cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfInvalidArgs1_0) { - EXPECT_CALL(*gl_, TexParameterf(_, _, _)).Times(0); - SpecializedSetup<TexParameterf, 0>(); - TexParameterf cmd; - cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvValidArgs) { - EXPECT_CALL( - *gl_, TexParameterfv( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, - reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvInvalidArgs0_0) { - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init( - GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvInvalidArgs0_1) { - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init( - GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvInvalidArgs1_0) { - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvInvalidArgs2_0) { - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvInvalidArgs2_1) { - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfv, 0>(); - TexParameterfv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterfvImmediateValidArgs) { - TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); - EXPECT_CALL( - *gl_, - TexParameterfv(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<TexParameterfvImmediate, 0>(); - GLfloat temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterfvImmediateInvalidArgs0_0) { - TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfvImmediate, 0>(); - GLfloat temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterfvImmediateInvalidArgs0_1) { - TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfvImmediate, 0>(); - GLfloat temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterfvImmediateInvalidArgs1_0) { - TexParameterfvImmediate& cmd = *GetImmediateAs<TexParameterfvImmediate>(); - EXPECT_CALL(*gl_, TexParameterfv(_, _, _)).Times(0); - SpecializedSetup<TexParameterfvImmediate, 0>(); - GLfloat temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameteriValidArgs) { - EXPECT_CALL(*gl_, TexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3)); - SpecializedSetup<TexParameteri, 0>(); - TexParameteri cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameteriInvalidArgs0_0) { - EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); - SpecializedSetup<TexParameteri, 0>(); - TexParameteri cmd; - cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameteriInvalidArgs0_1) { - EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); - SpecializedSetup<TexParameteri, 0>(); - TexParameteri cmd; - cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameteriInvalidArgs1_0) { - EXPECT_CALL(*gl_, TexParameteri(_, _, _)).Times(0); - SpecializedSetup<TexParameteri, 0>(); - TexParameteri cmd; - cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivValidArgs) { - EXPECT_CALL( - *gl_, TexParameteriv( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, reinterpret_cast<const GLint*>( - shared_memory_address_))); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivInvalidArgs0_0) { - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init( - GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivInvalidArgs0_1) { - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init( - GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivInvalidArgs1_0) { - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_GENERATE_MIPMAP, shared_memory_id_, - shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivInvalidArgs2_0) { - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivInvalidArgs2_1) { - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameteriv, 0>(); - TexParameteriv cmd; - cmd.Init( - GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, shared_memory_id_, - kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, TexParameterivImmediateValidArgs) { - TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); - EXPECT_CALL( - *gl_, - TexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, - reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<TexParameterivImmediate, 0>(); - GLint temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterivImmediateInvalidArgs0_0) { - TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameterivImmediate, 0>(); - GLint temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterivImmediateInvalidArgs0_1) { - TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameterivImmediate, 0>(); - GLint temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, TexParameterivImmediateInvalidArgs1_0) { - TexParameterivImmediate& cmd = *GetImmediateAs<TexParameterivImmediate>(); - EXPECT_CALL(*gl_, TexParameteriv(_, _, _)).Times(0); - SpecializedSetup<TexParameterivImmediate, 0>(); - GLint temp[1] = { 0, }; - cmd.Init(GL_TEXTURE_2D, GL_GENERATE_MIPMAP, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} -// TODO(gman): TexSubImage2D - -// TODO(gman): TexSubImage2DImmediate - - -TEST_F(GLES2DecoderTest, Uniform1fValidArgs) { - EXPECT_CALL(*gl_, Uniform1f(1, 2)); - SpecializedSetup<Uniform1f, 0>(); - Uniform1f cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1fvValidArgs) { - EXPECT_CALL( - *gl_, Uniform1fv( - 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<Uniform1fv, 0>(); - Uniform1fv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform1fv(_, _, _)).Times(0); - SpecializedSetup<Uniform1fv, 0>(); - Uniform1fv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1fvInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform1fv(_, _, _)).Times(0); - SpecializedSetup<Uniform1fv, 0>(); - Uniform1fv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1fvImmediateValidArgs) { - Uniform1fvImmediate& cmd = *GetImmediateAs<Uniform1fvImmediate>(); - EXPECT_CALL( - *gl_, - Uniform1fv(1, 2, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform1fvImmediate, 0>(); - GLfloat temp[1 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform1iValidArgs) { - EXPECT_CALL(*gl_, Uniform1i(1, 2)); - SpecializedSetup<Uniform1i, 0>(); - Uniform1i cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1ivValidArgs) { - EXPECT_CALL( - *gl_, Uniform1iv( - 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); - SpecializedSetup<Uniform1iv, 0>(); - Uniform1iv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1ivInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform1iv(_, _, _)).Times(0); - SpecializedSetup<Uniform1iv, 0>(); - Uniform1iv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1ivInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform1iv(_, _, _)).Times(0); - SpecializedSetup<Uniform1iv, 0>(); - Uniform1iv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform1ivImmediateValidArgs) { - Uniform1ivImmediate& cmd = *GetImmediateAs<Uniform1ivImmediate>(); - EXPECT_CALL( - *gl_, - Uniform1iv(1, 2, - reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform1ivImmediate, 0>(); - GLint temp[1 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform2fValidArgs) { - EXPECT_CALL(*gl_, Uniform2f(1, 2, 3)); - SpecializedSetup<Uniform2f, 0>(); - Uniform2f cmd; - cmd.Init(1, 2, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2fvValidArgs) { - EXPECT_CALL( - *gl_, Uniform2fv( - 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<Uniform2fv, 0>(); - Uniform2fv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform2fv(_, _, _)).Times(0); - SpecializedSetup<Uniform2fv, 0>(); - Uniform2fv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2fvInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform2fv(_, _, _)).Times(0); - SpecializedSetup<Uniform2fv, 0>(); - Uniform2fv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2fvImmediateValidArgs) { - Uniform2fvImmediate& cmd = *GetImmediateAs<Uniform2fvImmediate>(); - EXPECT_CALL( - *gl_, - Uniform2fv(1, 2, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform2fvImmediate, 0>(); - GLfloat temp[2 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform2iValidArgs) { - EXPECT_CALL(*gl_, Uniform2i(1, 2, 3)); - SpecializedSetup<Uniform2i, 0>(); - Uniform2i cmd; - cmd.Init(1, 2, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2ivValidArgs) { - EXPECT_CALL( - *gl_, Uniform2iv( - 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); - SpecializedSetup<Uniform2iv, 0>(); - Uniform2iv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2ivInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform2iv(_, _, _)).Times(0); - SpecializedSetup<Uniform2iv, 0>(); - Uniform2iv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2ivInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform2iv(_, _, _)).Times(0); - SpecializedSetup<Uniform2iv, 0>(); - Uniform2iv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform2ivImmediateValidArgs) { - Uniform2ivImmediate& cmd = *GetImmediateAs<Uniform2ivImmediate>(); - EXPECT_CALL( - *gl_, - Uniform2iv(1, 2, - reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform2ivImmediate, 0>(); - GLint temp[2 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform3fValidArgs) { - EXPECT_CALL(*gl_, Uniform3f(1, 2, 3, 4)); - SpecializedSetup<Uniform3f, 0>(); - Uniform3f cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3fvValidArgs) { - EXPECT_CALL( - *gl_, Uniform3fv( - 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<Uniform3fv, 0>(); - Uniform3fv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform3fv(_, _, _)).Times(0); - SpecializedSetup<Uniform3fv, 0>(); - Uniform3fv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3fvInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform3fv(_, _, _)).Times(0); - SpecializedSetup<Uniform3fv, 0>(); - Uniform3fv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3fvImmediateValidArgs) { - Uniform3fvImmediate& cmd = *GetImmediateAs<Uniform3fvImmediate>(); - EXPECT_CALL( - *gl_, - Uniform3fv(1, 2, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform3fvImmediate, 0>(); - GLfloat temp[3 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform3iValidArgs) { - EXPECT_CALL(*gl_, Uniform3i(1, 2, 3, 4)); - SpecializedSetup<Uniform3i, 0>(); - Uniform3i cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3ivValidArgs) { - EXPECT_CALL( - *gl_, Uniform3iv( - 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); - SpecializedSetup<Uniform3iv, 0>(); - Uniform3iv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3ivInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform3iv(_, _, _)).Times(0); - SpecializedSetup<Uniform3iv, 0>(); - Uniform3iv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3ivInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform3iv(_, _, _)).Times(0); - SpecializedSetup<Uniform3iv, 0>(); - Uniform3iv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform3ivImmediateValidArgs) { - Uniform3ivImmediate& cmd = *GetImmediateAs<Uniform3ivImmediate>(); - EXPECT_CALL( - *gl_, - Uniform3iv(1, 2, - reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform3ivImmediate, 0>(); - GLint temp[3 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform4fValidArgs) { - EXPECT_CALL(*gl_, Uniform4f(1, 2, 3, 4, 5)); - SpecializedSetup<Uniform4f, 0>(); - Uniform4f cmd; - cmd.Init(1, 2, 3, 4, 5); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4fvValidArgs) { - EXPECT_CALL( - *gl_, Uniform4fv( - 1, 2, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<Uniform4fv, 0>(); - Uniform4fv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform4fv(_, _, _)).Times(0); - SpecializedSetup<Uniform4fv, 0>(); - Uniform4fv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4fvInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform4fv(_, _, _)).Times(0); - SpecializedSetup<Uniform4fv, 0>(); - Uniform4fv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4fvImmediateValidArgs) { - Uniform4fvImmediate& cmd = *GetImmediateAs<Uniform4fvImmediate>(); - EXPECT_CALL( - *gl_, - Uniform4fv(1, 2, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform4fvImmediate, 0>(); - GLfloat temp[4 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, Uniform4iValidArgs) { - EXPECT_CALL(*gl_, Uniform4i(1, 2, 3, 4, 5)); - SpecializedSetup<Uniform4i, 0>(); - Uniform4i cmd; - cmd.Init(1, 2, 3, 4, 5); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4ivValidArgs) { - EXPECT_CALL( - *gl_, Uniform4iv( - 1, 2, reinterpret_cast<const GLint*>(shared_memory_address_))); - SpecializedSetup<Uniform4iv, 0>(); - Uniform4iv cmd; - cmd.Init(1, 2, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4ivInvalidArgs2_0) { - EXPECT_CALL(*gl_, Uniform4iv(_, _, _)).Times(0); - SpecializedSetup<Uniform4iv, 0>(); - Uniform4iv cmd; - cmd.Init(1, 2, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4ivInvalidArgs2_1) { - EXPECT_CALL(*gl_, Uniform4iv(_, _, _)).Times(0); - SpecializedSetup<Uniform4iv, 0>(); - Uniform4iv cmd; - cmd.Init(1, 2, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, Uniform4ivImmediateValidArgs) { - Uniform4ivImmediate& cmd = *GetImmediateAs<Uniform4ivImmediate>(); - EXPECT_CALL( - *gl_, - Uniform4iv(1, 2, - reinterpret_cast<GLint*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<Uniform4ivImmediate, 0>(); - GLint temp[4 * 2] = { 0, }; - cmd.Init(1, 2, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvValidArgs) { - EXPECT_CALL( - *gl_, UniformMatrix2fv( - 1, 2, false, reinterpret_cast<const GLfloat*>( - shared_memory_address_))); - SpecializedSetup<UniformMatrix2fv, 0>(); - UniformMatrix2fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix2fv, 0>(); - UniformMatrix2fv cmd; - cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvInvalidArgs3_0) { - EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix2fv, 0>(); - UniformMatrix2fv cmd; - cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvInvalidArgs3_1) { - EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix2fv, 0>(); - UniformMatrix2fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvImmediateValidArgs) { - UniformMatrix2fvImmediate& cmd = - *GetImmediateAs<UniformMatrix2fvImmediate>(); - EXPECT_CALL( - *gl_, - UniformMatrix2fv(1, 2, false, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<UniformMatrix2fvImmediate, 0>(); - GLfloat temp[4 * 2] = { 0, }; - cmd.Init(1, 2, false, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix2fvImmediateInvalidArgs2_0) { - UniformMatrix2fvImmediate& cmd = - *GetImmediateAs<UniformMatrix2fvImmediate>(); - EXPECT_CALL(*gl_, UniformMatrix2fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix2fvImmediate, 0>(); - GLfloat temp[4 * 2] = { 0, }; - cmd.Init(1, 2, true, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvValidArgs) { - EXPECT_CALL( - *gl_, UniformMatrix3fv( - 1, 2, false, reinterpret_cast<const GLfloat*>( - shared_memory_address_))); - SpecializedSetup<UniformMatrix3fv, 0>(); - UniformMatrix3fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix3fv, 0>(); - UniformMatrix3fv cmd; - cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvInvalidArgs3_0) { - EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix3fv, 0>(); - UniformMatrix3fv cmd; - cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvInvalidArgs3_1) { - EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix3fv, 0>(); - UniformMatrix3fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvImmediateValidArgs) { - UniformMatrix3fvImmediate& cmd = - *GetImmediateAs<UniformMatrix3fvImmediate>(); - EXPECT_CALL( - *gl_, - UniformMatrix3fv(1, 2, false, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<UniformMatrix3fvImmediate, 0>(); - GLfloat temp[9 * 2] = { 0, }; - cmd.Init(1, 2, false, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix3fvImmediateInvalidArgs2_0) { - UniformMatrix3fvImmediate& cmd = - *GetImmediateAs<UniformMatrix3fvImmediate>(); - EXPECT_CALL(*gl_, UniformMatrix3fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix3fvImmediate, 0>(); - GLfloat temp[9 * 2] = { 0, }; - cmd.Init(1, 2, true, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvValidArgs) { - EXPECT_CALL( - *gl_, UniformMatrix4fv( - 1, 2, false, reinterpret_cast<const GLfloat*>( - shared_memory_address_))); - SpecializedSetup<UniformMatrix4fv, 0>(); - UniformMatrix4fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvInvalidArgs2_0) { - EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix4fv, 0>(); - UniformMatrix4fv cmd; - cmd.Init(1, 2, true, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvInvalidArgs3_0) { - EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix4fv, 0>(); - UniformMatrix4fv cmd; - cmd.Init(1, 2, false, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvInvalidArgs3_1) { - EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix4fv, 0>(); - UniformMatrix4fv cmd; - cmd.Init(1, 2, false, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvImmediateValidArgs) { - UniformMatrix4fvImmediate& cmd = - *GetImmediateAs<UniformMatrix4fvImmediate>(); - EXPECT_CALL( - *gl_, - UniformMatrix4fv(1, 2, false, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<UniformMatrix4fvImmediate, 0>(); - GLfloat temp[16 * 2] = { 0, }; - cmd.Init(1, 2, false, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, UniformMatrix4fvImmediateInvalidArgs2_0) { - UniformMatrix4fvImmediate& cmd = - *GetImmediateAs<UniformMatrix4fvImmediate>(); - EXPECT_CALL(*gl_, UniformMatrix4fv(_, _, _, _)).Times(0); - SpecializedSetup<UniformMatrix4fvImmediate, 0>(); - GLfloat temp[16 * 2] = { 0, }; - cmd.Init(1, 2, true, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} -// TODO(gman): UseProgram - -TEST_F(GLES2DecoderTest, ValidateProgramValidArgs) { - EXPECT_CALL(*gl_, ValidateProgram(kServiceProgramId)); - SpecializedSetup<ValidateProgram, 0>(); - ValidateProgram cmd; - cmd.Init(client_program_id_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib1fValidArgs) { - EXPECT_CALL(*gl_, VertexAttrib1f(1, 2)); - SpecializedSetup<VertexAttrib1f, 0>(); - VertexAttrib1f cmd; - cmd.Init(1, 2); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib1fvValidArgs) { - EXPECT_CALL( - *gl_, VertexAttrib1fv( - 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<VertexAttrib1fv, 0>(); - VertexAttrib1fv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib1fvInvalidArgs1_0) { - EXPECT_CALL(*gl_, VertexAttrib1fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib1fv, 0>(); - VertexAttrib1fv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib1fvInvalidArgs1_1) { - EXPECT_CALL(*gl_, VertexAttrib1fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib1fv, 0>(); - VertexAttrib1fv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib1fvImmediateValidArgs) { - VertexAttrib1fvImmediate& cmd = *GetImmediateAs<VertexAttrib1fvImmediate>(); - EXPECT_CALL( - *gl_, - VertexAttrib1fv(1, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<VertexAttrib1fvImmediate, 0>(); - GLfloat temp[1] = { 0, }; - cmd.Init(1, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, VertexAttrib2fValidArgs) { - EXPECT_CALL(*gl_, VertexAttrib2f(1, 2, 3)); - SpecializedSetup<VertexAttrib2f, 0>(); - VertexAttrib2f cmd; - cmd.Init(1, 2, 3); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib2fvValidArgs) { - EXPECT_CALL( - *gl_, VertexAttrib2fv( - 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<VertexAttrib2fv, 0>(); - VertexAttrib2fv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib2fvInvalidArgs1_0) { - EXPECT_CALL(*gl_, VertexAttrib2fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib2fv, 0>(); - VertexAttrib2fv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib2fvInvalidArgs1_1) { - EXPECT_CALL(*gl_, VertexAttrib2fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib2fv, 0>(); - VertexAttrib2fv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib2fvImmediateValidArgs) { - VertexAttrib2fvImmediate& cmd = *GetImmediateAs<VertexAttrib2fvImmediate>(); - EXPECT_CALL( - *gl_, - VertexAttrib2fv(1, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<VertexAttrib2fvImmediate, 0>(); - GLfloat temp[2] = { 0, }; - cmd.Init(1, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, VertexAttrib3fValidArgs) { - EXPECT_CALL(*gl_, VertexAttrib3f(1, 2, 3, 4)); - SpecializedSetup<VertexAttrib3f, 0>(); - VertexAttrib3f cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib3fvValidArgs) { - EXPECT_CALL( - *gl_, VertexAttrib3fv( - 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<VertexAttrib3fv, 0>(); - VertexAttrib3fv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib3fvInvalidArgs1_0) { - EXPECT_CALL(*gl_, VertexAttrib3fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib3fv, 0>(); - VertexAttrib3fv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib3fvInvalidArgs1_1) { - EXPECT_CALL(*gl_, VertexAttrib3fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib3fv, 0>(); - VertexAttrib3fv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib3fvImmediateValidArgs) { - VertexAttrib3fvImmediate& cmd = *GetImmediateAs<VertexAttrib3fvImmediate>(); - EXPECT_CALL( - *gl_, - VertexAttrib3fv(1, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<VertexAttrib3fvImmediate, 0>(); - GLfloat temp[3] = { 0, }; - cmd.Init(1, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} - -TEST_F(GLES2DecoderTest, VertexAttrib4fValidArgs) { - EXPECT_CALL(*gl_, VertexAttrib4f(1, 2, 3, 4, 5)); - SpecializedSetup<VertexAttrib4f, 0>(); - VertexAttrib4f cmd; - cmd.Init(1, 2, 3, 4, 5); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib4fvValidArgs) { - EXPECT_CALL( - *gl_, VertexAttrib4fv( - 1, reinterpret_cast<const GLfloat*>(shared_memory_address_))); - SpecializedSetup<VertexAttrib4fv, 0>(); - VertexAttrib4fv cmd; - cmd.Init(1, shared_memory_id_, shared_memory_offset_); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib4fvInvalidArgs1_0) { - EXPECT_CALL(*gl_, VertexAttrib4fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib4fv, 0>(); - VertexAttrib4fv cmd; - cmd.Init(1, kInvalidSharedMemoryId, 0); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib4fvInvalidArgs1_1) { - EXPECT_CALL(*gl_, VertexAttrib4fv(_, _)).Times(0); - SpecializedSetup<VertexAttrib4fv, 0>(); - VertexAttrib4fv cmd; - cmd.Init(1, shared_memory_id_, kInvalidSharedMemoryOffset); - EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd)); -} - -TEST_F(GLES2DecoderTest, VertexAttrib4fvImmediateValidArgs) { - VertexAttrib4fvImmediate& cmd = *GetImmediateAs<VertexAttrib4fvImmediate>(); - EXPECT_CALL( - *gl_, - VertexAttrib4fv(1, - reinterpret_cast<GLfloat*>(ImmediateDataAddress(&cmd)))); - SpecializedSetup<VertexAttrib4fvImmediate, 0>(); - GLfloat temp[4] = { 0, }; - cmd.Init(1, &temp[0]); - EXPECT_EQ(error::kNoError, - ExecuteImmediateCmd(cmd, sizeof(temp))); -} -// TODO(gman): VertexAttribPointer - - -TEST_F(GLES2DecoderTest, ViewportValidArgs) { - EXPECT_CALL(*gl_, Viewport(1, 2, 3, 4)); - SpecializedSetup<Viewport, 0>(); - Viewport cmd; - cmd.Init(1, 2, 3, 4); - EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); -} -// TODO(gman): SwapBuffers -#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_AUTOGEN_H_ - diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.cc b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.cc new file mode 100644 index 0000000..d0a7ceb --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.cc @@ -0,0 +1,424 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h" +#include "base/string_util.h" +#include "gpu/command_buffer/common/gles2_cmd_format.h" +#include "gpu/command_buffer/common/gles2_cmd_utils.h" +#include "gpu/command_buffer/service/gl_mock.h" +#include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/program_manager.h" +#include "testing/gtest/include/gtest/gtest.h" + +using ::gles2::MockGLInterface; +using ::testing::_; +using ::testing::DoAll; +using ::testing::InSequence; +using ::testing::MatcherCast; +using ::testing::Pointee; +using ::testing::Return; +using ::testing::SetArrayArgument; +using ::testing::SetArgumentPointee; +using ::testing::StrEq; +using ::testing::StrictMock; + +namespace gpu { +namespace gles2 { + +void GLES2DecoderTestBase::SetUp() { + gl_.reset(new StrictMock<MockGLInterface>()); + ::gles2::GLInterface::SetGLInterface(gl_.get()); + + InSequence sequence; + + EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_VERTEX_ATTRIBS, _)) + .WillOnce(SetArgumentPointee<1>(kNumVertexAttribs)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS, _)) + .WillOnce(SetArgumentPointee<1>(kNumTextureUnits)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_TEXTURE_SIZE, _)) + .WillOnce(SetArgumentPointee<1>(kMaxTextureSize)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, GetIntegerv(GL_MAX_CUBE_MAP_TEXTURE_SIZE, _)) + .WillOnce(SetArgumentPointee<1>(kMaxCubeMapTextureSize)) + .RetiresOnSaturation(); + static GLuint black_ids[] = { + kServiceBlackTexture2dId, + kServiceBlackTextureCubemapId, + }; + EXPECT_CALL(*gl_, GenTextures(2, _)) + .WillOnce(SetArrayArgument<1>(black_ids, black_ids + 2)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, kServiceBlackTexture2dId)) + .Times(1) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, TexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, + GL_UNSIGNED_BYTE, _)) + .Times(1) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, 0)) + .Times(1) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_CUBE_MAP, + kServiceBlackTextureCubemapId)) + .Times(1) + .RetiresOnSaturation(); + static GLenum faces[] = { + GL_TEXTURE_CUBE_MAP_POSITIVE_X, + GL_TEXTURE_CUBE_MAP_NEGATIVE_X, + GL_TEXTURE_CUBE_MAP_POSITIVE_Y, + GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, + GL_TEXTURE_CUBE_MAP_POSITIVE_Z, + GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, + }; + for (size_t ii = 0; ii < arraysize(faces); ++ii) { + EXPECT_CALL(*gl_, TexImage2D(faces[ii], 0, GL_RGBA, 1, 1, 0, GL_RGBA, + GL_UNSIGNED_BYTE, _)) + .Times(1) + .RetiresOnSaturation(); + } + EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_CUBE_MAP, 0)) + .Times(1) + .RetiresOnSaturation(); + + engine_.reset(new StrictMock<MockCommandBufferEngine>()); + Buffer buffer = engine_->GetSharedMemoryBuffer(kSharedMemoryId); + shared_memory_offset_ = kSharedMemoryOffset; + shared_memory_address_ = reinterpret_cast<int8*>(buffer.ptr) + + shared_memory_offset_; + shared_memory_id_ = kSharedMemoryId; + + decoder_.reset(GLES2Decoder::Create(&group_)); + decoder_->Initialize(); + decoder_->set_engine(engine_.get()); + + EXPECT_CALL(*gl_, GenBuffersARB(_, _)) + .WillOnce(SetArgumentPointee<1>(kServiceBufferId)) + .RetiresOnSaturation(); + GenHelper<GenBuffersImmediate>(client_buffer_id_); + EXPECT_CALL(*gl_, GenFramebuffersEXT(_, _)) + .WillOnce(SetArgumentPointee<1>(kServiceFramebufferId)) + .RetiresOnSaturation(); + GenHelper<GenFramebuffersImmediate>(client_framebuffer_id_); + EXPECT_CALL(*gl_, GenRenderbuffersEXT(_, _)) + .WillOnce(SetArgumentPointee<1>(kServiceRenderbufferId)) + .RetiresOnSaturation(); + GenHelper<GenRenderbuffersImmediate>(client_renderbuffer_id_); + EXPECT_CALL(*gl_, GenTextures(_, _)) + .WillOnce(SetArgumentPointee<1>(kServiceTextureId)) + .RetiresOnSaturation(); + GenHelper<GenTexturesImmediate>(client_texture_id_); + EXPECT_CALL(*gl_, GenBuffersARB(_, _)) + .WillOnce(SetArgumentPointee<1>(kServiceElementBufferId)) + .RetiresOnSaturation(); + GenHelper<GenBuffersImmediate>(client_element_buffer_id_); + + { + EXPECT_CALL(*gl_, CreateProgram()) + .Times(1) + .WillOnce(Return(kServiceProgramId)) + .RetiresOnSaturation(); + CreateProgram cmd; + cmd.Init(client_program_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + } + + { + EXPECT_CALL(*gl_, CreateShader(_)) + .Times(1) + .WillOnce(Return(kServiceShaderId)) + .RetiresOnSaturation(); + CreateShader cmd; + cmd.Init(GL_VERTEX_SHADER, client_shader_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + } + + EXPECT_EQ(GL_NO_ERROR, GetGLError()); +} + +void GLES2DecoderTestBase::TearDown() { + decoder_->Destroy(); + decoder_.reset(); + engine_.reset(); + ::gles2::GLInterface::SetGLInterface(NULL); + gl_.reset(); +} + +GLint GLES2DecoderTestBase::GetGLError() { + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + GetError cmd; + cmd.Init(shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + return static_cast<GLint>(*GetSharedMemoryAs<GLenum*>()); +} + +void GLES2DecoderTestBase::DoBindTexture( + GLenum target, GLuint client_id, GLuint service_id) { + EXPECT_CALL(*gl_, BindTexture(target, service_id)) + .Times(1) + .RetiresOnSaturation(); + BindTexture cmd; + cmd.Init(target, client_id); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderTestBase::DoTexImage2D( + GLenum target, GLint level, GLenum internal_format, + GLsizei width, GLsizei height, GLint border, + GLenum format, GLenum type, + uint32 shared_memory_id, uint32 shared_memory_offset) { + EXPECT_CALL(*gl_, TexImage2D(target, level, internal_format, + width, height, border, format, type, _)) + .Times(1) + .RetiresOnSaturation(); + TexImage2D cmd; + cmd.Init(target, level, internal_format, width, height, border, format, + type, shared_memory_id, shared_memory_offset); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::SetUp() { + GLES2DecoderTestBase::SetUp(); + + { + static AttribInfo attribs[] = { + { kAttrib1Name, kAttrib1Size, kAttrib1Type, kAttrib1Location, }, + { kAttrib2Name, kAttrib2Size, kAttrib2Type, kAttrib2Location, }, + { kAttrib3Name, kAttrib3Size, kAttrib3Type, kAttrib3Location, }, + }; + static UniformInfo uniforms[] = { + { kUniform1Name, kUniform1Size, kUniform1Type, kUniform1Location, }, + { kUniform2Name, kUniform2Size, kUniform2Type, kUniform2Location, }, + { kUniform3Name, kUniform3Size, kUniform3Type, kUniform3Location, }, + }; + SetupShader(attribs, arraysize(attribs), uniforms, arraysize(uniforms), + client_program_id_, kServiceProgramId); + } + + { + EXPECT_CALL(*gl_, UseProgram(kServiceProgramId)) + .Times(1) + .RetiresOnSaturation(); + UseProgram cmd; + cmd.Init(client_program_id_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); + } +} + +void GLES2DecoderWithShaderTestBase::TearDown() { + GLES2DecoderTestBase::TearDown(); +} + +void GLES2DecoderWithShaderTestBase::SetupShader( + GLES2DecoderWithShaderTestBase::AttribInfo* attribs, size_t num_attribs, + GLES2DecoderWithShaderTestBase::UniformInfo* uniforms, size_t num_uniforms, + GLuint client_id, GLuint service_id) { + LinkProgram cmd; + cmd.Init(client_id); + + { + InSequence s; + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, LinkProgram(service_id)) + .Times(1) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, + GetProgramiv(service_id, GL_ACTIVE_ATTRIBUTES, _)) + .WillOnce(SetArgumentPointee<2>(num_attribs)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, + GetProgramiv(service_id, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, _)) + .WillOnce(SetArgumentPointee<2>(kMaxAttribLength)) + .RetiresOnSaturation(); + for (size_t ii = 0; ii < num_attribs; ++ii) { + const AttribInfo& info = attribs[ii]; + EXPECT_CALL(*gl_, + GetActiveAttrib(service_id, ii, + kMaxAttribLength, _, _, _, _)) + .WillOnce(DoAll( + SetArgumentPointee<3>(strlen(info.name)), + SetArgumentPointee<4>(info.size), + SetArgumentPointee<5>(info.type), + SetArrayArgument<6>(info.name, + info.name + strlen(info.name) + 1))) + .RetiresOnSaturation(); + if (!ProgramManager::IsInvalidPrefix(info.name, strlen(info.name))) { + EXPECT_CALL(*gl_, GetAttribLocation(service_id, + StrEq(info.name))) + .WillOnce(Return(info.location)) + .RetiresOnSaturation(); + } + } + EXPECT_CALL(*gl_, + GetProgramiv(service_id, GL_ACTIVE_UNIFORMS, _)) + .WillOnce(SetArgumentPointee<2>(num_uniforms)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, + GetProgramiv(service_id, GL_ACTIVE_UNIFORM_MAX_LENGTH, _)) + .WillOnce(SetArgumentPointee<2>(kMaxUniformLength)) + .RetiresOnSaturation(); + for (size_t ii = 0; ii < num_uniforms; ++ii) { + const UniformInfo& info = uniforms[ii]; + EXPECT_CALL(*gl_, + GetActiveUniform(service_id, ii, + kMaxUniformLength, _, _, _, _)) + .WillOnce(DoAll( + SetArgumentPointee<3>(strlen(info.name)), + SetArgumentPointee<4>(info.size), + SetArgumentPointee<5>(info.type), + SetArrayArgument<6>(info.name, + info.name + strlen(info.name) + 1))) + .RetiresOnSaturation(); + if (!ProgramManager::IsInvalidPrefix(info.name, strlen(info.name))) { + EXPECT_CALL(*gl_, GetUniformLocation(service_id, + StrEq(info.name))) + .WillOnce(Return(info.location)) + .RetiresOnSaturation(); + if (info.size > 1) { + for (GLsizei jj = 1; jj < info.size; ++jj) { + std::string element_name( + std::string(info.name) + "[" + IntToString(jj) + "]"); + EXPECT_CALL(*gl_, GetUniformLocation(service_id, + StrEq(element_name))) + .WillOnce(Return(info.location + jj)) + .RetiresOnSaturation(); + } + } + } + } + } + + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoEnableVertexAttribArray(GLint index) { + EXPECT_CALL(*gl_, EnableVertexAttribArray(index)) + .Times(1) + .RetiresOnSaturation(); + EnableVertexAttribArray cmd; + cmd.Init(index); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoBindBuffer( + GLenum target, GLuint client_id, GLuint service_id) { + EXPECT_CALL(*gl_, BindBuffer(target, service_id)) + .Times(1) + .RetiresOnSaturation(); + BindBuffer cmd; + cmd.Init(target, client_id); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoBufferData(GLenum target, GLsizei size) { + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, BufferData(target, size, _, GL_STREAM_DRAW)) + .Times(1) + .RetiresOnSaturation(); + EXPECT_CALL(*gl_, GetError()) + .WillOnce(Return(GL_NO_ERROR)) + .RetiresOnSaturation(); + BufferData cmd; + cmd.Init(target, size, 0, 0, GL_STREAM_DRAW); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoBufferSubData( + GLenum target, GLint offset, GLsizei size, const void* data) { + EXPECT_CALL(*gl_, BufferSubData(target, offset, size, + shared_memory_address_)) + .Times(1) + .RetiresOnSaturation(); + memcpy(shared_memory_address_, data, size); + BufferSubData cmd; + cmd.Init(target, offset, size, shared_memory_id_, shared_memory_offset_); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoDeleteBuffer( + GLuint client_id, GLuint service_id) { + EXPECT_CALL(*gl_, DeleteBuffersARB(1, Pointee(service_id))) + .Times(1) + .RetiresOnSaturation(); + DeleteBuffers cmd; + cmd.Init(1, shared_memory_id_, shared_memory_offset_); + memcpy(shared_memory_address_, &client_id, sizeof(client_id)); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoDeleteProgram( + GLuint client_id, GLuint service_id) { + EXPECT_CALL(*gl_, DeleteProgram(service_id)) + .Times(1) + .RetiresOnSaturation(); + DeleteProgram cmd; + cmd.Init(client_id); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::DoVertexAttribPointer( + GLuint index, GLint size, GLenum type, GLsizei stride, GLuint offset) { + EXPECT_CALL(*gl_, + VertexAttribPointer(index, size, type, GL_FALSE, stride, + BufferOffset(offset))) + .Times(1) + .RetiresOnSaturation(); + VertexAttribPointer cmd; + cmd.Init(index, size, GL_FLOAT, GL_FALSE, stride, offset); + EXPECT_EQ(error::kNoError, ExecuteCmd(cmd)); +} + +void GLES2DecoderWithShaderTestBase::SetupVertexBuffer() { + DoEnableVertexAttribArray(1); + DoBindBuffer(GL_ARRAY_BUFFER, client_buffer_id_, kServiceBufferId); + GLfloat f = 0; + DoBufferData(GL_ARRAY_BUFFER, kNumVertices * 2 * sizeof(f)); +} + +void GLES2DecoderWithShaderTestBase::SetupIndexBuffer() { + DoBindBuffer(GL_ELEMENT_ARRAY_BUFFER, + client_element_buffer_id_, + kServiceElementBufferId); + static const GLshort indices[] = {100, 1, 2, 3, 4, 5, 6, 7, 100, 9}; + COMPILE_ASSERT(arraysize(indices) == kNumIndices, Indices_is_not_10); + DoBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices)); + DoBufferSubData(GL_ELEMENT_ARRAY_BUFFER, 0, sizeof(indices), indices); +} + +void GLES2DecoderWithShaderTestBase::SetupTexture() { + DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId); + DoTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE, + 0, 0); +}; + +void GLES2DecoderWithShaderTestBase::DeleteVertexBuffer() { + DoDeleteBuffer(client_buffer_id_, kServiceBufferId); +} + +void GLES2DecoderWithShaderTestBase::DeleteIndexBuffer() { + DoDeleteBuffer(client_element_buffer_id_, kServiceElementBufferId); +} + +const char* GLES2DecoderWithShaderTestBase::kAttrib1Name = "attrib1"; +const char* GLES2DecoderWithShaderTestBase::kAttrib2Name = "attrib2"; +const char* GLES2DecoderWithShaderTestBase::kAttrib3Name = "attrib3"; +const char* GLES2DecoderWithShaderTestBase::kUniform1Name = "uniform1"; +const char* GLES2DecoderWithShaderTestBase::kUniform2Name = "uniform2"; +const char* GLES2DecoderWithShaderTestBase::kUniform3Name = "uniform3"; + +} // namespace gles2 +} // namespace gpu + + diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h new file mode 100644 index 0000000..c732a2c --- /dev/null +++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_base.h @@ -0,0 +1,310 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_BASE_H_ +#define GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_BASE_H_ + +#include "gpu/command_buffer/common/gles2_cmd_format.h" +#include "gpu/command_buffer/common/gles2_cmd_utils.h" +#include "gpu/command_buffer/service/cmd_buffer_engine.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/gl_mock.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" +#include "gpu/command_buffer/service/program_manager.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace gpu { +namespace gles2 { + +class GLES2DecoderTestBase : public testing::Test { + public: + GLES2DecoderTestBase() + : client_buffer_id_(100), + client_framebuffer_id_(101), + client_program_id_(102), + client_renderbuffer_id_(103), + client_shader_id_(104), + client_texture_id_(105), + client_element_buffer_id_(106) { + memset(immediate_buffer_, 0xEE, sizeof(immediate_buffer_)); + } + + protected: + static const GLint kMaxTextureSize = 2048; + static const GLint kMaxCubeMapTextureSize = 256; + static const GLint kNumVertexAttribs = 16; + static const GLint kNumTextureUnits = 8; + + static const GLuint kServiceBlackTexture2dId = 701; + static const GLuint kServiceBlackTextureCubemapId = 702; + + static const GLuint kServiceBufferId = 301; + static const GLuint kServiceFramebufferId = 302; + static const GLuint kServiceRenderbufferId = 303; + static const GLuint kServiceTextureId = 304; + static const GLuint kServiceProgramId = 305; + static const GLuint kServiceShaderId = 306; + static const GLuint kServiceElementBufferId = 307; + + static const int32 kSharedMemoryId = 401; + static const size_t kSharedBufferSize = 2048; + static const uint32 kSharedMemoryOffset = 132; + static const int32 kInvalidSharedMemoryId = 402; + static const uint32 kInvalidSharedMemoryOffset = kSharedBufferSize + 1; + static const uint32 kInitialResult = 0xBDBDBDBDu; + static const uint8 kInitialMemoryValue = 0xBDu; + + static const uint32 kNewClientId = 501; + static const uint32 kNewServiceId = 502; + static const uint32 kInvalidClientId = 601; + + // Template to call glGenXXX functions. + template <typename T> + void GenHelper(GLuint client_id) { + int8 buffer[sizeof(T) + sizeof(client_id)]; + T& cmd = *reinterpret_cast<T*>(&buffer); + cmd.Init(1, &client_id); + EXPECT_EQ(error::kNoError, + ExecuteImmediateCmd(cmd, sizeof(client_id))); + } + + // This template exists solely so we can specialize it for + // certain commands. + template <typename T, int id> + void SpecializedSetup() { + } + + template <typename T> + T* GetImmediateAs() { + return reinterpret_cast<T*>(immediate_buffer_); + } + + template <typename T, typename Command> + T GetImmediateDataAs(Command* cmd) { + return reinterpret_cast<T>(ImmediateDataAddress(cmd)); + } + + void ClearSharedMemory() { + engine_->ClearSharedMemory(); + } + + virtual void SetUp(); + virtual void TearDown(); + + template <typename T> + error::Error ExecuteCmd(const T& cmd) { + COMPILE_ASSERT(T::kArgFlags == cmd::kFixed, Cmd_kArgFlags_not_kFixed); + return decoder_->DoCommand(cmd.kCmdId, + ComputeNumEntries(sizeof(cmd)) - 1, + &cmd); + } + + template <typename T> + error::Error ExecuteImmediateCmd(const T& cmd, size_t data_size) { + COMPILE_ASSERT(T::kArgFlags == cmd::kAtLeastN, Cmd_kArgFlags_not_kAtLeastN); + return decoder_->DoCommand(cmd.kCmdId, + ComputeNumEntries(sizeof(cmd) + data_size) - 1, + &cmd); + } + + template <typename T> + T GetSharedMemoryAs() { + return reinterpret_cast<T>(shared_memory_address_); + } + + template <typename T> + T GetSharedMemoryAsWithOffset(uint32 offset) { + void* ptr = reinterpret_cast<int8*>(shared_memory_address_) + offset; + return reinterpret_cast<T>(ptr); + } + + uint32 GetServiceId(uint32 client_id) { + return decoder_->GetServiceIdForTesting(client_id); + } + + // Note that the error is returned as GLint instead of GLenum. + // This is because there is a mismatch in the types of GLenum and + // the error values GL_NO_ERROR, GL_INVALID_ENUM, etc. GLenum is + // typedef'd as unsigned int while the error values are defined as + // integers. This is problematic for template functions such as + // EXPECT_EQ that expect both types to be the same. + GLint GetGLError(); + + void DoBindTexture(GLenum target, GLuint client_id, GLuint service_id); + + void DoTexImage2D(GLenum target, GLint level, GLenum internal_format, + GLsizei width, GLsizei height, GLint border, + GLenum format, GLenum type, + uint32 shared_memory_id, uint32 shared_memory_offset); + + // Use StrictMock to make 100% sure we know how GL will be called. + scoped_ptr<::testing::StrictMock<::gles2::MockGLInterface> > gl_; + scoped_ptr<GLES2Decoder> decoder_; + + GLuint client_buffer_id_; + GLuint client_framebuffer_id_; + GLuint client_program_id_; + GLuint client_renderbuffer_id_; + GLuint client_shader_id_; + GLuint client_texture_id_; + GLuint client_element_buffer_id_; + + uint32 shared_memory_id_; + uint32 shared_memory_offset_; + void* shared_memory_address_; + + int8 immediate_buffer_[256]; + + private: + class MockCommandBufferEngine : public CommandBufferEngine { + public: + MockCommandBufferEngine() { + data_.reset(new int8[kSharedBufferSize]); + ClearSharedMemory(); + valid_buffer_.ptr = data_.get(); + valid_buffer_.size = kSharedBufferSize; + } + + virtual ~MockCommandBufferEngine() { + } + + Buffer GetSharedMemoryBuffer(int32 shm_id) { + return shm_id == kSharedMemoryId ? valid_buffer_ : invalid_buffer_; + } + + void ClearSharedMemory() { + memset(data_.get(), kInitialMemoryValue, kSharedBufferSize); + } + + void set_token(int32 token) { + DCHECK(false); + } + + // Overridden from CommandBufferEngine. + virtual bool SetGetOffset(int32 offset) { + DCHECK(false); + return false; + } + + // Overridden from CommandBufferEngine. + virtual int32 GetGetOffset() { + DCHECK(false); + return 0; + } + + private: + scoped_array<int8> data_; + Buffer valid_buffer_; + Buffer invalid_buffer_; + }; + + scoped_ptr<::testing::StrictMock<MockCommandBufferEngine> > engine_; + ContextGroup group_; +}; + +class GLES2DecoderWithShaderTestBase : public GLES2DecoderTestBase { + public: + GLES2DecoderWithShaderTestBase() + : GLES2DecoderTestBase() { + } + + static const GLsizei kNumVertices = 100; + static const GLsizei kNumIndices = 10; + static const int kValidIndexRangeStart = 1; + static const int kValidIndexRangeCount = 7; + static const int kInvalidIndexRangeStart = 0; + static const int kInvalidIndexRangeCount = 7; + static const int kOutOfRangeIndexRangeEnd = 10; + + static const GLint kMaxAttribLength = 10; + static const char* kAttrib1Name; + static const char* kAttrib2Name; + static const char* kAttrib3Name; + static const GLint kAttrib1Size = 1; + static const GLint kAttrib2Size = 1; + static const GLint kAttrib3Size = 1; + static const GLint kAttrib1Location = 0; + static const GLint kAttrib2Location = 1; + static const GLint kAttrib3Location = 2; + static const GLenum kAttrib1Type = GL_FLOAT_VEC4; + static const GLenum kAttrib2Type = GL_FLOAT_VEC2; + static const GLenum kAttrib3Type = GL_FLOAT_VEC3; + static const GLint kInvalidAttribLocation = 30; + static const GLint kBadAttribIndex = kNumVertexAttribs; + + static const GLint kMaxUniformLength = 10; + static const char* kUniform1Name; + static const char* kUniform2Name; + static const char* kUniform3Name; + static const GLint kUniform1Size = 1; + static const GLint kUniform2Size = 3; + static const GLint kUniform3Size = 2; + static const GLint kUniform1Location = 3; + static const GLint kUniform2Location = 10; + static const GLint kUniform2ElementLocation = 12; + static const GLint kUniform3Location = 20; + static const GLenum kUniform1Type = GL_SAMPLER_2D; + static const GLenum kUniform2Type = GL_INT_VEC2; + static const GLenum kUniform3Type = GL_FLOAT_VEC3; + static const GLint kInvalidUniformLocation = 30; + static const GLint kBadUniformIndex = 1000; + + protected: + struct AttribInfo { + const char* name; + GLint size; + GLenum type; + GLint location; + }; + + struct UniformInfo { + const char* name; + GLint size; + GLenum type; + GLint location; + }; + + virtual void SetUp(); + virtual void TearDown(); + + void SetupShader(AttribInfo* attribs, size_t num_attribs, + UniformInfo* uniforms, size_t num_uniforms, + GLuint client_id, GLuint service_id); + + void SetupTexture(); + + GLvoid* BufferOffset(unsigned i) { + return static_cast<int8 *>(NULL)+(i); + } + + void DoEnableVertexAttribArray(GLint index); + + void DoBindBuffer(GLenum target, GLuint client_id, GLuint service_id); + + void DoBufferData(GLenum target, GLsizei size); + + void DoBufferSubData( + GLenum target, GLint offset, GLsizei size, const void* data); + + void DoDeleteBuffer(GLuint client_id, GLuint service_id); + + void DoDeleteProgram(GLuint client_id, GLuint service_id); + + void DoVertexAttribPointer( + GLuint index, GLint size, GLenum type, GLsizei stride, GLuint offset); + + void SetupVertexBuffer(); + + void SetupIndexBuffer(); + + void DeleteVertexBuffer(); + + void DeleteIndexBuffer(); +}; + +} // namespace gles2 +} // namespace gpu + +#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_BASE_H_ + diff --git a/gpu/command_buffer/service/gpu_processor.cc b/gpu/command_buffer/service/gpu_processor.cc index e72ed06..7a748e7 100644 --- a/gpu/command_buffer/service/gpu_processor.cc +++ b/gpu/command_buffer/service/gpu_processor.cc @@ -14,7 +14,7 @@ GPUProcessor::GPUProcessor(CommandBuffer* command_buffer) : command_buffer_(command_buffer), commands_per_update_(100) { DCHECK(command_buffer); - decoder_.reset(gles2::GLES2Decoder::Create()); + decoder_.reset(gles2::GLES2Decoder::Create(&group_)); decoder_->set_engine(this); } diff --git a/gpu/command_buffer/service/gpu_processor.h b/gpu/command_buffer/service/gpu_processor.h index 4b82374..6cad98d 100644 --- a/gpu/command_buffer/service/gpu_processor.h +++ b/gpu/command_buffer/service/gpu_processor.h @@ -13,6 +13,7 @@ #include "gpu/command_buffer/common/command_buffer.h" #include "gpu/command_buffer/service/cmd_buffer_engine.h" #include "gpu/command_buffer/service/cmd_parser.h" +#include "gpu/command_buffer/service/context_group.h" #include "gpu/command_buffer/service/gles2_cmd_decoder.h" namespace gpu { @@ -73,6 +74,7 @@ class GPUProcessor : public base::RefCounted<GPUProcessor>, scoped_ptr< ::base::SharedMemory> mapped_ring_buffer_; int commands_per_update_; + gles2::ContextGroup group_; scoped_ptr<gles2::GLES2Decoder> decoder_; scoped_ptr<CommandParser> parser_; }; diff --git a/gpu/command_buffer/service/gpu_processor_unittest.cc b/gpu/command_buffer/service/gpu_processor_unittest.cc index a71905c..51cfe01 100644 --- a/gpu/command_buffer/service/gpu_processor_unittest.cc +++ b/gpu/command_buffer/service/gpu_processor_unittest.cc @@ -6,10 +6,11 @@ #include "base/message_loop.h" #include "base/scoped_nsautorelease_pool.h" #include "gpu/command_buffer/common/command_buffer_mock.h" -#include "gpu/command_buffer/service/mocks.h" +#include "gpu/command_buffer/service/context_group.h" #include "gpu/command_buffer/service/gpu_processor.h" #include "gpu/command_buffer/service/gles2_cmd_decoder.h" #include "gpu/command_buffer/service/gles2_cmd_decoder_mock.h" +#include "gpu/command_buffer/service/mocks.h" #include "testing/gtest/include/gtest/gtest.h" #include "testing/gmock/include/gmock/gmock.h" @@ -48,7 +49,7 @@ class GPUProcessorTest : public testing::Test { async_api_.reset(new StrictMock<AsyncAPIMock>); - decoder_ = new gles2::MockGLES2Decoder(); + decoder_ = new gles2::MockGLES2Decoder(&group_); parser_ = new CommandParser(buffer_, kRingBufferEntries, @@ -80,6 +81,7 @@ class GPUProcessorTest : public testing::Test { scoped_ptr<base::SharedMemory> shared_memory_; Buffer shared_memory_buffer_; int32* buffer_; + gles2::ContextGroup group_; gles2::MockGLES2Decoder* decoder_; CommandParser* parser_; scoped_ptr<AsyncAPIMock> async_api_; diff --git a/gpu/command_buffer/service/id_manager.h b/gpu/command_buffer/service/id_manager.h index 5c5f603..9d439be 100644 --- a/gpu/command_buffer/service/id_manager.h +++ b/gpu/command_buffer/service/id_manager.h @@ -18,7 +18,7 @@ namespace gles2 { // need to be shared by multiple GLES2Decoders. class IdManager { public: - IdManager() { }; + IdManager() { } // Maps a client_id to a service_id. Return false if the client_id or // service_id are already mapped to something else. diff --git a/gpu/command_buffer/service/program_manager.cc b/gpu/command_buffer/service/program_manager.cc index ade12e2..b53938f 100644 --- a/gpu/command_buffer/service/program_manager.cc +++ b/gpu/command_buffer/service/program_manager.cc @@ -7,6 +7,7 @@ #include "base/logging.h" #include "base/scoped_ptr.h" #include "base/string_util.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" namespace gpu { namespace gles2 { @@ -20,9 +21,9 @@ bool ProgramManager::IsInvalidPrefix(const char* name, size_t length) { void ProgramManager::ProgramInfo::Update() { GLint num_attribs = 0; GLint max_len = 0; - glGetProgramiv(program_, GL_ACTIVE_ATTRIBUTES, &num_attribs); - SetNumAttributes(num_attribs); - glGetProgramiv(program_, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, &max_len); + glGetProgramiv(program_id_, GL_ACTIVE_ATTRIBUTES, &num_attribs); + attrib_infos_.resize(num_attribs); + glGetProgramiv(program_id_, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, &max_len); // TODO(gman): Should we check for error? scoped_array<char> name_buffer(new char[max_len]); for (GLint ii = 0; ii < num_attribs; ++ii) { @@ -30,27 +31,49 @@ void ProgramManager::ProgramInfo::Update() { GLsizei size; GLenum type; glGetActiveAttrib( - program_, ii, max_len, &length, &size, &type, name_buffer.get()); + program_id_, ii, max_len, &length, &size, &type, name_buffer.get()); // TODO(gman): Should we check for error? GLint location = IsInvalidPrefix(name_buffer.get(), length) ? -1 : - glGetAttribLocation(program_, name_buffer.get()); + glGetAttribLocation(program_id_, name_buffer.get()); SetAttributeInfo(ii, size, type, location, name_buffer.get()); } GLint num_uniforms; - glGetProgramiv(program_, GL_ACTIVE_UNIFORMS, &num_uniforms); - SetNumUniforms(num_uniforms); - glGetProgramiv(program_, GL_ACTIVE_UNIFORM_MAX_LENGTH, &max_len); + glGetProgramiv(program_id_, GL_ACTIVE_UNIFORMS, &num_uniforms); + uniform_infos_.resize(num_uniforms); + sampler_indices_.clear(); + glGetProgramiv(program_id_, GL_ACTIVE_UNIFORM_MAX_LENGTH, &max_len); name_buffer.reset(new char[max_len]); + GLint max_location = -1; for (GLint ii = 0; ii < num_uniforms; ++ii) { GLsizei length; GLsizei size; GLenum type; glGetActiveUniform( - program_, ii, max_len, &length, &size, &type, name_buffer.get()); + program_id_, ii, max_len, &length, &size, &type, name_buffer.get()); // TODO(gman): Should we check for error? GLint location = IsInvalidPrefix(name_buffer.get(), length) ? -1 : - glGetUniformLocation(program_, name_buffer.get()); + glGetUniformLocation(program_id_, name_buffer.get()); SetUniformInfo(ii, size, type, location, name_buffer.get()); + const UniformInfo& info = uniform_infos_[ii]; + for (size_t jj = 0; jj < info.element_locations.size(); ++jj) { + if (info.element_locations[jj] > max_location) { + max_location = info.element_locations[jj]; + } + } + if (info.IsSampler()) { + sampler_indices_.push_back(ii); + } + } + // Create location to index map. + location_to_index_map_.resize(max_location + 1); + for (GLint ii = 0; ii <= max_location; ++ii) { + location_to_index_map_[ii] = -1; + } + for (GLint ii = 0; ii < num_uniforms; ++ii) { + const UniformInfo& info = uniform_infos_[ii]; + for (size_t jj = 0; jj < info.element_locations.size(); ++jj) { + location_to_index_map_[info.element_locations[jj]] = ii; + } } } @@ -96,13 +119,12 @@ GLint ProgramManager::ProgramInfo::GetAttribLocation( bool ProgramManager::ProgramInfo::GetUniformTypeByLocation( GLint location, GLenum* type) const { - for (GLuint ii = 0; ii < uniform_infos_.size(); ++ii) { - const UniformInfo& info = uniform_infos_[ii]; - for (GLsizei jj = 0; jj < info.size; ++jj) { - if (info.element_locations[jj] == location) { - *type = info.type; - return true; - } + if (location >= 0 && + static_cast<size_t>(location) < location_to_index_map_.size()) { + GLint index = location_to_index_map_[location]; + if (index >= 0) { + *type = uniform_infos_[index].type; + return true; } } return false; @@ -118,6 +140,10 @@ void ProgramManager::ProgramInfo::SetUniformInfo( info.name = name; info.element_locations.resize(size); info.element_locations[0] = location; + size_t num_texture_units = info.IsSampler() ? size : 0u; + info.texture_units.clear(); + info.texture_units.resize(num_texture_units, 0); + // Go through the array element locations looking for a match. // We can skip the first element because it's the same as the // the location without the array operators. @@ -125,26 +151,44 @@ void ProgramManager::ProgramInfo::SetUniformInfo( for (GLsizei ii = 1; ii < info.size; ++ii) { std::string element_name(name + "[" + IntToString(ii) + "]"); info.element_locations[ii] = - glGetUniformLocation(program_, element_name.c_str()); + glGetUniformLocation(program_id_, element_name.c_str()); + } + } +} + +bool ProgramManager::ProgramInfo::SetSamplers( + GLint location, GLsizei count, const GLint* value) { + if (location >= 0 && + static_cast<size_t>(location) < location_to_index_map_.size()) { + GLint index = location_to_index_map_[location]; + if (index >= 0) { + UniformInfo& info = uniform_infos_[index]; + if (info.IsSampler() && count <= info.size) { + std::copy(value, value + count, info.texture_units.begin()); + return true; + } } } + return false; } -void ProgramManager::CreateProgramInfo(GLuint program) { +void ProgramManager::CreateProgramInfo(GLuint program_id) { std::pair<ProgramInfoMap::iterator, bool> result = program_infos_.insert( - std::make_pair(program, ProgramInfo(program))); + std::make_pair(program_id, + ProgramInfo::Ref(new ProgramInfo(program_id)))); DCHECK(result.second); } -ProgramManager::ProgramInfo* ProgramManager::GetProgramInfo(GLuint program) { - ProgramInfoMap::iterator it = program_infos_.find(program); - return it != program_infos_.end() ? &it->second : NULL; +ProgramManager::ProgramInfo* ProgramManager::GetProgramInfo(GLuint program_id) { + ProgramInfoMap::iterator it = program_infos_.find(program_id); + return it != program_infos_.end() ? it->second : NULL; } -void ProgramManager::RemoveProgramInfo(GLuint program) { - ProgramInfoMap::iterator it = program_infos_.find(program); +void ProgramManager::RemoveProgramInfo(GLuint program_id) { + ProgramInfoMap::iterator it = program_infos_.find(program_id); if (it != program_infos_.end()) { + it->second->MarkAsDeleted(); program_infos_.erase(it); } } diff --git a/gpu/command_buffer/service/program_manager.h b/gpu/command_buffer/service/program_manager.h index ec4fa21..47a1927 100644 --- a/gpu/command_buffer/service/program_manager.h +++ b/gpu/command_buffer/service/program_manager.h @@ -10,6 +10,7 @@ #include <vector> #include "base/basictypes.h" #include "base/logging.h" +#include "base/ref_counted.h" #include "gpu/command_buffer/service/gl_utils.h" namespace gpu { @@ -24,13 +25,20 @@ class ProgramManager { // This is used to track which attributes a particular program needs // so we can verify at glDrawXXX time that every attribute is either disabled // or if enabled that it points to a valid source. - class ProgramInfo { + class ProgramInfo : public base::RefCounted<ProgramInfo> { public: + typedef scoped_refptr<ProgramInfo> Ref; + struct UniformInfo { + bool IsSampler() const { + return type == GL_SAMPLER_2D || type == GL_SAMPLER_CUBE; + } + GLsizei size; GLenum type; std::string name; std::vector<GLint> element_locations; + std::vector<GLuint> texture_units; }; struct VertexAttribInfo { GLsizei size; @@ -41,9 +49,14 @@ class ProgramManager { typedef std::vector<UniformInfo> UniformInfoVector; typedef std::vector<VertexAttribInfo> AttribInfoVector; + typedef std::vector<int> SamplerIndices; + + explicit ProgramInfo(GLuint program_id) + : program_id_(program_id) { + } - explicit ProgramInfo(GLuint program) - : program_(program) { + const SamplerIndices& sampler_indices() { + return sampler_indices_; } void Update(); @@ -64,13 +77,29 @@ class ProgramManager { &uniform_infos_[index] : NULL; } + // Gets the location of a uniform by name. GLint GetUniformLocation(const std::string& name); + // Gets the type of a uniform by location. bool GetUniformTypeByLocation(GLint location, GLenum* type) const; + // Sets the sampler values for a uniform. + // This is safe to call for any location. If the location is not + // a sampler uniform nothing will happen. + bool SetSamplers(GLint location, GLsizei count, const GLint* value); + + bool IsDeleted() { + return program_id_ == 0; + } + private: - void SetNumAttributes(int num_attribs) { - attrib_infos_.resize(num_attribs); + friend class base::RefCounted<ProgramInfo>; + friend class ProgramManager; + + ~ProgramInfo() { } + + void MarkAsDeleted() { + program_id_ = 0; } void SetAttributeInfo( @@ -84,33 +113,35 @@ class ProgramManager { info.location = location; } - void SetNumUniforms(int num_uniforms) { - uniform_infos_.resize(num_uniforms); - } - void SetUniformInfo( GLint index, GLsizei size, GLenum type, GLint location, const std::string& name); AttribInfoVector attrib_infos_; - // Uniform info by info. + // Uniform info by index. UniformInfoVector uniform_infos_; + // Uniform location to index. + std::vector<GLint> location_to_index_map_; + + // The indices of the uniforms that are samplers. + SamplerIndices sampler_indices_; + // The program this ProgramInfo is tracking. - GLuint program_; + GLuint program_id_; }; - ProgramManager() { }; + ProgramManager() { } // Creates a new program info. - void CreateProgramInfo(GLuint program); + void CreateProgramInfo(GLuint program_id); // Gets a program info - ProgramInfo* GetProgramInfo(GLuint program); + ProgramInfo* GetProgramInfo(GLuint program_id); // Deletes the program info for the given program. - void RemoveProgramInfo(GLuint program); + void RemoveProgramInfo(GLuint program_id); // Returns true if prefix is invalid for gl. static bool IsInvalidPrefix(const char* name, size_t length); @@ -118,7 +149,7 @@ class ProgramManager { private: // Info for each "successfully linked" program by service side program Id. // TODO(gman): Choose a faster container. - typedef std::map<GLuint, ProgramInfo> ProgramInfoMap; + typedef std::map<GLuint, ProgramInfo::Ref> ProgramInfoMap; ProgramInfoMap program_infos_; DISALLOW_COPY_AND_ASSIGN(ProgramManager); diff --git a/gpu/command_buffer/service/program_manager_unittest.cc b/gpu/command_buffer/service/program_manager_unittest.cc index af03f1c..0647884 100644 --- a/gpu/command_buffer/service/program_manager_unittest.cc +++ b/gpu/command_buffer/service/program_manager_unittest.cc @@ -25,13 +25,15 @@ namespace gles2 { class ProgramManagerTest : public testing::Test { public: - ProgramManagerTest() { - } + ProgramManagerTest() { } protected: virtual void SetUp() { } + virtual void TearDown() { + } + ProgramManager manager_; }; diff --git a/gpu/command_buffer/service/shader_manager.cc b/gpu/command_buffer/service/shader_manager.cc index 0d6fa19..0daa0dc 100644 --- a/gpu/command_buffer/service/shader_manager.cc +++ b/gpu/command_buffer/service/shader_manager.cc @@ -8,20 +8,22 @@ namespace gpu { namespace gles2 { -void ShaderManager::CreateShaderInfo(GLuint shader) { +void ShaderManager::CreateShaderInfo(GLuint shader_id) { std::pair<ShaderInfoMap::iterator, bool> result = - shader_infos_.insert(std::make_pair(shader, ShaderInfo(shader))); + shader_infos_.insert(std::make_pair( + shader_id, ShaderInfo::Ref(new ShaderInfo(shader_id)))); DCHECK(result.second); } -ShaderManager::ShaderInfo* ShaderManager::GetShaderInfo(GLuint shader) { - ShaderInfoMap::iterator it = shader_infos_.find(shader); - return it != shader_infos_.end() ? &it->second : NULL; +ShaderManager::ShaderInfo* ShaderManager::GetShaderInfo(GLuint shader_id) { + ShaderInfoMap::iterator it = shader_infos_.find(shader_id); + return it != shader_infos_.end() ? it->second : NULL; } -void ShaderManager::RemoveShaderInfo(GLuint shader) { - ShaderInfoMap::iterator it = shader_infos_.find(shader); +void ShaderManager::RemoveShaderInfo(GLuint shader_id) { + ShaderInfoMap::iterator it = shader_infos_.find(shader_id); if (it != shader_infos_.end()) { + it->second->MarkAsDeleted(); shader_infos_.erase(it); } } diff --git a/gpu/command_buffer/service/shader_manager.h b/gpu/command_buffer/service/shader_manager.h index 833117b..f9529e9 100644 --- a/gpu/command_buffer/service/shader_manager.h +++ b/gpu/command_buffer/service/shader_manager.h @@ -8,6 +8,7 @@ #include <map> #include <string> #include "base/basictypes.h" +#include "base/ref_counted.h" #include "gpu/command_buffer/service/gl_utils.h" namespace gpu { @@ -23,10 +24,12 @@ class ShaderManager { // to emluate GLES2 the shaders will have to be re-written before passed to // the underlying OpenGL. But, when the user calls glGetShaderSource they // should get the source they passed in, not the re-written source. - class ShaderInfo { + class ShaderInfo : public base::RefCounted<ShaderInfo> { public: - explicit ShaderInfo(GLuint shader) - : shader_(shader) { + typedef scoped_refptr<ShaderInfo> Ref; + + explicit ShaderInfo(GLuint shader_id) + : shader_id_(shader_id) { } void Update(const std::string& source) { @@ -37,29 +40,42 @@ class ShaderManager { return source_; } + bool IsDeleted() { + return shader_id_ == 0; + } + private: + friend class base::RefCounted<ShaderInfo>; + friend class ShaderManager; + ~ShaderInfo() { } + + void MarkAsDeleted() { + shader_id_ = 0; + } + // The shader this ShaderInfo is tracking. - GLuint shader_; + GLuint shader_id_; // The shader source as passed to glShaderSource. std::string source_; }; - ShaderManager() { }; + ShaderManager() { + } // Creates a shader info for the given shader ID. - void CreateShaderInfo(GLuint shader); + void CreateShaderInfo(GLuint shader_id); // Gets an existing shader info for the given shader ID. Returns NULL if none // exists. - ShaderInfo* GetShaderInfo(GLuint shader); + ShaderInfo* GetShaderInfo(GLuint shader_id); // Deletes the shader info for the given shader. - void RemoveShaderInfo(GLuint shader); + void RemoveShaderInfo(GLuint shader_id); private: // Info for each shader by service side shader Id. - typedef std::map<GLuint, ShaderInfo> ShaderInfoMap; + typedef std::map<GLuint, ShaderInfo::Ref> ShaderInfoMap; ShaderInfoMap shader_infos_; DISALLOW_COPY_AND_ASSIGN(ShaderManager); diff --git a/gpu/command_buffer/service/texture_manager.cc b/gpu/command_buffer/service/texture_manager.cc index 1496f88..a2f72bb 100644 --- a/gpu/command_buffer/service/texture_manager.cc +++ b/gpu/command_buffer/service/texture_manager.cc @@ -4,6 +4,8 @@ #include "gpu/command_buffer/service/texture_manager.h" #include "base/bits.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" namespace gpu { namespace gles2 { @@ -55,8 +57,31 @@ static size_t FaceIndexToGLTarget(size_t index) { } } -void TextureManager::TextureInfo::MarkMipmapsGenerated() { - DCHECK(CanGenerateMipmaps()); +bool TextureManager::TextureInfo::CanRender() const { + if (target_ == 0 || IsDeleted()) { + return false; + } + bool needs_mips = NeedsMips(); + if (npot()) { + return !needs_mips && + wrap_s_ == GL_CLAMP_TO_EDGE && + wrap_t_ == GL_CLAMP_TO_EDGE; + } + if (needs_mips) { + if (target_ == GL_TEXTURE_2D) { + return texture_complete(); + } else { + return texture_complete() && cube_complete(); + } + } else { + return true; + } +} + +bool TextureManager::TextureInfo::MarkMipmapsGenerated() { + if (!CanGenerateMipmaps()) { + return false; + } for (size_t ii = 0; ii < level_infos_.size(); ++ii) { const TextureInfo::LevelInfo& info1 = level_infos_[ii][0]; GLsizei width = info1.width; @@ -79,10 +104,11 @@ void TextureManager::TextureInfo::MarkMipmapsGenerated() { info1.type); } } + return true; } bool TextureManager::TextureInfo::CanGenerateMipmaps() const { - if (npot()) { + if (npot() || level_infos_.empty()) { return false; } const TextureInfo::LevelInfo& first = level_infos_[0][0]; @@ -134,6 +160,26 @@ void TextureManager::TextureInfo::SetLevelInfo( Update(); } +void TextureManager::TextureInfo::SetParameter(GLenum pname, GLint param) { + switch (pname) { + case GL_TEXTURE_MIN_FILTER: + min_filter_ = param; + break; + case GL_TEXTURE_MAG_FILTER: + mag_filter_ = param; + break; + case GL_TEXTURE_WRAP_S: + wrap_s_ = param; + break; + case GL_TEXTURE_WRAP_T: + wrap_t_ = param; + break; + default: + NOTREACHED(); + break; + } +} + void TextureManager::TextureInfo::Update() { // Update npot status. npot_ = false; @@ -194,7 +240,8 @@ void TextureManager::TextureInfo::Update() { } TextureManager::TextureManager( - GLint max_texture_size, GLint max_cube_map_texture_size) + GLint max_texture_size, + GLint max_cube_map_texture_size) : max_texture_size_(max_texture_size), max_cube_map_texture_size_(max_cube_map_texture_size), max_levels_(ComputeMipMapCount(max_texture_size, @@ -205,22 +252,26 @@ TextureManager::TextureManager( max_cube_map_texture_size)) { } -void TextureManager::CreateTextureInfo(GLuint texture) { - TextureInfo* info = new TextureInfo(texture); +void TextureManager::CreateTextureInfo(GLuint texture_id) { std::pair<TextureInfoMap::iterator, bool> result = texture_infos_.insert( - std::make_pair(texture, linked_ptr<TextureInfo>(info))); + std::make_pair(texture_id, + TextureInfo::Ref(new TextureInfo(texture_id)))); DCHECK(result.second); } TextureManager::TextureInfo* TextureManager::GetTextureInfo( - GLuint texture) { - TextureInfoMap::iterator it = texture_infos_.find(texture); - return it != texture_infos_.end() ? &(*it->second) : NULL; + GLuint texture_id) { + TextureInfoMap::iterator it = texture_infos_.find(texture_id); + return it != texture_infos_.end() ? it->second : NULL; } void TextureManager::RemoveTextureInfo(GLuint texture_id) { - texture_infos_.erase(texture_id); + TextureInfoMap::iterator it = texture_infos_.find(texture_id); + if (it != texture_infos_.end()) { + it->second->MarkAsDeleted(); + texture_infos_.erase(texture_id); + } } } // namespace gles2 diff --git a/gpu/command_buffer/service/texture_manager.h b/gpu/command_buffer/service/texture_manager.h index efb08f0..6407721 100644 --- a/gpu/command_buffer/service/texture_manager.h +++ b/gpu/command_buffer/service/texture_manager.h @@ -8,7 +8,8 @@ #include <map> #include <vector> #include "base/basictypes.h" -#include "base/linked_ptr.h" +#include "base/logging.h" +#include "base/ref_counted.h" #include "gpu/command_buffer/service/gl_utils.h" namespace gpu { @@ -22,21 +23,36 @@ namespace gles2 { class TextureManager { public: // Info about Textures currently in the system. - class TextureInfo { + class TextureInfo : public base::RefCounted<TextureInfo> { public: - explicit TextureInfo(GLuint texture) - : texture_(texture), + typedef scoped_refptr<TextureInfo> Ref; + + explicit TextureInfo(GLuint texture_id) + : texture_id_(texture_id), target_(0), + min_filter_(GL_NEAREST_MIPMAP_LINEAR), + mag_filter_(GL_LINEAR), + wrap_s_(GL_REPEAT), + wrap_t_(GL_REPEAT), max_level_set_(-1), texture_complete_(false), cube_complete_(false), npot_(false) { } + // True if this texture meets all the GLES2 criteria for rendering. + // See section 3.8.2 of the GLES2 spec. + bool CanRender() const; + + // The service side OpenGL id of the texture. + GLuint texture_id() const { + return texture_id_; + } + // Returns the target this texure was first bound to or 0 if it has not // been bound. Once a texture is bound to a specific target it can never be // bound to a different target. - GLenum target() { + GLenum target() const { return target_; } @@ -62,7 +78,7 @@ class TextureManager { bool CanGenerateMipmaps() const; // Makes each of the mip levels as though they were generated. - void MarkMipmapsGenerated(); + bool MarkMipmapsGenerated(); // Set the info for a particular level. void SetLevelInfo( @@ -76,8 +92,19 @@ class TextureManager { GLenum format, GLenum type); + // Sets a texture parameter. + // TODO(gman): Expand to SetParameteri,f,iv,fv + void SetParameter(GLenum pname, GLint param); + + bool IsDeleted() const { + return texture_id_ == 0; + } + private: friend class TextureManager; + friend class base::RefCounted<TextureInfo>; + + ~TextureInfo() { } struct LevelInfo { LevelInfo() @@ -101,6 +128,14 @@ class TextureManager { GLenum type; }; + void MarkAsDeleted() { + texture_id_ = 0; + } + + bool NeedsMips() const { + return min_filter_ != GL_NEAREST && min_filter_ != GL_LINEAR; + } + // Sets the TextureInfo's target // Parameters: // target: GL_TEXTURE_2D or GL_TEXTURE_CUBE_MAP @@ -122,11 +157,17 @@ class TextureManager { std::vector<std::vector<LevelInfo> > level_infos_; // The id of the texure - GLuint texture_; + GLuint texture_id_; // The target. 0 if unset, otherwise GL_TEXTURE_2D or GL_TEXTURE_CUBE_MAP. GLenum target_; + // Texture parameters. + GLenum min_filter_; + GLenum mag_filter_; + GLenum wrap_s_; + GLenum wrap_t_; + // The maximum level that has been set. GLint max_level_set_; @@ -142,7 +183,8 @@ class TextureManager { DISALLOW_COPY_AND_ASSIGN(TextureInfo); }; - TextureManager(GLsizei max_texture_size, GLsizei max_cube_map_texture_size); + TextureManager(GLsizei max_texture_size, + GLsizei max_cube_map_texture_size); // Returns the maximum number of levels. GLint MaxLevelsForTarget(GLenum target) const { @@ -182,10 +224,10 @@ class TextureManager { } // Creates a new texture info. - void CreateTextureInfo(GLuint texture); + void CreateTextureInfo(GLuint texture_id); // Gets the texture info for the given texture. - TextureInfo* GetTextureInfo(GLuint texture); + TextureInfo* GetTextureInfo(GLuint texture_id); // Removes a texture info. void RemoveTextureInfo(GLuint texture_id); @@ -193,7 +235,7 @@ class TextureManager { private: // Info for each texture in the system. // TODO(gman): Choose a faster container. - typedef std::map<GLuint, linked_ptr<TextureInfo> > TextureInfoMap; + typedef std::map<GLuint, TextureInfo::Ref> TextureInfoMap; TextureInfoMap texture_infos_; GLsizei max_texture_size_; diff --git a/gpu/command_buffer/service/texture_manager_unittest.cc b/gpu/command_buffer/service/texture_manager_unittest.cc index 8bf2814..dc74605 100644 --- a/gpu/command_buffer/service/texture_manager_unittest.cc +++ b/gpu/command_buffer/service/texture_manager_unittest.cc @@ -127,6 +127,15 @@ class TextureInfoTest : public testing::Test { TextureManager::TextureInfo* info_; }; +TEST_F(TextureInfoTest, Basic) { + EXPECT_EQ(0, info_->target()); + EXPECT_FALSE(info_->texture_complete()); + EXPECT_FALSE(info_->cube_complete()); + EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->npot()); + EXPECT_FALSE(info_->CanRender()); +} + TEST_F(TextureInfoTest, POT2D) { manager_.SetInfoTarget(info_, GL_TEXTURE_2D); EXPECT_EQ(GL_TEXTURE_2D, info_->target()); @@ -135,22 +144,32 @@ TEST_F(TextureInfoTest, POT2D) { GL_TEXTURE_2D, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); EXPECT_FALSE(info_->npot()); EXPECT_FALSE(info_->texture_complete()); + EXPECT_FALSE(info_->CanRender()); + // Set filters to something that will work with a single mip. + info_->SetParameter(GL_TEXTURE_MIN_FILTER, GL_LINEAR); + EXPECT_TRUE(info_->CanRender()); + // Set them back. + info_->SetParameter(GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR); + EXPECT_TRUE(info_->CanGenerateMipmaps()); // Make mips. - info_->MarkMipmapsGenerated(); + EXPECT_TRUE(info_->MarkMipmapsGenerated()); EXPECT_TRUE(info_->texture_complete()); + EXPECT_TRUE(info_->CanRender()); // Change a mip. info_->SetLevelInfo( GL_TEXTURE_2D, 1, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); EXPECT_FALSE(info_->npot()); EXPECT_FALSE(info_->texture_complete()); EXPECT_TRUE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); // Set a level past the number of mips that would get generated. info_->SetLevelInfo( GL_TEXTURE_2D, 3, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); EXPECT_TRUE(info_->CanGenerateMipmaps()); // Make mips. - info_->MarkMipmapsGenerated(); + EXPECT_TRUE(info_->MarkMipmapsGenerated()); + EXPECT_FALSE(info_->CanRender()); EXPECT_FALSE(info_->texture_complete()); } @@ -163,6 +182,13 @@ TEST_F(TextureInfoTest, NPOT2D) { EXPECT_TRUE(info_->npot()); EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); + info_->SetParameter(GL_TEXTURE_MIN_FILTER, GL_LINEAR); + EXPECT_FALSE(info_->CanRender()); + info_->SetParameter(GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); + EXPECT_FALSE(info_->CanRender()); + info_->SetParameter(GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); + EXPECT_TRUE(info_->CanRender()); // Change it to POT. info_->SetLevelInfo( GL_TEXTURE_2D, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); @@ -182,6 +208,7 @@ TEST_F(TextureInfoTest, POTCubeMap) { EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->cube_complete()); EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); info_->SetLevelInfo( GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); @@ -189,6 +216,7 @@ TEST_F(TextureInfoTest, POTCubeMap) { EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->cube_complete()); EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); info_->SetLevelInfo( GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); @@ -196,12 +224,14 @@ TEST_F(TextureInfoTest, POTCubeMap) { EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->cube_complete()); EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); info_->SetLevelInfo( GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); EXPECT_FALSE(info_->npot()); EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->cube_complete()); + EXPECT_FALSE(info_->CanRender()); EXPECT_FALSE(info_->CanGenerateMipmaps()); info_->SetLevelInfo( GL_TEXTURE_CUBE_MAP_POSITIVE_Z, @@ -210,6 +240,7 @@ TEST_F(TextureInfoTest, POTCubeMap) { EXPECT_FALSE(info_->texture_complete()); EXPECT_FALSE(info_->cube_complete()); EXPECT_FALSE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); info_->SetLevelInfo( GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); @@ -217,9 +248,10 @@ TEST_F(TextureInfoTest, POTCubeMap) { EXPECT_FALSE(info_->texture_complete()); EXPECT_TRUE(info_->cube_complete()); EXPECT_TRUE(info_->CanGenerateMipmaps()); + EXPECT_FALSE(info_->CanRender()); // Make mips. - info_->MarkMipmapsGenerated(); + EXPECT_TRUE(info_->MarkMipmapsGenerated()); EXPECT_TRUE(info_->texture_complete()); EXPECT_TRUE(info_->cube_complete()); @@ -237,7 +269,7 @@ TEST_F(TextureInfoTest, POTCubeMap) { 3, GL_RGBA, 4, 4, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE); EXPECT_TRUE(info_->CanGenerateMipmaps()); // Make mips. - info_->MarkMipmapsGenerated(); + EXPECT_TRUE(info_->MarkMipmapsGenerated()); EXPECT_FALSE(info_->texture_complete()); EXPECT_TRUE(info_->cube_complete()); } |