PATCH: PR target/59605: Create jump_around_label only if it doesn't exist

Andrew Pinski pinskia@gmail.com
Mon Feb 10 23:09:00 GMT 2014


On Thu, Dec 26, 2013 at 6:31 PM, H.J. Lu <hjl.tools@gmail.com> wrote:
> Hi Honza,
>
> r203937 may create jump_around_label earlier. But later code doesn't
> check if jump_around_label exists.  This patch fixes it.  Tested
> on Linux/x86-64.  OK to install?

This test times out when running on a simulator.  Is there a way to
reduce the MAX_LENGTH size?

Thanks,
Andrew Pinski


>
> Thanks.
>
> H.J.
> --
> gcc/
>
> 2013-12-26   H.J. Lu  <hongjiu.lu@intel.com>
>
>         PR target/59605
>         * config/i386/i386.c (ix86_expand_set_or_movmem): Create
>         jump_around_label only if it doesn't exist.
>
> gcc/testsuite/
>
> 2013-12-26   H.J. Lu  <hongjiu.lu@intel.com>
>
>         PR target/59605
>         * gcc.dg/pr59605.c: New test.
>
> diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
> index 0cf0a9d..07f9a86 100644
> --- a/gcc/config/i386/i386.c
> +++ b/gcc/config/i386/i386.c
> @@ -24015,7 +24015,8 @@ ix86_expand_set_or_movmem (rtx dst, rtx src, rtx count_exp, rtx val_exp,
>        else
>         {
>           rtx hot_label = gen_label_rtx ();
> -         jump_around_label = gen_label_rtx ();
> +         if (jump_around_label == NULL_RTX)
> +           jump_around_label = gen_label_rtx ();
>           emit_cmp_and_jump_insns (count_exp, GEN_INT (dynamic_check - 1),
>                                    LEU, 0, GET_MODE (count_exp), 1, hot_label);
>           predict_jump (REG_BR_PROB_BASE * 90 / 100);
> diff --git a/gcc/testsuite/gcc.dg/pr59605.c b/gcc/testsuite/gcc.dg/pr59605.c
> new file mode 100644
> index 0000000..4556843
> --- /dev/null
> +++ b/gcc/testsuite/gcc.dg/pr59605.c
> @@ -0,0 +1,55 @@
> +/* { dg-do run } */
> +/* { dg-options "-O2" } */
> +/* { dg-additional-options "-minline-stringops-dynamically" { target { i?86-*-* x86_64-*-* } } } */
> +
> +extern void abort (void);
> +
> +#define MAX_OFFSET (sizeof (long long))
> +#define MAX_COPY (1024 + 8192)
> +#define MAX_EXTRA (sizeof (long long))
> +
> +#define MAX_LENGTH (MAX_OFFSET + MAX_COPY + MAX_EXTRA)
> +
> +static union {
> +  char buf[MAX_LENGTH];
> +  long long align_int;
> +  long double align_fp;
> +} u;
> +
> +char A[MAX_LENGTH];
> +
> +int
> +main ()
> +{
> +  int off, len, i;
> +  char *p, *q;
> +
> +  for (i = 0; i < MAX_LENGTH; i++)
> +    A[i] = 'A';
> +
> +  for (off = 0; off < MAX_OFFSET; off++)
> +    for (len = 1; len < MAX_COPY; len++)
> +      {
> +       for (i = 0; i < MAX_LENGTH; i++)
> +         u.buf[i] = 'a';
> +
> +       p = __builtin_memcpy (u.buf + off, A, len);
> +       if (p != u.buf + off)
> +         abort ();
> +
> +       q = u.buf;
> +       for (i = 0; i < off; i++, q++)
> +         if (*q != 'a')
> +           abort ();
> +
> +       for (i = 0; i < len; i++, q++)
> +         if (*q != 'A')
> +           abort ();
> +
> +       for (i = 0; i < MAX_EXTRA; i++, q++)
> +         if (*q != 'a')
> +           abort ();
> +      }
> +
> +  return 0;
> +}



More information about the Gcc-patches mailing list