Commit 28deecca authored by Wayne Davison's avatar Wayne Davison

Changed NO_INT64 to INT64_IS_OFF_T because off_t might actually be

64 bits.  The code now only complains if int64 is really too short.
parent 4db88e5b
......@@ -744,13 +744,14 @@ int64 read_longint(int f)
if ((int32)ret != (int32)0xffffffff)
return ret;
#ifdef NO_INT64
rprintf(FERROR,"Integer overflow - attempted 64 bit offset\n");
exit_cleanup(RERR_UNSUPPORTED);
#else
#ifdef INT64_IS_OFF_T
if (sizeof (int64) < 8) {
rprintf(FERROR, "Integer overflow: attempted 64-bit offset\n");
exit_cleanup(RERR_UNSUPPORTED);
}
#endif
readfd(f,b,8);
ret = IVAL(b,0) | (((int64)IVAL(b,4))<<32);
#endif
return ret;
}
......@@ -1018,16 +1019,18 @@ void write_longint(int f, int64 x)
return;
}
#ifdef NO_INT64
rprintf(FERROR,"Integer overflow - attempted 64 bit offset\n");
exit_cleanup(RERR_UNSUPPORTED);
#else
#ifdef INT64_IS_OFF_T
if (sizeof (int64) < 8) {
rprintf(FERROR, "Integer overflow: attempted 64-bit offset\n");
exit_cleanup(RERR_UNSUPPORTED);
}
#endif
write_int(f, (int32)0xFFFFFFFF);
SIVAL(b,0,(x&0xFFFFFFFF));
SIVAL(b,4,((x>>32)&0xFFFFFFFF));
writefd(f,b,8);
#endif
}
void write_buf(int f,char *buf,size_t len)
......
......@@ -197,8 +197,9 @@ static void print_rsync_version(enum logcode f)
get_panic_action());
#endif
#ifdef NO_INT64
rprintf(f, "WARNING: no 64-bit integers on this platform!\n");
#ifdef INT64_IS_OFF_T
if (sizeof (int64) < 8)
rprintf(f, "WARNING: no 64-bit integers on this platform!\n");
#endif
rprintf(f,
......
......@@ -312,7 +312,7 @@ enum msgcode {
#else
/* As long as it gets... */
#define int64 off_t
#define NO_INT64
#define INT64_IS_OFF_T
#endif
#if (SIZEOF_LONG == 8)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment