diff options
| author | Eli Bendersky <eliben@google.com> | 2014-06-19 18:30:15 +0000 |
|---|---|---|
| committer | Eli Bendersky <eliben@google.com> | 2014-06-19 18:30:15 +0000 |
| commit | f637790102ea414da2c43fb1c5f6d2aab9d354c7 (patch) | |
| tree | a84bb08d3c9e98265e3b37bfa209f5ed265649c4 /clang/test | |
| parent | df4d5efc7c70b902d2b2083fcdbc37f44ef81c4e (diff) | |
| download | bcm5719-llvm-f637790102ea414da2c43fb1c5f6d2aab9d354c7.tar.gz bcm5719-llvm-f637790102ea414da2c43fb1c5f6d2aab9d354c7.zip | |
Fix PR20069: bad loop pragma arguments crash FE
This patch fixes a crash when handling malformed arguments to loop pragmas such
as: "#pragma clang loop vectorize(()". Essentially any argument which is not an
identifier or constant resulted in a crash. This patch also changes a couple of
the error messages which weren't quite correct. New behavior with this patch vs
old behavior:
#pragma clang loop vectorize(1)
OLD: error: missing keyword; expected 'enable' or 'disable'
NEW: error: invalid argument; expected 'enable' or 'disable'
#pragma clang loop vectorize()
OLD: error: expected ')'
NEW: error: missing argument to loop pragma 'vectorize'
#pragma clang loop vectorize_width(bad)
OLD: error: missing value; expected a positive integer value
NEW: error: invalid argument; expected a positive integer value
#pragma clang loop vectorize(bad)
OLD: invalid keyword 'bad'; expected 'enable' or 'disable'
NEW: error: invalid argument; expected 'enable' or 'disable'
http://reviews.llvm.org/D4197
Patch by Mark Heffernan
llvm-svn: 211292
Diffstat (limited to 'clang/test')
| -rw-r--r-- | clang/test/Parser/pragma-loop.cpp | 40 |
1 files changed, 28 insertions, 12 deletions
diff --git a/clang/test/Parser/pragma-loop.cpp b/clang/test/Parser/pragma-loop.cpp index 6535b62e3b5..fad4feb8707 100644 --- a/clang/test/Parser/pragma-loop.cpp +++ b/clang/test/Parser/pragma-loop.cpp @@ -55,6 +55,10 @@ void test(int *List, int Length) { /* expected-error {{expected ')'}} */ #pragma clang loop interleave_count(4 /* expected-error {{expected ')'}} */ #pragma clang loop unroll_count(4 +/* expected-error {{missing argument to loop pragma 'vectorize'}} */ #pragma clang loop vectorize() +/* expected-error {{missing argument to loop pragma 'interleave_count'}} */ #pragma clang loop interleave_count() +/* expected-error {{missing argument to loop pragma 'unroll'}} */ #pragma clang loop unroll() + /* expected-error {{missing option}} */ #pragma clang loop /* expected-error {{invalid option 'badkeyword'}} */ #pragma clang loop badkeyword /* expected-error {{invalid option 'badkeyword'}} */ #pragma clang loop badkeyword(enable) @@ -65,34 +69,46 @@ void test(int *List, int Length) { List[i] = i; } -/* expected-error {{invalid value 0; expected a positive integer value}} */ #pragma clang loop vectorize_width(0) -/* expected-error {{invalid value 0; expected a positive integer value}} */ #pragma clang loop interleave_count(0) -/* expected-error {{invalid value 0; expected a positive integer value}} */ #pragma clang loop unroll_count(0) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop vectorize_width(0) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop interleave_count(0) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop unroll_count(0) while (i-5 < Length) { List[i] = i; } -/* expected-error {{invalid value -1294967296; expected a positive integer value}} */ #pragma clang loop vectorize_width(3000000000) -/* expected-error {{invalid value -1294967296; expected a positive integer value}} */ #pragma clang loop interleave_count(3000000000) -/* expected-error {{invalid value -1294967296; expected a positive integer value}} */ #pragma clang loop unroll_count(3000000000) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop vectorize_width(3000000000) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop interleave_count(3000000000) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop unroll_count(3000000000) while (i-6 < Length) { List[i] = i; } -/* expected-error {{missing value; expected a positive integer value}} */ #pragma clang loop vectorize_width(badvalue) -/* expected-error {{missing value; expected a positive integer value}} */ #pragma clang loop interleave_count(badvalue) -/* expected-error {{missing value; expected a positive integer value}} */ #pragma clang loop unroll_count(badvalue) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop vectorize_width(badvalue) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop interleave_count(badvalue) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop unroll_count(badvalue) while (i-6 < Length) { List[i] = i; } -/* expected-error {{invalid keyword 'badidentifier'; expected 'enable' or 'disable'}} */ #pragma clang loop vectorize(badidentifier) -/* expected-error {{invalid keyword 'badidentifier'; expected 'enable' or 'disable'}} */ #pragma clang loop interleave(badidentifier) -/* expected-error {{invalid keyword 'badidentifier'; expected 'enable' or 'disable'}} */ #pragma clang loop unroll(badidentifier) +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop vectorize(badidentifier) +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop interleave(badidentifier) +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop unroll(badidentifier) while (i-7 < Length) { List[i] = i; } +// PR20069 - Loop pragma arguments that are not identifiers or numeric +// constants crash FE. +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop vectorize(() +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop interleave(*) +/* expected-error {{invalid argument; expected 'enable' or 'disable'}} */ #pragma clang loop unroll(=) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop vectorize_width(^) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop interleave_count(/) +/* expected-error {{invalid argument; expected a positive integer value}} */ #pragma clang loop unroll_count(==) + while (i-8 < Length) { + List[i] = i; + } + #pragma clang loop vectorize(enable) /* expected-error {{expected a for, while, or do-while loop to follow the '#pragma clang loop' directive}} */ int j = Length; List[0] = List[1]; |

