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
3 // found in the LICENSE file.
5 // This file is here so other GLES2 related files can have a common set of
6 // includes where appropriate.
8 #ifndef GPU_COMMAND_BUFFER_COMMON_GLES2_CMD_UTILS_H_
9 #define GPU_COMMAND_BUFFER_COMMON_GLES2_CMD_UTILS_H_
17 #include "base/numerics/safe_math.h"
18 #include "gpu/command_buffer/common/gles2_utils_export.h"
23 // Does a multiply and checks for overflow. If the multiply did not overflow
26 // Multiplies 2 32 bit unsigned numbers checking for overflow.
27 // If there was no overflow returns true.
28 inline bool SafeMultiplyUint32(uint32_t a
, uint32_t b
, uint32_t* dst
) {
30 base::CheckedNumeric
<uint32_t> checked
= a
;
32 *dst
= checked
.ValueOrDefault(0);
33 return checked
.IsValid();
36 // Does an add checking for overflow. If there was no overflow returns true.
37 inline bool SafeAddUint32(uint32_t a
, uint32_t b
, uint32_t* dst
) {
39 base::CheckedNumeric
<uint32_t> checked
= a
;
41 *dst
= checked
.ValueOrDefault(0);
42 return checked
.IsValid();
45 // Does an add checking for overflow. If there was no overflow returns true.
46 inline bool SafeAddInt32(int32_t a
, int32_t b
, int32_t* dst
) {
48 base::CheckedNumeric
<int32_t> checked
= a
;
50 *dst
= checked
.ValueOrDefault(0);
51 return checked
.IsValid();
54 // Utilties for GLES2 support.
55 class GLES2_UTILS_EXPORT GLES2Util
{
57 static const int kNumFaces
= 6;
59 // Bits returned by GetChannelsForFormat
68 kRGB
= kRed
| kGreen
| kBlue
,
78 : num_compressed_texture_formats_(0),
79 num_shader_binary_formats_(0) {
82 int num_compressed_texture_formats() const {
83 return num_compressed_texture_formats_
;
86 void set_num_compressed_texture_formats(int num_compressed_texture_formats
) {
87 num_compressed_texture_formats_
= num_compressed_texture_formats
;
90 int num_shader_binary_formats() const {
91 return num_shader_binary_formats_
;
94 void set_num_shader_binary_formats(int num_shader_binary_formats
) {
95 num_shader_binary_formats_
= num_shader_binary_formats
;
98 // Gets the number of values a particular id will return when a glGet
99 // function is called. If 0 is returned the id is invalid.
100 int GLGetNumValuesReturned(int id
) const;
102 // Computes the size of a single group of elements from a format and type pair
103 static uint32_t ComputeImageGroupSize(int format
, int type
);
105 // Computes the size of an image row including alignment padding
106 static bool ComputeImagePaddedRowSize(
107 int width
, int format
, int type
, int unpack_alignment
,
108 uint32_t* padded_row_size
);
110 // Computes the size of image data for TexImage2D and TexSubImage2D.
111 // Optionally the unpadded and padded row sizes can be returned. If height < 2
112 // then the padded_row_size will be the same as the unpadded_row_size since
113 // padding is not necessary.
114 static bool ComputeImageDataSizes(
115 int width
, int height
, int depth
, int format
, int type
,
116 int unpack_alignment
, uint32_t* size
, uint32_t* unpadded_row_size
,
117 uint32_t* padded_row_size
);
119 static size_t RenderbufferBytesPerPixel(int format
);
121 static uint32_t GetGLDataTypeSizeForUniforms(int type
);
123 static size_t GetGLTypeSizeForTexturesAndBuffers(uint32_t type
);
125 static uint32_t GLErrorToErrorBit(uint32_t gl_error
);
127 static uint32_t GLErrorBitToGLError(uint32_t error_bit
);
129 static uint32_t IndexToGLFaceTarget(int index
);
131 static size_t GLTargetToFaceIndex(uint32_t target
);
133 static uint32_t GetPreferredGLReadPixelsFormat(uint32_t internal_format
);
135 static uint32_t GetPreferredGLReadPixelsType(
136 uint32_t internal_format
, uint32_t texture_type
);
138 // Returns a bitmask for the channels the given format supports.
140 static uint32_t GetChannelsForFormat(int format
);
142 // Returns a bitmask for the channels the given attachment type needs.
143 static uint32_t GetChannelsNeededForAttachmentType(
144 int type
, uint32_t max_color_attachments
);
146 // Return true if value is neither a power of two nor zero.
147 static bool IsNPOT(uint32_t value
) {
148 return (value
& (value
- 1)) != 0;
151 // Return true if value is a power of two or zero.
152 static bool IsPOT(uint32_t value
) {
153 return (value
& (value
- 1)) == 0;
156 static std::string
GetStringEnum(uint32_t value
);
157 static std::string
GetStringBool(uint32_t value
);
158 static std::string
GetStringError(uint32_t value
);
160 // Parses a uniform name.
161 // array_pos: the position of the last '[' character in name.
162 // element_index: the index of the array element specifed in the name.
163 // getting_array: True if name refers to array.
164 // returns true of parsing was successful. Returing true does NOT mean
165 // it's a valid uniform name. On the otherhand, returning false does mean
166 // it's an invalid uniform name.
167 static bool ParseUniformName(
168 const std::string
& name
,
171 bool* getting_array
);
173 static size_t CalcClearBufferivDataCount(int buffer
);
174 static size_t CalcClearBufferfvDataCount(int buffer
);
176 static void MapUint64ToTwoUint32(
177 uint64_t v64
, uint32_t* v32_0
, uint32_t* v32_1
);
178 static uint64_t MapTwoUint32ToUint64(uint32_t v32_0
, uint32_t v32_1
);
180 static uint32_t MapBufferTargetToBindingEnum(uint32_t target
);
182 #include "../common/gles2_cmd_utils_autogen.h"
185 static std::string
GetQualifiedEnumString(
186 const EnumToString
* table
, size_t count
, uint32_t value
);
188 static const EnumToString
* const enum_to_string_table_
;
189 static const size_t enum_to_string_table_len_
;
191 int num_compressed_texture_formats_
;
192 int num_shader_binary_formats_
;
195 struct GLES2_UTILS_EXPORT ContextCreationAttribHelper
{
196 ContextCreationAttribHelper();
198 void Serialize(std::vector
<int32_t>* attribs
) const;
199 bool Parse(const std::vector
<int32_t>& attribs
);
201 // -1 if invalid or unspecified.
207 int32_t stencil_size
;
209 int32_t sample_buffers
;
210 bool buffer_preserved
;
211 bool bind_generates_resource
;
212 bool fail_if_major_perf_caveat
;
213 bool lose_context_when_out_of_memory
;
214 bool es3_context_required
;
220 #endif // GPU_COMMAND_BUFFER_COMMON_GLES2_CMD_UTILS_H_