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

Side by Side Diff: command_buffer/service/cross/gl/effect_gl.cc

Issue 234002: More work in Command Buffers... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/o3d/
Patch Set: Created 11 years, 2 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 | Annotate | Revision Log
« no previous file with comments | « command_buffer/service/cross/gl/effect_gl.h ('k') | command_buffer/service/cross/gl/gapi_gl.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2009, Google Inc. 2 * Copyright 2009, Google Inc.
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are 6 * modification, are permitted provided that the following conditions are
7 * met: 7 * met:
8 * 8 *
9 * * Redistributions of source code must retain the above copyright 9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer. 10 * notice, this list of conditions and the following disclaimer.
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
55 55
56 EffectParamGL::~EffectParamGL() { 56 EffectParamGL::~EffectParamGL() {
57 if (effect_) 57 if (effect_)
58 effect_->UnlinkParam(this); 58 effect_->UnlinkParam(this);
59 } 59 }
60 60
61 static effect_param::DataType CgTypeToCBType(CGtype cg_type) { 61 static effect_param::DataType CgTypeToCBType(CGtype cg_type) {
62 switch (cg_type) { 62 switch (cg_type) {
63 case CG_FLOAT: 63 case CG_FLOAT:
64 case CG_FLOAT1: 64 case CG_FLOAT1:
65 return effect_param::FLOAT1; 65 return effect_param::kFloat1;
66 case CG_FLOAT2: 66 case CG_FLOAT2:
67 return effect_param::FLOAT2; 67 return effect_param::kFloat2;
68 case CG_FLOAT3: 68 case CG_FLOAT3:
69 return effect_param::FLOAT3; 69 return effect_param::kFloat3;
70 case CG_FLOAT4: 70 case CG_FLOAT4:
71 return effect_param::FLOAT4; 71 return effect_param::kFloat4;
72 case CG_INT: 72 case CG_INT:
73 case CG_INT1: 73 case CG_INT1:
74 return effect_param::INT; 74 return effect_param::kInt;
75 case CG_BOOL: 75 case CG_BOOL:
76 case CG_BOOL1: 76 case CG_BOOL1:
77 return effect_param::BOOL; 77 return effect_param::kBool;
78 case CG_FLOAT4x4: 78 case CG_FLOAT4x4:
79 return effect_param::MATRIX4; 79 return effect_param::kMatrix4;
80 case CG_SAMPLER: 80 case CG_SAMPLER:
81 case CG_SAMPLER1D: 81 case CG_SAMPLER1D:
82 case CG_SAMPLER2D: 82 case CG_SAMPLER2D:
83 case CG_SAMPLER3D: 83 case CG_SAMPLER3D:
84 case CG_SAMPLERCUBE: 84 case CG_SAMPLERCUBE:
85 return effect_param::SAMPLER; 85 return effect_param::kSampler;
86 case CG_TEXTURE: 86 case CG_TEXTURE:
87 return effect_param::TEXTURE; 87 return effect_param::kTexture;
88 default : { 88 default : {
89 DLOG(INFO) << "Cannot convert CGtype " 89 DLOG(INFO) << "Cannot convert CGtype "
90 << cgGetTypeString(cg_type) 90 << cgGetTypeString(cg_type)
91 << " to a Param type."; 91 << " to a Param type.";
92 return effect_param::UNKNOWN; 92 return effect_param::kUnknown;
93 } 93 }
94 } 94 }
95 } 95 }
96 96
97 EffectParamGL *EffectParamGL::Create(EffectGL *effect, 97 EffectParamGL *EffectParamGL::Create(EffectGL *effect,
98 unsigned int index) { 98 unsigned int index) {
99 DCHECK(effect); 99 DCHECK(effect);
100 const EffectGL::LowLevelParam &low_level_param = 100 const EffectGL::LowLevelParam &low_level_param =
101 effect->low_level_params_[index]; 101 effect->low_level_params_[index];
102 CGparameter cg_param = EffectGL::GetEitherCgParameter(low_level_param); 102 CGparameter cg_param = EffectGL::GetEitherCgParameter(low_level_param);
103 CGtype cg_type = cgGetParameterType(cg_param); 103 CGtype cg_type = cgGetParameterType(cg_param);
104 if (cg_type == CG_ARRAY) { 104 if (cg_type == CG_ARRAY) {
105 cg_type = cgGetParameterType(cgGetArrayParameter(cg_param, 0)); 105 cg_type = cgGetParameterType(cgGetArrayParameter(cg_param, 0));
106 } 106 }
107 effect_param::DataType type = CgTypeToCBType(cg_type); 107 effect_param::DataType type = CgTypeToCBType(cg_type);
108 108
109 if (type == effect_param::UNKNOWN) 109 if (type == effect_param::kUnknown)
110 return NULL; 110 return NULL;
111 return new EffectParamGL(type, effect, index); 111 return new EffectParamGL(type, effect, index);
112 } 112 }
113 113
114 // Fills the Desc structure, appending name and semantic if any, and if enough 114 // Fills the Desc structure, appending name and semantic if any, and if enough
115 // room is available in the buffer. 115 // room is available in the buffer.
116 bool EffectParamGL::GetDesc(unsigned int size, void *data) { 116 bool EffectParamGL::GetDesc(unsigned int size, void *data) {
117 using effect_param::Desc; 117 using effect_param::Desc;
118 if (size < sizeof(Desc)) // NOLINT 118 if (size < sizeof(Desc)) // NOLINT
119 return false; 119 return false;
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
170 return false; 170 return false;
171 } 171 }
172 172
173 CGparameter vp_param = low_level_param.vp_param; 173 CGparameter vp_param = low_level_param.vp_param;
174 CGparameter fp_param = low_level_param.fp_param; 174 CGparameter fp_param = low_level_param.fp_param;
175 effect_param::DataType type = data_type(); 175 effect_param::DataType type = data_type();
176 if (size < effect_param::GetDataSize(type)) 176 if (size < effect_param::GetDataSize(type))
177 return false; 177 return false;
178 178
179 switch (type) { 179 switch (type) {
180 case effect_param::FLOAT1: 180 case effect_param::kFloat1:
181 if (vp_param) 181 if (vp_param)
182 cgSetParameter1f(vp_param, *static_cast<const float *>(data)); 182 cgSetParameter1f(vp_param, *static_cast<const float *>(data));
183 if (fp_param) 183 if (fp_param)
184 cgSetParameter1f(fp_param, *static_cast<const float *>(data)); 184 cgSetParameter1f(fp_param, *static_cast<const float *>(data));
185 break; 185 break;
186 case effect_param::FLOAT2: 186 case effect_param::kFloat2:
187 if (vp_param) 187 if (vp_param)
188 cgSetParameter2fv(vp_param, static_cast<const float *>(data)); 188 cgSetParameter2fv(vp_param, static_cast<const float *>(data));
189 if (fp_param) 189 if (fp_param)
190 cgSetParameter2fv(fp_param, static_cast<const float *>(data)); 190 cgSetParameter2fv(fp_param, static_cast<const float *>(data));
191 break; 191 break;
192 case effect_param::FLOAT3: 192 case effect_param::kFloat3:
193 if (vp_param) 193 if (vp_param)
194 cgSetParameter3fv(vp_param, static_cast<const float *>(data)); 194 cgSetParameter3fv(vp_param, static_cast<const float *>(data));
195 if (fp_param) 195 if (fp_param)
196 cgSetParameter3fv(fp_param, static_cast<const float *>(data)); 196 cgSetParameter3fv(fp_param, static_cast<const float *>(data));
197 break; 197 break;
198 case effect_param::FLOAT4: 198 case effect_param::kFloat4:
199 if (vp_param) 199 if (vp_param)
200 cgSetParameter4fv(vp_param, static_cast<const float *>(data)); 200 cgSetParameter4fv(vp_param, static_cast<const float *>(data));
201 if (fp_param) 201 if (fp_param)
202 cgSetParameter4fv(fp_param, static_cast<const float *>(data)); 202 cgSetParameter4fv(fp_param, static_cast<const float *>(data));
203 break; 203 break;
204 case effect_param::MATRIX4: 204 case effect_param::kMatrix4:
205 if (vp_param) 205 if (vp_param)
206 cgSetMatrixParameterfr(vp_param, static_cast<const float *>(data)); 206 cgSetMatrixParameterfr(vp_param, static_cast<const float *>(data));
207 if (fp_param) 207 if (fp_param)
208 cgSetMatrixParameterfr(fp_param, static_cast<const float *>(data)); 208 cgSetMatrixParameterfr(fp_param, static_cast<const float *>(data));
209 break; 209 break;
210 case effect_param::INT: 210 case effect_param::kInt:
211 if (vp_param) cgSetParameter1i(vp_param, *static_cast<const int *>(data)); 211 if (vp_param) cgSetParameter1i(vp_param, *static_cast<const int *>(data));
212 if (fp_param) cgSetParameter1i(fp_param, *static_cast<const int *>(data)); 212 if (fp_param) cgSetParameter1i(fp_param, *static_cast<const int *>(data));
213 break; 213 break;
214 case effect_param::BOOL: { 214 case effect_param::kBool: {
215 int bool_value = *static_cast<const bool *>(data)?1:0; 215 int bool_value = *static_cast<const bool *>(data)?1:0;
216 if (vp_param) cgSetParameter1i(vp_param, bool_value); 216 if (vp_param) cgSetParameter1i(vp_param, bool_value);
217 if (fp_param) cgSetParameter1i(fp_param, bool_value); 217 if (fp_param) cgSetParameter1i(fp_param, bool_value);
218 break; 218 break;
219 } 219 }
220 case effect_param::SAMPLER: { 220 case effect_param::kSampler: {
221 DCHECK_GE(low_level_param.sampler_ids.size(), 1); 221 DCHECK_GE(low_level_param.sampler_ids.size(), 1);
222 low_level_param.sampler_ids[0] = *static_cast<const ResourceID *>(data); 222 low_level_param.sampler_ids[0] = *static_cast<const ResourceId *>(data);
223 if (effect_ == gapi->current_effect()) { 223 if (effect_ == gapi->current_effect()) {
224 gapi->DirtyEffect(); 224 gapi->DirtyEffect();
225 } 225 }
226 break; 226 break;
227 } 227 }
228 default: 228 default:
229 DLOG(ERROR) << "Invalid parameter type."; 229 DLOG(ERROR) << "Invalid parameter type.";
230 return false; 230 return false;
231 } 231 }
232 return true; 232 return true;
(...skipping 205 matching lines...) Expand 10 before | Expand all | Expand 10 after
438 continue; 438 continue;
439 const char *name = cgGetParameterName(cg_param); 439 const char *name = cgGetParameterName(cg_param);
440 if (!name) 440 if (!name)
441 continue; 441 continue;
442 442
443 CGtype cg_type = cgGetParameterType(cg_param); 443 CGtype cg_type = cgGetParameterType(cg_param);
444 444
445 int num_elements; 445 int num_elements;
446 if (cg_type == CG_ARRAY) { 446 if (cg_type == CG_ARRAY) {
447 num_elements = cgGetArraySize(cg_param, 0); 447 num_elements = cgGetArraySize(cg_param, 0);
448 // Substitute the first element's type for our type.» 448 // Substitute the first element's type for our type.
449 cg_type = cgGetParameterType(cgGetArrayParameter(cg_param, 0)); 449 cg_type = cgGetParameterType(cgGetArrayParameter(cg_param, 0));
450 } else { 450 } else {
451 num_elements = 0; 451 num_elements = 0;
452 } 452 }
453 453
454 int index = GetLowLevelParamIndexByName(name); 454 int index = GetLowLevelParamIndexByName(name);
455 if (index < 0) { 455 if (index < 0) {
456 LowLevelParam param; 456 LowLevelParam param;
457 param.name = name; 457 param.name = name;
458 param.vp_param = NULL; 458 param.vp_param = NULL;
459 param.fp_param = NULL; 459 param.fp_param = NULL;
460 param.num_elements = num_elements; 460 param.num_elements = num_elements;
461 461
462 index = low_level_params_.size(); 462 index = low_level_params_.size();
463 if (cg_type == CG_SAMPLER || 463 if (cg_type == CG_SAMPLER ||
464 cg_type == CG_SAMPLER1D || 464 cg_type == CG_SAMPLER1D ||
465 cg_type == CG_SAMPLER2D || 465 cg_type == CG_SAMPLER2D ||
466 cg_type == CG_SAMPLER3D || 466 cg_type == CG_SAMPLER3D ||
467 cg_type == CG_SAMPLERCUBE) { 467 cg_type == CG_SAMPLERCUBE) {
468 sampler_params_.push_back(index); 468 sampler_params_.push_back(index);
469 if (num_elements == 0) { 469 if (num_elements == 0) {
470 param.sampler_ids.push_back(kInvalidResource); 470 param.sampler_ids.push_back(kInvalidResource);
471 } else { 471 } else {
472 param.sampler_ids.resize(num_elements); 472 param.sampler_ids.resize(num_elements);
473 std::vector<ResourceID>::iterator iter; 473 std::vector<ResourceId>::iterator iter;
474 for (iter = param.sampler_ids.begin(); 474 for (iter = param.sampler_ids.begin();
475 iter != param.sampler_ids.end(); 475 iter != param.sampler_ids.end();
476 ++iter) { 476 ++iter) {
477 *iter = kInvalidResource; 477 *iter = kInvalidResource;
478 } 478 }
479 } 479 }
480 } 480 }
481 low_level_params_.push_back(param); 481 low_level_params_.push_back(param);
482 } 482 }
483 483
484 if (vp) { 484 if (vp) {
485 low_level_params_[index].vp_param = cg_param; 485 low_level_params_[index].vp_param = cg_param;
486 } else { 486 } else {
487 low_level_params_[index].fp_param = cg_param; 487 low_level_params_[index].fp_param = cg_param;
488 } 488 }
489 } 489 }
490 } 490 }
491 491
492 typedef std::pair<String, effect_stream::Desc> SemanticMapElement; 492 typedef std::pair<String, effect_stream::Desc> SemanticMapElement;
493 typedef std::map<String, effect_stream::Desc> SemanticMap; 493 typedef std::map<String, effect_stream::Desc> SemanticMap;
494 494
495 // The map batween the semantics on vertex program varying parameters names 495 // The map batween the semantics on vertex program varying parameters names
496 // and vertex attribute indices under the VP_30 profile. 496 // and vertex attribute indices under the VP_30 profile.
497 // TODO(gman): remove this.
497 SemanticMapElement semantic_map_array[] = { 498 SemanticMapElement semantic_map_array[] = {
498 SemanticMapElement("POSITION", 499 SemanticMapElement("POSITION",
499 effect_stream::Desc(vertex_struct::POSITION, 0)), 500 effect_stream::Desc(vertex_struct::kPosition, 0)),
500 SemanticMapElement("ATTR0", 501 SemanticMapElement("ATTR0",
501 effect_stream::Desc(vertex_struct::POSITION, 0)), 502 effect_stream::Desc(vertex_struct::kPosition, 0)),
502 SemanticMapElement("BLENDWEIGHT", 503 SemanticMapElement("BLENDWEIGHT",
503 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 504 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
504 SemanticMapElement("ATTR1", 505 SemanticMapElement("ATTR1",
505 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 506 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
506 SemanticMapElement("NORMAL", 507 SemanticMapElement("NORMAL",
507 effect_stream::Desc(vertex_struct::NORMAL, 0)), 508 effect_stream::Desc(vertex_struct::kNormal, 0)),
508 SemanticMapElement("ATTR2", 509 SemanticMapElement("ATTR2",
509 effect_stream::Desc(vertex_struct::NORMAL, 0)), 510 effect_stream::Desc(vertex_struct::kNormal, 0)),
510 SemanticMapElement("COLOR0", 511 SemanticMapElement("COLOR0",
511 effect_stream::Desc(vertex_struct::COLOR, 0)), 512 effect_stream::Desc(vertex_struct::kColor, 0)),
512 SemanticMapElement("DIFFUSE", 513 SemanticMapElement("DIFFUSE",
513 effect_stream::Desc(vertex_struct::COLOR, 0)), 514 effect_stream::Desc(vertex_struct::kColor, 0)),
514 SemanticMapElement("ATTR3", 515 SemanticMapElement("ATTR3",
515 effect_stream::Desc(vertex_struct::COLOR, 0)), 516 effect_stream::Desc(vertex_struct::kColor, 0)),
516 SemanticMapElement("COLOR1", 517 SemanticMapElement("COLOR1",
517 effect_stream::Desc(vertex_struct::COLOR, 1)), 518 effect_stream::Desc(vertex_struct::kColor, 1)),
518 SemanticMapElement("SPECULAR", 519 SemanticMapElement("SPECULAR",
519 effect_stream::Desc(vertex_struct::COLOR, 1)), 520 effect_stream::Desc(vertex_struct::kColor, 1)),
520 SemanticMapElement("ATTR4", 521 SemanticMapElement("ATTR4",
521 effect_stream::Desc(vertex_struct::COLOR, 1)), 522 effect_stream::Desc(vertex_struct::kColor, 1)),
522 SemanticMapElement("TESSFACTOR", 523 SemanticMapElement("TESSFACTOR",
523 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 524 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
524 SemanticMapElement("FOGCOORD", 525 SemanticMapElement("FOGCOORD",
525 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 526 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
526 SemanticMapElement("ATTR5", 527 SemanticMapElement("ATTR5",
527 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 528 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
528 SemanticMapElement("PSIZE", 529 SemanticMapElement("PSIZE",
529 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 530 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
530 SemanticMapElement("ATTR6", 531 SemanticMapElement("ATTR6",
531 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 532 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
532 SemanticMapElement("BLENDINDICES", 533 SemanticMapElement("BLENDINDICES",
533 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 534 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
534 SemanticMapElement("ATTR7", 535 SemanticMapElement("ATTR7",
535 effect_stream::Desc(vertex_struct::UNKNOWN_SEMANTIC, 0)), 536 effect_stream::Desc(vertex_struct::kUnknownSemantic, 0)),
536 SemanticMapElement("TEXCOORD0", 537 SemanticMapElement("TEXCOORD0",
537 effect_stream::Desc(vertex_struct::TEX_COORD, 0)), 538 effect_stream::Desc(vertex_struct::kTexCoord, 0)),
538 SemanticMapElement("ATTR8", 539 SemanticMapElement("ATTR8",
539 effect_stream::Desc(vertex_struct::TEX_COORD, 0)), 540 effect_stream::Desc(vertex_struct::kTexCoord, 0)),
540 SemanticMapElement("TEXCOORD1", 541 SemanticMapElement("TEXCOORD1",
541 effect_stream::Desc(vertex_struct::TEX_COORD, 1)), 542 effect_stream::Desc(vertex_struct::kTexCoord, 1)),
542 SemanticMapElement("ATTR9", 543 SemanticMapElement("ATTR9",
543 effect_stream::Desc(vertex_struct::TEX_COORD, 1)), 544 effect_stream::Desc(vertex_struct::kTexCoord, 1)),
544 SemanticMapElement("TEXCOORD2", 545 SemanticMapElement("TEXCOORD2",
545 effect_stream::Desc(vertex_struct::TEX_COORD, 2)), 546 effect_stream::Desc(vertex_struct::kTexCoord, 2)),
546 SemanticMapElement("ATTR10", 547 SemanticMapElement("ATTR10",
547 effect_stream::Desc(vertex_struct::TEX_COORD, 2)), 548 effect_stream::Desc(vertex_struct::kTexCoord, 2)),
548 SemanticMapElement("TEXCOORD3", 549 SemanticMapElement("TEXCOORD3",
549 effect_stream::Desc(vertex_struct::TEX_COORD, 3)), 550 effect_stream::Desc(vertex_struct::kTexCoord, 3)),
550 SemanticMapElement("ATTR11", 551 SemanticMapElement("ATTR11",
551 effect_stream::Desc(vertex_struct::TEX_COORD, 3)), 552 effect_stream::Desc(vertex_struct::kTexCoord, 3)),
552 SemanticMapElement("TEXCOORD4", 553 SemanticMapElement("TEXCOORD4",
553 effect_stream::Desc(vertex_struct::TEX_COORD, 4)), 554 effect_stream::Desc(vertex_struct::kTexCoord, 4)),
554 SemanticMapElement("ATTR12", 555 SemanticMapElement("ATTR12",
555 effect_stream::Desc(vertex_struct::TEX_COORD, 4)), 556 effect_stream::Desc(vertex_struct::kTexCoord, 4)),
556 SemanticMapElement("TEXCOORD5", 557 SemanticMapElement("TEXCOORD5",
557 effect_stream::Desc(vertex_struct::TEX_COORD, 5)), 558 effect_stream::Desc(vertex_struct::kTexCoord, 5)),
558 SemanticMapElement("ATTR13", 559 SemanticMapElement("ATTR13",
559 effect_stream::Desc(vertex_struct::TEX_COORD, 5)), 560 effect_stream::Desc(vertex_struct::kTexCoord, 5)),
560 SemanticMapElement("TEXCOORD6", 561 SemanticMapElement("TEXCOORD6",
561 effect_stream::Desc(vertex_struct::TEX_COORD, 6)), 562 effect_stream::Desc(vertex_struct::kTexCoord, 6)),
562 SemanticMapElement("TANGENT", 563 SemanticMapElement("TANGENT",
563 effect_stream::Desc(vertex_struct::TEX_COORD, 6)), 564 effect_stream::Desc(vertex_struct::kTexCoord, 6)),
564 SemanticMapElement("ATTR14", 565 SemanticMapElement("ATTR14",
565 effect_stream::Desc(vertex_struct::TEX_COORD, 7)), 566 effect_stream::Desc(vertex_struct::kTexCoord, 7)),
566 SemanticMapElement("TEXCOORD7", 567 SemanticMapElement("TEXCOORD7",
567 effect_stream::Desc(vertex_struct::TEX_COORD, 7)), 568 effect_stream::Desc(vertex_struct::kTexCoord, 7)),
568 SemanticMapElement("BINORMAL", 569 SemanticMapElement("BINORMAL",
569 effect_stream::Desc(vertex_struct::TEX_COORD, 8)), 570 effect_stream::Desc(vertex_struct::kTexCoord, 8)),
570 SemanticMapElement("ATTR15", 571 SemanticMapElement("ATTR15",
571 effect_stream::Desc(vertex_struct::TEX_COORD, 8)) 572 effect_stream::Desc(vertex_struct::kTexCoord, 8))
572 }; 573 };
573 574
574 static SemanticMap semantic_map(semantic_map_array, 575 static SemanticMap semantic_map(semantic_map_array,
575 semantic_map_array + 576 semantic_map_array +
576 arraysize(semantic_map_array)); 577 arraysize(semantic_map_array));
577 578
578 void EffectGL::Initialize() { 579 void EffectGL::Initialize() {
579 AddLowLevelParams(vertex_program_, CG_PROGRAM, true); 580 AddLowLevelParams(vertex_program_, CG_PROGRAM, true);
580 AddLowLevelParams(vertex_program_, CG_GLOBAL, true); 581 AddLowLevelParams(vertex_program_, CG_GLOBAL, true);
581 AddLowLevelParams(fragment_program_, CG_PROGRAM, false); 582 AddLowLevelParams(fragment_program_, CG_PROGRAM, false);
(...skipping 15 matching lines...) Expand all
597 CGenum direction = cgGetParameterDirection(cg_param); 598 CGenum direction = cgGetParameterDirection(cg_param);
598 if (direction != CG_IN) 599 if (direction != CG_IN)
599 continue; 600 continue;
600 const char* cg_semantic = cgGetParameterSemantic(cg_param); 601 const char* cg_semantic = cgGetParameterSemantic(cg_param);
601 if (cg_semantic == NULL) 602 if (cg_semantic == NULL)
602 continue; 603 continue;
603 604
604 SemanticMap::iterator iter = semantic_map.find(String(cg_semantic)); 605 SemanticMap::iterator iter = semantic_map.find(String(cg_semantic));
605 if (iter == semantic_map.end()) { 606 if (iter == semantic_map.end()) {
606 streams_.push_back(effect_stream::Desc( 607 streams_.push_back(effect_stream::Desc(
607 vertex_struct::UNKNOWN_SEMANTIC, 0)); 608 vertex_struct::kUnknownSemantic, 0));
608 } else { 609 } else {
609 streams_.push_back(iter->second); 610 streams_.push_back(iter->second);
610 } 611 }
611 } 612 }
612 } 613 }
613 614
614 // Begins rendering with the effect, setting all the appropriate states. 615 // Begins rendering with the effect, setting all the appropriate states.
615 bool EffectGL::Begin(GAPIGL *gapi) { 616 bool EffectGL::Begin(GAPIGL *gapi) {
616 cgGLBindProgram(vertex_program_); 617 cgGLBindProgram(vertex_program_);
617 cgGLBindProgram(fragment_program_); 618 cgGLBindProgram(fragment_program_);
618 619
619 // sampler->ApplyStates will mess with the texture binding on unit 0, so we 620 // sampler->ApplyStates will mess with the texture binding on unit 0, so we
620 // do 2 passes. 621 // do 2 passes.
621 // First to set the sampler states on the texture 622 // First to set the sampler states on the texture
622 for (unsigned int i = 0; i < sampler_params_.size(); ++i) { 623 for (unsigned int i = 0; i < sampler_params_.size(); ++i) {
623 unsigned int param_index = sampler_params_[i]; 624 unsigned int param_index = sampler_params_[i];
624 std::vector<ResourceID> &ids = low_level_params_[param_index].sampler_ids; 625 std::vector<ResourceId> &ids = low_level_params_[param_index].sampler_ids;
625 for (std::vector<ResourceID>::iterator iter = ids.begin(); 626 for (std::vector<ResourceId>::iterator iter = ids.begin();
626 iter != ids.end(); 627 iter != ids.end();
627 ++iter) { 628 ++iter) {
628 ResourceID id = *iter; 629 ResourceId id = *iter;
629 if (id != kInvalidResource) { 630 if (id != kInvalidResource) {
630 SamplerGL *sampler = gapi->GetSampler(id); 631 SamplerGL *sampler = gapi->GetSampler(id);
631 if (!sampler->ApplyStates(gapi)) { 632 if (!sampler->ApplyStates(gapi)) {
632 return false; 633 return false;
633 } 634 }
634 } 635 }
635 } 636 }
636 } 637 }
637 // Second to enable/disable the sampler params. 638 // Second to enable/disable the sampler params.
638 for (unsigned int i = 0; i < sampler_params_.size(); ++i) { 639 for (unsigned int i = 0; i < sampler_params_.size(); ++i) {
639 unsigned int param_index = sampler_params_[i]; 640 unsigned int param_index = sampler_params_[i];
640 const LowLevelParam &ll_param = low_level_params_[param_index]; 641 const LowLevelParam &ll_param = low_level_params_[param_index];
641 std::vector<ResourceID> &ids = low_level_params_[param_index].sampler_ids; 642 std::vector<ResourceId> &ids = low_level_params_[param_index].sampler_ids;
642 // TODO(petersont): Rewrite the following so it handles arrays of samplers 643 // TODO(petersont): Rewrite the following so it handles arrays of samplers
643 // instead of simply bailing. 644 // instead of simply bailing.
644 if (cgGetParameterType(ll_param.fp_param) == CG_ARRAY) 645 if (cgGetParameterType(ll_param.fp_param) == CG_ARRAY)
645 return false; 646 return false;
646 for (std::vector<ResourceID>::iterator iter = ids.begin(); 647 for (std::vector<ResourceId>::iterator iter = ids.begin();
647 iter != ids.end(); 648 iter != ids.end();
648 ++iter) { 649 ++iter) {
649 ResourceID id = *iter; 650 ResourceId id = *iter;
650 if (id != kInvalidResource) { 651 if (id != kInvalidResource) {
651 SamplerGL *sampler = gapi->GetSampler(id); 652 SamplerGL *sampler = gapi->GetSampler(id);
652 GLuint gl_texture = sampler->gl_texture(); 653 GLuint gl_texture = sampler->gl_texture();
653 cgGLSetTextureParameter(ll_param.fp_param, gl_texture); 654 cgGLSetTextureParameter(ll_param.fp_param, gl_texture);
654 cgGLEnableTextureParameter(ll_param.fp_param); 655 cgGLEnableTextureParameter(ll_param.fp_param);
655 } else { 656 } else {
656 cgGLSetTextureParameter(ll_param.fp_param, 0); 657 cgGLSetTextureParameter(ll_param.fp_param, 0);
657 cgGLDisableTextureParameter(ll_param.fp_param); 658 cgGLDisableTextureParameter(ll_param.fp_param);
658 } 659 }
659 } 660 }
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
698 } 699 }
699 700
700 // Gets a handle to the selected parameter, and wraps it into an 701 // Gets a handle to the selected parameter, and wraps it into an
701 // EffectParamGL if successful. 702 // EffectParamGL if successful.
702 EffectParamGL *EffectGL::CreateParamByName(const char *name) { 703 EffectParamGL *EffectGL::CreateParamByName(const char *name) {
703 int index = GetLowLevelParamIndexByName(name); 704 int index = GetLowLevelParamIndexByName(name);
704 if (index < 0) return NULL; 705 if (index < 0) return NULL;
705 return EffectParamGL::Create(this, index); 706 return EffectParamGL::Create(this, index);
706 } 707 }
707 708
708 BufferSyncInterface::ParseError GAPIGL::CreateEffect(ResourceID id, 709 BufferSyncInterface::ParseError GAPIGL::CreateEffect(ResourceId id,
709 unsigned int size, 710 unsigned int size,
710 const void *data) { 711 const void *data) {
711 if (id == current_effect_id_) DirtyEffect(); 712 if (id == current_effect_id_) DirtyEffect();
712 // Even though Assign would Destroy the effect at id, we do it explicitly in 713 // Even though Assign would Destroy the effect at id, we do it explicitly in
713 // case the creation fails. 714 // case the creation fails.
714 effects_.Destroy(id); 715 effects_.Destroy(id);
715 // Data is vp_main \0 fp_main \0 effect_text. 716 // Data is vp_main \0 fp_main \0 effect_text.
716 String vertex_program_entry; 717 String vertex_program_entry;
717 String fragment_program_entry; 718 String fragment_program_entry;
718 String effect_code; 719 String effect_code;
719 if (!ParseEffectData(size, data, 720 if (!ParseEffectData(size, data,
720 &vertex_program_entry, 721 &vertex_program_entry,
721 &fragment_program_entry, 722 &fragment_program_entry,
722 &effect_code)) { 723 &effect_code)) {
723 return BufferSyncInterface::kParseInvalidArguments; 724 return BufferSyncInterface::kParseInvalidArguments;
724 } 725 }
725 EffectGL * effect = EffectGL::Create(this, effect_code, 726 EffectGL * effect = EffectGL::Create(this, effect_code,
726 vertex_program_entry, 727 vertex_program_entry,
727 fragment_program_entry); 728 fragment_program_entry);
728 if (!effect) return BufferSyncInterface::kParseInvalidArguments; 729 if (!effect) return BufferSyncInterface::kParseInvalidArguments;
729 effects_.Assign(id, effect); 730 effects_.Assign(id, effect);
730 return BufferSyncInterface::kParseNoError; 731 return BufferSyncInterface::kParseNoError;
731 } 732 }
732 733
733 BufferSyncInterface::ParseError GAPIGL::DestroyEffect(ResourceID id) { 734 BufferSyncInterface::ParseError GAPIGL::DestroyEffect(ResourceId id) {
734 if (id == current_effect_id_) DirtyEffect(); 735 if (id == current_effect_id_) DirtyEffect();
735 return effects_.Destroy(id) ? 736 return effects_.Destroy(id) ?
736 BufferSyncInterface::kParseNoError : 737 BufferSyncInterface::kParseNoError :
737 BufferSyncInterface::kParseInvalidArguments; 738 BufferSyncInterface::kParseInvalidArguments;
738 } 739 }
739 740
740 BufferSyncInterface::ParseError GAPIGL::SetEffect(ResourceID id) { 741 BufferSyncInterface::ParseError GAPIGL::SetEffect(ResourceId id) {
741 DirtyEffect(); 742 DirtyEffect();
742 current_effect_id_ = id; 743 current_effect_id_ = id;
743 return BufferSyncInterface::kParseNoError; 744 return BufferSyncInterface::kParseNoError;
744 } 745 }
745 746
746 BufferSyncInterface::ParseError GAPIGL::GetParamCount(ResourceID id, 747 BufferSyncInterface::ParseError GAPIGL::GetParamCount(ResourceId id,
747 unsigned int size, 748 unsigned int size,
748 void *data) { 749 void *data) {
749 EffectGL *effect = effects_.Get(id); 750 EffectGL *effect = effects_.Get(id);
750 if (!effect || size < sizeof(Uint32)) // NOLINT 751 if (!effect || size < sizeof(Uint32)) // NOLINT
751 return BufferSyncInterface::kParseInvalidArguments; 752 return BufferSyncInterface::kParseInvalidArguments;
752 *static_cast<Uint32 *>(data) = effect->GetParamCount(); 753 *static_cast<Uint32 *>(data) = effect->GetParamCount();
753 return BufferSyncInterface::kParseNoError; 754 return BufferSyncInterface::kParseNoError;
754 } 755 }
755 756
756 BufferSyncInterface::ParseError GAPIGL::CreateParam(ResourceID param_id, 757 BufferSyncInterface::ParseError GAPIGL::CreateParam(ResourceId param_id,
757 ResourceID effect_id, 758 ResourceId effect_id,
758 unsigned int index) { 759 unsigned int index) {
759 EffectGL *effect = effects_.Get(effect_id); 760 EffectGL *effect = effects_.Get(effect_id);
760 if (!effect) return BufferSyncInterface::kParseInvalidArguments; 761 if (!effect) return BufferSyncInterface::kParseInvalidArguments;
761 EffectParamGL *param = effect->CreateParam(index); 762 EffectParamGL *param = effect->CreateParam(index);
762 if (!param) return BufferSyncInterface::kParseInvalidArguments; 763 if (!param) return BufferSyncInterface::kParseInvalidArguments;
763 effect_params_.Assign(param_id, param); 764 effect_params_.Assign(param_id, param);
764 return BufferSyncInterface::kParseNoError; 765 return BufferSyncInterface::kParseNoError;
765 } 766 }
766 767
767 BufferSyncInterface::ParseError GAPIGL::CreateParamByName(ResourceID param_id, 768 BufferSyncInterface::ParseError GAPIGL::CreateParamByName(ResourceId param_id,
768 ResourceID effect_id, 769 ResourceId effect_id,
769 unsigned int size, 770 unsigned int size,
770 const void *name) { 771 const void *name) {
771 EffectGL *effect = effects_.Get(effect_id); 772 EffectGL *effect = effects_.Get(effect_id);
772 if (!effect) return BufferSyncInterface::kParseInvalidArguments; 773 if (!effect) return BufferSyncInterface::kParseInvalidArguments;
773 std::string string_name(static_cast<const char *>(name), size); 774 std::string string_name(static_cast<const char *>(name), size);
774 EffectParamGL *param = effect->CreateParamByName(string_name.c_str()); 775 EffectParamGL *param = effect->CreateParamByName(string_name.c_str());
775 if (!param) return BufferSyncInterface::kParseInvalidArguments; 776 if (!param) return BufferSyncInterface::kParseInvalidArguments;
776 effect_params_.Assign(param_id, param); 777 effect_params_.Assign(param_id, param);
777 return BufferSyncInterface::kParseNoError; 778 return BufferSyncInterface::kParseNoError;
778 } 779 }
779 780
780 BufferSyncInterface::ParseError GAPIGL::DestroyParam(ResourceID id) { 781 BufferSyncInterface::ParseError GAPIGL::DestroyParam(ResourceId id) {
781 return effect_params_.Destroy(id) ? 782 return effect_params_.Destroy(id) ?
782 BufferSyncInterface::kParseNoError : 783 BufferSyncInterface::kParseNoError :
783 BufferSyncInterface::kParseInvalidArguments; 784 BufferSyncInterface::kParseInvalidArguments;
784 } 785 }
785 786
786 BufferSyncInterface::ParseError GAPIGL::SetParamData(ResourceID id, 787 BufferSyncInterface::ParseError GAPIGL::SetParamData(ResourceId id,
787 unsigned int size, 788 unsigned int size,
788 const void *data) { 789 const void *data) {
789 EffectParamGL *param = effect_params_.Get(id); 790 EffectParamGL *param = effect_params_.Get(id);
790 if (!param) return BufferSyncInterface::kParseInvalidArguments; 791 if (!param) return BufferSyncInterface::kParseInvalidArguments;
791 return param->SetData(this, size, data) ? 792 return param->SetData(this, size, data) ?
792 BufferSyncInterface::kParseNoError : 793 BufferSyncInterface::kParseNoError :
793 BufferSyncInterface::kParseInvalidArguments; 794 BufferSyncInterface::kParseInvalidArguments;
794 } 795 }
795 796
796 BufferSyncInterface::ParseError GAPIGL::GetParamDesc(ResourceID id, 797 BufferSyncInterface::ParseError GAPIGL::GetParamDesc(ResourceId id,
797 unsigned int size, 798 unsigned int size,
798 void *data) { 799 void *data) {
799 EffectParamGL *param = effect_params_.Get(id); 800 EffectParamGL *param = effect_params_.Get(id);
800 if (!param) return BufferSyncInterface::kParseInvalidArguments; 801 if (!param) return BufferSyncInterface::kParseInvalidArguments;
801 return param->GetDesc(size, data) ? 802 return param->GetDesc(size, data) ?
802 BufferSyncInterface::kParseNoError : 803 BufferSyncInterface::kParseNoError :
803 BufferSyncInterface::kParseInvalidArguments; 804 BufferSyncInterface::kParseInvalidArguments;
804 } 805 }
805 806
806 BufferSyncInterface::ParseError GAPIGL::GetStreamCount( 807 BufferSyncInterface::ParseError GAPIGL::GetStreamCount(
807 ResourceID id, 808 ResourceId id,
808 unsigned int size, 809 unsigned int size,
809 void *data) { 810 void *data) {
810 EffectGL *effect = effects_.Get(id); 811 EffectGL *effect = effects_.Get(id);
811 if (!effect || size < sizeof(Uint32)) // NOLINT 812 if (!effect || size < sizeof(Uint32)) // NOLINT
812 return BufferSyncInterface::kParseInvalidArguments; 813 return BufferSyncInterface::kParseInvalidArguments;
813 *static_cast<Uint32 *>(data) = effect->GetStreamCount(); 814 *static_cast<Uint32 *>(data) = effect->GetStreamCount();
814 return BufferSyncInterface::kParseNoError; 815 return BufferSyncInterface::kParseNoError;
815 } 816 }
816 817
817 BufferSyncInterface::ParseError GAPIGL::GetStreamDesc(ResourceID id, 818 BufferSyncInterface::ParseError GAPIGL::GetStreamDesc(ResourceId id,
818 unsigned int index, 819 unsigned int index,
819 unsigned int size, 820 unsigned int size,
820 void *data) { 821 void *data) {
821 EffectGL *effect = effects_.Get(id); 822 EffectGL *effect = effects_.Get(id);
822 if (!effect) return BufferSyncInterface::kParseInvalidArguments; 823 if (!effect) return BufferSyncInterface::kParseInvalidArguments;
823 return effect->GetStreamDesc(index, size, data) ? 824 return effect->GetStreamDesc(index, size, data) ?
824 BufferSyncInterface::kParseNoError : 825 BufferSyncInterface::kParseNoError :
825 BufferSyncInterface::kParseInvalidArguments; 826 BufferSyncInterface::kParseInvalidArguments;
826 } 827 }
827 828
(...skipping 12 matching lines...) Expand all
840 DCHECK(validate_effect_); 841 DCHECK(validate_effect_);
841 DCHECK(!current_effect_); 842 DCHECK(!current_effect_);
842 current_effect_ = effects_.Get(current_effect_id_); 843 current_effect_ = effects_.Get(current_effect_id_);
843 if (!current_effect_) return false; 844 if (!current_effect_) return false;
844 validate_effect_ = false; 845 validate_effect_ = false;
845 return current_effect_->Begin(this); 846 return current_effect_->Begin(this);
846 } 847 }
847 848
848 } // namespace command_buffer 849 } // namespace command_buffer
849 } // namespace o3d 850 } // namespace o3d
OLDNEW
« no previous file with comments | « command_buffer/service/cross/gl/effect_gl.h ('k') | command_buffer/service/cross/gl/gapi_gl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698