summaryrefslogtreecommitdiffstats
path: root/gpu/command_buffer
diff options
context:
space:
mode:
Diffstat (limited to 'gpu/command_buffer')
-rwxr-xr-xgpu/command_buffer/build_gles2_cmd_buffer.py6
-rw-r--r--gpu/command_buffer/client/gles2_c_lib_autogen.h17
-rw-r--r--gpu/command_buffer/client/gles2_cmd_helper_autogen.h16
-rw-r--r--gpu/command_buffer/client/gles2_implementation_autogen.h10
-rw-r--r--gpu/command_buffer/client/gles2_implementation_impl_autogen.h32
-rw-r--r--gpu/command_buffer/client/gles2_implementation_unittest_autogen.h11
-rw-r--r--gpu/command_buffer/client/gles2_interface_autogen.h9
-rw-r--r--gpu/command_buffer/client/gles2_interface_stub_autogen.h9
-rw-r--r--gpu/command_buffer/client/gles2_interface_stub_impl_autogen.h10
-rw-r--r--gpu/command_buffer/client/gles2_trace_implementation_autogen.h9
-rw-r--r--gpu/command_buffer/client/gles2_trace_implementation_impl_autogen.h16
-rw-r--r--gpu/command_buffer/cmd_buffer_functions.txt1
-rw-r--r--gpu/command_buffer/common/gles2_cmd_format_autogen.h87
-rw-r--r--gpu/command_buffer/common/gles2_cmd_format_test_autogen.h24
-rw-r--r--gpu/command_buffer/common/gles2_cmd_ids_autogen.h131
-rw-r--r--gpu/command_buffer/service/gles2_cmd_decoder.cc234
-rw-r--r--gpu/command_buffer/service/gles2_cmd_decoder_autogen.h31
-rw-r--r--gpu/command_buffer/service/gles2_cmd_decoder_unittest_3_autogen.h8
-rw-r--r--gpu/command_buffer/service/gles2_cmd_decoder_unittest_4_autogen.h7
-rw-r--r--gpu/command_buffer/tests/gl_compressed_copy_texture_CHROMIUM_unittest.cc413
20 files changed, 96 insertions, 985 deletions
diff --git a/gpu/command_buffer/build_gles2_cmd_buffer.py b/gpu/command_buffer/build_gles2_cmd_buffer.py
index d75d473..6809b65 100755
--- a/gpu/command_buffer/build_gles2_cmd_buffer.py
+++ b/gpu/command_buffer/build_gles2_cmd_buffer.py
@@ -3975,12 +3975,6 @@ _FUNCTION_INFO = {
'extension': 'CHROMIUM_copy_compressed_texture',
'chromium': True,
},
- 'CompressedCopySubTextureCHROMIUM': {
- 'decoder_func': 'DoCompressedCopySubTextureCHROMIUM',
- 'unit_test': False,
- 'extension': 'CHROMIUM_copy_compressed_texture',
- 'chromium': True,
- },
'TexStorage2DEXT': {
'unit_test': False,
'extension': 'EXT_texture_storage',
diff --git a/gpu/command_buffer/client/gles2_c_lib_autogen.h b/gpu/command_buffer/client/gles2_c_lib_autogen.h
index 0feb120..3c348b1 100644
--- a/gpu/command_buffer/client/gles2_c_lib_autogen.h
+++ b/gpu/command_buffer/client/gles2_c_lib_autogen.h
@@ -1367,18 +1367,6 @@ void GL_APIENTRY GLES2CompressedCopyTextureCHROMIUM(GLenum target,
gles2::GetGLContext()->CompressedCopyTextureCHROMIUM(target, source_id,
dest_id);
}
-void GL_APIENTRY GLES2CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) {
- gles2::GetGLContext()->CompressedCopySubTextureCHROMIUM(
- target, source_id, dest_id, xoffset, yoffset, x, y, width, height);
-}
void GL_APIENTRY GLES2DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
@@ -2756,11 +2744,6 @@ extern const NameToFunc g_gles2_function_table[] = {
reinterpret_cast<GLES2FunctionPointer>(glCompressedCopyTextureCHROMIUM),
},
{
- "glCompressedCopySubTextureCHROMIUM",
- reinterpret_cast<GLES2FunctionPointer>(
- glCompressedCopySubTextureCHROMIUM),
- },
- {
"glDrawArraysInstancedANGLE",
reinterpret_cast<GLES2FunctionPointer>(glDrawArraysInstancedANGLE),
},
diff --git a/gpu/command_buffer/client/gles2_cmd_helper_autogen.h b/gpu/command_buffer/client/gles2_cmd_helper_autogen.h
index ba82b35..b8a4032 100644
--- a/gpu/command_buffer/client/gles2_cmd_helper_autogen.h
+++ b/gpu/command_buffer/client/gles2_cmd_helper_autogen.h
@@ -2535,22 +2535,6 @@ void CompressedCopyTextureCHROMIUM(GLenum target,
}
}
-void CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) {
- gles2::cmds::CompressedCopySubTextureCHROMIUM* c =
- GetCmdSpace<gles2::cmds::CompressedCopySubTextureCHROMIUM>();
- if (c) {
- c->Init(target, source_id, dest_id, xoffset, yoffset, x, y, width, height);
- }
-}
-
void DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/client/gles2_implementation_autogen.h b/gpu/command_buffer/client/gles2_implementation_autogen.h
index d7be9a0..0ac39f9 100644
--- a/gpu/command_buffer/client/gles2_implementation_autogen.h
+++ b/gpu/command_buffer/client/gles2_implementation_autogen.h
@@ -951,16 +951,6 @@ void CompressedCopyTextureCHROMIUM(GLenum target,
GLenum source_id,
GLenum dest_id) override;
-void CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) override;
-
void DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/client/gles2_implementation_impl_autogen.h b/gpu/command_buffer/client/gles2_implementation_impl_autogen.h
index 559e480..2727a87 100644
--- a/gpu/command_buffer/client/gles2_implementation_impl_autogen.h
+++ b/gpu/command_buffer/client/gles2_implementation_impl_autogen.h
@@ -3240,38 +3240,6 @@ void GLES2Implementation::CompressedCopyTextureCHROMIUM(GLenum target,
CheckGLError();
}
-void GLES2Implementation::CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) {
- GPU_CLIENT_SINGLE_THREAD_CHECK();
- GPU_CLIENT_LOG("[" << GetLogPrefix()
- << "] glCompressedCopySubTextureCHROMIUM("
- << GLES2Util::GetStringEnum(target) << ", "
- << GLES2Util::GetStringEnum(source_id) << ", "
- << GLES2Util::GetStringEnum(dest_id) << ", " << xoffset
- << ", " << yoffset << ", " << x << ", " << y << ", "
- << width << ", " << height << ")");
- if (width < 0) {
- SetGLError(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "width < 0");
- return;
- }
- if (height < 0) {
- SetGLError(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "height < 0");
- return;
- }
- helper_->CompressedCopySubTextureCHROMIUM(target, source_id, dest_id, xoffset,
- yoffset, x, y, width, height);
- CheckGLError();
-}
-
void GLES2Implementation::GenValuebuffersCHROMIUM(GLsizei n, GLuint* buffers) {
GPU_CLIENT_LOG("[" << GetLogPrefix() << "] glGenValuebuffersCHROMIUM(" << n
<< ", " << static_cast<const void*>(buffers) << ")");
diff --git a/gpu/command_buffer/client/gles2_implementation_unittest_autogen.h b/gpu/command_buffer/client/gles2_implementation_unittest_autogen.h
index 0015c46..6f3a011 100644
--- a/gpu/command_buffer/client/gles2_implementation_unittest_autogen.h
+++ b/gpu/command_buffer/client/gles2_implementation_unittest_autogen.h
@@ -2842,17 +2842,6 @@ TEST_F(GLES2ImplementationTest, CompressedCopyTextureCHROMIUM) {
EXPECT_EQ(0, memcmp(&expected, commands_, sizeof(expected)));
}
-TEST_F(GLES2ImplementationTest, CompressedCopySubTextureCHROMIUM) {
- struct Cmds {
- cmds::CompressedCopySubTextureCHROMIUM cmd;
- };
- Cmds expected;
- expected.cmd.Init(1, 2, 3, 4, 5, 6, 7, 8, 9);
-
- gl_->CompressedCopySubTextureCHROMIUM(1, 2, 3, 4, 5, 6, 7, 8, 9);
- EXPECT_EQ(0, memcmp(&expected, commands_, sizeof(expected)));
-}
-
TEST_F(GLES2ImplementationTest, DrawArraysInstancedANGLE) {
struct Cmds {
cmds::DrawArraysInstancedANGLE cmd;
diff --git a/gpu/command_buffer/client/gles2_interface_autogen.h b/gpu/command_buffer/client/gles2_interface_autogen.h
index 56b1c0b..1940d30 100644
--- a/gpu/command_buffer/client/gles2_interface_autogen.h
+++ b/gpu/command_buffer/client/gles2_interface_autogen.h
@@ -709,15 +709,6 @@ virtual void CopySubTextureCHROMIUM(GLenum source_id,
virtual void CompressedCopyTextureCHROMIUM(GLenum target,
GLenum source_id,
GLenum dest_id) = 0;
-virtual void CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) = 0;
virtual void DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/client/gles2_interface_stub_autogen.h b/gpu/command_buffer/client/gles2_interface_stub_autogen.h
index aed6e72..be25847 100644
--- a/gpu/command_buffer/client/gles2_interface_stub_autogen.h
+++ b/gpu/command_buffer/client/gles2_interface_stub_autogen.h
@@ -688,15 +688,6 @@ void CopySubTextureCHROMIUM(GLenum source_id,
void CompressedCopyTextureCHROMIUM(GLenum target,
GLenum source_id,
GLenum dest_id) override;
-void CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) override;
void DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/client/gles2_interface_stub_impl_autogen.h b/gpu/command_buffer/client/gles2_interface_stub_impl_autogen.h
index 6babece..d645e63 100644
--- a/gpu/command_buffer/client/gles2_interface_stub_impl_autogen.h
+++ b/gpu/command_buffer/client/gles2_interface_stub_impl_autogen.h
@@ -934,16 +934,6 @@ void GLES2InterfaceStub::CopySubTextureCHROMIUM(
void GLES2InterfaceStub::CompressedCopyTextureCHROMIUM(GLenum /* target */,
GLenum /* source_id */,
GLenum /* dest_id */) {}
-void GLES2InterfaceStub::CompressedCopySubTextureCHROMIUM(
- GLenum /* target */,
- GLenum /* source_id */,
- GLenum /* dest_id */,
- GLint /* xoffset */,
- GLint /* yoffset */,
- GLint /* x */,
- GLint /* y */,
- GLsizei /* width */,
- GLsizei /* height */) {}
void GLES2InterfaceStub::DrawArraysInstancedANGLE(GLenum /* mode */,
GLint /* first */,
GLsizei /* count */,
diff --git a/gpu/command_buffer/client/gles2_trace_implementation_autogen.h b/gpu/command_buffer/client/gles2_trace_implementation_autogen.h
index 9c9f936..2b86e41 100644
--- a/gpu/command_buffer/client/gles2_trace_implementation_autogen.h
+++ b/gpu/command_buffer/client/gles2_trace_implementation_autogen.h
@@ -688,15 +688,6 @@ void CopySubTextureCHROMIUM(GLenum source_id,
void CompressedCopyTextureCHROMIUM(GLenum target,
GLenum source_id,
GLenum dest_id) override;
-void CompressedCopySubTextureCHROMIUM(GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) override;
void DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/client/gles2_trace_implementation_impl_autogen.h b/gpu/command_buffer/client/gles2_trace_implementation_impl_autogen.h
index 3f84d11..cf40552 100644
--- a/gpu/command_buffer/client/gles2_trace_implementation_impl_autogen.h
+++ b/gpu/command_buffer/client/gles2_trace_implementation_impl_autogen.h
@@ -1979,22 +1979,6 @@ void GLES2TraceImplementation::CompressedCopyTextureCHROMIUM(GLenum target,
gl_->CompressedCopyTextureCHROMIUM(target, source_id, dest_id);
}
-void GLES2TraceImplementation::CompressedCopySubTextureCHROMIUM(
- GLenum target,
- GLenum source_id,
- GLenum dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) {
- TRACE_EVENT_BINARY_EFFICIENT0("gpu",
- "GLES2Trace::CompressedCopySubTextureCHROMIUM");
- gl_->CompressedCopySubTextureCHROMIUM(target, source_id, dest_id, xoffset,
- yoffset, x, y, width, height);
-}
-
void GLES2TraceImplementation::DrawArraysInstancedANGLE(GLenum mode,
GLint first,
GLsizei count,
diff --git a/gpu/command_buffer/cmd_buffer_functions.txt b/gpu/command_buffer/cmd_buffer_functions.txt
index 2d78a73..2ca188c 100644
--- a/gpu/command_buffer/cmd_buffer_functions.txt
+++ b/gpu/command_buffer/cmd_buffer_functions.txt
@@ -281,7 +281,6 @@ GL_APICALL void GL_APIENTRY glTexImageIOSurface2DCHROMIUM (GLenumTexture
GL_APICALL void GL_APIENTRY glCopyTextureCHROMIUM (GLenum source_id, GLenum dest_id, GLintTextureInternalFormat internalformat, GLenumPixelType dest_type, GLboolean unpack_flip_y, GLboolean unpack_premultiply_alpha, GLboolean unpack_unmultiply_alpha);
GL_APICALL void GL_APIENTRY glCopySubTextureCHROMIUM (GLenum source_id, GLenum dest_id, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height, GLboolean unpack_flip_y, GLboolean unpack_premultiply_alpha, GLboolean unpack_unmultiply_alpha);
GL_APICALL void GL_APIENTRY glCompressedCopyTextureCHROMIUM (GLenum target, GLenum source_id, GLenum dest_id);
-GL_APICALL void GL_APIENTRY glCompressedCopySubTextureCHROMIUM (GLenum target, GLenum source_id, GLenum dest_id, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height);
GL_APICALL void GL_APIENTRY glDrawArraysInstancedANGLE (GLenumDrawMode mode, GLint first, GLsizei count, GLsizei primcount);
GL_APICALL void GL_APIENTRY glDrawElementsInstancedANGLE (GLenumDrawMode mode, GLsizei count, GLenumIndexType type, const void* indices, GLsizei primcount);
GL_APICALL void GL_APIENTRY glVertexAttribDivisorANGLE (GLuint index, GLuint divisor);
diff --git a/gpu/command_buffer/common/gles2_cmd_format_autogen.h b/gpu/command_buffer/common/gles2_cmd_format_autogen.h
index 3419f6c..23a5011 100644
--- a/gpu/command_buffer/common/gles2_cmd_format_autogen.h
+++ b/gpu/command_buffer/common/gles2_cmd_format_autogen.h
@@ -12533,93 +12533,6 @@ static_assert(offsetof(CompressedCopyTextureCHROMIUM, source_id) == 8,
static_assert(offsetof(CompressedCopyTextureCHROMIUM, dest_id) == 12,
"offset of CompressedCopyTextureCHROMIUM dest_id should be 12");
-struct CompressedCopySubTextureCHROMIUM {
- typedef CompressedCopySubTextureCHROMIUM ValueType;
- static const CommandId kCmdId = kCompressedCopySubTextureCHROMIUM;
- static const cmd::ArgFlags kArgFlags = cmd::kFixed;
- static const uint8_t cmd_flags = CMD_FLAG_SET_TRACE_LEVEL(3);
-
- static uint32_t ComputeSize() {
- return static_cast<uint32_t>(sizeof(ValueType)); // NOLINT
- }
-
- void SetHeader() { header.SetCmd<ValueType>(); }
-
- void Init(GLenum _target,
- GLenum _source_id,
- GLenum _dest_id,
- GLint _xoffset,
- GLint _yoffset,
- GLint _x,
- GLint _y,
- GLsizei _width,
- GLsizei _height) {
- SetHeader();
- target = _target;
- source_id = _source_id;
- dest_id = _dest_id;
- xoffset = _xoffset;
- yoffset = _yoffset;
- x = _x;
- y = _y;
- width = _width;
- height = _height;
- }
-
- void* Set(void* cmd,
- GLenum _target,
- GLenum _source_id,
- GLenum _dest_id,
- GLint _xoffset,
- GLint _yoffset,
- GLint _x,
- GLint _y,
- GLsizei _width,
- GLsizei _height) {
- static_cast<ValueType*>(cmd)->Init(_target, _source_id, _dest_id, _xoffset,
- _yoffset, _x, _y, _width, _height);
- return NextCmdAddress<ValueType>(cmd);
- }
-
- gpu::CommandHeader header;
- uint32_t target;
- uint32_t source_id;
- uint32_t dest_id;
- int32_t xoffset;
- int32_t yoffset;
- int32_t x;
- int32_t y;
- int32_t width;
- int32_t height;
-};
-
-static_assert(sizeof(CompressedCopySubTextureCHROMIUM) == 40,
- "size of CompressedCopySubTextureCHROMIUM should be 40");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, header) == 0,
- "offset of CompressedCopySubTextureCHROMIUM header should be 0");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, target) == 4,
- "offset of CompressedCopySubTextureCHROMIUM target should be 4");
-static_assert(
- offsetof(CompressedCopySubTextureCHROMIUM, source_id) == 8,
- "offset of CompressedCopySubTextureCHROMIUM source_id should be 8");
-static_assert(
- offsetof(CompressedCopySubTextureCHROMIUM, dest_id) == 12,
- "offset of CompressedCopySubTextureCHROMIUM dest_id should be 12");
-static_assert(
- offsetof(CompressedCopySubTextureCHROMIUM, xoffset) == 16,
- "offset of CompressedCopySubTextureCHROMIUM xoffset should be 16");
-static_assert(
- offsetof(CompressedCopySubTextureCHROMIUM, yoffset) == 20,
- "offset of CompressedCopySubTextureCHROMIUM yoffset should be 20");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, x) == 24,
- "offset of CompressedCopySubTextureCHROMIUM x should be 24");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, y) == 28,
- "offset of CompressedCopySubTextureCHROMIUM y should be 28");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, width) == 32,
- "offset of CompressedCopySubTextureCHROMIUM width should be 32");
-static_assert(offsetof(CompressedCopySubTextureCHROMIUM, height) == 36,
- "offset of CompressedCopySubTextureCHROMIUM height should be 36");
-
struct DrawArraysInstancedANGLE {
typedef DrawArraysInstancedANGLE ValueType;
static const CommandId kCmdId = kDrawArraysInstancedANGLE;
diff --git a/gpu/command_buffer/common/gles2_cmd_format_test_autogen.h b/gpu/command_buffer/common/gles2_cmd_format_test_autogen.h
index f8ebe0f..727fc7d 100644
--- a/gpu/command_buffer/common/gles2_cmd_format_test_autogen.h
+++ b/gpu/command_buffer/common/gles2_cmd_format_test_autogen.h
@@ -4199,30 +4199,6 @@ TEST_F(GLES2FormatTest, CompressedCopyTextureCHROMIUM) {
CheckBytesWrittenMatchesExpectedSize(next_cmd, sizeof(cmd));
}
-TEST_F(GLES2FormatTest, CompressedCopySubTextureCHROMIUM) {
- cmds::CompressedCopySubTextureCHROMIUM& cmd =
- *GetBufferAs<cmds::CompressedCopySubTextureCHROMIUM>();
- void* next_cmd = cmd.Set(&cmd, static_cast<GLenum>(11),
- static_cast<GLenum>(12), static_cast<GLenum>(13),
- static_cast<GLint>(14), static_cast<GLint>(15),
- static_cast<GLint>(16), static_cast<GLint>(17),
- static_cast<GLsizei>(18), static_cast<GLsizei>(19));
- EXPECT_EQ(
- static_cast<uint32_t>(cmds::CompressedCopySubTextureCHROMIUM::kCmdId),
- cmd.header.command);
- EXPECT_EQ(sizeof(cmd), cmd.header.size * 4u);
- EXPECT_EQ(static_cast<GLenum>(11), cmd.target);
- EXPECT_EQ(static_cast<GLenum>(12), cmd.source_id);
- EXPECT_EQ(static_cast<GLenum>(13), cmd.dest_id);
- EXPECT_EQ(static_cast<GLint>(14), cmd.xoffset);
- EXPECT_EQ(static_cast<GLint>(15), cmd.yoffset);
- EXPECT_EQ(static_cast<GLint>(16), cmd.x);
- EXPECT_EQ(static_cast<GLint>(17), cmd.y);
- EXPECT_EQ(static_cast<GLsizei>(18), cmd.width);
- EXPECT_EQ(static_cast<GLsizei>(19), cmd.height);
- CheckBytesWrittenMatchesExpectedSize(next_cmd, sizeof(cmd));
-}
-
TEST_F(GLES2FormatTest, DrawArraysInstancedANGLE) {
cmds::DrawArraysInstancedANGLE& cmd =
*GetBufferAs<cmds::DrawArraysInstancedANGLE>();
diff --git a/gpu/command_buffer/common/gles2_cmd_ids_autogen.h b/gpu/command_buffer/common/gles2_cmd_ids_autogen.h
index 1d8cfd6..9091f41 100644
--- a/gpu/command_buffer/common/gles2_cmd_ids_autogen.h
+++ b/gpu/command_buffer/common/gles2_cmd_ids_autogen.h
@@ -271,72 +271,71 @@
OP(CopyTextureCHROMIUM) /* 512 */ \
OP(CopySubTextureCHROMIUM) /* 513 */ \
OP(CompressedCopyTextureCHROMIUM) /* 514 */ \
- OP(CompressedCopySubTextureCHROMIUM) /* 515 */ \
- OP(DrawArraysInstancedANGLE) /* 516 */ \
- OP(DrawElementsInstancedANGLE) /* 517 */ \
- OP(VertexAttribDivisorANGLE) /* 518 */ \
- OP(GenMailboxCHROMIUM) /* 519 */ \
- OP(ProduceTextureCHROMIUMImmediate) /* 520 */ \
- OP(ProduceTextureDirectCHROMIUMImmediate) /* 521 */ \
- OP(ConsumeTextureCHROMIUMImmediate) /* 522 */ \
- OP(CreateAndConsumeTextureCHROMIUMImmediate) /* 523 */ \
- OP(BindUniformLocationCHROMIUMBucket) /* 524 */ \
- OP(GenValuebuffersCHROMIUMImmediate) /* 525 */ \
- OP(DeleteValuebuffersCHROMIUMImmediate) /* 526 */ \
- OP(IsValuebufferCHROMIUM) /* 527 */ \
- OP(BindValuebufferCHROMIUM) /* 528 */ \
- OP(SubscribeValueCHROMIUM) /* 529 */ \
- OP(PopulateSubscribedValuesCHROMIUM) /* 530 */ \
- OP(UniformValuebufferCHROMIUM) /* 531 */ \
- OP(BindTexImage2DCHROMIUM) /* 532 */ \
- OP(ReleaseTexImage2DCHROMIUM) /* 533 */ \
- OP(TraceBeginCHROMIUM) /* 534 */ \
- OP(TraceEndCHROMIUM) /* 535 */ \
- OP(DiscardFramebufferEXTImmediate) /* 536 */ \
- OP(LoseContextCHROMIUM) /* 537 */ \
- OP(InsertSyncPointCHROMIUM) /* 538 */ \
- OP(WaitSyncPointCHROMIUM) /* 539 */ \
- OP(InsertFenceSyncCHROMIUM) /* 540 */ \
- OP(GenSyncTokenCHROMIUMImmediate) /* 541 */ \
- OP(GenUnverifiedSyncTokenCHROMIUMImmediate) /* 542 */ \
- OP(VerifySyncTokensCHROMIUMImmediate) /* 543 */ \
- OP(WaitSyncTokenCHROMIUM) /* 544 */ \
- OP(DrawBuffersEXTImmediate) /* 545 */ \
- OP(DiscardBackbufferCHROMIUM) /* 546 */ \
- OP(ScheduleOverlayPlaneCHROMIUM) /* 547 */ \
- OP(ScheduleCALayerCHROMIUM) /* 548 */ \
- OP(CommitOverlayPlanesCHROMIUM) /* 549 */ \
- OP(SwapInterval) /* 550 */ \
- OP(FlushDriverCachesCHROMIUM) /* 551 */ \
- OP(MatrixLoadfCHROMIUMImmediate) /* 552 */ \
- OP(MatrixLoadIdentityCHROMIUM) /* 553 */ \
- OP(GenPathsCHROMIUM) /* 554 */ \
- OP(DeletePathsCHROMIUM) /* 555 */ \
- OP(IsPathCHROMIUM) /* 556 */ \
- OP(PathCommandsCHROMIUM) /* 557 */ \
- OP(PathParameterfCHROMIUM) /* 558 */ \
- OP(PathParameteriCHROMIUM) /* 559 */ \
- OP(PathStencilFuncCHROMIUM) /* 560 */ \
- OP(StencilFillPathCHROMIUM) /* 561 */ \
- OP(StencilStrokePathCHROMIUM) /* 562 */ \
- OP(CoverFillPathCHROMIUM) /* 563 */ \
- OP(CoverStrokePathCHROMIUM) /* 564 */ \
- OP(StencilThenCoverFillPathCHROMIUM) /* 565 */ \
- OP(StencilThenCoverStrokePathCHROMIUM) /* 566 */ \
- OP(StencilFillPathInstancedCHROMIUM) /* 567 */ \
- OP(StencilStrokePathInstancedCHROMIUM) /* 568 */ \
- OP(CoverFillPathInstancedCHROMIUM) /* 569 */ \
- OP(CoverStrokePathInstancedCHROMIUM) /* 570 */ \
- OP(StencilThenCoverFillPathInstancedCHROMIUM) /* 571 */ \
- OP(StencilThenCoverStrokePathInstancedCHROMIUM) /* 572 */ \
- OP(BindFragmentInputLocationCHROMIUMBucket) /* 573 */ \
- OP(ProgramPathFragmentInputGenCHROMIUM) /* 574 */ \
- OP(CoverageModulationCHROMIUM) /* 575 */ \
- OP(BlendBarrierKHR) /* 576 */ \
- OP(ApplyScreenSpaceAntialiasingCHROMIUM) /* 577 */ \
- OP(BindFragDataLocationIndexedEXTBucket) /* 578 */ \
- OP(BindFragDataLocationEXTBucket) /* 579 */ \
- OP(GetFragDataIndexEXT) /* 580 */
+ OP(DrawArraysInstancedANGLE) /* 515 */ \
+ OP(DrawElementsInstancedANGLE) /* 516 */ \
+ OP(VertexAttribDivisorANGLE) /* 517 */ \
+ OP(GenMailboxCHROMIUM) /* 518 */ \
+ OP(ProduceTextureCHROMIUMImmediate) /* 519 */ \
+ OP(ProduceTextureDirectCHROMIUMImmediate) /* 520 */ \
+ OP(ConsumeTextureCHROMIUMImmediate) /* 521 */ \
+ OP(CreateAndConsumeTextureCHROMIUMImmediate) /* 522 */ \
+ OP(BindUniformLocationCHROMIUMBucket) /* 523 */ \
+ OP(GenValuebuffersCHROMIUMImmediate) /* 524 */ \
+ OP(DeleteValuebuffersCHROMIUMImmediate) /* 525 */ \
+ OP(IsValuebufferCHROMIUM) /* 526 */ \
+ OP(BindValuebufferCHROMIUM) /* 527 */ \
+ OP(SubscribeValueCHROMIUM) /* 528 */ \
+ OP(PopulateSubscribedValuesCHROMIUM) /* 529 */ \
+ OP(UniformValuebufferCHROMIUM) /* 530 */ \
+ OP(BindTexImage2DCHROMIUM) /* 531 */ \
+ OP(ReleaseTexImage2DCHROMIUM) /* 532 */ \
+ OP(TraceBeginCHROMIUM) /* 533 */ \
+ OP(TraceEndCHROMIUM) /* 534 */ \
+ OP(DiscardFramebufferEXTImmediate) /* 535 */ \
+ OP(LoseContextCHROMIUM) /* 536 */ \
+ OP(InsertSyncPointCHROMIUM) /* 537 */ \
+ OP(WaitSyncPointCHROMIUM) /* 538 */ \
+ OP(InsertFenceSyncCHROMIUM) /* 539 */ \
+ OP(GenSyncTokenCHROMIUMImmediate) /* 540 */ \
+ OP(GenUnverifiedSyncTokenCHROMIUMImmediate) /* 541 */ \
+ OP(VerifySyncTokensCHROMIUMImmediate) /* 542 */ \
+ OP(WaitSyncTokenCHROMIUM) /* 543 */ \
+ OP(DrawBuffersEXTImmediate) /* 544 */ \
+ OP(DiscardBackbufferCHROMIUM) /* 545 */ \
+ OP(ScheduleOverlayPlaneCHROMIUM) /* 546 */ \
+ OP(ScheduleCALayerCHROMIUM) /* 547 */ \
+ OP(CommitOverlayPlanesCHROMIUM) /* 548 */ \
+ OP(SwapInterval) /* 549 */ \
+ OP(FlushDriverCachesCHROMIUM) /* 550 */ \
+ OP(MatrixLoadfCHROMIUMImmediate) /* 551 */ \
+ OP(MatrixLoadIdentityCHROMIUM) /* 552 */ \
+ OP(GenPathsCHROMIUM) /* 553 */ \
+ OP(DeletePathsCHROMIUM) /* 554 */ \
+ OP(IsPathCHROMIUM) /* 555 */ \
+ OP(PathCommandsCHROMIUM) /* 556 */ \
+ OP(PathParameterfCHROMIUM) /* 557 */ \
+ OP(PathParameteriCHROMIUM) /* 558 */ \
+ OP(PathStencilFuncCHROMIUM) /* 559 */ \
+ OP(StencilFillPathCHROMIUM) /* 560 */ \
+ OP(StencilStrokePathCHROMIUM) /* 561 */ \
+ OP(CoverFillPathCHROMIUM) /* 562 */ \
+ OP(CoverStrokePathCHROMIUM) /* 563 */ \
+ OP(StencilThenCoverFillPathCHROMIUM) /* 564 */ \
+ OP(StencilThenCoverStrokePathCHROMIUM) /* 565 */ \
+ OP(StencilFillPathInstancedCHROMIUM) /* 566 */ \
+ OP(StencilStrokePathInstancedCHROMIUM) /* 567 */ \
+ OP(CoverFillPathInstancedCHROMIUM) /* 568 */ \
+ OP(CoverStrokePathInstancedCHROMIUM) /* 569 */ \
+ OP(StencilThenCoverFillPathInstancedCHROMIUM) /* 570 */ \
+ OP(StencilThenCoverStrokePathInstancedCHROMIUM) /* 571 */ \
+ OP(BindFragmentInputLocationCHROMIUMBucket) /* 572 */ \
+ OP(ProgramPathFragmentInputGenCHROMIUM) /* 573 */ \
+ OP(CoverageModulationCHROMIUM) /* 574 */ \
+ OP(BlendBarrierKHR) /* 575 */ \
+ OP(ApplyScreenSpaceAntialiasingCHROMIUM) /* 576 */ \
+ OP(BindFragDataLocationIndexedEXTBucket) /* 577 */ \
+ OP(BindFragDataLocationEXTBucket) /* 578 */ \
+ OP(GetFragDataIndexEXT) /* 579 */
enum CommandId {
kStartPoint = cmd::kLastCommonId, // All GLES2 commands start after this.
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder.cc b/gpu/command_buffer/service/gles2_cmd_decoder.cc
index 02697ea..a5f42aff 100644
--- a/gpu/command_buffer/service/gles2_cmd_decoder.cc
+++ b/gpu/command_buffer/service/gles2_cmd_decoder.cc
@@ -964,16 +964,6 @@ class GLES2DecoderImpl : public GLES2Decoder, public ErrorStateClient {
GLuint source_id,
GLuint dest_id);
- void DoCompressedCopySubTextureCHROMIUM(GLenum target,
- GLuint source_id,
- GLuint dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height);
-
// Wrapper for TexStorage2DEXT.
void DoTexStorage2DEXT(
GLenum target,
@@ -13696,230 +13686,6 @@ void GLES2DecoderImpl::DoCompressedCopyTextureCHROMIUM(GLenum target,
}
}
-void GLES2DecoderImpl::DoCompressedCopySubTextureCHROMIUM(GLenum target,
- GLuint source_id,
- GLuint dest_id,
- GLint xoffset,
- GLint yoffset,
- GLint x,
- GLint y,
- GLsizei width,
- GLsizei height) {
- TRACE_EVENT0("gpu", "GLES2DecoderImpl::DoCompressedCopySubTextureCHROMIUM");
-
- TextureRef* source_texture_ref = GetTexture(source_id);
- TextureRef* dest_texture_ref = GetTexture(dest_id);
-
- if (!source_texture_ref || !dest_texture_ref) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "unknown texture ids");
- return;
- }
-
- Texture* source_texture = source_texture_ref->texture();
- Texture* dest_texture = dest_texture_ref->texture();
- int source_width = 0;
- int source_height = 0;
- gl::GLImage* image =
- source_texture->GetLevelImage(source_texture->target(), 0);
- if (image) {
- gfx::Size size = image->GetSize();
- source_width = size.width();
- source_height = size.height();
- if (source_width <= 0 || source_height <= 0) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "invalid image size");
- return;
- }
- } else {
- if (!source_texture->GetLevelSize(source_texture->target(), 0,
- &source_width, &source_height, nullptr)) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "source texture has no level 0");
- return;
- }
-
- // Check that this type of texture is allowed.
- if (!texture_manager()->ValidForTarget(source_texture->target(), 0,
- source_width, source_height, 1)) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "source texture bad dimensions");
- return;
- }
- }
-
- GLenum source_type = 0;
- GLenum source_internal_format = 0;
- source_texture->GetLevelType(source_texture->target(), 0, &source_type,
- &source_internal_format);
- if (!source_texture->ValidForTexture(source_texture->target(), 0, x, y, 0,
- width, height, 1)) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "source texture bad dimensions.");
- return;
- }
-
- GLenum dest_type = 0;
- GLenum dest_internal_format = 0;
- bool dest_level_defined = dest_texture->GetLevelType(
- dest_texture->target(), 0, &dest_type, &dest_internal_format);
- if (!dest_level_defined) {
- LOCAL_SET_GL_ERROR(GL_INVALID_OPERATION,
- "glCompressedCopySubTextureCHROMIUM",
- "destination texture is not defined");
- return;
- }
- if (!dest_texture->ValidForTexture(dest_texture->target(), 0, xoffset,
- yoffset, 0, width, height, 1)) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "destination texture bad dimensions.");
- return;
- }
-
- if (!ValidateCompressedCopyTextureCHROMIUM(
- "glCompressedCopySubTextureCHROMIUM", target, source_texture_ref,
- dest_texture_ref)) {
- return;
- }
-
- if (!ValidateCompressedTexSubDimensions("glCompressedCopySubTextureCHROMIUM",
- source_texture->target(), 0, x, y, 0,
- width, height, 1,
- source_internal_format,
- source_texture) ||
- !ValidateCompressedTexSubDimensions("glCompressedCopySubTextureCHROMIUM",
- dest_texture->target(), 0,
- xoffset, yoffset, 0, width, height, 1,
- dest_internal_format,
- dest_texture)) {
- return;
- }
-
- // Defer initializing the CopyTextureCHROMIUMResourceManager until it is
- // needed because it takes 10s of milliseconds to initialize.
- if (!copy_texture_CHROMIUM_.get()) {
- LOCAL_COPY_REAL_GL_ERRORS_TO_WRAPPER("glCompressedCopySubTextureCHROMIUM");
- copy_texture_CHROMIUM_.reset(new CopyTextureCHROMIUMResourceManager());
- copy_texture_CHROMIUM_->Initialize(this);
- RestoreCurrentFramebufferBindings();
- if (LOCAL_PEEK_GL_ERROR("glCompressedCopySubTextureCHROMIUM") !=
- GL_NO_ERROR) {
- return;
- }
- }
-
- // Clear the source texture if necessary.
- if (!texture_manager()->ClearTextureLevel(this, source_texture_ref,
- source_texture->target(), 0)) {
- LOCAL_SET_GL_ERROR(GL_OUT_OF_MEMORY, "glCompressedCopySubTextureCHROMIUM",
- "source texture dimensions too big");
- return;
- }
-
- int dest_width = 0;
- int dest_height = 0;
- bool ok = dest_texture->GetLevelSize(
- GL_TEXTURE_2D, 0, &dest_width, &dest_height, nullptr);
- DCHECK(ok);
- if (xoffset != 0 || yoffset != 0 || width != dest_width ||
- height != dest_height) {
- gfx::Rect cleared_rect;
- if (TextureManager::CombineAdjacentRects(
- dest_texture->GetLevelClearedRect(target, 0),
- gfx::Rect(xoffset, yoffset, width, height), &cleared_rect)) {
- DCHECK_GE(cleared_rect.size().GetArea(),
- dest_texture->GetLevelClearedRect(target, 0).size().GetArea());
- texture_manager()->SetLevelClearedRect(dest_texture_ref, target, 0,
- cleared_rect);
- } else {
- // Otherwise clear part of texture level that is not already cleared.
- if (!texture_manager()->ClearTextureLevel(this, dest_texture_ref, target,
- 0)) {
- LOCAL_SET_GL_ERROR(GL_OUT_OF_MEMORY,
- "glCompressedCopySubTextureCHROMIUM",
- "destination texture dimensions too big");
- return;
- }
- }
- } else {
- texture_manager()->SetLevelCleared(dest_texture_ref, GL_TEXTURE_2D, 0,
- true);
- }
-
- ScopedTextureBinder binder(
- &state_, dest_texture->service_id(), GL_TEXTURE_2D);
-
- // Try using GLImage::CopyTexSubImage when possible.
- if (image &&
- image->CopyTexSubImage(GL_TEXTURE_2D, gfx::Point(xoffset, yoffset),
- gfx::Rect(x, y, width, height))) {
- return;
- }
-
- TRACE_EVENT0(
- "gpu",
- "GLES2DecoderImpl::DoCompressedCopySubTextureCHROMIUM, fallback");
-
- DoCopyTexImageIfNeeded(source_texture, source_texture->target());
-
- // As a fallback, copy into a non-compressed GL_RGBA texture.
- if (dest_internal_format != GL_RGBA) {
- DCHECK_EQ(static_cast<GLenum>(GL_TEXTURE_2D), dest_texture->target());
-
- // To preserve the contents of the original destination texture we must
- // first copy the original destination texture to a temporary storage, then
- // copy it back to the original destination texture.
- GLenum tmp_target = GL_TEXTURE_2D;
- GLuint tmp_service_id;
- glGenTextures(1, &tmp_service_id);
- DCHECK_NE(0u, tmp_service_id);
-
- glBindTexture(tmp_target, tmp_service_id);
-
- LOCAL_COPY_REAL_GL_ERRORS_TO_WRAPPER("glCompressedCopyTextureCHROMIUM");
- glTexImage2D(tmp_target, 0, GL_RGBA, dest_width, dest_height, 0, GL_RGBA,
- GL_UNSIGNED_BYTE, NULL);
- GLenum error = LOCAL_PEEK_GL_ERROR("glCompressedCopySubTextureCHROMIUM");
- if (error != GL_NO_ERROR)
- return;
-
- copy_texture_CHROMIUM_->DoCopyTexture(
- this, dest_texture->target(), dest_texture->service_id(),
- dest_internal_format, tmp_target, tmp_service_id, GL_RGBA,
- dest_width, dest_height, false, false, false);
-
- // Redefine destination texture to use RGBA.
- glBindTexture(dest_texture->target(), dest_texture->service_id());
- LOCAL_COPY_REAL_GL_ERRORS_TO_WRAPPER("glCompressedCopyTextureCHROMIUM");
- glTexImage2D(dest_texture->target(), 0, GL_RGBA, dest_width, dest_height, 0,
- GL_RGBA, GL_UNSIGNED_BYTE, NULL);
- error = LOCAL_PEEK_GL_ERROR("glCompressedCopySubTextureCHROMIUM");
- if (error != GL_NO_ERROR)
- return;
-
- texture_manager()->SetLevelInfo(dest_texture_ref, dest_texture->target(), 0,
- GL_RGBA, dest_width, dest_height, 1, 0,
- GL_RGBA, GL_UNSIGNED_BYTE,
- gfx::Rect(dest_width, dest_height));
-
- copy_texture_CHROMIUM_->DoCopyTexture(
- this, tmp_target, tmp_service_id, GL_RGBA,
- dest_texture->target(), dest_texture->service_id(), GL_RGBA,
- dest_width, dest_height, false, false, false);
-
- glDeleteTextures(1, &tmp_service_id);
- }
-
- // TODO(hkuang): get the StreamTexture transform matrix in GPU process.
- // crbug.com/226218.
- copy_texture_CHROMIUM_->DoCopySubTexture(
- this, source_texture->target(), source_texture->service_id(),
- source_internal_format, dest_texture->target(),
- dest_texture->service_id(), GL_RGBA, xoffset, yoffset, x, y, width,
- height, dest_width, dest_height, source_width, source_height, false,
- false, false);
-}
-
void GLES2DecoderImpl::DoTexStorage2DEXT(
GLenum target,
GLint levels,
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h
index c6da4ef..b751b2a 100644
--- a/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h
+++ b/gpu/command_buffer/service/gles2_cmd_decoder_autogen.h
@@ -4478,37 +4478,6 @@ error::Error GLES2DecoderImpl::HandleCompressedCopyTextureCHROMIUM(
return error::kNoError;
}
-error::Error GLES2DecoderImpl::HandleCompressedCopySubTextureCHROMIUM(
- uint32_t immediate_data_size,
- const void* cmd_data) {
- const gles2::cmds::CompressedCopySubTextureCHROMIUM& c =
- *static_cast<const gles2::cmds::CompressedCopySubTextureCHROMIUM*>(
- cmd_data);
- (void)c;
- GLenum target = static_cast<GLenum>(c.target);
- GLenum source_id = static_cast<GLenum>(c.source_id);
- GLenum dest_id = static_cast<GLenum>(c.dest_id);
- GLint xoffset = static_cast<GLint>(c.xoffset);
- GLint yoffset = static_cast<GLint>(c.yoffset);
- GLint x = static_cast<GLint>(c.x);
- GLint y = static_cast<GLint>(c.y);
- GLsizei width = static_cast<GLsizei>(c.width);
- GLsizei height = static_cast<GLsizei>(c.height);
- if (width < 0) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "width < 0");
- return error::kNoError;
- }
- if (height < 0) {
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "glCompressedCopySubTextureCHROMIUM",
- "height < 0");
- return error::kNoError;
- }
- DoCompressedCopySubTextureCHROMIUM(target, source_id, dest_id, xoffset,
- yoffset, x, y, width, height);
- return error::kNoError;
-}
-
error::Error GLES2DecoderImpl::HandleProduceTextureCHROMIUMImmediate(
uint32_t immediate_data_size,
const void* cmd_data) {
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_3_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_3_autogen.h
index 5cda2e1..e8b9eb6 100644
--- a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_3_autogen.h
+++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_3_autogen.h
@@ -394,4 +394,12 @@ TEST_P(GLES2DecoderTest3, IsValuebufferCHROMIUMInvalidArgsBadSharedMemoryId) {
kInvalidSharedMemoryOffset);
EXPECT_EQ(error::kOutOfBounds, ExecuteCmd(cmd));
}
+
+TEST_P(GLES2DecoderTest3, SwapIntervalValidArgs) {
+ SpecializedSetup<cmds::SwapInterval, 0>(true);
+ cmds::SwapInterval cmd;
+ cmd.Init(1);
+ EXPECT_EQ(error::kNoError, ExecuteCmd(cmd));
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+}
#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_3_AUTOGEN_H_
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_4_autogen.h b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_4_autogen.h
index 166ced9..9abba52 100644
--- a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_4_autogen.h
+++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_4_autogen.h
@@ -12,11 +12,4 @@
#ifndef GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_4_AUTOGEN_H_
#define GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_4_AUTOGEN_H_
-TEST_P(GLES2DecoderTest4, SwapIntervalValidArgs) {
- SpecializedSetup<cmds::SwapInterval, 0>(true);
- cmds::SwapInterval cmd;
- cmd.Init(1);
- EXPECT_EQ(error::kNoError, ExecuteCmd(cmd));
- EXPECT_EQ(GL_NO_ERROR, GetGLError());
-}
#endif // GPU_COMMAND_BUFFER_SERVICE_GLES2_CMD_DECODER_UNITTEST_4_AUTOGEN_H_
diff --git a/gpu/command_buffer/tests/gl_compressed_copy_texture_CHROMIUM_unittest.cc b/gpu/command_buffer/tests/gl_compressed_copy_texture_CHROMIUM_unittest.cc
index b444bb9..333da3c 100644
--- a/gpu/command_buffer/tests/gl_compressed_copy_texture_CHROMIUM_unittest.cc
+++ b/gpu/command_buffer/tests/gl_compressed_copy_texture_CHROMIUM_unittest.cc
@@ -22,12 +22,6 @@ namespace gpu {
namespace {
-enum CopyType { TexImage, TexSubImage };
-const CopyType kCopyTypes[] = {
- TexImage,
- TexSubImage,
-};
-
const uint8_t kCompressedImageColor[4] = {255u, 0u, 0u, 255u};
// Single compressed ATC block of source pixels all set to:
@@ -46,14 +40,6 @@ const uint8_t kCompressedImageATCIA[16] = {0xff, 0xff, 0x0, 0x0, 0x0, 0x0,
const uint8_t kCompressedImageDXT1[8] = {0x00, 0xf8, 0x00, 0xf8,
0xaa, 0xaa, 0xaa, 0xaa};
-// Four compressed DXT1 blocks solidly colored in red, green, blue and black:
-// [R][G]
-// [B][b]
-const uint8_t kCompressedImageDXT1RGB[32] = {
- 0x0, 0xf8, 0x0, 0xf8, 0xaa, 0xaa, 0xaa, 0xaa, 0xe0, 0x7, 0xe0,
- 0x7, 0xaa, 0xaa, 0xaa, 0xaa, 0x1f, 0x0, 0x1f, 0x0, 0xaa, 0xaa,
- 0xaa, 0xaa, 0x0, 0x0, 0x0, 0x0, 0xaa, 0xaa, 0xaa, 0xaa};
-
// Single compressed DXT5 block of source pixels all set to:
// kCompressedImageColor.
const uint8_t kCompressedImageDXT5[16] = {0xff, 0xff, 0x0, 0x0, 0x0, 0x0,
@@ -65,16 +51,6 @@ const uint8_t kCompressedImageDXT5[16] = {0xff, 0xff, 0x0, 0x0, 0x0, 0x0,
const uint8_t kCompressedImageETC1[8] = {0x0, 0x0, 0xf8, 0x2,
0xff, 0xff, 0x0, 0x0};
-// Single block of zeroes, used for texture pre-allocation.
-const uint8_t kInvalidCompressedImage[8] = {0x0, 0x0, 0x0, 0x0,
- 0x0, 0x0, 0x0, 0x0};
-
-// Four blocks of zeroes, used for texture pre-allocation.
-const uint8_t kInvalidCompressedImageLarge[32] = {
- 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
- 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
- 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
-
void glEnableDisable(GLint param, GLboolean value) {
if (value)
glEnable(param);
@@ -86,8 +62,7 @@ void glEnableDisable(GLint param, GLboolean value) {
// A collection of tests that exercise the GL_CHROMIUM_copy_texture extension.
class GLCompressedCopyTextureCHROMIUMTest
- : public testing::Test,
- public ::testing::WithParamInterface<CopyType> {
+ : public testing::Test {
protected:
void SetUp() override {
gl_.Initialize(GLManager::Options());
@@ -125,20 +100,14 @@ class GLCompressedCopyTextureCHROMIUMTest
GLuint framebuffer_id_;
};
-INSTANTIATE_TEST_CASE_P(CopyType,
- GLCompressedCopyTextureCHROMIUMTest,
- ::testing::ValuesIn(kCopyTypes));
-
// Test to ensure that the basic functionality of the extension works.
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, Basic) {
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, Basic) {
if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
LOG(INFO) <<
"GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
return;
}
- CopyType copy_type = GetParam();
-
glBindTexture(GL_TEXTURE_2D, textures_[0]);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
@@ -154,17 +123,7 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, Basic) {
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
- } else {
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 4, 4, 0,
- sizeof(kInvalidCompressedImage),
- kInvalidCompressedImage);
-
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 4, 4);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
EXPECT_TRUE(glGetError() == GL_NO_ERROR);
// Load shader program.
@@ -193,9 +152,7 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, Basic) {
EXPECT_TRUE(GL_NO_ERROR == glGetError());
}
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormat) {
- CopyType copy_type = GetParam();
-
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, InternalFormat) {
struct Image {
const GLint format;
const uint8_t* data;
@@ -206,9 +163,8 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormat) {
};
std::vector<scoped_ptr<Image>> supported_formats;
- if ((GLTestHelper::HasExtension("GL_AMD_compressed_ATC_texture") ||
- GLTestHelper::HasExtension("GL_ATI_texture_compression_atitc")) &&
- copy_type != TexSubImage) {
+ if (GLTestHelper::HasExtension("GL_AMD_compressed_ATC_texture") ||
+ GLTestHelper::HasExtension("GL_ATI_texture_compression_atitc")) {
supported_formats.push_back(make_scoped_ptr(new Image(
GL_ATC_RGB_AMD,
kCompressedImageATC,
@@ -231,8 +187,7 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormat) {
kCompressedImageDXT5,
sizeof(kCompressedImageDXT5))));
}
- if (GLTestHelper::HasExtension("GL_OES_compressed_ETC1_RGB8_texture") &&
- copy_type != TexSubImage) {
+ if (GLTestHelper::HasExtension("GL_OES_compressed_ETC1_RGB8_texture")) {
supported_formats.push_back(make_scoped_ptr(new Image(
GL_ETC1_RGB8_OES,
kCompressedImageETC1,
@@ -254,30 +209,18 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormat) {
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1]);
- } else {
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, image->format, 4, 4, 0,
- sizeof(kInvalidCompressedImage),
- kInvalidCompressedImage);
-
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 4, 4);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
EXPECT_TRUE(GL_NO_ERROR == glGetError());
}
}
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormatNotSupported) {
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, InternalFormatNotSupported) {
if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
LOG(INFO) <<
"GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
return;
}
- CopyType copy_type = GetParam();
-
const uint8_t kUncompressedPixels[1 * 4] = {255u, 0u, 0u, 255u};
glBindTexture(GL_TEXTURE_2D, textures_[0]);
@@ -296,27 +239,17 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, InternalFormatNotSupported) {
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
// Check that the GL_RGBA format reports an error.
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
- } else {
- glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, GL_UNSIGNED_BYTE,
- kUncompressedPixels);
-
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 1, 1);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
EXPECT_TRUE(GL_INVALID_OPERATION == glGetError());
}
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, InvalidTextureIds) {
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, InvalidTextureIds) {
if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
LOG(INFO)
<< "GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
return;
}
- CopyType copy_type = GetParam();
-
glBindTexture(GL_TEXTURE_2D, textures_[0]);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
@@ -332,52 +265,29 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, InvalidTextureIds) {
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], 99993);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, 99994, textures_[1]);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, 99995, 99996);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
- } else {
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT, 4,
- 4, 0, sizeof(kInvalidCompressedImage),
- kInvalidCompressedImage);
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], 99993, 0, 0,
- 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], 99993);
+ EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, 99994, textures_[1], 0, 0,
- 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, 99994, textures_[1]);
+ EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, 99995, 99996, 0, 0, 0, 0,
- 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, 99995, 99996);
+ EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
+ EXPECT_TRUE(glGetError() == GL_NO_ERROR);
}
// Validate that some basic GL state is not touched upon execution of
// the extension.
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, BasicStatePreservation) {
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, BasicStatePreservation) {
if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
LOG(INFO) <<
"GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
return;
}
- CopyType copy_type = GetParam();
-
glBindTexture(GL_TEXTURE_2D, textures_[0]);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
@@ -394,13 +304,6 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, BasicStatePreservation) {
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- if (copy_type == TexSubImage) {
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 4, 4, 0,
- sizeof(kInvalidCompressedImage),
- kInvalidCompressedImage);
- }
-
GLboolean reference_settings[2] = { GL_TRUE, GL_FALSE };
for (int x = 0; x < 2; ++x) {
GLboolean setting = reference_settings[x];
@@ -413,14 +316,7 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, BasicStatePreservation) {
glDepthMask(setting);
glActiveTexture(GL_TEXTURE1 + x);
-
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1]);
- } else {
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 4, 4);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
EXPECT_TRUE(glGetError() == GL_NO_ERROR);
EXPECT_EQ(setting, glIsEnabled(GL_DEPTH_TEST));
@@ -450,15 +346,13 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, BasicStatePreservation) {
// Verify that invocation of the extension does not modify the bound
// texture state.
-TEST_P(GLCompressedCopyTextureCHROMIUMTest, TextureStatePreserved) {
+TEST_F(GLCompressedCopyTextureCHROMIUMTest, TextureStatePreserved) {
if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
LOG(INFO) <<
"GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
return;
}
- CopyType copy_type = GetParam();
-
glBindTexture(GL_TEXTURE_2D, textures_[0]);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
@@ -475,13 +369,6 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, TextureStatePreserved) {
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- if (copy_type == TexSubImage) {
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 4, 4, 0,
- sizeof(kInvalidCompressedImage),
- kInvalidCompressedImage);
- }
-
GLuint texture_ids[2];
glGenTextures(2, texture_ids);
@@ -491,12 +378,7 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, TextureStatePreserved) {
glActiveTexture(GL_TEXTURE1);
glBindTexture(GL_TEXTURE_2D, texture_ids[1]);
- if (copy_type == TexImage) {
- glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
- } else {
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 0, 4, 4);
- }
+ glCompressedCopyTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1]);
EXPECT_TRUE(GL_NO_ERROR == glGetError());
GLint active_texture = 0;
@@ -519,253 +401,4 @@ TEST_P(GLCompressedCopyTextureCHROMIUMTest, TextureStatePreserved) {
EXPECT_TRUE(GL_NO_ERROR == glGetError());
}
-TEST_F(GLCompressedCopyTextureCHROMIUMTest, CopySubTextureDimension) {
- if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
- LOG(INFO) <<
- "GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
- return;
- }
-
- glBindTexture(GL_TEXTURE_2D, textures_[0]);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kCompressedImageDXT1RGB),
- kCompressedImageDXT1RGB);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 4, 4, 0, 0, 4, 4);
- EXPECT_TRUE(GL_NO_ERROR == glGetError());
-
- // Reset the destination texture as it might have been converted to RGBA.
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- // xoffset < 0
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- -4, 4, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- // x < 0
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- 4, 4, -4, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- // xoffset + width > dest_width
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- 8, 8, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- // x + width > source_width
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- 0, 0, 8, 8, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_VALUE);
-
- // xoffset not within block-boundary
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- 3, 0, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_OPERATION);
-
- // x not within block-boundary
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0], textures_[1],
- 0, 0, 3, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_INVALID_OPERATION);
-}
-
-TEST_F(GLCompressedCopyTextureCHROMIUMTest, CopySubTextureOffset) {
- if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
- LOG(INFO) <<
- "GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
- return;
- }
-
- glBindTexture(GL_TEXTURE_2D, textures_[0]);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kCompressedImageDXT1RGB),
- kCompressedImageDXT1RGB);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- // Load shader program.
- GLuint program = LoadProgram();
- ASSERT_NE(program, 0u);
- GLint position_loc = glGetAttribLocation(program, "a_position");
- GLint texture_loc = glGetUniformLocation(program, "u_texture");
- ASSERT_NE(position_loc, -1);
- ASSERT_NE(texture_loc, -1);
- glUseProgram(program);
-
- // Load geometry.
- GLuint vbo = GLTestHelper::SetupUnitQuad(position_loc);
- ASSERT_NE(vbo, 0u);
-
- // Load texture.
- glActiveTexture(GL_TEXTURE0);
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glUniform1i(texture_loc, 0);
-
- const uint8_t kBlack[1 * 4] = {0u, 0u, 0u, 255u};
- const uint8_t kRed[1 * 4] = {255u, 0u, 0u, 255u};
- const uint8_t kGreen[1 * 4] = {0u, 255u, 0u, 255u};
- const uint8_t kBlue[1 * 4] = {0u, 0u, 255u, 255u};
-
- // Copy each block one by one in a clockwise fashion. Note that we reset the
- // destination texture after each copy operation. That's because on some
- // platforms we might fallback into replacing the compressed destination
- // texture with an uncompressed one.
-
- // Move blue block up.
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 0, 0, 4, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glDrawArrays(GL_TRIANGLES, 0, 6);
- glFlush();
- GLTestHelper::CheckPixels(0, 0, 2, 2, 0, kBlue);
-
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- // Move red block right.
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 4, 0, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glDrawArrays(GL_TRIANGLES, 0, 6);
- glFlush();
- GLTestHelper::CheckPixels(2, 0, 2, 2, 0, kRed);
-
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- // Move green block down.
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 4, 4, 4, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glDrawArrays(GL_TRIANGLES, 0, 6);
- glFlush();
- GLTestHelper::CheckPixels(2, 2, 2, 2, 0, kGreen);
-
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kInvalidCompressedImageLarge),
- kInvalidCompressedImageLarge);
-
- // Move black block left.
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 0, 4, 4, 4, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glDrawArrays(GL_TRIANGLES, 0, 6);
- glFlush();
- GLTestHelper::CheckPixels(0, 2, 2, 2, 0, kBlack);
-
- EXPECT_TRUE(GL_NO_ERROR == glGetError());
-}
-
-TEST_F(GLCompressedCopyTextureCHROMIUMTest, CopySubTexturePreservation) {
- if (!GLTestHelper::HasExtension("GL_EXT_texture_compression_dxt1")) {
- LOG(INFO) <<
- "GL_EXT_texture_compression_dxt1 not supported. Skipping test...";
- return;
- }
-
- glBindTexture(GL_TEXTURE_2D, textures_[0]);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 4, 4, 0,
- sizeof(kCompressedImageDXT1),
- kCompressedImageDXT1);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glCompressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB_S3TC_DXT1_EXT,
- 8, 8, 0,
- sizeof(kCompressedImageDXT1RGB),
- kCompressedImageDXT1RGB);
-
- // Copy entire first texture into the second, replacing the green block:
- // [R][R]
- // [B][b]
- glCompressedCopySubTextureCHROMIUM(GL_TEXTURE_2D, textures_[0],
- textures_[1], 4, 0, 0, 0, 4, 4);
- EXPECT_TRUE(glGetError() == GL_NO_ERROR);
-
- // Load shader program.
- GLuint program = LoadProgram();
- ASSERT_NE(program, 0u);
- GLint position_loc = glGetAttribLocation(program, "a_position");
- GLint texture_loc = glGetUniformLocation(program, "u_texture");
- ASSERT_NE(position_loc, -1);
- ASSERT_NE(texture_loc, -1);
- glUseProgram(program);
-
- // Load geometry.
- GLuint vbo = GLTestHelper::SetupUnitQuad(position_loc);
- ASSERT_NE(vbo, 0u);
-
- // Load texture.
- glActiveTexture(GL_TEXTURE0);
- glBindTexture(GL_TEXTURE_2D, textures_[1]);
- glUniform1i(texture_loc, 0);
-
- // Draw.
- glDrawArrays(GL_TRIANGLES, 0, 6);
- glFlush();
-
- const uint8_t kBlack[1 * 4] = {0u, 0u, 0u, 255u};
- const uint8_t kRed[1 * 4] = {255u, 0u, 0u, 255u};
- const uint8_t kBlue[1 * 4] = {0u, 0u, 255u, 255u};
-
- // Note that while destination texture is 8 x 8 pixels the viewport is only
- // 4 x 4.
- GLTestHelper::CheckPixels(0, 0, 4, 2, 0, kRed);
- GLTestHelper::CheckPixels(0, 2, 2, 2, 0, kBlue);
- GLTestHelper::CheckPixels(2, 2, 2, 2, 0, kBlack);
- EXPECT_TRUE(GL_NO_ERROR == glGetError());
-}
-
} // namespace gpu