Blame SOURCES/redhat-lsb-trigger.patch

eb24c2
--- redhat_lsb_trigger.c.triggerfix	2008-04-16 18:50:14.000000000 +0100
eb24c2
+++ redhat_lsb_trigger.c	2011-09-14 11:50:42.563080000 +0100
eb24c2
@@ -423,10 +423,76 @@
eb24c2
 #define is_ia64() 0
eb24c2
 #endif
eb24c2
 
eb24c2
+char *
eb24c2
+strtok (char *p, const char *delim)
eb24c2
+{
eb24c2
+  static char *olds;
eb24c2
+  const char *d;
eb24c2
+  char *token;
eb24c2
+  if (p == NULL)
eb24c2
+    p = olds;
eb24c2
+  while (*p)
eb24c2
+    {
eb24c2
+      for (d = delim; *d; d++)
eb24c2
+	if (*p == *d)
eb24c2
+	  break;
eb24c2
+      if (!*d)
eb24c2
+	break;
eb24c2
+      p++;
eb24c2
+    }
eb24c2
+  if (!*p)
eb24c2
+    {
eb24c2
+      olds = p;
eb24c2
+      return NULL;
eb24c2
+    }
eb24c2
+  token = p;
eb24c2
+  while (*p)
eb24c2
+    {
eb24c2
+      for (d = delim; *d; d++)
eb24c2
+	if (*p == *d)
eb24c2
+	  break;
eb24c2
+      if (*d)
eb24c2
+	break;
eb24c2
+      p++;
eb24c2
+    }
eb24c2
+  if (!*p)
eb24c2
+    olds = p;
eb24c2
+  else
eb24c2
+    {
eb24c2
+      *p = '\0';
eb24c2
+      olds = p + 1;
eb24c2
+    }
eb24c2
+  return token;
eb24c2
+}
eb24c2
+
eb24c2
+size_t
eb24c2
+strlen (const char *s)
eb24c2
+{
eb24c2
+  const char *p;
eb24c2
+  for (p = s; *p; ++p);
eb24c2
+  return p - s;
eb24c2
+}
eb24c2
+
eb24c2
+void *
eb24c2
+mempcpy (void *dst, const void *src, size_t n)
eb24c2
+{
eb24c2
+  char *d = dst;
eb24c2
+  const char *s = src;
eb24c2
+  while (n--)
eb24c2
+    *d++ = *s++;
eb24c2
+  return d;
eb24c2
+}
eb24c2
+
eb24c2
+char *
eb24c2
+strcpy (char *dst, const char *src)
eb24c2
+{
eb24c2
+  char *ret = dst;
eb24c2
+  while ((*dst++ = *src++) != '\0');
eb24c2
+  return ret;
eb24c2
+}
eb24c2
+
eb24c2
 int main (int argc, char **argv)
eb24c2
 {
eb24c2
-/* redhat_lsb_trigger.c:428: warning: unused variable 'ret' */
eb24c2
-/*  long ret; */ 
eb24c2
   INTERNAL_SYSCALL_DECL (err);
eb24c2
   char lsbsover[] = LSBSOVER;
eb24c2
   char *LSBVER, *p = lsbsover;
eb24c2
@@ -450,15 +516,38 @@
eb24c2
 int __libc_multiple_threads __attribute__((nocommon));
eb24c2
 int __libc_enable_asynccancel (void) { return 0; }
eb24c2
 void __libc_disable_asynccancel (int x) { }
eb24c2
+#ifndef __arm__
eb24c2
 void __libc_csu_init (void) { }
eb24c2
 void __libc_csu_fini (void) { }
eb24c2
+#endif
eb24c2
 pid_t __fork (void) { return -1; }
eb24c2
 char thr_buf[65536];
eb24c2
 
eb24c2
-#ifndef __powerpc__
eb24c2
+void
eb24c2
+__attribute__ ((noreturn))
eb24c2
+__stack_chk_fail (void)
eb24c2
+{
eb24c2
+  INTERNAL_SYSCALL_DECL (err);
eb24c2
+  while (1)
eb24c2
+    INTERNAL_SYSCALL (exit, err, 1, 1);
eb24c2
+}
eb24c2
+
eb24c2
+#if defined __powerpc__
eb24c2
+
eb24c2
+struct startup_info
eb24c2
+{
eb24c2
+  void *sda_base;
eb24c2
+  int (*main) (int, char **, char **, void *);
eb24c2
+  int (*init) (int, char **, char **, void *);
eb24c2
+  void (*fini) (void);
eb24c2
+};
eb24c2
+
eb24c2
+int __libc_start_main (int argc, char **argv, char **ev,
eb24c2
+		       void *auxvec, void (*rtld_fini) (void),
eb24c2
+		       struct startup_info *stinfo,
eb24c2
+		       char **stack_on_entry)
eb24c2
+#elif defined __arm__
eb24c2
 
eb24c2
-/* /usr/lib/gcc/ppc64-redhat-linux/4.1.2/../../../../lib64/libc.a(libc-start.o): In function `__libc_start_main':
eb24c2
- *  * (.opd+0x10): multiple definition of `__libc_start_main'  */
eb24c2
 int ___libc_start_main (int (*main) (int argc, char **argv),
eb24c2
                        int argc, char **argv,
eb24c2
 		       void (*init) (void), void (*fini) (void),
eb24c2
@@ -472,9 +561,7 @@
eb24c2
   void (*fini) (void);
eb24c2
 };
eb24c2
 
eb24c2
-/* /usr/lib/gcc/ppc64-redhat-linux/4.1.2/../../../../lib64/libc.a(libc-start.o): In function `__libc_start_main':
eb24c2
- * (.opd+0x10): multiple definition of `__libc_start_main'  */
eb24c2
-int ___libc_start_main (int argc, char **argv, char **ev,
eb24c2
+int __libc_start_main (int argc, char **argv, char **ev,
eb24c2
 		       void *auxvec, void (*rtld_fini) (void),
eb24c2
 		       struct startup_info *stinfo,
eb24c2
 		       char **stack_on_entry)