tags 391516 + patch
quit

On Mon, Oct 16, 2006 at 12:49:39AM +0200, Stefan Westerfeld wrote:
> I can confirm that the problem exists on Debian/AMD64. Maybe this link
> which I found with google helps to solve the problem:
> 
> http://lists.freebsd.org/pipermail/freebsd-amd64/2005-January/003173.html
> 
> The mail refers to a freebsd cfs tarball which was modified to be 64bit
> clean. Probably the relevant changes made to that version of cfs could
> be backfolded into the Debian package.

Hi Stefan, thanks a lot for this pointer.  I found a patch that needs
just slight modifications to apply to the Debian package source.

Regards, Gerrit.
Index: cfs.h
===================================================================
RCS file: /cvs/cfs/cfs.h,v
retrieving revision 1.4
diff -u -r1.4 cfs.h
--- cfs.h       31 Mar 2002 14:59:52 -0000      1.4
+++ cfs.h       16 Oct 2006 10:06:29 -0000
@@ -23,6 +23,8 @@
 #include "safer.h"
 #include "cfs_bf.h"
 
+#include <inttypes.h>
+
 #define H_REG 0
 #define H_ATTACH 0     /* same as regular */
 #define H_ROOT 1
@@ -57,10 +59,10 @@
        u_char magic[8];/* 0x0123456789abcdef */
        u_short htype;  /* 0=reg, 1=attachpt, 2=root(but notused) */
        u_short instance;       /* which attach */
-       u_long fileid;  /* inode # */
+       uint32_t fileid;        /* inode # */
        u_char check[8];/* we just encrypt the date and copy it here */
 #ifdef SHORTLINKS
-       u_long linkid;  /* To uniquify short links */
+       uint32_t linkid;        /* To uniquify short links */
        u_char pad[4];  /* empty */
 #else
        u_char pad[8];  /* empty */
Index: cfs_bf.h
===================================================================
RCS file: /cvs/cfs/cfs_bf.h,v
retrieving revision 1.2
diff -u -r1.2 cfs_bf.h
--- cfs_bf.h    8 Oct 2001 03:10:18 -0000       1.2
+++ cfs_bf.h    16 Oct 2006 10:06:29 -0000
@@ -70,7 +70,7 @@
  * the Alpha, otherwise they will not.  Strangly using the '8 byte'
  * BF_LONG and the default 'non-pointer' inner loop is the best configuration
  * for the Alpha */
-#define BF_LONG unsigned long
+#define BF_LONG unsigned int
 
 #define BF_ROUNDS      16
 #define BF_BLOCK       8
Index: cfs_des.c
===================================================================
RCS file: /cvs/cfs/cfs_des.c,v
retrieving revision 1.1.1.1
diff -u -r1.1.1.1 cfs_des.c
--- cfs_des.c   8 Oct 2001 02:24:39 -0000       1.1.1.1
+++ cfs_des.c   16 Oct 2006 10:06:31 -0000
@@ -22,13 +22,15 @@
  *     block_cipher(key, block, decrypting)
  */
 
+#include <inttypes.h>
+
 #ifdef SOLARIS2X
 #define bcopy(s, d, l)         memcpy(d, s, l)
 #define bcmp(s, d, l)          (memcmp(s, d, l)? 1 : 0)
 #endif
 
-static long    ip_low();
-static long    ip_high();
+static int32_t ip_low();
+static int32_t ip_high();
 static void    fp();
 void   des_key_setup();
 
@@ -36,7 +38,7 @@
  *     Tables for Combined S and P Boxes
  */
 
-static long  s0p[] = {
+static int32_t  s0p[] = {
 
0x00410100,0x00010000,0x40400000,0x40410100,0x00400000,0x40010100,0x40010000,0x40400000,
 
0x40010100,0x00410100,0x00410000,0x40000100,0x40400100,0x00400000,0x00000000,0x40010000,
 
0x00010000,0x40000000,0x00400100,0x00010100,0x40410100,0x00410000,0x40000100,0x00400100,
@@ -47,7 +49,7 @@
 
0x00010000,0x00400000,0x40400100,0x00410100,0x40000000,0x40410000,0x00000100,0x40010100,
 };
 
-static long  s1p[] = {
+static int32_t  s1p[] = {
 
0x08021002,0x00000000,0x00021000,0x08020000,0x08000002,0x00001002,0x08001000,0x00021000,
 
0x00001000,0x08020002,0x00000002,0x08001000,0x00020002,0x08021000,0x08020000,0x00000002,
 
0x00020000,0x08001002,0x08020002,0x00001000,0x00021002,0x08000000,0x00000000,0x00020002,
@@ -58,7 +60,7 @@
 
0x08020002,0x00020000,0x00001002,0x08001000,0x08001002,0x00000002,0x08020000,0x00021000,
 };
 
-static long  s2p[] = {
+static int32_t  s2p[] = {
 
0x20800000,0x00808020,0x00000020,0x20800020,0x20008000,0x00800000,0x20800020,0x00008020,
 
0x00800020,0x00008000,0x00808000,0x20000000,0x20808020,0x20000020,0x20000000,0x20808000,
 
0x00000000,0x20008000,0x00808020,0x00000020,0x20000020,0x20808020,0x00008000,0x20800000,
@@ -69,7 +71,7 @@
 
0x00800020,0x00000000,0x20808000,0x20000020,0x20800000,0x20008020,0x00000020,0x00808000,
 };
 
-static long  s3p[] = {
+static int32_t  s3p[] = {
 
0x00080201,0x02000200,0x00000001,0x02080201,0x00000000,0x02080000,0x02000201,0x00080001,
 
0x02080200,0x02000001,0x02000000,0x00000201,0x02000001,0x00080201,0x00080000,0x02000000,
 
0x02080001,0x00080200,0x00000200,0x00000001,0x00080200,0x02000201,0x02080000,0x00000200,
@@ -80,7 +82,7 @@
 
0x00080001,0x00080200,0x02080000,0x02000201,0x00000201,0x02000000,0x02000001,0x02080200,
 };
 
-static long  s4p[] = {
+static int32_t  s4p[] = {
 
0x01000000,0x00002000,0x00000080,0x01002084,0x01002004,0x01000080,0x00002084,0x01002000,
 
0x00002000,0x00000004,0x01000004,0x00002080,0x01000084,0x01002004,0x01002080,0x00000000,
 
0x00002080,0x01000000,0x00002004,0x00000084,0x01000080,0x00002084,0x00000000,0x01000004,
@@ -91,7 +93,7 @@
 
0x00002080,0x01002004,0x01000080,0x00000084,0x00000004,0x00002084,0x01002000,0x01000004,
 };
 
-static long  s5p[] = {
+static int32_t  s5p[] = {
 
0x10000008,0x00040008,0x00000000,0x10040400,0x00040008,0x00000400,0x10000408,0x00040000,
 
0x00000408,0x10040408,0x00040400,0x10000000,0x10000400,0x10000008,0x10040000,0x00040408,
 
0x00040000,0x10000408,0x10040008,0x00000000,0x00000400,0x00000008,0x10040400,0x10040008,
@@ -102,7 +104,7 @@
 
0x00000400,0x10000008,0x10000408,0x10040400,0x10040000,0x00000408,0x00000008,0x10040008,
 };
 
-static long  s6p[] = {
+static int32_t  s6p[] = {
 
0x00000800,0x00000040,0x00200040,0x80200000,0x80200840,0x80000800,0x00000840,0x00000000,
 
0x00200000,0x80200040,0x80000040,0x00200800,0x80000000,0x00200840,0x00200800,0x80000040,
 
0x80200040,0x00000800,0x80000800,0x80200840,0x00000000,0x00200040,0x80200000,0x00000840,
@@ -113,7 +115,7 @@
 
0x00200840,0x80000000,0x80000800,0x80200840,0x80200000,0x00200840,0x00200800,0x80000800,
 };
 
-static long  s7p[] = {
+static int32_t  s7p[] = {
 
0x04100010,0x04104000,0x00004010,0x00000000,0x04004000,0x00100010,0x04100000,0x04104010,
 
0x00000010,0x04000000,0x00104000,0x00004010,0x00104010,0x04004010,0x04000010,0x04100000,
 
0x00004000,0x00104010,0x00100010,0x04004000,0x04104010,0x04000010,0x00000000,0x00104000,
@@ -134,8 +136,8 @@
 int decrypting;
 {
        register char *key;
-       register long temp;
-       register long left, right;
+       register int32_t temp;
+       register int32_t left, right;
        register i;
        register key_offset;
        int j,k;
@@ -199,8 +201,8 @@
 int decrypting;
 {
        register char *key;
-       register long temp;
-       register long left, right;
+       register int32_t temp;
+       register int32_t left, right;
        register i;
        register key_offset;
 
@@ -240,78 +242,78 @@
 /*
  *     Final Permutation
  */
-static long    fph0[16] = {
+static int32_t fph0[16] = {
 
0x00000000,0x40000000,0x00400000,0x40400000,0x00004000,0x40004000,0x00404000,0x40404000,
 
0x00000040,0x40000040,0x00400040,0x40400040,0x00004040,0x40004040,0x00404040,0x40404040,
 };
-static long    fpl1[16] = {
+static int32_t fpl1[16] = {
 
0x00000000,0x40000000,0x00400000,0x40400000,0x00004000,0x40004000,0x00404000,0x40404000,
 
0x00000040,0x40000040,0x00400040,0x40400040,0x00004040,0x40004040,0x00404040,0x40404040,
 };
-static long    fph2[16] = {
+static int32_t fph2[16] = {
 
0x00000000,0x10000000,0x00100000,0x10100000,0x00001000,0x10001000,0x00101000,0x10101000,
 
0x00000010,0x10000010,0x00100010,0x10100010,0x00001010,0x10001010,0x00101010,0x10101010,
 };
-static long    fpl3[16] = {
+static int32_t fpl3[16] = {
 
0x00000000,0x10000000,0x00100000,0x10100000,0x00001000,0x10001000,0x00101000,0x10101000,
 
0x00000010,0x10000010,0x00100010,0x10100010,0x00001010,0x10001010,0x00101010,0x10101010,
 };
-static long    fph4[16] = {
+static int32_t fph4[16] = {
 
0x00000000,0x04000000,0x00040000,0x04040000,0x00000400,0x04000400,0x00040400,0x04040400,
 
0x00000004,0x04000004,0x00040004,0x04040004,0x00000404,0x04000404,0x00040404,0x04040404,
 };
-static long    fpl5[16] = {
+static int32_t fpl5[16] = {
 
0x00000000,0x04000000,0x00040000,0x04040000,0x00000400,0x04000400,0x00040400,0x04040400,
 
0x00000004,0x04000004,0x00040004,0x04040004,0x00000404,0x04000404,0x00040404,0x04040404,
 };
-static long    fph6[16] = {
+static int32_t fph6[16] = {
 
0x00000000,0x01000000,0x00010000,0x01010000,0x00000100,0x01000100,0x00010100,0x01010100,
 
0x00000001,0x01000001,0x00010001,0x01010001,0x00000101,0x01000101,0x00010101,0x01010101,
 };
-static long    fpl7[16] = {
+static int32_t fpl7[16] = {
 
0x00000000,0x01000000,0x00010000,0x01010000,0x00000100,0x01000100,0x00010100,0x01010100,
 
0x00000001,0x01000001,0x00010001,0x01010001,0x00000101,0x01000101,0x00010101,0x01010101,
 };
-static long    fph8[16] = {
+static int32_t fph8[16] = {
 
0x00000000,0x80000000,0x00800000,0x80800000,0x00008000,0x80008000,0x00808000,0x80808000,
 
0x00000080,0x80000080,0x00800080,0x80800080,0x00008080,0x80008080,0x00808080,0x80808080,
 };
-static long    fpl9[16] = {
+static int32_t fpl9[16] = {
 
0x00000000,0x80000000,0x00800000,0x80800000,0x00008000,0x80008000,0x00808000,0x80808000,
 
0x00000080,0x80000080,0x00800080,0x80800080,0x00008080,0x80008080,0x00808080,0x80808080,
 };
-static long    fpha[16] = {
+static int32_t fpha[16] = {
 
0x00000000,0x20000000,0x00200000,0x20200000,0x00002000,0x20002000,0x00202000,0x20202000,
 
0x00000020,0x20000020,0x00200020,0x20200020,0x00002020,0x20002020,0x00202020,0x20202020,
 };
-static long    fplb[16] = {
+static int32_t fplb[16] = {
 
0x00000000,0x20000000,0x00200000,0x20200000,0x00002000,0x20002000,0x00202000,0x20202000,
 
0x00000020,0x20000020,0x00200020,0x20200020,0x00002020,0x20002020,0x00202020,0x20202020,
 };
-static long    fphc[16] = {
+static int32_t fphc[16] = {
 
0x00000000,0x08000000,0x00080000,0x08080000,0x00000800,0x08000800,0x00080800,0x08080800,
 
0x00000008,0x08000008,0x00080008,0x08080008,0x00000808,0x08000808,0x00080808,0x08080808,
 };
-static long    fpld[16] = {
+static int32_t fpld[16] = {
 
0x00000000,0x08000000,0x00080000,0x08080000,0x00000800,0x08000800,0x00080800,0x08080800,
 
0x00000008,0x08000008,0x00080008,0x08080008,0x00000808,0x08000808,0x00080808,0x08080808,
 };
-static long    fphe[16] = {
+static int32_t fphe[16] = {
 
0x00000000,0x02000000,0x00020000,0x02020000,0x00000200,0x02000200,0x00020200,0x02020200,
 
0x00000002,0x02000002,0x00020002,0x02020002,0x00000202,0x02000202,0x00020202,0x02020202,
 };
-static long    fplf[16] = {
+static int32_t fplf[16] = {
 
0x00000000,0x02000000,0x00020000,0x02020000,0x00000200,0x02000200,0x00020200,0x02020200,
 
0x00000002,0x02000002,0x00020002,0x02020002,0x00000202,0x02000202,0x00020202,0x02020202,
 };
 
 static void
 fp(left, right, text)
-long left, right;
+int32_t left, right;
 char text[8];
 {
-       register unsigned long low, high;
-       register unsigned long temp;
+       register uint32_t low, high;
+       register uint32_t temp;
 
        temp = left;
        high = fph0[temp & 0xf];
@@ -358,140 +360,140 @@
 /*
  *     Initial Permutation
  */
-static long    ipl0[16] = {
+static int32_t ipl0[16] = {
 0x00000000,
 
0x00008000,0x00000000,0x00008000,0x00000080,0x00008080,0x00000080,0x00008080,0x00000000,
 0x00008000,0x00000000,0x00008000,0x00000080,0x00008080,0x00000080,0x00008080,};
-static long    iph0[16] = {
+static int32_t iph0[16] = {
 0x00000000,
 
0x00000000,0x00008000,0x00008000,0x00000000,0x00000000,0x00008000,0x00008000,0x00000080,
 0x00000080,0x00008080,0x00008080,0x00000080,0x00000080,0x00008080,0x00008080,};
-static long    ipl1[16] = {
+static int32_t ipl1[16] = {
 0x00000000,
 
0x80000000,0x00000000,0x80000000,0x00800000,0x80800000,0x00800000,0x80800000,0x00000000,
 0x80000000,0x00000000,0x80000000,0x00800000,0x80800000,0x00800000,0x80800000,};
-static long    iph1[16] = {
+static int32_t iph1[16] = {
 0x00000000,
 
0x00000000,0x80000000,0x80000000,0x00000000,0x00000000,0x80000000,0x80000000,0x00800000,
 0x00800000,0x80800000,0x80800000,0x00800000,0x00800000,0x80800000,0x80800000,};
-static long    ipl2[16] = {
+static int32_t ipl2[16] = {
 0x00000000,
 
0x00004000,0x00000000,0x00004000,0x00000040,0x00004040,0x00000040,0x00004040,0x00000000,
 0x00004000,0x00000000,0x00004000,0x00000040,0x00004040,0x00000040,0x00004040,};
-static long    iph2[16] = {
+static int32_t iph2[16] = {
 0x00000000,
 
0x00000000,0x00004000,0x00004000,0x00000000,0x00000000,0x00004000,0x00004000,0x00000040,
 0x00000040,0x00004040,0x00004040,0x00000040,0x00000040,0x00004040,0x00004040,};
-static long    ipl3[16] = {
+static int32_t ipl3[16] = {
 0x00000000,
 
0x40000000,0x00000000,0x40000000,0x00400000,0x40400000,0x00400000,0x40400000,0x00000000,
 0x40000000,0x00000000,0x40000000,0x00400000,0x40400000,0x00400000,0x40400000,};
-static long    iph3[16] = {
+static int32_t iph3[16] = {
 0x00000000,
 
0x00000000,0x40000000,0x40000000,0x00000000,0x00000000,0x40000000,0x40000000,0x00400000,
 0x00400000,0x40400000,0x40400000,0x00400000,0x00400000,0x40400000,0x40400000,};
-static long    ipl4[16] = {
+static int32_t ipl4[16] = {
 0x00000000,
 
0x00002000,0x00000000,0x00002000,0x00000020,0x00002020,0x00000020,0x00002020,0x00000000,
 0x00002000,0x00000000,0x00002000,0x00000020,0x00002020,0x00000020,0x00002020,};
-static long    iph4[16] = {
+static int32_t iph4[16] = {
 0x00000000,
 
0x00000000,0x00002000,0x00002000,0x00000000,0x00000000,0x00002000,0x00002000,0x00000020,
 0x00000020,0x00002020,0x00002020,0x00000020,0x00000020,0x00002020,0x00002020,};
-static long    ipl5[16] = {
+static int32_t ipl5[16] = {
 0x00000000,
 
0x20000000,0x00000000,0x20000000,0x00200000,0x20200000,0x00200000,0x20200000,0x00000000,
 0x20000000,0x00000000,0x20000000,0x00200000,0x20200000,0x00200000,0x20200000,};
-static long    iph5[16] = {
+static int32_t iph5[16] = {
 0x00000000,
 
0x00000000,0x20000000,0x20000000,0x00000000,0x00000000,0x20000000,0x20000000,0x00200000,
 0x00200000,0x20200000,0x20200000,0x00200000,0x00200000,0x20200000,0x20200000,};
-static long    ipl6[16] = {
+static int32_t ipl6[16] = {
 0x00000000,
 
0x00001000,0x00000000,0x00001000,0x00000010,0x00001010,0x00000010,0x00001010,0x00000000,
 0x00001000,0x00000000,0x00001000,0x00000010,0x00001010,0x00000010,0x00001010,};
-static long    iph6[16] = {
+static int32_t iph6[16] = {
 0x00000000,
 
0x00000000,0x00001000,0x00001000,0x00000000,0x00000000,0x00001000,0x00001000,0x00000010,
 0x00000010,0x00001010,0x00001010,0x00000010,0x00000010,0x00001010,0x00001010,};
-static long    ipl7[16] = {
+static int32_t ipl7[16] = {
 0x00000000,
 
0x10000000,0x00000000,0x10000000,0x00100000,0x10100000,0x00100000,0x10100000,0x00000000,
 0x10000000,0x00000000,0x10000000,0x00100000,0x10100000,0x00100000,0x10100000,};
-static long    iph7[16] = {
+static int32_t iph7[16] = {
 0x00000000,
 
0x00000000,0x10000000,0x10000000,0x00000000,0x00000000,0x10000000,0x10000000,0x00100000,
 0x00100000,0x10100000,0x10100000,0x00100000,0x00100000,0x10100000,0x10100000,};
-static long    ipl8[16] = {
+static int32_t ipl8[16] = {
 0x00000000,
 
0x00000800,0x00000000,0x00000800,0x00000008,0x00000808,0x00000008,0x00000808,0x00000000,
 0x00000800,0x00000000,0x00000800,0x00000008,0x00000808,0x00000008,0x00000808,};
-static long    iph8[16] = {
+static int32_t iph8[16] = {
 0x00000000,
 
0x00000000,0x00000800,0x00000800,0x00000000,0x00000000,0x00000800,0x00000800,0x00000008,
 0x00000008,0x00000808,0x00000808,0x00000008,0x00000008,0x00000808,0x00000808,};
-static long    ipl9[16] = {
+static int32_t ipl9[16] = {
 0x00000000,
 
0x08000000,0x00000000,0x08000000,0x00080000,0x08080000,0x00080000,0x08080000,0x00000000,
 0x08000000,0x00000000,0x08000000,0x00080000,0x08080000,0x00080000,0x08080000,};
-static long    iph9[16] = {
+static int32_t iph9[16] = {
 0x00000000,
 
0x00000000,0x08000000,0x08000000,0x00000000,0x00000000,0x08000000,0x08000000,0x00080000,
 0x00080000,0x08080000,0x08080000,0x00080000,0x00080000,0x08080000,0x08080000,};
-static long    ipla[16] = {
+static int32_t ipla[16] = {
 0x00000000,
 
0x00000400,0x00000000,0x00000400,0x00000004,0x00000404,0x00000004,0x00000404,0x00000000,
 0x00000400,0x00000000,0x00000400,0x00000004,0x00000404,0x00000004,0x00000404,};
-static long    ipha[16] = {
+static int32_t ipha[16] = {
 0x00000000,
 
0x00000000,0x00000400,0x00000400,0x00000000,0x00000000,0x00000400,0x00000400,0x00000004,
 0x00000004,0x00000404,0x00000404,0x00000004,0x00000004,0x00000404,0x00000404,};
-static long    iplb[16] = {
+static int32_t iplb[16] = {
 0x00000000,
 
0x04000000,0x00000000,0x04000000,0x00040000,0x04040000,0x00040000,0x04040000,0x00000000,
 0x04000000,0x00000000,0x04000000,0x00040000,0x04040000,0x00040000,0x04040000,};
-static long    iphb[16] = {
+static int32_t iphb[16] = {
 0x00000000,
 
0x00000000,0x04000000,0x04000000,0x00000000,0x00000000,0x04000000,0x04000000,0x00040000,
 0x00040000,0x04040000,0x04040000,0x00040000,0x00040000,0x04040000,0x04040000,};
-static long    iplc[16] = {
+static int32_t iplc[16] = {
 0x00000000,
 
0x00000200,0x00000000,0x00000200,0x00000002,0x00000202,0x00000002,0x00000202,0x00000000,
 0x00000200,0x00000000,0x00000200,0x00000002,0x00000202,0x00000002,0x00000202,};
-static long    iphc[16] = {
+static int32_t iphc[16] = {
 0x00000000,
 
0x00000000,0x00000200,0x00000200,0x00000000,0x00000000,0x00000200,0x00000200,0x00000002,
 0x00000002,0x00000202,0x00000202,0x00000002,0x00000002,0x00000202,0x00000202,};
-static long    ipld[16] = {
+static int32_t ipld[16] = {
 0x00000000,
 
0x02000000,0x00000000,0x02000000,0x00020000,0x02020000,0x00020000,0x02020000,0x00000000,
 0x02000000,0x00000000,0x02000000,0x00020000,0x02020000,0x00020000,0x02020000,};
-static long    iphd[16] = {
+static int32_t iphd[16] = {
 0x00000000,
 
0x00000000,0x02000000,0x02000000,0x00000000,0x00000000,0x02000000,0x02000000,0x00020000,
 0x00020000,0x02020000,0x02020000,0x00020000,0x00020000,0x02020000,0x02020000,};
-static long    iple[16] = {
+static int32_t iple[16] = {
 0x00000000,
 
0x00000100,0x00000000,0x00000100,0x00000001,0x00000101,0x00000001,0x00000101,0x00000000,
 0x00000100,0x00000000,0x00000100,0x00000001,0x00000101,0x00000001,0x00000101,};
-static long    iphe[16] = {
+static int32_t iphe[16] = {
 0x00000000,
 
0x00000000,0x00000100,0x00000100,0x00000000,0x00000000,0x00000100,0x00000100,0x00000001,
 0x00000001,0x00000101,0x00000101,0x00000001,0x00000001,0x00000101,0x00000101,};
-static long    iplf[16] = {
+static int32_t iplf[16] = {
 0x00000000,
 
0x01000000,0x00000000,0x01000000,0x00010000,0x01010000,0x00010000,0x01010000,0x00000000,
 0x01000000,0x00000000,0x01000000,0x00010000,0x01010000,0x00010000,0x01010000,};
-static long    iphf[16] = {
+static int32_t iphf[16] = {
 0x00000000,
 
0x00000000,0x01000000,0x01000000,0x00000000,0x00000000,0x01000000,0x01000000,0x00010000,
 0x00010000,0x01010000,0x01010000,0x00010000,0x00010000,0x01010000,0x01010000,};
 
-static long
+static int32_t
 ip_low(block)
 register char block[8];
 {
-       register long l;
+       register int32_t l;
 
        l  = ipl1[block[0] & 0xf];
        l |= ipl0[(block[0] >> 4) & 0xf];
@@ -512,11 +514,11 @@
        return l;
 }
 
-static long
+static int32_t
 ip_high(block)
 register char block[8];
 {
-       register long l;
+       register int32_t l;
 
        l  = iph1[block[0] & 0xf];
        l |= iph0[(block[0] >> 4) & 0xf];
@@ -962,7 +964,7 @@
   int size;
 {
     int i;
-    struct {long fo; char key[9];} s;
+    struct {int32_t fo; char key[9];} s;
 
     bcopy("encrypt!",s.key,8);
 
Index: cfs_fh.c
===================================================================
RCS file: /cvs/cfs/cfs_fh.c,v
retrieving revision 1.9
diff -u -r1.9 cfs_fh.c
--- cfs_fh.c    11 Jul 2006 21:01:24 -0000      1.9
+++ cfs_fh.c    16 Oct 2006 10:06:32 -0000
@@ -61,7 +61,7 @@
 }
 #endif
 
-#define hash(x) ((u_long)((x)&HMASK))
+#define hash(x) ((uint32_t)((x)&HMASK))
 int inst = 0;/* starting point */
 instance *instances[NINSTANCES];
 
@@ -135,7 +135,6 @@
        int headlen;
        int writemore=0;
        struct stat sb;
-       u_long mask = ~0;       /*tells us whether to expand file */
        char buf[8216]; /* big enough, may not even need it */
 
        /* first, normalize to the proper boundries */
@@ -833,7 +832,7 @@
        char vect[9];
        union{
                u_char ch[9];
-               u_long i[2];
+               uint32_t i[2];
        } buf;
        char linkname[NFS_MAXPATHLEN+1];
        
@@ -862,8 +861,8 @@
                /*
                sprintf((char 
*)buf,"%08x",(u_long)sb.st_ino+(u_long)sb.st_ctime);
                */
-               buf.i[0]=(u_long)sb.st_ino;
-               buf.i[1]=(u_long)sb.st_ctime;
+               buf.i[0]=(uint32_t)sb.st_ino;
+               buf.i[1]=(uint32_t)sb.st_ctime;
                q_block_cipher("fixedkey",&buf,1);
                /* des is just used here as a hash fn to spread the bits */
                /* since we only use 32 bits of the result, its a nonperfect */
@@ -1228,7 +1227,7 @@
    break anything */
 struct dirent *
 rootrd(cookie)
-     long cookie;
+     int32_t cookie;
 {
        static struct dirent d;
 
Index: cfs_nfs.c
===================================================================
RCS file: /cvs/cfs/cfs_nfs.c,v
retrieving revision 1.3
diff -u -r1.3 cfs_nfs.c
--- cfs_nfs.c   2 Apr 2004 20:14:02 -0000       1.3
+++ cfs_nfs.c   16 Oct 2006 10:06:32 -0000
@@ -843,12 +843,11 @@
        static DIR *dp=NULL;
        static struct dirent *dent;
        entry **prev;
-       long loc;
        char s1[NFS_MAXNAMLEN+1];
        char *s;
        cfskey *key;
-       static long curcookie=0;
-       long cookie;
+       static int32_t curcookie=0;
+       int32_t cookie;
        int eof;
        int ne;
        int bytes;
@@ -910,7 +909,7 @@
                else if (strcmp(s,"..")==0)     /* parent */
                        entrytab[ne].fileid=fhpid(h);
                else entrytab[ne].fileid=dent->d_fileno;
-               *(unsigned long*)entrytab[ne].cookie = htonl(cookie);
+               *(int32_t*)entrytab[ne].cookie = htonl(cookie);
                *prev = &entrytab[ne];
                prev = &entrytab[ne].nextentry;
                entrytab[ne].nextentry=NULL;
@@ -930,12 +929,12 @@
 
 DIR *curdir;
 int curdirid=0;
-long curcookie;
+int32_t curcookie;
 
 DIR *
 cfsopendir(dir,cookie)
      cfs_fileid *dir;
-     long cookie;
+     int32_t cookie;
 {
        DIR *ret;
        DIR *fhopendir();
@@ -1115,7 +1114,7 @@
        typedef char str[NFS_MAXNAMLEN+1];
        static str names[MAXENTRIES];
        entry **prev;
-       long cookie;
+       int32_t cookie;
        int eof;
        int ne;
        int bytes;
@@ -1127,7 +1126,7 @@
        ne=0;
        prev= &ret.readdirres_u.reply.entries;
        *prev=NULL;
-       cookie = ntohl(*(unsigned long*)(ap->cookie));
+       cookie = ntohl(*(int32_t*)(ap->cookie));
        eof=1;
        
        ret.status=NFS_OK;
@@ -1146,7 +1145,7 @@
                else entrytab[ne].fileid=dent->d_fileno;
                cookie=dent->d_reclen;  /* may not work everywhere */
                *prev = &entrytab[ne];
-               *(unsigned long*)entrytab[ne].cookie = htonl(cookie);
+               *(int32_t*)entrytab[ne].cookie = htonl(cookie);
                prev = &entrytab[ne].nextentry;
                entrytab[ne].nextentry=NULL;
                ne++;
Index: esm_cipher.c
===================================================================
RCS file: /cvs/cfs/esm_cipher.c,v
retrieving revision 1.1.1.1
diff -u -r1.1.1.1 esm_cipher.c
--- esm_cipher.c        8 Oct 2001 02:24:39 -0000       1.1.1.1
+++ esm_cipher.c        16 Oct 2006 10:06:33 -0000
@@ -157,7 +157,7 @@
        unsigned int n;
        int i;
        struct timeval tv;
-       unsigned long truerand();
+       uint32_t truerand();
        unsigned char b[20];
        
        R_RandomInit(&rs);
Index: shs.c
===================================================================
RCS file: /cvs/cfs/shs.c,v
retrieving revision 1.1.1.1
diff -u -r1.1.1.1 shs.c
--- shs.c       8 Oct 2001 02:24:39 -0000       1.1.1.1
+++ shs.c       16 Oct 2006 10:06:33 -0000
@@ -50,9 +50,9 @@
 #include <stdio.h>
 #include "shs.h"
 
-static long nbits;
-static unsigned long *h;
-static unsigned long *w;
+static int32_t nbits;
+static uint32_t *h;
+static uint32_t *w;
 static void shs1();
 /*
 static void packl (unsigned long);
@@ -61,7 +61,7 @@
 static void opack(unsigned char);
 */
 
-#define MASK        (unsigned long)0xffffffffL        /* in case more than 32 
bits per long */
+#define MASK        (uint32_t)0xffffffffL        /* in case more than 32 bits 
per long */
 
 /*
  * stick one byte into the current block; process the block when full
@@ -70,14 +70,14 @@
   unsigned char c;
 {
        int n32, nd32, shiftbits;
-       register unsigned long x, mask, y;
+       register uint32_t x, mask, y;
        
        nd32 = (int)(nbits >> 5);  /* nbits/32 */
        n32 = (int)(nbits & 0x1f); /* nbits%32 */
        shiftbits = 24-n32;
        
-       x = (unsigned long)(c<<shiftbits);
-       mask = (unsigned long)(0xff << shiftbits);
+       x = (uint32_t)(c<<shiftbits);
+       mask = (uint32_t)(0xff << shiftbits);
        mask = ~mask;
        
        y = w[nd32];
@@ -97,7 +97,7 @@
        int nd32;
        
        nd32 = (int)(nbits >> 5);
-       w[nd32] = (u_long)(((u_long)c0<<24) | ((u_long)c1<<16) | 
((u_long)c2<<8) | (u_long)c3);
+       w[nd32] = (uint32_t)(((uint32_t)c0<<24) | ((uint32_t)c1<<16) | 
((uint32_t)c2<<8) | (uint32_t)c3);
        
        nbits += 32;
        if(nbits==512){
@@ -111,7 +111,7 @@
  */
 static void
 packl(x)
-  unsigned long x;
+  uint32_t x;
 {
        pack((unsigned char)(x>>24), (unsigned char)(x>>16),
             (unsigned char)(x>>8), (unsigned char)(x>>0));
@@ -123,24 +123,24 @@
 static void
 shs1()
 {
-       unsigned long *wp;
-       unsigned long temp;
-       unsigned long A, B, C, D, E;
+       uint32_t *wp;
+       uint32_t temp;
+       uint32_t A, B, C, D, E;
        int t;
        
-#define S(n,x) (u_long)(((x)<<(n))|((MASK&(x))>>(32-(n))))
+#define S(n,x) (uint32_t)(((x)<<(n))|((MASK&(x))>>(32-(n))))
        
        wp = w;
        t = 8;
        do {
-               wp[16] = S(1, (u_long)(wp[13]^wp[8]^wp[2]^wp[0]));
-               wp[17] = S(1, (u_long)(wp[14]^wp[9]^wp[3]^wp[1]));
-               wp[18] = S(1, (u_long)(wp[15]^wp[10]^wp[4]^wp[2]));
-               wp[19] = S(1, (u_long)(wp[16]^wp[11]^wp[5]^wp[3]));
-               wp[20] = S(1, (u_long)(wp[17]^wp[12]^wp[6]^wp[4]));
-               wp[21] = S(1, (u_long)(wp[18]^wp[13]^wp[7]^wp[5]));
-               wp[22] = S(1, (u_long)(wp[19]^wp[14]^wp[8]^wp[6]));
-               wp[23] = S(1, (u_long)(wp[20]^wp[15]^wp[9]^wp[7]));
+               wp[16] = S(1, (uint32_t)(wp[13]^wp[8]^wp[2]^wp[0]));
+               wp[17] = S(1, (uint32_t)(wp[14]^wp[9]^wp[3]^wp[1]));
+               wp[18] = S(1, (uint32_t)(wp[15]^wp[10]^wp[4]^wp[2]));
+               wp[19] = S(1, (uint32_t)(wp[16]^wp[11]^wp[5]^wp[3]));
+               wp[20] = S(1, (uint32_t)(wp[17]^wp[12]^wp[6]^wp[4]));
+               wp[21] = S(1, (uint32_t)(wp[18]^wp[13]^wp[7]^wp[5]));
+               wp[22] = S(1, (uint32_t)(wp[19]^wp[14]^wp[8]^wp[6]));
+               wp[23] = S(1, (uint32_t)(wp[20]^wp[15]^wp[9]^wp[7]));
                wp += 8;
                t--;
        } while (t > 0);
@@ -154,22 +154,22 @@
        t = 0;
        while (t<20) {
                temp = S(5,A) + E + w[t++];
-               temp += (unsigned long)0x5a827999L + ((B&C)|(D&~B));
+               temp += (uint32_t)0x5a827999L + ((B&C)|(D&~B));
                E = D; D = C; C = S(30,B); B = A; A = temp;
        }
        while (t<40) {
                temp = S(5,A) + E + w[t++];
-               temp += (unsigned long)0x6ed9eba1L + (B^C^D);
+               temp += (uint32_t)0x6ed9eba1L + (B^C^D);
                E = D; D = C; C = S(30,B); B = A; A = temp;
        }
        while (t<60) {
                temp = S(5,A) + E + w[t++];
-               temp += (unsigned long)0x8f1bbcdcL + ((B&C)|(B&D)|(C&D));
+               temp += (uint32_t)0x8f1bbcdcL + ((B&C)|(B&D)|(C&D));
                E = D; D = C; C = S(30,B); B = A; A = temp;
        }
        while (t<80) {
                temp = S(5,A) + E + w[t++];
-               temp += (unsigned long)0xca62c1d6L + (B^C^D);
+               temp += (uint32_t)0xca62c1d6L + (B^C^D);
                E = D; D = C; C = S(30,B); B = A; A = temp;
        }
        h[0] = MASK&(h[0] + A);
@@ -179,7 +179,7 @@
        h[4] = MASK&(h[4] + E);
 }
 
-#define CHARSTOLONG(wp,s,i) {*wp++ = 
(u_long)((((u_long)(s[i])&0xff)<<24)|(((u_long)(s[i+1])&0xff)<<16)|(((u_long)(s[i+2])&0xff)<<8)|(u_long)(s[i+3]&0xff));}
+#define CHARSTOLONG(wp,s,i) {*wp++ = 
(uint32_t)((((uint32_t)(s[i])&0xff)<<24)|(((uint32_t)(s[i+1])&0xff)<<16)|(((uint32_t)(s[i+2])&0xff)<<8)|(uint32_t)(s[i+3]&0xff));}
 
 
 void
@@ -187,11 +187,11 @@
   SHS_CTX *mdContext;
 {
        nbits = 0;
-       mdContext->h[0] = (unsigned long)0x67452301L;
-       mdContext->h[1] = (unsigned long)0xefcdab89L;
-       mdContext->h[2] = (unsigned long)0x98badcfeL;
-       mdContext->h[3] = (unsigned long)0x10325476L;
-       mdContext->h[4] = (unsigned long)0xc3d2e1f0L;
+       mdContext->h[0] = (uint32_t)0x67452301L;
+       mdContext->h[1] = (uint32_t)0xefcdab89L;
+       mdContext->h[2] = (uint32_t)0x98badcfeL;
+       mdContext->h[3] = (uint32_t)0x10325476L;
+       mdContext->h[4] = (uint32_t)0xc3d2e1f0L;
        mdContext->totalLength = 0;
 }
 
@@ -202,16 +202,16 @@
   unsigned char *s;
   unsigned int n;
 {
-       register unsigned long *wp;
-       long nn = n;
-       long i;
+       register uint32_t *wp;
+       int32_t nn = n;
+       int32_t i;
        
        w = mdContext->w;
        h = mdContext->h;
        mdContext->totalLength += n;
        
        nbits = 0;
-       n = n/(u_long)64;
+       n = n/(uint32_t)64;
        wp = w;
        
        while(n>0){
@@ -240,7 +240,7 @@
        while(i>3) {
                CHARSTOLONG(wp,s,0);
                s = (s + 4);
-               nbits += (u_long)32;
+               nbits += (uint32_t)32;
                i -= 4;
        }
        while (i) {
@@ -253,14 +253,14 @@
 shsFinal(mdContext)
   SHS_CTX *mdContext;
 {
-       long nn = mdContext->totalLength;
+       int32_t nn = mdContext->totalLength;
        w = mdContext->w;
        h = mdContext->h;
        
        opack(128);
        while(nbits != 448)opack(0);
-       packl((unsigned long)(nn>>29));
-       packl((unsigned long)(nn<<3));
+       packl((uint32_t)(nn>>29));
+       packl((uint32_t)(nn<<3));
        
        /* if(nbits != 0)
           handle_exception(CRITICAL,"shsFinal(): nbits != 0\n");*/
@@ -269,7 +269,7 @@
 unsigned char *
 qshs(s, n)
   unsigned char *s;
-  long n;
+  int32_t n;
 {
         SHS_CTX *mdContext;
        static SHS_CTX mdC;
@@ -291,6 +291,7 @@
        return ret;
 }
 
+#if 0  /* This doesn't work and isn't used.  */
 /*int fread(char *, int, int, FILE *);*/
 
 unsigned long *
@@ -316,6 +317,5 @@
 
        return mdContext->h;
 }
-
-
+#endif
 
Index: shs.h
===================================================================
RCS file: /cvs/cfs/shs.h,v
retrieving revision 1.1.1.1
diff -u -r1.1.1.1 shs.h
--- shs.h       8 Oct 2001 02:24:39 -0000       1.1.1.1
+++ shs.h       16 Oct 2006 10:06:33 -0000
@@ -1,7 +1,9 @@
+#include <inttypes.h>
+
 typedef struct {
-    long totalLength;
-    unsigned long h[5];
-    unsigned long w[80];
+    int32_t totalLength;
+    uint32_t h[5];
+    uint32_t w[80];
 } SHS_CTX;
 
 unsigned char *qshs();
Index: truerand.c
===================================================================
RCS file: /cvs/cfs/truerand.c,v
retrieving revision 1.1.1.2
diff -u -r1.1.1.2 truerand.c
--- truerand.c  8 Oct 2001 02:27:34 -0000       1.1.1.2
+++ truerand.c  16 Oct 2006 10:06:33 -0000
@@ -89,6 +89,8 @@
 #include <math.h>
 #include <stdio.h>
 
+#include <inttypes.h>
+
 static jmp_buf env;
 static unsigned count;
 static unsigned ocount;
@@ -115,7 +117,7 @@
        tick();
 }
 
-static unsigned long
+static uint32_t
 roulette()
 {
        if (setjmp(env))
@@ -131,15 +133,15 @@
  * basic interface to 32 bit truerand.
  * note that any scheduled SIGALRM will be delayed by about .3 secs.
  */
-unsigned long
+uint32_t
 raw_truerand()
 {
        void (*oldalrm)();
        struct itimerval it;
-       unsigned long counts[12];
+       uint32_t counts[12];
        unsigned char *qshs();
        unsigned char *r;
-       unsigned long buf;
+       uint32_t buf;
        int i;
 
        getitimer(ITIMER_REAL, &it);
@@ -153,7 +155,7 @@
        setitimer(ITIMER_REAL, &it, NULL);
 
        r = qshs(counts,sizeof(counts));
-       buf = *((unsigned long *) r);
+       buf = *((uint32_t *) r);
 
        return buf;
 }
@@ -182,8 +184,8 @@
  *     usage: 
  *             unsigned char r8;
  *             unsigned short r16;
- *             unsigned long r32;
- *             unsigned long trand8(), trand16(), trand32();
+ *             uint32_t r32;
+ *             uint32_t trand8(), trand16(), trand32();
  *             r8=trand8();
  *             r16=trand16();
  *             r32=trand32();
@@ -206,11 +208,11 @@
  * OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE.
  */
 
-unsigned long randbyte()
+uint32_t randbyte()
 {
-       unsigned long raw_truerand();
+       uint32_t raw_truerand();
        unsigned char *qshs();
-       unsigned long r[2];
+       uint32_t r[2];
        unsigned char *hash;
 
        r[0]=raw_truerand(); r[1]=raw_truerand();
@@ -218,17 +220,17 @@
        return ((int) (*hash)) & 0xff;
 }
 
-unsigned long trand8()
+uint32_t trand8()
 {
        return randbyte();
 }
 
-unsigned long trand16()
+uint32_t trand16()
 {
        return randbyte() ^ (randbyte()<<8);
 }
 
-unsigned long trand32()
+uint32_t trand32()
 {
        return randbyte() ^ (randbyte()<<8)
                ^ (randbyte()<<16) ^ (randbyte()<<24);
Index: debian/changelog
===================================================================
RCS file: /cvs/cfs/debian/changelog,v
retrieving revision 1.38
diff -u -r1.38 changelog
--- debian/changelog    13 Sep 2006 11:49:08 -0000      1.38
+++ debian/changelog    16 Oct 2006 10:06:33 -0000
@@ -1,3 +1,11 @@
+cfs (1.4.1-17.1) unstable; urgency=low
+
+  * apply patch from Ville-Pertti Keinonen to fix type issues on 64bit
+    archs, http://www.freebsd.org/cgi/query-pr.cgi?pr=75878 (closes:
+    #391516, thx Stefan Westerfeld).
+
+ -- Gerrit Pape <[EMAIL PROTECTED]>  Mon, 16 Oct 2006 10:05:56 +0000
+
 cfs (1.4.1-17) unstable; urgency=high
 
   * cfs_fh.c: doencrypt(), dodecrypt(): make salt unsigned long, not int,

Reply via email to