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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib-1.10.0/] [newlib/] [libc/] [machine/] [xscale/] [strcpy.c] - Rev 1771

Go to most recent revision | Compare with Previous | Blame | View Log

#if defined __thumb__
 
#include "../../string/strcpy.c"
 
#else
 
#include <string.h>
#include "xscale.h"
 
char *
strcpy (char *dest, const char *src)
{
  char *dest0 = dest;
 
  asm (PRELOADSTR ("%0") : : "r" (src));
 
#ifndef __OPTIMIZE_SIZE__
  if (((long)src & 3) == ((long)dest & 3))
    {
      /* Skip unaligned part.  */
      while ((long)src & 3)
	{
	  if (! (*dest++ = *src++))
	    return dest0;
	}
 
  /* Load two constants:
     R4 = 0xfefefeff [ == ~(0x80808080 << 1) ]
     R5 = 0x80808080  */
 
  asm ("mov	r5, #0x80
	ldr	r1, [%1, #0]
	add	r5, r5, #0x8000
	add	r5, r5, r5, lsl #16
	mvn	r4, r5, lsl #1
 
	add	r3, r1, r5
	bic	r3, r3, r1
	ands	r2, r3, r4
	bne	1f
0:
	ldr	r3, [%1, #0]
	ldr	r1, [%1, #4]!
"	PRELOADSTR("%1") "
	str	r3, [%0], #4
	add	r2, r1, r4
	bic	r2, r2, r1
	ands	r3, r2, r5
	beq	0b
1:"
       : "=&r" (dest), "=&r" (src)
       : "0" (dest), "1" (src)
       : "r1", "r2", "r3", "r4", "r5", "memory", "cc");
    }
#endif
 
  while (*dest++ = *src++)
    asm (PRELOADSTR ("%0") : : "r" (src));
  return dest0;
}
 
#endif
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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