Mercurial > projects > ldc
diff gen/runtime.cpp @ 445:cc40db549aea
Changed the handling of variadic intrinsics a bit.
Removed the -fp80 option and made real be 80bit floats on X86, this is what the D spec really says it should be and fixes a bunch of issues.
Changed the handling of parameter attributes to a bit more generalized approach.
Added sext/zext attributes for byte/short/ubyte/ushort parameters, fixes #60 .
Parameter attribs now properly set for intrinsic calls if necessary.
Made the tango.math.Math patch less intrusive.
Fixed/added some mini tests.
author | Tomas Lindquist Olsen <tomas.l.olsen@gmail.com> |
---|---|
date | Fri, 01 Aug 2008 17:59:58 +0200 |
parents | 351c0077d0b3 |
children | d30c40f1128d |
line wrap: on
line diff
--- a/gen/runtime.cpp Fri Aug 01 01:12:33 2008 +0200 +++ b/gen/runtime.cpp Fri Aug 01 17:59:58 2008 +0200 @@ -165,7 +165,11 @@ const LLType* longTy = LLType::Int64Ty; const LLType* floatTy = LLType::FloatTy; const LLType* doubleTy = LLType::DoubleTy; - const LLType* realTy = (global.params.useFP80) ? LLType::X86_FP80Ty : LLType::DoubleTy; + const LLType* realTy; + if (global.params.cpu == ARCHx86) + realTy = LLType::X86_FP80Ty; + else + realTy = LLType::DoubleTy; const LLType* sizeTy = DtoSize_t(); const LLType* voidPtrTy = rt_ptr(byteTy); const LLType* stringTy = rt_array(byteTy);