summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2007-10-26 18:15:21 +0000
committerDevang Patel <dpatel@apple.com>2007-10-26 18:15:21 +0000
commit7718d7a2eba45a6dc322b54d09f1e00bb73f509f (patch)
tree3ee84d4c2988f07dac3bac2f98f2babb99cfad65
parentffdb07c9396ad9f8099231aa5cc826027349136d (diff)
downloadbcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.tar.gz
bcm5719-llvm-7718d7a2eba45a6dc322b54d09f1e00bb73f509f.zip
Handle non LValue base expressions.
llvm-svn: 43387
-rw-r--r--clang/CodeGen/CGExpr.cpp13
-rw-r--r--clang/test/CodeGen/struct.c4
2 files changed, 9 insertions, 8 deletions
diff --git a/clang/CodeGen/CGExpr.cpp b/clang/CodeGen/CGExpr.cpp
index b03caaa6666..1c8eda1f607 100644
--- a/clang/CodeGen/CGExpr.cpp
+++ b/clang/CodeGen/CGExpr.cpp
@@ -394,21 +394,18 @@ LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) {
}
llvm::Value *BaseValue = NULL;
- if (const CallExpr *CE = dyn_cast<CallExpr>(BaseExpr)) {
- RValue Base = EmitCallExpr(CE);
- BaseValue = Base.getScalarVal();
- }
- else {
+ if (BaseExpr->isLvalue() == Expr::LV_Valid) {
LValue BaseLV = EmitLValue(BaseExpr);
BaseValue = BaseLV.getAddress();
-
+
if (E->isArrow()) {
QualType PTy = cast<PointerType>(BaseExpr->getType())->getPointeeType();
BaseValue = Builder.CreateBitCast(BaseValue,
- llvm::PointerType::get(ConvertType(PTy)),
+ llvm::PointerType::get(ConvertType(PTy)),
"tmp");
}
- }
+ } else
+ BaseValue = EmitScalarExpr(BaseExpr);
FieldDecl *Field = E->getMemberDecl();
unsigned idx = CGM.getTypes().getLLVMFieldNo(Field);
diff --git a/clang/test/CodeGen/struct.c b/clang/test/CodeGen/struct.c
index 4e73cd47af0..443fc33ccb3 100644
--- a/clang/test/CodeGen/struct.c
+++ b/clang/test/CodeGen/struct.c
@@ -59,3 +59,7 @@ extern NB *f3();
void f4() {
f3()->d1 = 42;
}
+
+void f5() {
+ (f3())->d1 = 42;
+}
OpenPOWER on IntegriCloud