Loading...
--- Libc/Libc-320/sys/gettimeofday.c
+++ Libc/Libc-262.2.12/sys/gettimeofday.c
@@ -39,6 +39,17 @@
#include <machine/cpu_capabilities.h>
#undef __APPLE_API_PRIVATE
+#ifdef __ppc__
+#define expand(arg) strgfy(arg)
+#define strgfy(arg) #arg
+
+static __attribute__ ((noinline))
+int commpage_gettimeofday(struct timeval *tp)
+{
+ asm volatile("ba " expand(_COMM_PAGE_GETTIMEOFDAY) );
+ return 1;
+}
+#endif /* __ppc__ */
int gettimeofday (struct timeval *tp, struct timezone *tzp)
{
@@ -47,17 +58,14 @@
struct timeval localtv;
if (tp == NULL) {
- if (tzp == NULL)
- return (0);
tp = &localtv;
}
#ifdef __ppc__
{
extern int __ppc_gettimeofday(struct timeval *, struct timezone *);
- extern int __commpage_gettimeofday(struct timeval *);
- if (__commpage_gettimeofday(tp)) { /* first try commpage */
+ if (commpage_gettimeofday(tp)) { /* first try commpage */
if (__ppc_gettimeofday(tp,tzp)) { /* if it fails, use syscall */
return (-1);
}