On 10/07/2012, at 8:51 AM, Igor Zamyatin wrote: > Let's try with this patch then. Is it ok for trunk after all > appropriate testing is done?
Sorry for the late reply, I've been down with a virus last week. Uros, Would you please approve this patch for i386 provided my review below? > > ChangeLog: > > 2012-07-09 Sergey Melnikov <sergey.melni...@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. > > > diff --git a/gcc-4.6/gcc/config/i386/i386.md b/gcc-4.6/gcc/config/i386/i386.md > index b1d7e5e..c4dd6e3 100644 > --- a/gcc-4.6/gcc/config/i386/i386.md > +++ b/gcc-4.6/gcc/config/i386/i386.md > @@ -17955,7 +17955,7 @@ > (define_expand "stack_protect_set" > [(match_operand 0 "memory_operand" "") > (match_operand 1 "memory_operand" "")] > - "" > + "!(flag_android && OPTION_BIONIC)" This should be just !OPTION_BIONIC, no flag_android. Same applies below. OK with that change. -mandroid, which sets flag_android, tells the compiler to use compilation mode suitable for Android, like don't use C++ exceptions. The particular implementation of stack protector, on the other hand, is a feature related to the C library. > { > rtx (*insn)(rtx, rtx); > > @@ -17979,7 +17979,7 @@ > (unspec:P [(match_operand:P 1 "memory_operand" "m")] UNSPEC_SP_SET)) > (set (match_scratch:P 2 "=&r") (const_int 0)) > (clobber (reg:CC FLAGS_REG))] > - "" > + "!(flag_android && 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")]) > > @@ -17997,7 +17997,7 @@ > [(match_operand 0 "memory_operand" "") > (match_operand 1 "memory_operand" "") > (match_operand 2 "" "")] > - "" > + "!(flag_android && OPTION_BIONIC)" > { > rtx flags = gen_rtx_REG (CCZmode, FLAGS_REG); > > @@ -18027,7 +18027,7 @@ > (match_operand:P 2 "memory_operand" "m")] > UNSPEC_SP_TEST)) > (clobber (match_scratch:P 3 "=&r"))] > - "" > + "!(flag_android && OPTION_BIONIC)" > "mov{<imodesuffix>}\t{%1, %3|%3, %1}\;xor{<imodesuffix>}\t{%2, %3|%3, %2}" > [(set_attr "type" "multi")]) Thanks, -- Maxim Kuvyrkov CodeSourcery / Mentor Graphics