Mercurial > projects > ldc
view gen/structs.h @ 1053:11e28922ac76
Always pass an address expression (not a var expression) to asm operands of
type Arg_Memory.
This fixes the following code:
{{{
void f(real x) { asm { fld x[RBP]; } }
void g(int x) { asm { mov EAX, x[RBP]; } }
}}}
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Sun, 08 Mar 2009 00:57:58 +0100 |
parents | af7a6faf9406 |
children | 3cf0066e6faf |
line wrap: on
line source
#ifndef LLVMD_GEN_STRUCTS_H #define LLVMD_GEN_STRUCTS_H struct StructInitializer; LLConstant* DtoConstStructInitializer(StructInitializer* si); std::vector<llvm::Value*> DtoStructLiteralValues(const StructDeclaration* sd, const std::vector<llvm::Value*>& inits); /** * Resolves the llvm type for a struct */ void DtoResolveStruct(StructDeclaration* sd); /** * Provides the llvm declaration for a struct */ void DtoDeclareStruct(StructDeclaration* sd); /** * Constructs the constant default initializer a struct */ void DtoConstInitStruct(StructDeclaration* sd); /** * Provides the llvm definition for a struct */ void DtoDefineStruct(StructDeclaration* sd); /** * Returns a boolean=true if the two structs are equal */ LLValue* DtoStructEquals(TOK op, DValue* lhs, DValue* rhs); // index a struct one level LLValue* DtoIndexStruct(LLValue* src, StructDeclaration* sd, VarDeclaration* vd); #endif