summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
Diffstat (limited to 'source')
-rw-r--r--source/slang/slang-emit-glsl.cpp60
-rw-r--r--source/slang/slang-emit-glsl.h2
-rw-r--r--source/slang/slang-ir.cpp4
3 files changed, 62 insertions, 4 deletions
diff --git a/source/slang/slang-emit-glsl.cpp b/source/slang/slang-emit-glsl.cpp
index a1142749b..5b29fb8fa 100644
--- a/source/slang/slang-emit-glsl.cpp
+++ b/source/slang/slang-emit-glsl.cpp
@@ -737,6 +737,17 @@ void GLSLSourceEmitter::emitLoopControlDecorationImpl(IRLoopControlDecoration* d
}
}
+void GLSLSourceEmitter::_emitSpecialFloatImpl(IRType* type, const char* valueExpr)
+{
+ if( type->getOp() != kIROp_FloatType )
+ {
+ emitType(type);
+ }
+ m_writer->emit("(");
+ m_writer->emit(valueExpr);
+ m_writer->emit(")");
+}
+
void GLSLSourceEmitter::emitSimpleValueImpl(IRInst* inst)
{
switch (inst->getOp())
@@ -753,14 +764,38 @@ void GLSLSourceEmitter::emitSimpleValueImpl(IRInst* inst)
default:
case BaseType::Int8:
+ {
+ emitType(type);
+ m_writer->emit("(");
+ m_writer->emit(litInst->value.intVal);
+ m_writer->emit(")");
+ return;
+ }
case BaseType::Int16:
+ {
+ m_writer->emit(litInst->value.intVal);
+ m_writer->emit("S");
+ return;
+ }
case BaseType::Int:
{
m_writer->emit(litInst->value.intVal);
return;
}
case BaseType::UInt8:
+ {
+ emitType(type);
+ m_writer->emit("(");
+ m_writer->emit(UInt(litInst->value.intVal));
+ m_writer->emit("U)");
+ return;
+ }
case BaseType::UInt16:
+ {
+ m_writer->emit(UInt(litInst->value.intVal));
+ m_writer->emit("US");
+ return;
+ }
case BaseType::UInt:
{
m_writer->emit(UInt(litInst->value.intVal));
@@ -789,26 +824,43 @@ void GLSLSourceEmitter::emitSimpleValueImpl(IRInst* inst)
{
IRConstant* constantInst = static_cast<IRConstant*>(inst);
+ auto type = constantInst->getDataType();
IRConstant::FloatKind kind = constantInst->getFloatKind();
switch (kind)
{
case IRConstant::FloatKind::Nan:
{
- m_writer->emit("(0.0 / 0.0)");
+ _emitSpecialFloatImpl(type, "0.0 / 0.0");
return;
}
case IRConstant::FloatKind::PositiveInfinity:
{
- m_writer->emit("(1.0 / 0.0)");
+ _emitSpecialFloatImpl(type, "1.0 / 0.0");
return;
}
case IRConstant::FloatKind::NegativeInfinity:
{
- m_writer->emit("(-1.0 / 0.0)");
+ _emitSpecialFloatImpl(type, "-1.0 / 0.0");
+ return;
+ }
+ default:
+ {
+ m_writer->emit(((IRConstant*) inst)->value.floatVal);
+ switch( type->getOp() )
+ {
+ case kIROp_HalfType:
+ m_writer->emit("HF");
+ break;
+ case kIROp_DoubleType:
+ m_writer->emit("LF");
+ break;
+ default:
+ break;
+ }
+
return;
}
- default: break;
}
break;
}
diff --git a/source/slang/slang-emit-glsl.h b/source/slang/slang-emit-glsl.h
index 48ed95a53..e9d45de11 100644
--- a/source/slang/slang-emit-glsl.h
+++ b/source/slang/slang-emit-glsl.h
@@ -108,6 +108,8 @@ protected:
void _requireRayTracing();
+ void _emitSpecialFloatImpl(IRType* type, const char* valueExpr);
+
RefPtr<GLSLExtensionTracker> m_glslExtensionTracker;
};
diff --git a/source/slang/slang-ir.cpp b/source/slang/slang-ir.cpp
index 945cf488f..a983188b7 100644
--- a/source/slang/slang-ir.cpp
+++ b/source/slang/slang-ir.cpp
@@ -4945,10 +4945,14 @@ namespace Slang
{
case kIROp_IntLit:
dump(context, irConst->value.intVal);
+ dump(context, " : ");
+ dumpType(context, irConst->getFullType());
return;
case kIROp_FloatLit:
dump(context, irConst->value.floatVal);
+ dump(context, " : ");
+ dumpType(context, irConst->getFullType());
return;
case kIROp_BoolLit: