From: ramana Date: Wed, 23 Dec 2009 16:36:40 +0000 (+0000) Subject: Fix PR target/42093 X-Git-Url: http://git.sourceforge.jp/view?a=commitdiff_plain;h=f110e938b5a81bfb64f89b6571d9fbc3607c86ca;p=pf3gnuchains%2Fgcc-fork.git Fix PR target/42093 2009-12-23 Ramana Radhakrishnan PR target/42093 * config/arm/arm.h (CASE_VECTOR_PC_RELATIVE): Fix macro usage to TARGET_THUMB1. (CASE_VECTOR_SHORTEN_MODE): Allow signed offsets only for TARGET_THUMB1. 2009-12-23 Ramana Radhakrishnan PR target/42093 * gcc.target/arm/pr42093.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@155428 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c22b10f6f6d..be260888761 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2009-12-23 Ramana Radhakrishnan + + PR target/42093 + * config/arm/arm.h (CASE_VECTOR_PC_RELATIVE): Fix macro usage + to TARGET_THUMB1. + (CASE_VECTOR_SHORTEN_MODE): Allow signed offsets + only for TARGET_THUMB1. + 2009-12-23 Ramana Radhakrishnan PR target/40670 diff --git a/gcc/config/arm/arm.h b/gcc/config/arm/arm.h index 691a8600e0a..26ffaf8dff8 100644 --- a/gcc/config/arm/arm.h +++ b/gcc/config/arm/arm.h @@ -2118,11 +2118,11 @@ typedef struct #define CASE_VECTOR_MODE Pmode #define CASE_VECTOR_PC_RELATIVE (TARGET_THUMB2 \ - || (TARGET_THUMB \ + || (TARGET_THUMB1 \ && (optimize_size || flag_pic))) #define CASE_VECTOR_SHORTEN_MODE(min, max, body) \ - (TARGET_THUMB \ + (TARGET_THUMB1 \ ? (min >= 0 && max < 512 \ ? (ADDR_DIFF_VEC_FLAGS (body).offset_unsigned = 1, QImode) \ : min >= -256 && max < 256 \ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b5717572077..da6d3b1e5b3 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-12-23 Ramana Radhakrishnan + + PR target/42093 + * gcc.target/arm/pr42093.c: New test. + 2009-12-23 Ramana Radhakrishnan PR target/40670 diff --git a/gcc/testsuite/gcc.target/arm/pr42093.c b/gcc/testsuite/gcc.target/arm/pr42093.c new file mode 100644 index 00000000000..5d43982bf1c --- /dev/null +++ b/gcc/testsuite/gcc.target/arm/pr42093.c @@ -0,0 +1,51 @@ +/* { dg-options "-mthumb -O2" } */ +/* { dg-require-effective-target arm_thumb2_ok } */ +/* { dg-final { scan-assembler-not "tbb" } } */ +/* { dg-final { scan-assembler-not "tbh" } } */ + +#include + +int gbl; +int foo (int *buf, int n) +{ + int ctr = 0; + int c; + while (1) + { + c = buf[ctr++]; + switch (c) + { + case '\n': + gbl++; + break; + + case ' ': case '\t' : case '\f' : case '\r': + break; + + case ';': + do + c = buf [ctr++]; + while (c != '\n' && c != -1); + gbl++; + break; + + case '/': + { + int prevc; + c = buf [ctr++]; + if (c != '*') + abort (); + + prevc = 0; + while ((c = buf[ctr++]) && c != -1) + { + if (c == '\n') + gbl++; + } + break; + } + default: + return c; + } + } +}