2005-11-30 Shaun Jackman <sjackman@gmail.com>
* arm/libcfunc.c (clock, sleep, usleep): New functions. * arm/syscalls.c (_clock): New function. (_times): Call _clock.
This commit is contained in:
parent
1740d2580b
commit
7c15164f17
@ -1,3 +1,9 @@
|
|||||||
|
2005-11-30 Shaun Jackman <sjackman@gmail.com>
|
||||||
|
|
||||||
|
* arm/libcfunc.c (clock, sleep, usleep): New functions.
|
||||||
|
* arm/syscalls.c (_clock): New function.
|
||||||
|
(_times): Call _clock.
|
||||||
|
|
||||||
2005-11-17 Shaun Jackman <sjackman@gmail.com>
|
2005-11-17 Shaun Jackman <sjackman@gmail.com>
|
||||||
|
|
||||||
* libgloss/arm/libcfunc.c (isatty): Call _isatty. GDB now supports
|
* libgloss/arm/libcfunc.c (isatty): Call _isatty. GDB now supports
|
||||||
|
@ -43,6 +43,13 @@ alarm (unsigned seconds)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
clock_t _clock(void);
|
||||||
|
clock_t __attribute__((weak))
|
||||||
|
clock(void)
|
||||||
|
{
|
||||||
|
return _clock();
|
||||||
|
}
|
||||||
|
|
||||||
int _isatty(int fildes);
|
int _isatty(int fildes);
|
||||||
int __attribute__((weak))
|
int __attribute__((weak))
|
||||||
isatty(int fildes)
|
isatty(int fildes)
|
||||||
@ -51,8 +58,31 @@ isatty(int fildes)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int __attribute__((weak))
|
int __attribute__((weak))
|
||||||
pause (void)
|
pause(void)
|
||||||
{
|
{
|
||||||
errno = ENOSYS;
|
errno = ENOSYS;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
unsigned __attribute__((weak))
|
||||||
|
sleep(unsigned seconds)
|
||||||
|
{
|
||||||
|
clock_t t0 = _clock();
|
||||||
|
clock_t dt = seconds * CLOCKS_PER_SEC;
|
||||||
|
|
||||||
|
while (_clock() - t0 < dt);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int __attribute__((weak))
|
||||||
|
usleep(useconds_t useconds)
|
||||||
|
{
|
||||||
|
clock_t t0 = _clock();
|
||||||
|
clock_t dt = useconds / (1000000/CLOCKS_PER_SEC);
|
||||||
|
|
||||||
|
while (_clock() - t0 < dt);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -31,6 +31,7 @@ int _getpid _PARAMS ((int));
|
|||||||
int _kill _PARAMS ((int, int));
|
int _kill _PARAMS ((int, int));
|
||||||
void _exit _PARAMS ((int));
|
void _exit _PARAMS ((int));
|
||||||
int _close _PARAMS ((int));
|
int _close _PARAMS ((int));
|
||||||
|
clock_t _clock _PARAMS ((void));
|
||||||
int _swiclose _PARAMS ((int));
|
int _swiclose _PARAMS ((int));
|
||||||
int _open _PARAMS ((const char *, int, ...));
|
int _open _PARAMS ((const char *, int, ...));
|
||||||
int _swiopen _PARAMS ((const char *, int));
|
int _swiopen _PARAMS ((const char *, int));
|
||||||
@ -597,7 +598,7 @@ _gettimeofday (struct timeval * tp, struct timezone * tzp)
|
|||||||
|
|
||||||
/* Return a clock that ticks at 100Hz. */
|
/* Return a clock that ticks at 100Hz. */
|
||||||
clock_t
|
clock_t
|
||||||
_times (struct tms * tp)
|
_clock (void)
|
||||||
{
|
{
|
||||||
clock_t timeval;
|
clock_t timeval;
|
||||||
|
|
||||||
@ -606,6 +607,14 @@ _times (struct tms * tp)
|
|||||||
#else
|
#else
|
||||||
asm ("swi %a1; mov %0, r0" : "=r" (timeval): "i" (SWI_Clock) : "r0");
|
asm ("swi %a1; mov %0, r0" : "=r" (timeval): "i" (SWI_Clock) : "r0");
|
||||||
#endif
|
#endif
|
||||||
|
return timeval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return a clock that ticks at 100Hz. */
|
||||||
|
clock_t
|
||||||
|
_times (struct tms * tp)
|
||||||
|
{
|
||||||
|
clock_t timeval = _clock();
|
||||||
|
|
||||||
if (tp)
|
if (tp)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user