* [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes @ 2011-08-05 13:32 Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 1/3] slirp: Fix types of IP address parameters Jan Kiszka ` (3 more replies) 0 siblings, 4 replies; 5+ messages in thread From: Jan Kiszka @ 2011-08-05 13:32 UTC (permalink / raw) To: Anthony Liguori, qemu-devel; +Cc: Gerd Hoffmann, Fabien Chouteau The following changes since commit 81e34a2401f7ffd519bb7f093e833cb48734169f: Merge remote-tracking branch 'mst/for_anthony' into staging (2011-08-04 17:15:22 -0500) are available in the git repository at: git://git.kiszka.org/qemu.git queues/slirp Fixes some fall-outs from the latest merge, ie. a build breakage on mingw and a regression that broke at least ping. CC: Gerd Hoffmann <kraxel@redhat.com> Jan Kiszka (3): slirp: Fix types of IP address parameters slirp: Read current time only once per if_start call slirp: Only start packet expiration for delayed ones slirp/arp_table.c | 16 ++++++++-------- slirp/if.c | 8 +------- slirp/slirp.c | 3 +++ slirp/slirp.h | 4 ++-- 4 files changed, 14 insertions(+), 17 deletions(-) -- 1.7.3.4 ^ permalink raw reply [flat|nested] 5+ messages in thread
* [Qemu-devel] [PATCH 1/3] slirp: Fix types of IP address parameters 2011-08-05 13:32 [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Jan Kiszka @ 2011-08-05 13:32 ` Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 2/3] slirp: Read current time only once per if_start call Jan Kiszka ` (2 subsequent siblings) 3 siblings, 0 replies; 5+ messages in thread From: Jan Kiszka @ 2011-08-05 13:32 UTC (permalink / raw) To: Anthony Liguori, qemu-devel; +Cc: Fabien Chouteau Should be uint32_t for IPv4, not int. Also avoid in_addr_t without proper includes. Fixes build regression on mingw32. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> --- slirp/arp_table.c | 16 ++++++++-------- slirp/slirp.h | 4 ++-- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/slirp/arp_table.c b/slirp/arp_table.c index 820dee2..5d7b8ac 100644 --- a/slirp/arp_table.c +++ b/slirp/arp_table.c @@ -24,9 +24,9 @@ #include "slirp.h" -void arp_table_add(Slirp *slirp, int ip_addr, uint8_t ethaddr[ETH_ALEN]) +void arp_table_add(Slirp *slirp, uint32_t ip_addr, uint8_t ethaddr[ETH_ALEN]) { - const in_addr_t broadcast_addr = + const uint32_t broadcast_addr = ~slirp->vnetwork_mask.s_addr | slirp->vnetwork_addr.s_addr; ArpTable *arptbl = &slirp->arp_table; int i; @@ -60,29 +60,29 @@ void arp_table_add(Slirp *slirp, int ip_addr, uint8_t ethaddr[ETH_ALEN]) arptbl->next_victim = (arptbl->next_victim + 1) % ARP_TABLE_SIZE; } -bool arp_table_search(Slirp *slirp, int in_ip_addr, +bool arp_table_search(Slirp *slirp, uint32_t ip_addr, uint8_t out_ethaddr[ETH_ALEN]) { - const in_addr_t broadcast_addr = + const uint32_t broadcast_addr = ~slirp->vnetwork_mask.s_addr | slirp->vnetwork_addr.s_addr; ArpTable *arptbl = &slirp->arp_table; int i; DEBUG_CALL("arp_table_search"); - DEBUG_ARG("ip = 0x%x", in_ip_addr); + DEBUG_ARG("ip = 0x%x", ip_addr); /* Check 0.0.0.0/8 invalid source-only addresses */ - assert((in_ip_addr & htonl(~(0xf << 28))) != 0); + assert((ip_addr & htonl(~(0xf << 28))) != 0); /* If broadcast address */ - if (in_ip_addr == 0xffffffff || in_ip_addr == broadcast_addr) { + if (ip_addr == 0xffffffff || ip_addr == broadcast_addr) { /* return Ethernet broadcast address */ memset(out_ethaddr, 0xff, ETH_ALEN); return 1; } for (i = 0; i < ARP_TABLE_SIZE; i++) { - if (arptbl->table[i].ar_sip == in_ip_addr) { + if (arptbl->table[i].ar_sip == ip_addr) { memcpy(out_ethaddr, arptbl->table[i].ar_sha, ETH_ALEN); DEBUG_ARGS((dfd, " found hw addr = %02x:%02x:%02x:%02x:%02x:%02x\n", out_ethaddr[0], out_ethaddr[1], out_ethaddr[2], diff --git a/slirp/slirp.h b/slirp/slirp.h index 2a070e6..dcf99d5 100644 --- a/slirp/slirp.h +++ b/slirp/slirp.h @@ -208,9 +208,9 @@ typedef struct ArpTable { int next_victim; } ArpTable; -void arp_table_add(Slirp *slirp, int ip_addr, uint8_t ethaddr[ETH_ALEN]); +void arp_table_add(Slirp *slirp, uint32_t ip_addr, uint8_t ethaddr[ETH_ALEN]); -bool arp_table_search(Slirp *slirp, int in_ip_addr, +bool arp_table_search(Slirp *slirp, uint32_t ip_addr, uint8_t out_ethaddr[ETH_ALEN]); struct Slirp { -- 1.7.3.4 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* [Qemu-devel] [PATCH 2/3] slirp: Read current time only once per if_start call 2011-08-05 13:32 [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 1/3] slirp: Fix types of IP address parameters Jan Kiszka @ 2011-08-05 13:32 ` Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 3/3] slirp: Only start packet expiration for delayed ones Jan Kiszka 2011-08-05 17:17 ` [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Anthony Liguori 3 siblings, 0 replies; 5+ messages in thread From: Jan Kiszka @ 2011-08-05 13:32 UTC (permalink / raw) To: Anthony Liguori, qemu-devel; +Cc: Fabien Chouteau No need to update the current time for each packet we send from the queue. Processing time is comparably short. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> --- slirp/if.c | 5 +---- 1 files changed, 1 insertions(+), 4 deletions(-) diff --git a/slirp/if.c b/slirp/if.c index 2d79e45..47bebe4 100644 --- a/slirp/if.c +++ b/slirp/if.c @@ -157,9 +157,8 @@ diddit: void if_start(Slirp *slirp) { + uint64_t now = qemu_get_clock_ns(rt_clock); int requeued = 0; - uint64_t now; - struct mbuf *ifm, *ifqt; DEBUG_CALL("if_start"); @@ -172,8 +171,6 @@ if_start(Slirp *slirp) if (!slirp_can_output(slirp->opaque)) return; - now = qemu_get_clock_ns(rt_clock); - /* * See which queue to get next packet from * If there's something in the fastq, select it immediately -- 1.7.3.4 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* [Qemu-devel] [PATCH 3/3] slirp: Only start packet expiration for delayed ones 2011-08-05 13:32 [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 1/3] slirp: Fix types of IP address parameters Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 2/3] slirp: Read current time only once per if_start call Jan Kiszka @ 2011-08-05 13:32 ` Jan Kiszka 2011-08-05 17:17 ` [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Anthony Liguori 3 siblings, 0 replies; 5+ messages in thread From: Jan Kiszka @ 2011-08-05 13:32 UTC (permalink / raw) To: Anthony Liguori, qemu-devel; +Cc: Fabien Chouteau The expiration timeout must only affect packets that are queued due to pending ARP resolutions. The old version broke ping e.g. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> --- slirp/if.c | 3 --- slirp/slirp.c | 3 +++ 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/slirp/if.c b/slirp/if.c index 47bebe4..2852396 100644 --- a/slirp/if.c +++ b/slirp/if.c @@ -106,9 +106,6 @@ if_output(struct socket *so, struct mbuf *ifm) ifs_init(ifm); insque(ifm, ifq); - /* Expiration date = Now + 1 second */ - ifm->expiration_date = qemu_get_clock_ns(rt_clock) + 1000000000ULL; - diddit: slirp->if_queued++; diff --git a/slirp/slirp.c b/slirp/slirp.c index a86cc6e..2c242ef 100644 --- a/slirp/slirp.c +++ b/slirp/slirp.c @@ -738,6 +738,9 @@ int if_encap(Slirp *slirp, struct mbuf *ifm) slirp->client_ipaddr = iph->ip_dst; slirp_output(slirp->opaque, arp_req, sizeof(arp_req)); ifm->arp_requested = true; + + /* Expire request and drop outgoing packet after 1 second */ + ifm->expiration_date = qemu_get_clock_ns(rt_clock) + 1000000000ULL; } return 0; } else { -- 1.7.3.4 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes 2011-08-05 13:32 [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Jan Kiszka ` (2 preceding siblings ...) 2011-08-05 13:32 ` [Qemu-devel] [PATCH 3/3] slirp: Only start packet expiration for delayed ones Jan Kiszka @ 2011-08-05 17:17 ` Anthony Liguori 3 siblings, 0 replies; 5+ messages in thread From: Anthony Liguori @ 2011-08-05 17:17 UTC (permalink / raw) To: Jan Kiszka; +Cc: qemu-devel, Fabien Chouteau, Gerd Hoffmann On 08/05/2011 08:32 AM, Jan Kiszka wrote: > The following changes since commit 81e34a2401f7ffd519bb7f093e833cb48734169f: > > Merge remote-tracking branch 'mst/for_anthony' into staging (2011-08-04 17:15:22 -0500) > > are available in the git repository at: > > git://git.kiszka.org/qemu.git queues/slirp > > Fixes some fall-outs from the latest merge, ie. a build breakage on > mingw and a regression that broke at least ping. > > > CC: Gerd Hoffmann<kraxel@redhat.com> Pulled. Thanks. Regards, Anthony Liguori > > Jan Kiszka (3): > slirp: Fix types of IP address parameters > slirp: Read current time only once per if_start call > slirp: Only start packet expiration for delayed ones > > slirp/arp_table.c | 16 ++++++++-------- > slirp/if.c | 8 +------- > slirp/slirp.c | 3 +++ > slirp/slirp.h | 4 ++-- > 4 files changed, 14 insertions(+), 17 deletions(-) > ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2011-08-05 17:19 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2011-08-05 13:32 [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 1/3] slirp: Fix types of IP address parameters Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 2/3] slirp: Read current time only once per if_start call Jan Kiszka 2011-08-05 13:32 ` [Qemu-devel] [PATCH 3/3] slirp: Only start packet expiration for delayed ones Jan Kiszka 2011-08-05 17:17 ` [Qemu-devel] [PATCH 0/3] [PULL] slirp: ARP table related fixes Anthony Liguori
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).