diff options
author | Reid Kleckner <reid@kleckner.net> | 2014-07-22 00:53:05 +0000 |
---|---|---|
committer | Reid Kleckner <reid@kleckner.net> | 2014-07-22 00:53:05 +0000 |
commit | 1a711b169619e1109cb9affed650f8f12ae85f6e (patch) | |
tree | 9a98befc44b4d58db315ee12e854b5e7426ef2d0 /clang/test/SemaCXX/pragma-init_seg.cpp | |
parent | e1aaced0cb0ee4888800bb4a705caa76a7cf9ea4 (diff) | |
download | bcm5719-llvm-1a711b169619e1109cb9affed650f8f12ae85f6e.tar.gz bcm5719-llvm-1a711b169619e1109cb9affed650f8f12ae85f6e.zip |
-fms-extensions: Implement half of #pragma init_seg
Summary:
This pragma is very rare. We could *hypothetically* lower some uses of
it down to @llvm.global_ctors, but given that GlobalOpt isn't able to
optimize prioritized global ctors today, there's really no point.
If we wanted to do this in the future, I would check if the section used
in the pragma started with ".CRT$XC" and had up to two characters after
it. Those two characters could form the 16-bit initialization priority
that we support in @llvm.global_ctors. We would have to teach LLVM to
lower prioritized global ctors on COFF as well.
This should let us compile some silly uses of this pragma in WebKit /
Blink.
Reviewers: rsmith, majnemer
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D4549
llvm-svn: 213593
Diffstat (limited to 'clang/test/SemaCXX/pragma-init_seg.cpp')
-rw-r--r-- | clang/test/SemaCXX/pragma-init_seg.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/pragma-init_seg.cpp b/clang/test/SemaCXX/pragma-init_seg.cpp new file mode 100644 index 00000000000..38520b0c2ef --- /dev/null +++ b/clang/test/SemaCXX/pragma-init_seg.cpp @@ -0,0 +1,15 @@ +// RUN: %clang_cc1 -fsyntax-only -verify -fms-extensions %s -triple x86_64-pc-win32 + +#pragma init_seg(L".my_seg") // expected-warning {{expected 'compiler', 'lib', 'user', or a string literal}} +#pragma init_seg( // expected-warning {{expected 'compiler', 'lib', 'user', or a string literal}} +#pragma init_seg asdf // expected-warning {{missing '('}} +#pragma init_seg) // expected-warning {{missing '('}} +#pragma init_seg("a" "b") // no warning +#pragma init_seg("a", "b") // expected-warning {{missing ')'}} +#pragma init_seg("a") asdf // expected-warning {{extra tokens at end of '#pragma init_seg'}} +#pragma init_seg("\x") // expected-error {{\x used with no following hex digits}} +#pragma init_seg("a" L"b") // expected-warning {{expected non-wide string literal in '#pragma init_seg'}} + +int f(); +#pragma init_seg(compiler) +int __declspec(thread) x = f(); // expected-error {{initializer for thread-local variable must be a constant expression}} |