Keep track of field offsets during structure layout.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43539 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Devang Patel 2007-10-31 01:23:10 +00:00
Родитель f767e218ee
Коммит 8967e9e6c3
2 изменённых файлов: 12 добавлений и 4 удалений

Просмотреть файл

@ -16,6 +16,7 @@
#include "clang/AST/AST.h" #include "clang/AST/AST.h"
#include "llvm/DerivedTypes.h" #include "llvm/DerivedTypes.h"
#include "llvm/Module.h" #include "llvm/Module.h"
#include "llvm/Target/TargetData.h"
using namespace clang; using namespace clang;
using namespace CodeGen; using namespace CodeGen;
@ -39,7 +40,7 @@ namespace {
/// layoutStructFields - Do the actual work and lay out all fields. Create /// layoutStructFields - Do the actual work and lay out all fields. Create
/// corresponding llvm struct type. This should be invoked only after /// corresponding llvm struct type. This should be invoked only after
/// all fields are added. /// all fields are added.
void layoutStructFields(CodeGenTypes &CGT); void layoutStructFields(CodeGenTypes &CGT, const RecordLayout &RL);
/// layoutUnionFields - Do the actual work and lay out all fields. Create /// layoutUnionFields - Do the actual work and lay out all fields. Create
/// corresponding llvm struct type. This should be invoked only after /// corresponding llvm struct type. This should be invoked only after
@ -246,7 +247,8 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) {
RecordOrganizer RO; RecordOrganizer RO;
for (unsigned i = 0, e = RD->getNumMembers(); i != e; ++i) for (unsigned i = 0, e = RD->getNumMembers(); i != e; ++i)
RO.addField(RD->getMember(i)); RO.addField(RD->getMember(i));
RO.layoutStructFields(*this); const RecordLayout &RL = Context.getRecordLayout(RD, SourceLocation());
RO.layoutStructFields(*this, RL);
// Get llvm::StructType. // Get llvm::StructType.
RecordLayoutInfo *RLI = new RecordLayoutInfo(RO.getLLVMType()); RecordLayoutInfo *RLI = new RecordLayoutInfo(RO.getLLVMType());
@ -353,16 +355,21 @@ void RecordOrganizer::addField(const FieldDecl *FD) {
/// - Ignore bit fields /// - Ignore bit fields
/// - Ignore field aligments /// - Ignore field aligments
/// - Ignore packed structs /// - Ignore packed structs
void RecordOrganizer::layoutStructFields(CodeGenTypes &CGT) { void RecordOrganizer::layoutStructFields(CodeGenTypes &CGT,
const RecordLayout &RL) {
// FIXME : Use SmallVector // FIXME : Use SmallVector
std::vector<const llvm::Type*> Fields; std::vector<const llvm::Type*> Fields;
unsigned FieldNo = 0; unsigned FieldNo = 0;
uint64_t Cursor = 0;
for (llvm::SmallVector<const FieldDecl *, 8>::iterator I = FieldDecls.begin(), for (llvm::SmallVector<const FieldDecl *, 8>::iterator I = FieldDecls.begin(),
E = FieldDecls.end(); I != E; ++I) { E = FieldDecls.end(); I != E; ++I) {
const FieldDecl *FD = *I; const FieldDecl *FD = *I;
const llvm::Type *Ty = CGT.ConvertType(FD->getType()); const llvm::Type *Ty = CGT.ConvertType(FD->getType());
// FIXME : Layout FieldDecl FD uint64_t Offset = RL.getFieldOffset(FieldNo);
assert (Offset == Cursor && "FIXME Invalid struct layout");
Cursor += CGT.getTargetData().getTypeSizeInBits(Ty);
Fields.push_back(Ty); Fields.push_back(Ty);
CGT.addFieldInfo(FD, FieldNo++); CGT.addFieldInfo(FD, FieldNo++);

Просмотреть файл

@ -96,6 +96,7 @@ public:
CodeGenTypes(ASTContext &Ctx, llvm::Module &M, const llvm::TargetData &TD); CodeGenTypes(ASTContext &Ctx, llvm::Module &M, const llvm::TargetData &TD);
~CodeGenTypes(); ~CodeGenTypes();
const llvm::TargetData &getTargetData() const { return TheTargetData; }
TargetInfo &getTarget() const { return Target; } TargetInfo &getTarget() const { return Target; }
ASTContext &getContext() const { return Context; } ASTContext &getContext() const { return Context; }