提交 ecc804ca 编写于 作者: S Stefan Weil 提交者: Jason Wang

slirp: Fix type casts and format strings in debug code

Casting pointers to long won't work on 64 bit Windows.
It is not needed with the right format strings.
Signed-off-by: NStefan Weil <sw@weilnetz.de>
Signed-off-by: NJason Wang <jasowang@redhat.com>
上级 31e49ac1
...@@ -23,6 +23,12 @@ ...@@ -23,6 +23,12 @@
*/ */
#include <slirp.h> #include <slirp.h>
#if defined(_WIN32)
/* Windows ntohl() returns an u_long value.
* Add a type cast to match the format strings. */
# define ntohl(n) ((uint32_t)ntohl(n))
#endif
/* XXX: only DHCP is supported */ /* XXX: only DHCP is supported */
#define LEASE_TIME (24 * 3600) #define LEASE_TIME (24 * 3600)
...@@ -155,7 +161,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp) ...@@ -155,7 +161,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp)
dhcp_decode(bp, &dhcp_msg_type, &preq_addr); dhcp_decode(bp, &dhcp_msg_type, &preq_addr);
DPRINTF("bootp packet op=%d msgtype=%d", bp->bp_op, dhcp_msg_type); DPRINTF("bootp packet op=%d msgtype=%d", bp->bp_op, dhcp_msg_type);
if (preq_addr.s_addr != htonl(0L)) if (preq_addr.s_addr != htonl(0L))
DPRINTF(" req_addr=%08x\n", ntohl(preq_addr.s_addr)); DPRINTF(" req_addr=%08" PRIx32 "\n", ntohl(preq_addr.s_addr));
else else
DPRINTF("\n"); DPRINTF("\n");
...@@ -234,7 +240,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp) ...@@ -234,7 +240,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp)
q += 4; q += 4;
if (bc) { if (bc) {
DPRINTF("%s addr=%08x\n", DPRINTF("%s addr=%08" PRIx32 "\n",
(dhcp_msg_type == DHCPDISCOVER) ? "offered" : "ack'ed", (dhcp_msg_type == DHCPDISCOVER) ? "offered" : "ack'ed",
ntohl(daddr.sin_addr.s_addr)); ntohl(daddr.sin_addr.s_addr));
...@@ -302,7 +308,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp) ...@@ -302,7 +308,7 @@ static void bootp_reply(Slirp *slirp, const struct bootp_t *bp)
} else { } else {
static const char nak_msg[] = "requested address not available"; static const char nak_msg[] = "requested address not available";
DPRINTF("nak'ed addr=%08x\n", ntohl(preq_addr.s_addr)); DPRINTF("nak'ed addr=%08" PRIx32 "\n", ntohl(preq_addr.s_addr));
*q++ = RFC2132_MSG_TYPE; *q++ = RFC2132_MSG_TYPE;
*q++ = 1; *q++ = 1;
......
...@@ -53,8 +53,8 @@ if_output(struct socket *so, struct mbuf *ifm) ...@@ -53,8 +53,8 @@ if_output(struct socket *so, struct mbuf *ifm)
int on_fastq = 1; int on_fastq = 1;
DEBUG_CALL("if_output"); DEBUG_CALL("if_output");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("ifm = %lx", (long)ifm); DEBUG_ARG("ifm = %p", ifm);
/* /*
* First remove the mbuf from m_usedlist, * First remove the mbuf from m_usedlist,
......
...@@ -125,7 +125,7 @@ icmp_input(struct mbuf *m, int hlen) ...@@ -125,7 +125,7 @@ icmp_input(struct mbuf *m, int hlen)
Slirp *slirp = m->slirp; Slirp *slirp = m->slirp;
DEBUG_CALL("icmp_input"); DEBUG_CALL("icmp_input");
DEBUG_ARG("m = %lx", (long )m); DEBUG_ARG("m = %p", m);
DEBUG_ARG("m_len = %d", m->m_len); DEBUG_ARG("m_len = %d", m->m_len);
/* /*
...@@ -252,7 +252,7 @@ icmp_error(struct mbuf *msrc, u_char type, u_char code, int minsize, ...@@ -252,7 +252,7 @@ icmp_error(struct mbuf *msrc, u_char type, u_char code, int minsize,
register struct mbuf *m; register struct mbuf *m;
DEBUG_CALL("icmp_error"); DEBUG_CALL("icmp_error");
DEBUG_ARG("msrc = %lx", (long )msrc); DEBUG_ARG("msrc = %p", msrc);
DEBUG_ARG("msrc_len = %d", msrc->m_len); DEBUG_ARG("msrc_len = %d", msrc->m_len);
if(type!=ICMP_UNREACH && type!=ICMP_TIMXCEED) goto end_error; if(type!=ICMP_UNREACH && type!=ICMP_TIMXCEED) goto end_error;
......
...@@ -80,7 +80,7 @@ ip_input(struct mbuf *m) ...@@ -80,7 +80,7 @@ ip_input(struct mbuf *m)
int hlen; int hlen;
DEBUG_CALL("ip_input"); DEBUG_CALL("ip_input");
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
DEBUG_ARG("m_len = %d", m->m_len); DEBUG_ARG("m_len = %d", m->m_len);
if (m->m_len < sizeof (struct ip)) { if (m->m_len < sizeof (struct ip)) {
...@@ -232,9 +232,9 @@ ip_reass(Slirp *slirp, struct ip *ip, struct ipq *fp) ...@@ -232,9 +232,9 @@ ip_reass(Slirp *slirp, struct ip *ip, struct ipq *fp)
int i, next; int i, next;
DEBUG_CALL("ip_reass"); DEBUG_CALL("ip_reass");
DEBUG_ARG("ip = %lx", (long)ip); DEBUG_ARG("ip = %p", ip);
DEBUG_ARG("fp = %lx", (long)fp); DEBUG_ARG("fp = %p", fp);
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
/* /*
* Presence of header sizes in mbufs * Presence of header sizes in mbufs
...@@ -400,7 +400,7 @@ static void ...@@ -400,7 +400,7 @@ static void
ip_enq(register struct ipasfrag *p, register struct ipasfrag *prev) ip_enq(register struct ipasfrag *p, register struct ipasfrag *prev)
{ {
DEBUG_CALL("ip_enq"); DEBUG_CALL("ip_enq");
DEBUG_ARG("prev = %lx", (long)prev); DEBUG_ARG("prev = %p", prev);
p->ipf_prev = prev; p->ipf_prev = prev;
p->ipf_next = prev->ipf_next; p->ipf_next = prev->ipf_next;
((struct ipasfrag *)(prev->ipf_next))->ipf_prev = p; ((struct ipasfrag *)(prev->ipf_next))->ipf_prev = p;
......
...@@ -60,8 +60,8 @@ ip_output(struct socket *so, struct mbuf *m0) ...@@ -60,8 +60,8 @@ ip_output(struct socket *so, struct mbuf *m0)
int len, off, error = 0; int len, off, error = 0;
DEBUG_CALL("ip_output"); DEBUG_CALL("ip_output");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("m0 = %lx", (long)m0); DEBUG_ARG("m0 = %p", m0);
ip = mtod(m, struct ip *); ip = mtod(m, struct ip *);
/* /*
......
...@@ -94,7 +94,7 @@ m_get(Slirp *slirp) ...@@ -94,7 +94,7 @@ m_get(Slirp *slirp)
m->arp_requested = false; m->arp_requested = false;
m->expiration_date = (uint64_t)-1; m->expiration_date = (uint64_t)-1;
end_error: end_error:
DEBUG_ARG("m = %lx", (long )m); DEBUG_ARG("m = %p", m);
return m; return m;
} }
...@@ -103,7 +103,7 @@ m_free(struct mbuf *m) ...@@ -103,7 +103,7 @@ m_free(struct mbuf *m)
{ {
DEBUG_CALL("m_free"); DEBUG_CALL("m_free");
DEBUG_ARG("m = %lx", (long )m); DEBUG_ARG("m = %p", m);
if(m) { if(m) {
/* Remove from m_usedlist */ /* Remove from m_usedlist */
...@@ -221,7 +221,7 @@ dtom(Slirp *slirp, void *dat) ...@@ -221,7 +221,7 @@ dtom(Slirp *slirp, void *dat)
struct mbuf *m; struct mbuf *m;
DEBUG_CALL("dtom"); DEBUG_CALL("dtom");
DEBUG_ARG("dat = %lx", (long )dat); DEBUG_ARG("dat = %p", dat);
/* bug corrected for M_EXT buffers */ /* bug corrected for M_EXT buffers */
for (m = slirp->m_usedlist.m_next; m != &slirp->m_usedlist; for (m = slirp->m_usedlist.m_next; m != &slirp->m_usedlist;
......
...@@ -123,9 +123,9 @@ fork_exec(struct socket *so, const char *ex, int do_pty) ...@@ -123,9 +123,9 @@ fork_exec(struct socket *so, const char *ex, int do_pty)
pid_t pid; pid_t pid;
DEBUG_CALL("fork_exec"); DEBUG_CALL("fork_exec");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("ex = %lx", (long)ex); DEBUG_ARG("ex = %p", ex);
DEBUG_ARG("do_pty = %lx", (long)do_pty); DEBUG_ARG("do_pty = %x", do_pty);
if (do_pty == 2) { if (do_pty == 2) {
return 0; return 0;
......
...@@ -72,8 +72,8 @@ sbappend(struct socket *so, struct mbuf *m) ...@@ -72,8 +72,8 @@ sbappend(struct socket *so, struct mbuf *m)
int ret = 0; int ret = 0;
DEBUG_CALL("sbappend"); DEBUG_CALL("sbappend");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
DEBUG_ARG("m->m_len = %d", m->m_len); DEBUG_ARG("m->m_len = %d", m->m_len);
/* Shouldn't happen, but... e.g. foreign host closes connection */ /* Shouldn't happen, but... e.g. foreign host closes connection */
......
...@@ -91,7 +91,7 @@ size_t sopreprbuf(struct socket *so, struct iovec *iov, int *np) ...@@ -91,7 +91,7 @@ size_t sopreprbuf(struct socket *so, struct iovec *iov, int *np)
int mss = so->so_tcpcb->t_maxseg; int mss = so->so_tcpcb->t_maxseg;
DEBUG_CALL("sopreprbuf"); DEBUG_CALL("sopreprbuf");
DEBUG_ARG("so = %lx", (long )so); DEBUG_ARG("so = %p", so);
if (len <= 0) if (len <= 0)
return 0; return 0;
...@@ -155,7 +155,7 @@ soread(struct socket *so) ...@@ -155,7 +155,7 @@ soread(struct socket *so)
struct iovec iov[2]; struct iovec iov[2];
DEBUG_CALL("soread"); DEBUG_CALL("soread");
DEBUG_ARG("so = %lx", (long )so); DEBUG_ARG("so = %p", so);
/* /*
* No need to check if there's enough room to read. * No need to check if there's enough room to read.
...@@ -215,7 +215,7 @@ int soreadbuf(struct socket *so, const char *buf, int size) ...@@ -215,7 +215,7 @@ int soreadbuf(struct socket *so, const char *buf, int size)
struct iovec iov[2]; struct iovec iov[2];
DEBUG_CALL("soreadbuf"); DEBUG_CALL("soreadbuf");
DEBUG_ARG("so = %lx", (long )so); DEBUG_ARG("so = %p", so);
/* /*
* No need to check if there's enough room to read. * No need to check if there's enough room to read.
...@@ -263,7 +263,7 @@ sorecvoob(struct socket *so) ...@@ -263,7 +263,7 @@ sorecvoob(struct socket *so)
struct tcpcb *tp = sototcpcb(so); struct tcpcb *tp = sototcpcb(so);
DEBUG_CALL("sorecvoob"); DEBUG_CALL("sorecvoob");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
/* /*
* We take a guess at how much urgent data has arrived. * We take a guess at how much urgent data has arrived.
...@@ -293,7 +293,7 @@ sosendoob(struct socket *so) ...@@ -293,7 +293,7 @@ sosendoob(struct socket *so)
int n, len; int n, len;
DEBUG_CALL("sosendoob"); DEBUG_CALL("sosendoob");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("sb->sb_cc = %d", sb->sb_cc); DEBUG_ARG("sb->sb_cc = %d", sb->sb_cc);
if (so->so_urgc > 2048) if (so->so_urgc > 2048)
...@@ -351,7 +351,7 @@ sowrite(struct socket *so) ...@@ -351,7 +351,7 @@ sowrite(struct socket *so)
struct iovec iov[2]; struct iovec iov[2];
DEBUG_CALL("sowrite"); DEBUG_CALL("sowrite");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
if (so->so_urgc) { if (so->so_urgc) {
sosendoob(so); sosendoob(so);
...@@ -441,7 +441,7 @@ sorecvfrom(struct socket *so) ...@@ -441,7 +441,7 @@ sorecvfrom(struct socket *so)
socklen_t addrlen = sizeof(struct sockaddr_in); socklen_t addrlen = sizeof(struct sockaddr_in);
DEBUG_CALL("sorecvfrom"); DEBUG_CALL("sorecvfrom");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
if (so->so_type == IPPROTO_ICMP) { /* This is a "ping" reply */ if (so->so_type == IPPROTO_ICMP) { /* This is a "ping" reply */
char buff[256]; char buff[256];
...@@ -543,8 +543,8 @@ sosendto(struct socket *so, struct mbuf *m) ...@@ -543,8 +543,8 @@ sosendto(struct socket *so, struct mbuf *m)
struct sockaddr_in addr; struct sockaddr_in addr;
DEBUG_CALL("sosendto"); DEBUG_CALL("sosendto");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
addr.sin_family = AF_INET; addr.sin_family = AF_INET;
if ((so->so_faddr.s_addr & slirp->vnetwork_mask.s_addr) == if ((so->so_faddr.s_addr & slirp->vnetwork_mask.s_addr) ==
......
...@@ -231,8 +231,8 @@ tcp_input(struct mbuf *m, int iphlen, struct socket *inso) ...@@ -231,8 +231,8 @@ tcp_input(struct mbuf *m, int iphlen, struct socket *inso)
Slirp *slirp; Slirp *slirp;
DEBUG_CALL("tcp_input"); DEBUG_CALL("tcp_input");
DEBUG_ARGS((dfd, " m = %8lx iphlen = %2d inso = %lx\n", DEBUG_ARGS((dfd, " m = %p iphlen = %2d inso = %p\n",
(long )m, iphlen, (long )inso )); m, iphlen, inso));
/* /*
* If called with m == 0, then we're continuing the connect * If called with m == 0, then we're continuing the connect
...@@ -923,8 +923,8 @@ trimthenstep6: ...@@ -923,8 +923,8 @@ trimthenstep6:
if (SEQ_LEQ(ti->ti_ack, tp->snd_una)) { if (SEQ_LEQ(ti->ti_ack, tp->snd_una)) {
if (ti->ti_len == 0 && tiwin == tp->snd_wnd) { if (ti->ti_len == 0 && tiwin == tp->snd_wnd) {
DEBUG_MISC((dfd, " dup ack m = %lx so = %lx\n", DEBUG_MISC((dfd, " dup ack m = %p so = %p\n",
(long )m, (long )so)); m, so));
/* /*
* If we have outstanding data (other than * If we have outstanding data (other than
* a window probe), this is a completely * a window probe), this is a completely
...@@ -1302,7 +1302,7 @@ tcp_dooptions(struct tcpcb *tp, u_char *cp, int cnt, struct tcpiphdr *ti) ...@@ -1302,7 +1302,7 @@ tcp_dooptions(struct tcpcb *tp, u_char *cp, int cnt, struct tcpiphdr *ti)
int opt, optlen; int opt, optlen;
DEBUG_CALL("tcp_dooptions"); DEBUG_CALL("tcp_dooptions");
DEBUG_ARGS((dfd, " tp = %lx cnt=%i\n", (long)tp, cnt)); DEBUG_ARGS((dfd, " tp = %p cnt=%i\n", tp, cnt));
for (; cnt > 0; cnt -= optlen, cp += optlen) { for (; cnt > 0; cnt -= optlen, cp += optlen) {
opt = cp[0]; opt = cp[0];
...@@ -1383,7 +1383,7 @@ tcp_xmit_timer(register struct tcpcb *tp, int rtt) ...@@ -1383,7 +1383,7 @@ tcp_xmit_timer(register struct tcpcb *tp, int rtt)
register short delta; register short delta;
DEBUG_CALL("tcp_xmit_timer"); DEBUG_CALL("tcp_xmit_timer");
DEBUG_ARG("tp = %lx", (long)tp); DEBUG_ARG("tp = %p", tp);
DEBUG_ARG("rtt = %d", rtt); DEBUG_ARG("rtt = %d", rtt);
if (tp->t_srtt != 0) { if (tp->t_srtt != 0) {
...@@ -1471,7 +1471,7 @@ tcp_mss(struct tcpcb *tp, u_int offer) ...@@ -1471,7 +1471,7 @@ tcp_mss(struct tcpcb *tp, u_int offer)
int mss; int mss;
DEBUG_CALL("tcp_mss"); DEBUG_CALL("tcp_mss");
DEBUG_ARG("tp = %lx", (long)tp); DEBUG_ARG("tp = %p", tp);
DEBUG_ARG("offer = %d", offer); DEBUG_ARG("offer = %d", offer);
mss = min(IF_MTU, IF_MRU) - sizeof(struct tcpiphdr); mss = min(IF_MTU, IF_MRU) - sizeof(struct tcpiphdr);
......
...@@ -66,7 +66,7 @@ tcp_output(struct tcpcb *tp) ...@@ -66,7 +66,7 @@ tcp_output(struct tcpcb *tp)
int idle, sendalot; int idle, sendalot;
DEBUG_CALL("tcp_output"); DEBUG_CALL("tcp_output");
DEBUG_ARG("tp = %lx", (long )tp); DEBUG_ARG("tp = %p", tp);
/* /*
* Determine length of data that should be transmitted, * Determine length of data that should be transmitted,
......
...@@ -224,7 +224,7 @@ tcp_newtcpcb(struct socket *so) ...@@ -224,7 +224,7 @@ tcp_newtcpcb(struct socket *so)
struct tcpcb *tcp_drop(struct tcpcb *tp, int err) struct tcpcb *tcp_drop(struct tcpcb *tp, int err)
{ {
DEBUG_CALL("tcp_drop"); DEBUG_CALL("tcp_drop");
DEBUG_ARG("tp = %lx", (long)tp); DEBUG_ARG("tp = %p", tp);
DEBUG_ARG("errno = %d", errno); DEBUG_ARG("errno = %d", errno);
if (TCPS_HAVERCVDSYN(tp->t_state)) { if (TCPS_HAVERCVDSYN(tp->t_state)) {
...@@ -249,7 +249,7 @@ tcp_close(struct tcpcb *tp) ...@@ -249,7 +249,7 @@ tcp_close(struct tcpcb *tp)
register struct mbuf *m; register struct mbuf *m;
DEBUG_CALL("tcp_close"); DEBUG_CALL("tcp_close");
DEBUG_ARG("tp = %lx", (long )tp); DEBUG_ARG("tp = %p", tp);
/* free the reassembly queue, if any */ /* free the reassembly queue, if any */
t = tcpfrag_list_first(tp); t = tcpfrag_list_first(tp);
...@@ -290,7 +290,7 @@ tcp_sockclosed(struct tcpcb *tp) ...@@ -290,7 +290,7 @@ tcp_sockclosed(struct tcpcb *tp)
{ {
DEBUG_CALL("tcp_sockclosed"); DEBUG_CALL("tcp_sockclosed");
DEBUG_ARG("tp = %lx", (long)tp); DEBUG_ARG("tp = %p", tp);
switch (tp->t_state) { switch (tp->t_state) {
...@@ -330,7 +330,7 @@ int tcp_fconnect(struct socket *so) ...@@ -330,7 +330,7 @@ int tcp_fconnect(struct socket *so)
int ret=0; int ret=0;
DEBUG_CALL("tcp_fconnect"); DEBUG_CALL("tcp_fconnect");
DEBUG_ARG("so = %lx", (long )so); DEBUG_ARG("so = %p", so);
if( (ret = so->s = qemu_socket(AF_INET,SOCK_STREAM,0)) >= 0) { if( (ret = so->s = qemu_socket(AF_INET,SOCK_STREAM,0)) >= 0) {
int opt, s=so->s; int opt, s=so->s;
...@@ -393,7 +393,7 @@ void tcp_connect(struct socket *inso) ...@@ -393,7 +393,7 @@ void tcp_connect(struct socket *inso)
int s, opt; int s, opt;
DEBUG_CALL("tcp_connect"); DEBUG_CALL("tcp_connect");
DEBUG_ARG("inso = %lx", (long)inso); DEBUG_ARG("inso = %p", inso);
/* /*
* If it's an SS_ACCEPTONCE socket, no need to socreate() * If it's an SS_ACCEPTONCE socket, no need to socreate()
...@@ -564,8 +564,8 @@ tcp_emu(struct socket *so, struct mbuf *m) ...@@ -564,8 +564,8 @@ tcp_emu(struct socket *so, struct mbuf *m)
char *bptr; char *bptr;
DEBUG_CALL("tcp_emu"); DEBUG_CALL("tcp_emu");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
switch(so->so_emu) { switch(so->so_emu) {
int x, i; int x, i;
...@@ -900,7 +900,7 @@ int tcp_ctl(struct socket *so) ...@@ -900,7 +900,7 @@ int tcp_ctl(struct socket *so)
int do_pty; int do_pty;
DEBUG_CALL("tcp_ctl"); DEBUG_CALL("tcp_ctl");
DEBUG_ARG("so = %lx", (long )so); DEBUG_ARG("so = %p", so);
if (so->so_faddr.s_addr != slirp->vhost_addr.s_addr) { if (so->so_faddr.s_addr != slirp->vhost_addr.s_addr) {
/* Check if it's pty_exec */ /* Check if it's pty_exec */
......
...@@ -72,7 +72,7 @@ udp_input(register struct mbuf *m, int iphlen) ...@@ -72,7 +72,7 @@ udp_input(register struct mbuf *m, int iphlen)
struct socket *so; struct socket *so;
DEBUG_CALL("udp_input"); DEBUG_CALL("udp_input");
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
DEBUG_ARG("iphlen = %d", iphlen); DEBUG_ARG("iphlen = %d", iphlen);
/* /*
...@@ -241,8 +241,8 @@ int udp_output2(struct socket *so, struct mbuf *m, ...@@ -241,8 +241,8 @@ int udp_output2(struct socket *so, struct mbuf *m,
int error = 0; int error = 0;
DEBUG_CALL("udp_output"); DEBUG_CALL("udp_output");
DEBUG_ARG("so = %lx", (long)so); DEBUG_ARG("so = %p", so);
DEBUG_ARG("m = %lx", (long)m); DEBUG_ARG("m = %p", m);
DEBUG_ARG("saddr = %lx", (long)saddr->sin_addr.s_addr); DEBUG_ARG("saddr = %lx", (long)saddr->sin_addr.s_addr);
DEBUG_ARG("daddr = %lx", (long)daddr->sin_addr.s_addr); DEBUG_ARG("daddr = %lx", (long)daddr->sin_addr.s_addr);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册