129 lines
3.7 KiB
Plaintext
129 lines
3.7 KiB
Plaintext
|
Patch helping 64 bit cleanness taken from the Debian Linux package made
|
|||
|
by St<53>phane Bortmeyer <bortzmeyer@debian.org>. 64 bit patch originally
|
|||
|
by Bart Warmerdam <bartw@xs4all.nl>.
|
|||
|
|
|||
|
A few casts in printfs to shut up warnings.
|
|||
|
|
|||
|
--- queso.c.orig Tue Sep 22 22:35:43 1998
|
|||
|
+++ queso.c Wed Sep 29 15:54:20 1999
|
|||
|
@@ -58,19 +58,19 @@
|
|||
|
static char CFGFILE[255] = DFLT_CONFIG_FILE;
|
|||
|
|
|||
|
/*------------- Prototiping -----------------*/
|
|||
|
-void debugtcp (unsigned long, tcprec);
|
|||
|
+void debugtcp (u_int32_t, tcprec);
|
|||
|
void usage (const char *);
|
|||
|
int checkos (struct sockaddr_in, short);
|
|||
|
|
|||
|
/*------------- Print TCP HDR ---------------*/
|
|||
|
void
|
|||
|
-debugtcp (unsigned long myseq, tcprec tcp)
|
|||
|
+debugtcp (u_int32_t myseq, tcprec tcp)
|
|||
|
{
|
|||
|
fprintf (stderr, "%d->%d S:%1d A:%s%lX W:%04X U:%X F: ",
|
|||
|
ntohs (tcp.sport), ntohs (tcp.dport),
|
|||
|
(tcp.seqnum?1:0),
|
|||
|
tcp.acknum?"+":" ",
|
|||
|
- (tcp.acknum?(unsigned long) ntohl (tcp.acknum)-myseq:0),
|
|||
|
+ (unsigned long) (tcp.acknum?(u_int32_t) ntohl (tcp.acknum)-myseq:0),
|
|||
|
ntohs (tcp.window), ntohs (tcp.urgentptr));
|
|||
|
|
|||
|
if (tcp.flags & URG)
|
|||
|
@@ -142,12 +142,12 @@
|
|||
|
|
|||
|
typedef struct
|
|||
|
{
|
|||
|
- unsigned short set;
|
|||
|
- unsigned long seq;
|
|||
|
- unsigned long ack;
|
|||
|
- unsigned short urg;
|
|||
|
- unsigned short win;
|
|||
|
- unsigned short flag;
|
|||
|
+ u_int16_t set;
|
|||
|
+ u_int32_t seq;
|
|||
|
+ u_int32_t ack;
|
|||
|
+ u_int16_t urg;
|
|||
|
+ u_int16_t win;
|
|||
|
+ u_int16_t flag;
|
|||
|
}
|
|||
|
OSRES;
|
|||
|
|
|||
|
@@ -158,12 +158,12 @@
|
|||
|
{
|
|||
|
spoofrec spoof;
|
|||
|
tcprec tcp;
|
|||
|
- unsigned short start, s;
|
|||
|
+ u_int16_t start, s;
|
|||
|
int n;
|
|||
|
long timeout;
|
|||
|
FILE *f;
|
|||
|
char line[1024];
|
|||
|
- unsigned long myseq;
|
|||
|
+ u_int32_t myseq;
|
|||
|
#ifdef PCAP
|
|||
|
char fromtxt[16], desttxt[16];
|
|||
|
char bpftxt[4096];
|
|||
|
@@ -284,8 +284,8 @@
|
|||
|
if ((f = fopen (CFGFILE, "r")))
|
|||
|
{
|
|||
|
char osname[256]; /* should be smaller than line[], 256 should suffice */
|
|||
|
- unsigned short flag1 = 0, found = 0, linez = 0;
|
|||
|
- unsigned short pn = 0, ps = 0, pa = 0, pw = 0, pf = 0, pu = 0;
|
|||
|
+ u_int16_t flag1 = 0, found = 0, linez = 0;
|
|||
|
+ u_int16_t pn = 0, ps = 0, pa = 0, pw = 0, pf = 0, pu = 0;
|
|||
|
char *p;
|
|||
|
|
|||
|
while (fgets (line, sizeof (osname) - 1, f))
|
|||
|
@@ -412,7 +412,7 @@
|
|||
|
if (CONFIGDEBUG)
|
|||
|
fprintf (stderr, " ** FAILED %d,%d,%d,%d,%02X != %ld,%ld,%d,%d,%02X\n",
|
|||
|
ps, pa, pw, pu, pf,
|
|||
|
- r[pn].seq,r[pn].ack,r[pn].win,r[pn].urg,r[pn].flag);
|
|||
|
+ (unsigned long) r[pn].seq,(unsigned long) r[pn].ack,r[pn].win,r[pn].urg,r[pn].flag);
|
|||
|
found = 0;
|
|||
|
flag1 = 0;
|
|||
|
continue;
|
|||
|
@@ -483,9 +483,9 @@
|
|||
|
if (r[pn].set)
|
|||
|
{
|
|||
|
fprintf ( f, "%d %ld %s",
|
|||
|
- pn, r[pn].seq, (r[pn].ack==RANDOM_ACK?"R":((r[pn].ack>=ACK_HACK)?"+":"")) );
|
|||
|
+ pn, (long) r[pn].seq, (r[pn].ack==RANDOM_ACK?"R":((r[pn].ack>=ACK_HACK)?"+":"")) );
|
|||
|
if(r[pn].ack!=RANDOM_ACK)
|
|||
|
- fprintf ( f, "%ld", (r[pn].ack>=ACK_HACK)?r[pn].ack-ACK_HACK:r[pn].ack);
|
|||
|
+ fprintf ( f, "%ld", (long) /* shut up a warning */ ((r[pn].ack>=ACK_HACK)?r[pn].ack-ACK_HACK:r[pn].ack));
|
|||
|
fprintf ( f, " %d %s\n", r[pn].win ? 1 : 0, line);
|
|||
|
}
|
|||
|
else
|
|||
|
@@ -516,13 +516,13 @@
|
|||
|
main (int argc, char *argv[])
|
|||
|
{
|
|||
|
struct sockaddr_in dest, from;
|
|||
|
- unsigned short port;
|
|||
|
+ u_int16_t port;
|
|||
|
char *s, *p;
|
|||
|
int c;
|
|||
|
int accuracy;
|
|||
|
int limit = 0;
|
|||
|
int bits = 32; /* single host */
|
|||
|
- unsigned long firsthost, lasthost, netmask, host;
|
|||
|
+ u_int32_t firsthost, lasthost, netmask, host;
|
|||
|
|
|||
|
/*
|
|||
|
* Unbuffer stdout and stderr
|
|||
|
@@ -652,7 +652,13 @@
|
|||
|
}
|
|||
|
|
|||
|
host = ntohl (dest.sin_addr.s_addr);
|
|||
|
- netmask = ~(0xFFFFFFFFL >> bits);
|
|||
|
+ netmask = 0xFFFFFFFFL;
|
|||
|
+ if(bits >= 1){
|
|||
|
+ netmask >>= 1;
|
|||
|
+ bits--;
|
|||
|
+ }
|
|||
|
+ netmask >>= bits;
|
|||
|
+ netmask = ~netmask;
|
|||
|
/*-- WARNING: 32bit arquitectures have problems when bits==32 --*/
|
|||
|
firsthost = (host & netmask) + 1;
|
|||
|
lasthost = (host | ~(netmask)) - 1;
|