summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
Diffstat (limited to 'source')
-rw-r--r--source/slang/slang-emit-glsl.cpp43
-rw-r--r--source/slang/slang-emit-hlsl.cpp14
2 files changed, 43 insertions, 14 deletions
diff --git a/source/slang/slang-emit-glsl.cpp b/source/slang/slang-emit-glsl.cpp
index 82804c6b5..634067ab7 100644
--- a/source/slang/slang-emit-glsl.cpp
+++ b/source/slang/slang-emit-glsl.cpp
@@ -1432,7 +1432,48 @@ bool GLSLSourceEmitter::tryEmitInstExprImpl(IRInst* inst, const EmitOpInfo& inOu
emitType(inst->getDataType());
}
break;
-
+ case BaseType::UInt16:
+ if (fromType == BaseType::Half)
+ {
+ m_writer->emit("uint16_t(packHalf2x16(vec2(");
+ emitOperand(inst->getOperand(0), getInfo(EmitOp::General));
+ m_writer->emit(", 0.0)))");
+ return true;
+ }
+ else
+ {
+ emitType(inst->getDataType());
+ }
+ break;
+ case BaseType::Int16:
+ if (fromType == BaseType::Half)
+ {
+ m_writer->emit("int16_t(packHalf2x16(vec2(");
+ emitOperand(inst->getOperand(0), getInfo(EmitOp::General));
+ m_writer->emit(", 0.0)))");
+ return true;
+ }
+ else
+ {
+ emitType(inst->getDataType());
+ }
+ break;
+ case BaseType::Half:
+ switch (fromType)
+ {
+ case BaseType::Int16:
+ case BaseType::UInt16:
+ case BaseType::Int:
+ case BaseType::UInt:
+ m_writer->emit("float16_t(unpackHalf2x16(uint(");
+ emitOperand(inst->getOperand(0), getInfo(EmitOp::General));
+ m_writer->emit(")).x)");
+ return true;
+ default:
+ emitType(inst->getDataType());
+ break;
+ }
+ break;
case BaseType::Float:
switch (fromType)
{
diff --git a/source/slang/slang-emit-hlsl.cpp b/source/slang/slang-emit-hlsl.cpp
index 2fda8ab99..dc58b7507 100644
--- a/source/slang/slang-emit-hlsl.cpp
+++ b/source/slang/slang-emit-hlsl.cpp
@@ -766,23 +766,11 @@ void HLSLSourceEmitter::emitSimpleTypeImpl(IRType* type)
case kIROp_UInt64Type:
case kIROp_FloatType:
case kIROp_DoubleType:
- {
- m_writer->emit(getDefaultBuiltinTypeName(type->getOp()));
- return;
- }
case kIROp_Int16Type:
- {
- m_writer->emit("min16int");
- return;
- }
case kIROp_UInt16Type:
{
- m_writer->emit("min16uint");
- return;
- }
case kIROp_HalfType:
- {
- m_writer->emit("min16float");
+ m_writer->emit(getDefaultBuiltinTypeName(type->getOp()));
return;
}
case kIROp_StructType: