Merge pull request #232 from Qining/fix-spec-const-bool-to-int-conversion
SPV: SpecOp bool->uint/int and uint<->int conversion
This commit is contained in:
		
						commit
						e1cd410d9c
					
				| @ -1960,7 +1960,6 @@ spv::Id TGlslangToSpvTraverser::makeArraySizeId(const glslang::TArraySizes& arra | |||||||
|     glslang::TIntermTyped* specNode = arraySizes.getDimNode(dim); |     glslang::TIntermTyped* specNode = arraySizes.getDimNode(dim); | ||||||
|     if (specNode != nullptr) { |     if (specNode != nullptr) { | ||||||
|         builder.clearAccessChain(); |         builder.clearAccessChain(); | ||||||
|         // SpecConstantOpModeGuard set_to_spec_const_mode(&builder);
 |  | ||||||
|         specNode->traverse(this); |         specNode->traverse(this); | ||||||
|         return accessChainLoad(specNode->getAsTyped()->getType()); |         return accessChainLoad(specNode->getAsTyped()->getType()); | ||||||
|     } |     } | ||||||
| @ -3308,6 +3307,15 @@ spv::Id TGlslangToSpvTraverser::createConversion(glslang::TOperator op, spv::Dec | |||||||
| 
 | 
 | ||||||
|     case glslang::EOpConvUintToInt: |     case glslang::EOpConvUintToInt: | ||||||
|     case glslang::EOpConvIntToUint: |     case glslang::EOpConvIntToUint: | ||||||
|  |         if (builder.isInSpecConstCodeGenMode()) { | ||||||
|  |             // Build zero scalar or vector for OpIAdd.
 | ||||||
|  |             zero = builder.makeUintConstant(0); | ||||||
|  |             zero = makeSmearedConstant(zero, vectorSize); | ||||||
|  |             // Use OpIAdd, instead of OpBitcast to do the conversion when
 | ||||||
|  |             // generating for OpSpecConstantOp instruction.
 | ||||||
|  |             return builder.createBinOp(spv::OpIAdd, destType, operand, zero); | ||||||
|  |         } | ||||||
|  |         // For normal run-time conversion instruction, use OpBitcast.
 | ||||||
|         convOp = spv::OpBitcast; |         convOp = spv::OpBitcast; | ||||||
|         break; |         break; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1212,6 +1212,16 @@ Id Builder::createBinOp(Op opCode, Id typeId, Id left, Id right) | |||||||
| 
 | 
 | ||||||
| Id Builder::createTriOp(Op opCode, Id typeId, Id op1, Id op2, Id op3) | Id Builder::createTriOp(Op opCode, Id typeId, Id op1, Id op2, Id op3) | ||||||
| { | { | ||||||
|  |     // Generate code for spec constants if in spec constant operation
 | ||||||
|  |     // generation mode.
 | ||||||
|  |     if (generatingOpCodeForSpecConst) { | ||||||
|  |         std::vector<Id> operands(3); | ||||||
|  |         operands[0] = op1; | ||||||
|  |         operands[1] = op2; | ||||||
|  |         operands[2] = op3; | ||||||
|  |         return createSpecConstantOp( | ||||||
|  |             opCode, typeId, operands, std::vector<Id>()); | ||||||
|  |     } | ||||||
|     Instruction* op = new Instruction(getUniqueId(), typeId, opCode); |     Instruction* op = new Instruction(getUniqueId(), typeId, opCode); | ||||||
|     op->addIdOperand(op1); |     op->addIdOperand(op1); | ||||||
|     op->addIdOperand(op2); |     op->addIdOperand(op2); | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ Linked vertex stage: | |||||||
| 
 | 
 | ||||||
| // Module Version 10000 | // Module Version 10000 | ||||||
| // Generated by (magic number): 80001 | // Generated by (magic number): 80001 | ||||||
| // Id's are bound by 101 | // Id's are bound by 134 | ||||||
| 
 | 
 | ||||||
|                               Capability Shader |                               Capability Shader | ||||||
|                1:             ExtInstImport  "GLSL.std.450" |                1:             ExtInstImport  "GLSL.std.450" | ||||||
| @ -16,109 +16,152 @@ Linked vertex stage: | |||||||
|                               Source GLSL 450 |                               Source GLSL 450 | ||||||
|                               Name 4  "main" |                               Name 4  "main" | ||||||
|                               Name 8  "non_const_array_size_from_spec_const(" |                               Name 8  "non_const_array_size_from_spec_const(" | ||||||
|                               Name 15  "array" |                               Name 11  "i" | ||||||
|                               Decorate 10 SpecId 201 |                               Name 27  "array" | ||||||
|                               Decorate 24 SpecId 200 |                               Decorate 19 SpecId 201 | ||||||
|                               Decorate 26 SpecId 202 |                               Decorate 40 SpecId 200 | ||||||
|                               Decorate 27 SpecId 203 |                               Decorate 42 SpecId 202 | ||||||
|  |                               Decorate 43 SpecId 203 | ||||||
|                2:             TypeVoid |                2:             TypeVoid | ||||||
|                3:             TypeFunction 2 |                3:             TypeFunction 2 | ||||||
|                6:             TypeInt 32 1 |                6:             TypeInt 32 1 | ||||||
|                7:             TypeFunction 6(int) |                7:             TypeFunction 6(int) | ||||||
|               10:      6(int) SpecConstant 10 |               10:             TypePointer Function 6(int) | ||||||
|               11:      6(int) Constant 2 |               12:      6(int) Constant 0 | ||||||
|               12:      6(int) SpecConstantOp 128 10 11 |               19:      6(int) SpecConstant 10 | ||||||
|               13:             TypeArray 6(int) 12 |               20:      6(int) Constant 2 | ||||||
|               14:             TypePointer Function 13 |               21:      6(int) SpecConstantOp 128 19 20 | ||||||
|               16:      6(int) Constant 1 |               22:             TypeBool | ||||||
|               17:      6(int) SpecConstantOp 128 10 16 |               24:      6(int) SpecConstantOp 128 19 20 | ||||||
|               18:             TypePointer Function 6(int) |               25:             TypeArray 6(int) 24 | ||||||
|               23:             TypeFloat 32 |               26:             TypePointer Function 25 | ||||||
|               24:   23(float) SpecConstant 1078530010 |               29:      6(int) Constant 1023 | ||||||
|               25:             TypeInt 32 0 |               32:      6(int) Constant 1 | ||||||
|               26:     25(int) SpecConstant 100 |               34:      6(int) SpecConstantOp 128 19 32 | ||||||
|               27:      6(int) SpecConstant 4294967286 |               39:             TypeFloat 32 | ||||||
|               28:      6(int) SpecConstantOp 126 10 |               40:   39(float) SpecConstant 1078530010 | ||||||
|               29:      6(int) SpecConstantOp 200 10 |               41:             TypeInt 32 0 | ||||||
|               30:      6(int) SpecConstantOp 128 10 11 |               42:     41(int) SpecConstant 100 | ||||||
|               31:      6(int) SpecConstantOp 128 10 11 |               43:      6(int) SpecConstant 4294967286 | ||||||
|               32:      6(int) Constant 3 |               44:     41(int) Constant 0 | ||||||
|               33:      6(int) SpecConstantOp 130 31 32 |               45:    22(bool) SpecConstantOp 171 19 44 | ||||||
|               34:      6(int) Constant 4 |               46:    22(bool) SpecConstantOp 171 42 44 | ||||||
|               35:      6(int) SpecConstantOp 130 30 34 |               47:      6(int) SpecConstantOp 169 45 32 12 | ||||||
|               36:      6(int) SpecConstantOp 132 27 11 |               48:     41(int) Constant 1 | ||||||
|               37:     25(int) Constant 2 |               49:     41(int) SpecConstantOp 169 45 48 44 | ||||||
|               38:     25(int) SpecConstantOp 132 26 37 |               50:     41(int) SpecConstantOp 128 43 44 | ||||||
|               39:      6(int) Constant 5 |               51:      6(int) SpecConstantOp 128 42 44 | ||||||
|               40:      6(int) SpecConstantOp 135 36 39 |               52:      6(int) SpecConstantOp 126 19 | ||||||
|               41:     25(int) Constant 5 |               53:      6(int) SpecConstantOp 200 19 | ||||||
|               42:     25(int) SpecConstantOp 134 38 41 |               54:      6(int) SpecConstantOp 128 19 20 | ||||||
|               43:      6(int) SpecConstantOp 139 27 34 |               55:      6(int) SpecConstantOp 128 19 20 | ||||||
|               44:     25(int) Constant 4 |               56:      6(int) Constant 3 | ||||||
|               45:     25(int) SpecConstantOp 137 26 44 |               57:      6(int) SpecConstantOp 130 55 56 | ||||||
|               46:      6(int) SpecConstantOp 132 27 32 |               58:      6(int) Constant 4 | ||||||
|               47:      6(int) SpecConstantOp 135 46 39 |               59:      6(int) SpecConstantOp 130 54 58 | ||||||
|               48:      6(int) Constant 10 |               60:      6(int) SpecConstantOp 132 43 20 | ||||||
|               49:      6(int) SpecConstantOp 195 27 48 |               61:     41(int) Constant 2 | ||||||
|               50:      6(int) Constant 20 |               62:     41(int) SpecConstantOp 132 42 61 | ||||||
|               51:     25(int) SpecConstantOp 194 26 50 |               63:      6(int) Constant 5 | ||||||
|               52:      6(int) SpecConstantOp 196 27 16 |               64:      6(int) SpecConstantOp 135 60 63 | ||||||
|               53:     25(int) SpecConstantOp 196 26 11 |               65:     41(int) Constant 5 | ||||||
|               54:      6(int) Constant 256 |               66:     41(int) SpecConstantOp 134 62 65 | ||||||
|               55:      6(int) SpecConstantOp 197 27 54 |               67:      6(int) SpecConstantOp 139 43 58 | ||||||
|               56:     25(int) Constant 512 |               68:     41(int) Constant 4 | ||||||
|               57:     25(int) SpecConstantOp 198 26 56 |               69:     41(int) SpecConstantOp 137 42 68 | ||||||
|               58:             TypeBool |               70:      6(int) SpecConstantOp 132 43 56 | ||||||
|               59:    58(bool) SpecConstantOp 177 10 27 |               71:      6(int) SpecConstantOp 135 70 63 | ||||||
|               60:    58(bool) SpecConstantOp 170 26 26 |               72:      6(int) Constant 10 | ||||||
|               61:    58(bool) SpecConstantOp 173 10 27 |               73:      6(int) SpecConstantOp 195 43 72 | ||||||
|               62:             TypeVector 6(int) 4 |               74:      6(int) Constant 20 | ||||||
|               63:      6(int) Constant 30 |               75:     41(int) SpecConstantOp 194 42 74 | ||||||
|               64:   62(ivec4) SpecConstantComposite 50 63 10 10 |               76:      6(int) SpecConstantOp 196 43 32 | ||||||
|               65:             TypeVector 25(int) 4 |               77:     41(int) SpecConstantOp 196 42 20 | ||||||
|               66:     25(int) Constant 4294967295 |               78:      6(int) Constant 256 | ||||||
|               67:     25(int) Constant 4294967294 |               79:      6(int) SpecConstantOp 197 43 78 | ||||||
|               68:   65(ivec4) SpecConstantComposite 26 26 66 67 |               80:     41(int) Constant 512 | ||||||
|               69:             TypeVector 23(float) 4 |               81:     41(int) SpecConstantOp 198 42 80 | ||||||
|               70:   23(float) Constant 1067450368 |               82:    22(bool) SpecConstantOp 177 19 43 | ||||||
|               71:   69(fvec4) SpecConstantComposite 24 70 24 70 |               83:    22(bool) SpecConstantOp 170 42 42 | ||||||
|               72:   62(ivec4) SpecConstantOp 200 64 |               84:    22(bool) SpecConstantOp 173 19 43 | ||||||
|               73:   62(ivec4) SpecConstantOp 126 64 |               85:             TypeVector 6(int) 4 | ||||||
|               74:   62(ivec4) ConstantComposite 11 11 11 11 |               86:      6(int) Constant 30 | ||||||
|               75:   62(ivec4) SpecConstantOp 128 64 74 |               87:   85(ivec4) SpecConstantComposite 74 86 19 19 | ||||||
|               76:   62(ivec4) SpecConstantOp 128 64 74 |               88:             TypeVector 41(int) 4 | ||||||
|               77:   62(ivec4) ConstantComposite 32 32 32 32 |               89:     41(int) Constant 4294967295 | ||||||
|               78:   62(ivec4) SpecConstantOp 130 76 77 |               90:     41(int) Constant 4294967294 | ||||||
|               79:   62(ivec4) ConstantComposite 34 34 34 34 |               91:   88(ivec4) SpecConstantComposite 42 42 89 90 | ||||||
|               80:   62(ivec4) SpecConstantOp 130 78 79 |               92:             TypeVector 39(float) 4 | ||||||
|               81:   62(ivec4) SpecConstantOp 132 64 74 |               93:   39(float) Constant 1067450368 | ||||||
|               82:   62(ivec4) ConstantComposite 39 39 39 39 |               94:   92(fvec4) SpecConstantComposite 40 93 40 93 | ||||||
|               83:   62(ivec4) SpecConstantOp 135 81 82 |               95:             TypeVector 22(bool) 4 | ||||||
|               84:   62(ivec4) SpecConstantOp 139 64 79 |               96:   88(ivec4) ConstantComposite 44 44 44 44 | ||||||
|               85:   62(ivec4) ConstantComposite 48 48 48 48 |               97:   95(bvec4) SpecConstantOp 171 87 96 | ||||||
|               86:   62(ivec4) SpecConstantOp 195 64 85 |               98:   95(bvec4) SpecConstantOp 171 91 96 | ||||||
|               87:   62(ivec4) SpecConstantOp 196 64 74 |               99:   85(ivec4) ConstantComposite 12 12 12 12 | ||||||
|               88:      6(int) Constant 1024 |              100:   85(ivec4) ConstantComposite 32 32 32 32 | ||||||
|               89:   62(ivec4) ConstantComposite 88 88 88 88 |              101:   85(ivec4) SpecConstantOp 169 97 100 99 | ||||||
|               90:   62(ivec4) SpecConstantOp 197 64 89 |              102:   88(ivec4) ConstantComposite 48 48 48 48 | ||||||
|               91:     25(int) Constant 2048 |              103:   88(ivec4) SpecConstantOp 169 97 102 96 | ||||||
|               92:   65(ivec4) ConstantComposite 91 91 91 91 |              104:   88(ivec4) SpecConstantOp 128 87 96 | ||||||
|               93:   65(ivec4) SpecConstantOp 198 68 92 |              105:   85(ivec4) SpecConstantOp 128 91 96 | ||||||
|               94:     25(int) Constant 0 |              106:   85(ivec4) SpecConstantOp 200 87 | ||||||
|               95:      6(int) SpecConstantOp 81 64 0 |              107:   85(ivec4) SpecConstantOp 126 87 | ||||||
|               96:             TypeVector 6(int) 2 |              108:   85(ivec4) ConstantComposite 20 20 20 20 | ||||||
|               97:   96(ivec2) SpecConstantOp 79 64 64 1(GLSL.std.450) 0 |              109:   85(ivec4) SpecConstantOp 128 87 108 | ||||||
|               98:             TypeVector 6(int) 3 |              110:   85(ivec4) SpecConstantOp 128 87 108 | ||||||
|               99:   98(ivec3) SpecConstantOp 79 64 64 2 1(GLSL.std.450) 0 |              111:   85(ivec4) ConstantComposite 56 56 56 56 | ||||||
|              100:   62(ivec4) SpecConstantOp 79 64 64 1(GLSL.std.450) 2 0 3 |              112:   85(ivec4) SpecConstantOp 130 110 111 | ||||||
|  |              113:   85(ivec4) ConstantComposite 58 58 58 58 | ||||||
|  |              114:   85(ivec4) SpecConstantOp 130 112 113 | ||||||
|  |              115:   85(ivec4) SpecConstantOp 132 87 108 | ||||||
|  |              116:   85(ivec4) ConstantComposite 63 63 63 63 | ||||||
|  |              117:   85(ivec4) SpecConstantOp 135 115 116 | ||||||
|  |              118:   85(ivec4) SpecConstantOp 139 87 113 | ||||||
|  |              119:   85(ivec4) ConstantComposite 72 72 72 72 | ||||||
|  |              120:   85(ivec4) SpecConstantOp 195 87 119 | ||||||
|  |              121:   85(ivec4) SpecConstantOp 196 87 108 | ||||||
|  |              122:      6(int) Constant 1024 | ||||||
|  |              123:   85(ivec4) ConstantComposite 122 122 122 122 | ||||||
|  |              124:   85(ivec4) SpecConstantOp 197 87 123 | ||||||
|  |              125:     41(int) Constant 2048 | ||||||
|  |              126:   88(ivec4) ConstantComposite 125 125 125 125 | ||||||
|  |              127:   88(ivec4) SpecConstantOp 198 91 126 | ||||||
|  |              128:      6(int) SpecConstantOp 81 87 0 | ||||||
|  |              129:             TypeVector 6(int) 2 | ||||||
|  |              130:  129(ivec2) SpecConstantOp 79 87 87 1(GLSL.std.450) 0 | ||||||
|  |              131:             TypeVector 6(int) 3 | ||||||
|  |              132:  131(ivec3) SpecConstantOp 79 87 87 2 1(GLSL.std.450) 0 | ||||||
|  |              133:   85(ivec4) SpecConstantOp 79 87 87 1(GLSL.std.450) 2 0 3 | ||||||
|          4(main):           2 Function None 3 |          4(main):           2 Function None 3 | ||||||
|                5:             Label |                5:             Label | ||||||
|                               Return |                               Return | ||||||
|                               FunctionEnd |                               FunctionEnd | ||||||
| 8(non_const_array_size_from_spec_const():      6(int) Function None 7 | 8(non_const_array_size_from_spec_const():      6(int) Function None 7 | ||||||
|                9:             Label |                9:             Label | ||||||
|        15(array):     14(ptr) Variable Function |            11(i):     10(ptr) Variable Function | ||||||
|               19:     18(ptr) AccessChain 15(array) 17 |        27(array):     26(ptr) Variable Function | ||||||
|               20:      6(int) Load 19 |                               Store 11(i) 12 | ||||||
|                               ReturnValue 20 |                               Branch 13 | ||||||
|  |               13:             Label | ||||||
|  |                               LoopMerge 15 16 None | ||||||
|  |                               Branch 17 | ||||||
|  |               17:             Label | ||||||
|  |               18:      6(int) Load 11(i) | ||||||
|  |               23:    22(bool) SLessThan 18 21 | ||||||
|  |                               BranchConditional 23 14 15 | ||||||
|  |               14:               Label | ||||||
|  |               28:      6(int)   Load 11(i) | ||||||
|  |               30:     10(ptr)   AccessChain 27(array) 28 | ||||||
|  |                                 Store 30 29 | ||||||
|  |                                 Branch 16 | ||||||
|  |               16:               Label | ||||||
|  |               31:      6(int)   Load 11(i) | ||||||
|  |               33:      6(int)   IAdd 31 32 | ||||||
|  |                                 Store 11(i) 33 | ||||||
|  |                                 Branch 13 | ||||||
|  |               15:             Label | ||||||
|  |               35:     10(ptr) AccessChain 27(array) 34 | ||||||
|  |               36:      6(int) Load 35 | ||||||
|  |                               ReturnValue 36 | ||||||
|                               FunctionEnd |                               FunctionEnd | ||||||
|  | |||||||
| @ -10,9 +10,15 @@ layout(constant_id = 203) const int sp_sint = -10; | |||||||
| // Scalars | // Scalars | ||||||
| // | // | ||||||
| 
 | 
 | ||||||
| // Size convert | // uint/int <-> bool conversion | ||||||
| //const double float_to_double = double(sp_float); | const bool bool_from_int = bool(sp_int); | ||||||
| //const float double_to_float = float(float_to_double); | const bool bool_from_uint = bool(sp_uint); | ||||||
|  | const int int_from_bool = int(bool_from_int); | ||||||
|  | const uint uint_from_bool = uint(bool_from_int); | ||||||
|  | 
 | ||||||
|  | // uint <-> int | ||||||
|  | const uint sp_uint_from_sint = uint(sp_sint); | ||||||
|  | const int sp_sint_from_uint = int(sp_uint); | ||||||
| 
 | 
 | ||||||
| // Negate and Not | // Negate and Not | ||||||
| const int negate_int = -sp_int; | const int negate_int = -sp_int; | ||||||
| @ -54,9 +60,15 @@ const ivec4 iv = ivec4(20, 30, sp_int, sp_int); | |||||||
| const uvec4 uv = uvec4(sp_uint, sp_uint, -1, -2); | const uvec4 uv = uvec4(sp_uint, sp_uint, -1, -2); | ||||||
| const vec4 fv = vec4(sp_float, 1.25, sp_float, 1.25); | const vec4 fv = vec4(sp_float, 1.25, sp_float, 1.25); | ||||||
| 
 | 
 | ||||||
| // Size convert | // uint/int <-> bool conversion | ||||||
| //const dvec4 fv_to_dv = dvec4(fv); | const bvec4 bv_from_iv = bvec4(iv); | ||||||
| //const vec4 dv_to_fv = vec4(fv_to_dv); | const bvec4 bv_from_uv = bvec4(uv); | ||||||
|  | const ivec4 iv_from_bv = ivec4(bv_from_iv); | ||||||
|  | const uvec4 uv_from_bv = uvec4(bv_from_iv); | ||||||
|  | 
 | ||||||
|  | // uint <-> int | ||||||
|  | const uvec4 uv_from_iv = uvec4(iv); | ||||||
|  | const ivec4 iv_from_uv = ivec4(uv); | ||||||
| 
 | 
 | ||||||
| // Negate and Not | // Negate and Not | ||||||
| const ivec4 not_iv = ~iv; | const ivec4 not_iv = ~iv; | ||||||
| @ -88,6 +100,9 @@ const ivec4 iv_yzxw = iv.yzxw; | |||||||
| 
 | 
 | ||||||
| int non_const_array_size_from_spec_const() { | int non_const_array_size_from_spec_const() { | ||||||
|     int array[sp_int + 2]; |     int array[sp_int + 2]; | ||||||
|  |     for (int i = 0; i < sp_int + 2; i++) { | ||||||
|  |         array[i] = 1023; | ||||||
|  |     } | ||||||
|     return array[sp_int + 1]; |     return array[sp_int + 1]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 John Kessenich
						John Kessenich