diff options
author | kyukhin <kyukhin@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-07-16 10:00:37 +0000 |
---|---|---|
committer | kyukhin <kyukhin@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-07-16 10:00:37 +0000 |
commit | bf1c0af128f33bd342636c4afeaa8f3a8a7cf8ca (patch) | |
tree | 883d76bae4cf5284831e359cf87a37009b26d9aa | |
parent | ae6224b2c7dd0827d5ca4bc0187cfa0a24786848 (diff) | |
download | gcc-bf1c0af128f33bd342636c4afeaa8f3a8a7cf8ca.tar.gz |
2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com>
* config/i386/i386.md (stack_protect_set): Disable the pattern
for Android since Android libc (bionic) does not provide random
value for stack protection guard at gs:0x14. Guard value
will be provided from external symbol (default implementation).
(stack_protect_set_<mode>): Likewise.
(stack_protect_test): Likewise.
(stack_protect_test_<mode>): Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@189513 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 10 | ||||
-rw-r--r-- | gcc/config/i386/i386.md | 8 |
2 files changed, 14 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2fe9b02dcf2..2decc3d7f13 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,13 @@ +2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com> + + * config/i386/i386.md (stack_protect_set): Disable the pattern + for Android since Android libc (bionic) does not provide random + value for stack protection guard at gs:0x14. Guard value + will be provided from external symbol (default implementation). + (stack_protect_set_<mode>): Likewise. + (stack_protect_test): Likewise. + (stack_protect_test_<mode>): Likewise. + 2012-07-16 Hans-Peter Nilsson <hp@axis.com> * config/cris/cris-protos.h (cris_legitimate_address_p): Declare. diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md index 49a56863617..a1c5b791282 100644 --- a/gcc/config/i386/i386.md +++ b/gcc/config/i386/i386.md @@ -17708,7 +17708,7 @@ (define_expand "stack_protect_set" [(match_operand 0 "memory_operand") (match_operand 1 "memory_operand")] - "" + "!OPTION_BIONIC" { rtx (*insn)(rtx, rtx); @@ -17733,7 +17733,7 @@ UNSPEC_SP_SET)) (set (match_scratch:PTR 2 "=&r") (const_int 0)) (clobber (reg:CC FLAGS_REG))] - "" + "!OPTION_BIONIC" "mov{<imodesuffix>}\t{%1, %2|%2, %1}\;mov{<imodesuffix>}\t{%2, %0|%0, %2}\;xor{l}\t%k2, %k2" [(set_attr "type" "multi")]) @@ -17751,7 +17751,7 @@ [(match_operand 0 "memory_operand") (match_operand 1 "memory_operand") (match_operand 2)] - "" + "!OPTION_BIONIC" { rtx flags = gen_rtx_REG (CCZmode, FLAGS_REG); @@ -17781,7 +17781,7 @@ (match_operand:PTR 2 "memory_operand" "m")] UNSPEC_SP_TEST)) (clobber (match_scratch:PTR 3 "=&r"))] - "" + "!OPTION_BIONIC" "mov{<imodesuffix>}\t{%1, %3|%3, %1}\;xor{<imodesuffix>}\t{%2, %3|%3, %2}" [(set_attr "type" "multi")]) |