Don't do compile time comparison of TARGET_PTR_BIT and TARGET_INT_BIT.
authorKevin Buettner <kevinb@redhat.com>
Fri, 24 Mar 2000 21:07:17 +0000 (21:07 +0000)
committerKevin Buettner <kevinb@redhat.com>
Fri, 24 Mar 2000 21:07:17 +0000 (21:07 +0000)
gdb/ChangeLog
gdb/lin-thread.c
gdb/linux-thread.c

index 5312fd93865bec079d3a606a10eb68208d37edce..41b7a768500344b25fac04d96b0de67d72eac21d 100644 (file)
@@ -1,3 +1,9 @@
+2000-03-24  Kevin Buettner  <kevinb@redhat.com>
+
+       * linux-thread.c, lin-thread.c (save_inferior_pid,
+       restore_inferior_pid): Don't do compile time comparison
+       of TARGET_PTR_BIT and TARGET_INT_BIT.
+
 Thu Mar 23 13:18:26 2000  Philippe De Muyter  <phdm@macqel.be>
 
        * m68k-tdep.c (P_LINKL_FP, P_LINKW_FP): Macros renamed from P_LINK_L
index a4f388dedb411073a46f7a34e99ce4ef96189cc5..de530f6888273c079d6dd309d917faf9f6ff060a 100644 (file)
@@ -658,21 +658,19 @@ init_thread_db_library ()
 static struct cleanup *
 save_inferior_pid (void)
 {
-#if TARGET_PTR_BIT > TARGET_INT_BIT
-  return make_cleanup (restore_inferior_pid, (void *) ((long) inferior_pid));
-#else
-  return make_cleanup (restore_inferior_pid, (void *) inferior_pid);
-#endif
+  int *saved_pid_ptr;
+  
+  saved_pid_ptr = xmalloc (sizeof (int));
+  *saved_pid_ptr = inferior_pid;
+  return make_cleanup (restore_inferior_pid, saved_pid_ptr);
 }
 
 static void
-restore_inferior_pid (void *saved_pid)
+restore_inferior_pid (void *arg)
 {
-#if TARGET_PTR_BIT > TARGET_INT_BIT
-  inferior_pid = (int) ((long) saved_pid);
-#else
-  inferior_pid = (int) saved_pid;
-#endif
+  int *saved_pid_ptr = arg;
+  inferior_pid = *saved_pid_ptr;
+  free (arg);
 }
 
 /*
index 2b9597db45f004c17c3fcfe83f967bde81496f62..146481c6ac8eaed9126371453767ab700795d728 100644 (file)
@@ -378,25 +378,22 @@ linuxthreads_find_trap (pid, stop)
 
 /* Cleanup stub for save_inferior_pid.  */
 static void
-restore_inferior_pid (arg)
-    void *arg;
+restore_inferior_pid (void *arg)
 {
-#if TARGET_PTR_BIT > TARGET_INT_BIT
-  inferior_pid = (int) ((long) arg);
-#else
-  inferior_pid = (int) arg;
-#endif
+  int *saved_pid_ptr = arg;
+  inferior_pid = *saved_pid_ptr;
+  free (arg);
 }
 
 /* Register a cleanup to restore the value of inferior_pid.  */
 static struct cleanup *
-save_inferior_pid ()
+save_inferior_pid (void)
 {
-#if TARGET_PTR_BIT > TARGET_INT_BIT
-  return make_cleanup (restore_inferior_pid, (void *) ((long) inferior_pid));
-#else
-  return make_cleanup (restore_inferior_pid, (void *) inferior_pid);
-#endif
+  int *saved_pid_ptr;
+  
+  saved_pid_ptr = xmalloc (sizeof (int));
+  *saved_pid_ptr = inferior_pid;
+  return make_cleanup (restore_inferior_pid, saved_pid_ptr);
 }
 
 static void