From cc7f008b850b301910132f94224dc02e32418f67 Mon Sep 17 00:00:00 2001 From: Fariborz Jahanian Date: Thu, 10 Jan 2013 23:28:43 +0000 Subject: c++ IRGen. In trivial cases that object is going into static storage and thus is implicitly zero-initialized, no need to do C++11 memory model. This patch unconditionally detects such condition and zeroinitializer's the variable. Patch has been commented on and OKed by Doug off-line. // rdar://12897704 llvm-svn: 172144 --- .../CodeGenCXX/cxx11-trivial-initializer-struct.cpp | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 clang/test/CodeGenCXX/cxx11-trivial-initializer-struct.cpp (limited to 'clang/test/CodeGenCXX/cxx11-trivial-initializer-struct.cpp') diff --git a/clang/test/CodeGenCXX/cxx11-trivial-initializer-struct.cpp b/clang/test/CodeGenCXX/cxx11-trivial-initializer-struct.cpp new file mode 100644 index 00000000000..f38d01a4678 --- /dev/null +++ b/clang/test/CodeGenCXX/cxx11-trivial-initializer-struct.cpp @@ -0,0 +1,18 @@ +// RUN: %clang_cc1 -S -emit-llvm -o %t.ll %s -triple x86_64-apple-darwin10 +// RUN: %clang_cc1 -std=c++11 -S -emit-llvm -o %t-c++11.ll %s -triple x86_64-apple-darwin10 +// RUN: diff %t.ll %t-c++11.ll + +// rdar://12897704 + +struct sAFSearchPos { + unsigned char *pos; + unsigned char count; +}; + +static volatile struct sAFSearchPos testPositions; + +static volatile struct sAFSearchPos arrayPositions[100][10][5]; + +int main() { + return testPositions.count + arrayPositions[10][4][3].count; +} -- cgit v1.2.3