зеркало из https://github.com/microsoft/clang-1.git
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:
Родитель
f767e218ee
Коммит
8967e9e6c3
|
@ -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; }
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче