Mercurial > projects > ldc
view gen/complex.h @ 978:6a32d2e18175
Fix a latent bug in the asm code.
I think that technically, using "*m0" instead of "*0" allows LLVM to pick
between using the same memory as output 0 and using a new memory location.
(So far I haven't been able to construct a testcase that actually breaks
because of this, though)
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Wed, 18 Feb 2009 03:38:12 +0100 |
parents | eef8ac26c66c |
children |
line wrap: on
line source
#ifndef LDC_GEN_COMPLEX_H #define LDC_GEN_COMPLEX_H const llvm::StructType* DtoComplexType(Type* t); const LLType* DtoComplexBaseType(Type* t); LLConstant* DtoConstComplex(Type* t, long double re, long double im); LLConstant* DtoComplexShuffleMask(unsigned a, unsigned b); LLValue* DtoRealPart(DValue* val); LLValue* DtoImagPart(DValue* val); DValue* DtoComplex(Loc& loc, Type* to, DValue* val); void DtoComplexSet(LLValue* c, LLValue* re, LLValue* im); void DtoGetComplexParts(Loc& loc, Type* to, DValue* c, LLValue*& re, LLValue*& im); DValue* DtoComplexAdd(Loc& loc, Type* type, DValue* lhs, DValue* rhs); DValue* DtoComplexSub(Loc& loc, Type* type, DValue* lhs, DValue* rhs); DValue* DtoComplexMul(Loc& loc, Type* type, DValue* lhs, DValue* rhs); DValue* DtoComplexDiv(Loc& loc, Type* type, DValue* lhs, DValue* rhs); DValue* DtoComplexNeg(Loc& loc, Type* type, DValue* val); LLValue* DtoComplexEquals(Loc& loc, TOK op, DValue* lhs, DValue* rhs); DValue* DtoCastComplex(Loc& loc, DValue* val, Type* to); #endif // LDC_GEN_COMPLEX_H