OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [gcc.target/] [i386/] [strinline.c] - Diff between revs 318 and 338

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 318 Rev 338
/* { dg-do compile } */
/* { dg-do compile } */
/* { dg-require-effective-target fpic } */
/* { dg-require-effective-target fpic } */
/* { dg-options "-O2 -fPIC" } */
/* { dg-options "-O2 -fPIC" } */
typedef unsigned int size_t;
typedef unsigned int size_t;
 char *
 char *
__mempcpy_by2 (char *__dest, __const char *__src, size_t __srclen)
__mempcpy_by2 (char *__dest, __const char *__src, size_t __srclen)
{
{
  register char *__tmp = __dest;
  register char *__tmp = __dest;
  register unsigned long int __d0, __d1;
  register unsigned long int __d0, __d1;
  __asm__ __volatile__
  __asm__ __volatile__
    ("shrl      $1,%3\n\t"
    ("shrl      $1,%3\n\t"
     "jz        2f\n"
     "jz        2f\n"
     "1:\n\t"
     "1:\n\t"
     "movl      (%2),%0\n\t"
     "movl      (%2),%0\n\t"
     "leal      4(%2),%2\n\t"
     "leal      4(%2),%2\n\t"
     "movl      %0,(%1)\n\t"
     "movl      %0,(%1)\n\t"
     "leal      4(%1),%1\n\t"
     "leal      4(%1),%1\n\t"
     "decl      %3\n\t"
     "decl      %3\n\t"
     "jnz       1b\n"
     "jnz       1b\n"
     "2:\n\t"
     "2:\n\t"
     "movw      (%2),%w0\n\t"
     "movw      (%2),%w0\n\t"
     "movw      %w0,(%1)"
     "movw      %w0,(%1)"
     : "=&q" (__d0), "=r" (__tmp), "=&r" (__src), "=&r" (__d1),
     : "=&q" (__d0), "=r" (__tmp), "=&r" (__src), "=&r" (__d1),
       "=m" ( *(struct { __extension__ char __x[__srclen]; } *)__dest)
       "=m" ( *(struct { __extension__ char __x[__srclen]; } *)__dest)
     : "1" (__tmp), "2" (__src), "3" (__srclen / 2),
     : "1" (__tmp), "2" (__src), "3" (__srclen / 2),
       "m" ( *(struct { __extension__ char __x[__srclen]; } *)__src)
       "m" ( *(struct { __extension__ char __x[__srclen]; } *)__src)
     : "cc");
     : "cc");
  return __tmp + 2;
  return __tmp + 2;
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.