Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(67)

Side by Side Diff: gpu/command_buffer/client/gles2_implementation.cc

Issue 1222563003: Revert of Added support for Time Elapsed queries through the command buffer. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // A class to emulate GLES2 over command buffers. 5 // A class to emulate GLES2 over command buffers.
6 6
7 #include "gpu/command_buffer/client/gles2_implementation.h" 7 #include "gpu/command_buffer/client/gles2_implementation.h"
8 8
9 #include <GLES2/gl2ext.h> 9 #include <GLES2/gl2ext.h>
10 #include <GLES2/gl2extchromium.h> 10 #include <GLES2/gl2extchromium.h>
(...skipping 689 matching lines...) Expand 10 before | Expand all | Expand 10 after
700 return true; 700 return true;
701 case GL_PIXEL_UNPACK_TRANSFER_BUFFER_BINDING_CHROMIUM: 701 case GL_PIXEL_UNPACK_TRANSFER_BUFFER_BINDING_CHROMIUM:
702 *params = bound_pixel_unpack_transfer_buffer_id_; 702 *params = bound_pixel_unpack_transfer_buffer_id_;
703 return true; 703 return true;
704 case GL_READ_FRAMEBUFFER_BINDING: 704 case GL_READ_FRAMEBUFFER_BINDING:
705 if (IsChromiumFramebufferMultisampleAvailable()) { 705 if (IsChromiumFramebufferMultisampleAvailable()) {
706 *params = bound_read_framebuffer_; 706 *params = bound_read_framebuffer_;
707 return true; 707 return true;
708 } 708 }
709 break; 709 break;
710 case GL_TIMESTAMP_EXT:
711 // We convert all GPU timestamps to CPU time.
712 *params = base::saturated_cast<GLint>(
713 (base::TraceTicks::Now() - base::TraceTicks()).InMicroseconds()
714 * base::Time::kNanosecondsPerMicrosecond);
715 return true;
716 710
717 // Non-cached parameters. 711 // Non-cached parameters.
718 case GL_ALIASED_LINE_WIDTH_RANGE: 712 case GL_ALIASED_LINE_WIDTH_RANGE:
719 case GL_ALIASED_POINT_SIZE_RANGE: 713 case GL_ALIASED_POINT_SIZE_RANGE:
720 case GL_ALPHA_BITS: 714 case GL_ALPHA_BITS:
721 case GL_BLEND: 715 case GL_BLEND:
722 case GL_BLEND_COLOR: 716 case GL_BLEND_COLOR:
723 case GL_BLEND_DST_ALPHA: 717 case GL_BLEND_DST_ALPHA:
724 case GL_BLEND_DST_RGB: 718 case GL_BLEND_DST_RGB:
725 case GL_BLEND_EQUATION_ALPHA: 719 case GL_BLEND_EQUATION_ALPHA:
(...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after
996 return true; 990 return true;
997 case GL_MAX_ELEMENT_INDEX: 991 case GL_MAX_ELEMENT_INDEX:
998 *params = capabilities_.max_element_index; 992 *params = capabilities_.max_element_index;
999 return true; 993 return true;
1000 case GL_MAX_SERVER_WAIT_TIMEOUT: 994 case GL_MAX_SERVER_WAIT_TIMEOUT:
1001 *params = capabilities_.max_server_wait_timeout; 995 *params = capabilities_.max_server_wait_timeout;
1002 return true; 996 return true;
1003 case GL_MAX_UNIFORM_BLOCK_SIZE: 997 case GL_MAX_UNIFORM_BLOCK_SIZE:
1004 *params = capabilities_.max_uniform_block_size; 998 *params = capabilities_.max_uniform_block_size;
1005 return true; 999 return true;
1006 case GL_TIMESTAMP_EXT:
1007 // We convert all GPU timestamps to CPU time.
1008 *params = (base::TraceTicks::Now() - base::TraceTicks()).InMicroseconds()
1009 * base::Time::kNanosecondsPerMicrosecond;
1010 return true;
1011 default: 1000 default:
1012 break; 1001 break;
1013 } 1002 }
1014 GLint value; 1003 GLint value;
1015 if (!GetHelper(pname, &value)) { 1004 if (!GetHelper(pname, &value)) {
1016 return false; 1005 return false;
1017 } 1006 }
1018 *params = static_cast<GLint64>(value); 1007 *params = static_cast<GLint64>(value);
1019 return true; 1008 return true;
1020 } 1009 }
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
1062 if (bufsize > 0) { 1051 if (bufsize > 0) {
1063 DCHECK(values); 1052 DCHECK(values);
1064 *values = value; 1053 *values = value;
1065 } 1054 }
1066 if (length) { 1055 if (length) {
1067 *length = 1; 1056 *length = 1;
1068 } 1057 }
1069 return true; 1058 return true;
1070 } 1059 }
1071 1060
1072 bool GLES2Implementation::GetQueryObjectValueHelper(
1073 const char* function_name, GLuint id, GLenum pname, GLuint64* params) {
1074 GPU_CLIENT_SINGLE_THREAD_CHECK();
1075 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] GetQueryObjectValueHelper("
1076 << id << ", "
1077 << GLES2Util::GetStringQueryObjectParameter(pname) << ", "
1078 << static_cast<const void*>(params) << ")");
1079
1080 QueryTracker::Query* query = query_tracker_->GetQuery(id);
1081 if (!query) {
1082 SetGLError(GL_INVALID_OPERATION,
1083 function_name, "unknown query id");
1084 return false;
1085 }
1086
1087 if (query->Active()) {
1088 SetGLError(
1089 GL_INVALID_OPERATION,
1090 function_name,
1091 "query active. Did you to call glEndQueryEXT?");
1092 return false;
1093 }
1094
1095 if (query->NeverUsed()) {
1096 SetGLError(
1097 GL_INVALID_OPERATION,
1098 function_name, "Never used. Did you call glBeginQueryEXT?");
1099 return false;
1100 }
1101
1102 bool valid_value = false;
1103 switch (pname) {
1104 case GL_QUERY_RESULT_EXT:
1105 if (!query->CheckResultsAvailable(helper_)) {
1106 helper_->WaitForToken(query->token());
1107 if (!query->CheckResultsAvailable(helper_)) {
1108 FinishHelper();
1109 CHECK(query->CheckResultsAvailable(helper_));
1110 }
1111 }
1112 *params = query->GetResult();
1113 valid_value = true;
1114 break;
1115 case GL_QUERY_RESULT_AVAILABLE_EXT:
1116 *params = query->CheckResultsAvailable(helper_);
1117 valid_value = true;
1118 break;
1119 default:
1120 SetGLErrorInvalidEnum(function_name, pname, "pname");
1121 break;
1122 }
1123 GPU_CLIENT_LOG(" " << *params);
1124 CheckGLError();
1125 return valid_value;
1126 }
1127
1128 GLuint GLES2Implementation::GetMaxValueInBufferCHROMIUMHelper( 1061 GLuint GLES2Implementation::GetMaxValueInBufferCHROMIUMHelper(
1129 GLuint buffer_id, GLsizei count, GLenum type, GLuint offset) { 1062 GLuint buffer_id, GLsizei count, GLenum type, GLuint offset) {
1130 typedef cmds::GetMaxValueInBufferCHROMIUM::Result Result; 1063 typedef cmds::GetMaxValueInBufferCHROMIUM::Result Result;
1131 Result* result = GetResultAs<Result*>(); 1064 Result* result = GetResultAs<Result*>();
1132 if (!result) { 1065 if (!result) {
1133 return 0; 1066 return 0;
1134 } 1067 }
1135 *result = 0; 1068 *result = 0;
1136 helper_->GetMaxValueInBufferCHROMIUM( 1069 helper_->GetMaxValueInBufferCHROMIUM(
1137 buffer_id, count, type, offset, GetResultShmId(), GetResultShmOffset()); 1070 buffer_id, count, type, offset, GetResultShmId(), GetResultShmOffset());
(...skipping 3749 matching lines...) Expand 10 before | Expand all | Expand 10 after
4887 CheckGLError(); 4820 CheckGLError();
4888 } 4821 }
4889 4822
4890 void GLES2Implementation::GetQueryivEXT( 4823 void GLES2Implementation::GetQueryivEXT(
4891 GLenum target, GLenum pname, GLint* params) { 4824 GLenum target, GLenum pname, GLint* params) {
4892 GPU_CLIENT_SINGLE_THREAD_CHECK(); 4825 GPU_CLIENT_SINGLE_THREAD_CHECK();
4893 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] GetQueryivEXT(" 4826 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] GetQueryivEXT("
4894 << GLES2Util::GetStringQueryTarget(target) << ", " 4827 << GLES2Util::GetStringQueryTarget(target) << ", "
4895 << GLES2Util::GetStringQueryParameter(pname) << ", " 4828 << GLES2Util::GetStringQueryParameter(pname) << ", "
4896 << static_cast<const void*>(params) << ")"); 4829 << static_cast<const void*>(params) << ")");
4897 if (pname == GL_QUERY_COUNTER_BITS_EXT) { 4830
4898 // We convert all queries to CPU time so we support 64 bits. 4831 if (pname != GL_CURRENT_QUERY_EXT) {
4899 *params = 64;
4900 return;
4901 } else if (pname != GL_CURRENT_QUERY_EXT) {
4902 SetGLErrorInvalidEnum("glGetQueryivEXT", pname, "pname"); 4832 SetGLErrorInvalidEnum("glGetQueryivEXT", pname, "pname");
4903 return; 4833 return;
4904 } 4834 }
4905 QueryTracker::Query* query = query_tracker_->GetCurrentQuery(target); 4835 QueryTracker::Query* query = query_tracker_->GetCurrentQuery(target);
4906 *params = query ? query->id() : 0; 4836 *params = query ? query->id() : 0;
4907 GPU_CLIENT_LOG(" " << *params); 4837 GPU_CLIENT_LOG(" " << *params);
4908 CheckGLError(); 4838 CheckGLError();
4909 } 4839 }
4910 4840
4911 void GLES2Implementation::GetQueryObjectuivEXT( 4841 void GLES2Implementation::GetQueryObjectuivEXT(
4912 GLuint id, GLenum pname, GLuint* params) { 4842 GLuint id, GLenum pname, GLuint* params) {
4913 GLuint64 result = 0; 4843 GPU_CLIENT_SINGLE_THREAD_CHECK();
4914 if (GetQueryObjectValueHelper("glQueryObjectuivEXT", id, pname, &result)) 4844 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] GetQueryivEXT(" << id << ", "
4915 *params = base::saturated_cast<GLuint>(result); 4845 << GLES2Util::GetStringQueryObjectParameter(pname) << ", "
4916 } 4846 << static_cast<const void*>(params) << ")");
4917 4847
4918 void GLES2Implementation::GetQueryObjectui64vEXT( 4848 QueryTracker::Query* query = query_tracker_->GetQuery(id);
4919 GLuint id, GLenum pname, GLuint64* params) { 4849 if (!query) {
4920 GLuint64 result = 0; 4850 SetGLError(GL_INVALID_OPERATION, "glQueryObjectuivEXT", "unknown query id");
4921 if (GetQueryObjectValueHelper("glQueryObjectui64vEXT", id, pname, &result)) 4851 return;
4922 *params = result; 4852 }
4853
4854 if (query->Active()) {
4855 SetGLError(
4856 GL_INVALID_OPERATION,
4857 "glQueryObjectuivEXT", "query active. Did you to call glEndQueryEXT?");
4858 return;
4859 }
4860
4861 if (query->NeverUsed()) {
4862 SetGLError(
4863 GL_INVALID_OPERATION,
4864 "glQueryObjectuivEXT", "Never used. Did you call glBeginQueryEXT?");
4865 return;
4866 }
4867
4868 switch (pname) {
4869 case GL_QUERY_RESULT_EXT:
4870 if (!query->CheckResultsAvailable(helper_)) {
4871 helper_->WaitForToken(query->token());
4872 if (!query->CheckResultsAvailable(helper_)) {
4873 FinishHelper();
4874 CHECK(query->CheckResultsAvailable(helper_));
4875 }
4876 }
4877 *params = query->GetResult();
4878 break;
4879 case GL_QUERY_RESULT_AVAILABLE_EXT:
4880 *params = query->CheckResultsAvailable(helper_);
4881 break;
4882 default:
4883 SetGLErrorInvalidEnum("glQueryObjectuivEXT", pname, "pname");
4884 break;
4885 }
4886 GPU_CLIENT_LOG(" " << *params);
4887 CheckGLError();
4923 } 4888 }
4924 4889
4925 void GLES2Implementation::DrawArraysInstancedANGLE( 4890 void GLES2Implementation::DrawArraysInstancedANGLE(
4926 GLenum mode, GLint first, GLsizei count, GLsizei primcount) { 4891 GLenum mode, GLint first, GLsizei count, GLsizei primcount) {
4927 GPU_CLIENT_SINGLE_THREAD_CHECK(); 4892 GPU_CLIENT_SINGLE_THREAD_CHECK();
4928 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] glDrawArraysInstancedANGLE(" 4893 GPU_CLIENT_LOG("[" << GetLogPrefix() << "] glDrawArraysInstancedANGLE("
4929 << GLES2Util::GetStringDrawMode(mode) << ", " 4894 << GLES2Util::GetStringDrawMode(mode) << ", "
4930 << first << ", " << count << ", " << primcount << ")"); 4895 << first << ", " << count << ", " << primcount << ")");
4931 if (count < 0) { 4896 if (count < 0) {
4932 SetGLError(GL_INVALID_VALUE, "glDrawArraysInstancedANGLE", "count < 0"); 4897 SetGLError(GL_INVALID_VALUE, "glDrawArraysInstancedANGLE", "count < 0");
(...skipping 851 matching lines...) Expand 10 before | Expand all | Expand 10 after
5784 CheckGLError(); 5749 CheckGLError();
5785 } 5750 }
5786 5751
5787 // Include the auto-generated part of this file. We split this because it means 5752 // Include the auto-generated part of this file. We split this because it means
5788 // we can easily edit the non-auto generated parts right here in this file 5753 // we can easily edit the non-auto generated parts right here in this file
5789 // instead of having to edit some template or the code generator. 5754 // instead of having to edit some template or the code generator.
5790 #include "gpu/command_buffer/client/gles2_implementation_impl_autogen.h" 5755 #include "gpu/command_buffer/client/gles2_implementation_impl_autogen.h"
5791 5756
5792 } // namespace gles2 5757 } // namespace gles2
5793 } // namespace gpu 5758 } // namespace gpu
OLDNEW
« no previous file with comments | « gpu/command_buffer/client/gles2_implementation.h ('k') | gpu/command_buffer/client/gles2_implementation_autogen.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698