From: Lauro Ramos Venancio Date: Wed, 11 Jul 2007 19:56:53 +0000 (+0000) Subject: Handle packed structs in the CBackend. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=a126bb71d5ba119fcddabfe022fad9647b9f1bf0;p=oota-llvm.git Handle packed structs in the CBackend. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@39752 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index 91f427fa2cb..b0c76c8e8e7 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -466,7 +466,10 @@ std::ostream &CWriter::printType(std::ostream &Out, const Type *Ty, printType(Out, *I, false, "field" + utostr(Idx++)); Out << ";\n"; } - return Out << '}'; + Out << '}'; + if (STy->isPacked()) + Out << " __attribute__ ((packed))"; + return Out; } case Type::PointerTyID: { diff --git a/test/CodeGen/CBackend/2007-07-11-PackedStruct.ll b/test/CodeGen/CBackend/2007-07-11-PackedStruct.ll new file mode 100644 index 00000000000..60576161118 --- /dev/null +++ b/test/CodeGen/CBackend/2007-07-11-PackedStruct.ll @@ -0,0 +1,9 @@ +; RUN: llvm-as < %s | llc -march=c | grep {packed} + + %struct.p = type <{ i16 }> + +define i32 @main() { +entry: + %t = alloca %struct.p, align 2 + ret i32 5 +}