]> git.eshelyaron.com Git - emacs.git/commitdiff
Attempt to fix 64-bit AIX build
authorEli Zaretskii <eliz@gnu.org>
Fri, 23 Dec 2016 20:26:25 +0000 (22:26 +0200)
committerEli Zaretskii <eliz@gnu.org>
Fri, 23 Dec 2016 20:26:25 +0000 (22:26 +0200)
* src/unexaix.c (make_hdr, copy_text_and_data, write_segment): Fix
type-casts that assumed 32-bit pointers.  (Bug#25141)

src/unexaix.c

index c2012f77cac71183f9b112aa6455f43cf85b28a5..5685aee5480312989bdb17edb254cc137de3ef4e 100644 (file)
@@ -245,15 +245,15 @@ make_hdr (int new, int a_out,
 
       if (f_thdr == 0)
        {
-         ERROR1 ("unexec: couldn't find \"%s\" section", (int) _TEXT);
+         ERROR1 ("unexec: couldn't find \"%s\" section", _TEXT);
        }
       if (f_dhdr == 0)
        {
-         ERROR1 ("unexec: couldn't find \"%s\" section", (int) _DATA);
+         ERROR1 ("unexec: couldn't find \"%s\" section", _DATA);
        }
       if (f_bhdr == 0)
        {
-         ERROR1 ("unexec: couldn't find \"%s\" section", (int) _BSS);
+         ERROR1 ("unexec: couldn't find \"%s\" section", _BSS);
        }
     }
   else
@@ -382,7 +382,7 @@ copy_text_and_data (int new)
   write_segment (new, ptr, end);
 
   lseek (new, data_scnptr, SEEK_SET);
-  ptr = (char *) f_ohdr.data_start;
+  ptr = (char *) (ptrdiff_t) f_ohdr.data_start;
   end = ptr + f_ohdr.dsize;
   write_segment (new, ptr, end);
 
@@ -399,7 +399,7 @@ write_segment (int new, char *ptr, char *end)
   for (i = 0; ptr < end;)
     {
       /* distance to next block.  */
-      nwrite = (((int) ptr + UnexBlockSz) & -UnexBlockSz) - (int) ptr;
+      nwrite = (((ptrdiff_t) ptr + UnexBlockSz) & -UnexBlockSz) - (ptrdiff_t) ptr;
       /* But not beyond specified end.  */
       if (nwrite > end - ptr) nwrite = end - ptr;
       ret = write (new, ptr, nwrite);