36 lines
650 B
C
36 lines
650 B
C
/*
|
|
* C library strlen routine
|
|
*
|
|
* This routine has been optimized for the CPU32+.
|
|
* It should run on all 68k machines.
|
|
*
|
|
* W. Eric Norum
|
|
* Saskatchewan Accelerator Laboratory
|
|
* University of Saskatchewan
|
|
* Saskatoon, Saskatchewan, CANADA
|
|
* eric@skatter.usask.ca
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
/*
|
|
* Test bytes using CPU32+ loop mode if possible.
|
|
*/
|
|
size_t
|
|
strlen (const char *str)
|
|
{
|
|
unsigned int n = ~0;
|
|
const char *cp = str;
|
|
|
|
asm volatile ("1:\n"
|
|
"\ttst.b (%0)+\n"
|
|
#if defined(__mcpu32__)
|
|
"\tdbeq %1,1b\n"
|
|
#endif
|
|
"\tbne.b 1b\n" :
|
|
"=a" (cp), "=d" (n) :
|
|
"0" (cp), "1" (n) :
|
|
"cc");
|
|
return (cp - str) - 1;
|
|
}
|