From 285f7a62e464eac97e472ba6803ddede1e6c459e Mon Sep 17 00:00:00 2001 From: Jan Kiszka Date: Wed, 24 Jun 2009 14:42:30 +0200 Subject: slirp: Make IP packet ID consistent Currently, ip_id is always initialized to 0 on slirp startup (despite the broken attempt to derive it from the clock). This is good for reproducibility. But it is not preserved across save/restore. This patch therefore drops the dead initialization code from ip_init and introduces ip_id to the persistent slirp state. Signed-off-by: Jan Kiszka Signed-off-by: Anthony Liguori --- slirp/ip_input.c | 1 - slirp/slirp.c | 8 +++++++- 2 files changed, 7 insertions(+), 2 deletions(-) (limited to 'slirp') diff --git a/slirp/ip_input.c b/slirp/ip_input.c index 0356eb5..b07d3d5 100644 --- a/slirp/ip_input.c +++ b/slirp/ip_input.c @@ -59,7 +59,6 @@ void ip_init(void) { ipq.ip_link.next = ipq.ip_link.prev = &ipq.ip_link; - ip_id = tt.tv_sec & 0xffff; udp_init(); tcp_init(); } diff --git a/slirp/slirp.c b/slirp/slirp.c index ea66c0c..02f6fe5 100644 --- a/slirp/slirp.c +++ b/slirp/slirp.c @@ -234,7 +234,7 @@ void slirp_init(int restricted, struct in_addr vnetwork, vdhcp_startaddr = vdhcp_start; vnameserver_addr = vnameserver; - register_savevm("slirp", 0, 1, slirp_state_save, slirp_state_load, NULL); + register_savevm("slirp", 0, 2, slirp_state_save, slirp_state_load, NULL); } #define CONN_CANFSEND(so) (((so)->so_state & (SS_FCANTSENDMORE|SS_ISFCONNECTED)) == SS_ISFCONNECTED) @@ -973,6 +973,8 @@ static void slirp_state_save(QEMUFile *f, void *opaque) slirp_socket_save(f, so); } qemu_put_byte(f, 0); + + qemu_put_be16(f, ip_id); } static void slirp_tcp_load(QEMUFile *f, struct tcpcb *tp) @@ -1103,5 +1105,9 @@ static int slirp_state_load(QEMUFile *f, void *opaque, int version_id) so->extra = (void *)ex_ptr->ex_exec; } + if (version_id >= 2) { + ip_id = qemu_get_be16(f); + } + return 0; } -- cgit v1.1