]> Git Repo - qemu.git/commitdiff
net/colo.c: Make vnet_hdr_len as packet property
authorZhang Chen <[email protected]>
Tue, 4 Jul 2017 06:53:50 +0000 (14:53 +0800)
committerJason Wang <[email protected]>
Mon, 17 Jul 2017 12:13:48 +0000 (20:13 +0800)
We can use this property flush and send packet with vnet_hdr_len.

Signed-off-by: Zhang Chen <[email protected]>
Signed-off-by: Jason Wang <[email protected]>
net/colo-compare.c
net/colo.c
net/colo.h
net/filter-rewriter.c

index ea9bccca46c014ea8447f1012750c6d850cdb520..9c2b1ead19bf195e68cc40bf5f1c387d5da1b3f7 100644 (file)
@@ -121,9 +121,13 @@ static int packet_enqueue(CompareState *s, int mode)
     Connection *conn;
 
     if (mode == PRIMARY_IN) {
-        pkt = packet_new(s->pri_rs.buf, s->pri_rs.packet_len);
+        pkt = packet_new(s->pri_rs.buf,
+                         s->pri_rs.packet_len,
+                         s->pri_rs.vnet_hdr_len);
     } else {
-        pkt = packet_new(s->sec_rs.buf, s->sec_rs.packet_len);
+        pkt = packet_new(s->sec_rs.buf,
+                         s->sec_rs.packet_len,
+                         s->sec_rs.vnet_hdr_len);
     }
 
     if (parse_packet_early(pkt)) {
index 8cc166bc22258368fa2986fdec825f2c9b740d71..180eaed49afe97bcf9f4618e095d9ef68294132c 100644 (file)
@@ -153,13 +153,14 @@ void connection_destroy(void *opaque)
     g_slice_free(Connection, conn);
 }
 
-Packet *packet_new(const void *data, int size)
+Packet *packet_new(const void *data, int size, int vnet_hdr_len)
 {
     Packet *pkt = g_slice_new(Packet);
 
     pkt->data = g_memdup(data, size);
     pkt->size = size;
     pkt->creation_ms = qemu_clock_get_ms(QEMU_CLOCK_HOST);
+    pkt->vnet_hdr_len = vnet_hdr_len;
 
     return pkt;
 }
index 7c524f3a1cd6a8bf88a3d074406cf46b09282dcb..caedb0dca7c4c86fd5b38ec284cbbe1c2f1562f3 100644 (file)
@@ -43,6 +43,8 @@ typedef struct Packet {
     int size;
     /* Time of packet creation, in wall clock ms */
     int64_t creation_ms;
+    /* Get vnet_hdr_len from filter */
+    uint32_t vnet_hdr_len;
 } Packet;
 
 typedef struct ConnectionKey {
@@ -82,7 +84,7 @@ Connection *connection_get(GHashTable *connection_track_table,
                            ConnectionKey *key,
                            GQueue *conn_list);
 void connection_hashtable_reset(GHashTable *connection_track_table);
-Packet *packet_new(const void *data, int size);
+Packet *packet_new(const void *data, int size, int vnet_hdr_len);
 void packet_destroy(void *opaque, void *user_data);
 
 #endif /* QEMU_COLO_PROXY_H */
index afa06e89190c25abfafc9bbff39089a3cf9d0618..63256c72a07b8cfe7d088fa5a1ba270cebe584b5 100644 (file)
@@ -158,7 +158,7 @@ static ssize_t colo_rewriter_receive_iov(NetFilterState *nf,
     char *buf = g_malloc0(size);
 
     iov_to_buf(iov, iovcnt, 0, buf, size);
-    pkt = packet_new(buf, size);
+    pkt = packet_new(buf, size, 0);
     g_free(buf);
 
     /*
This page took 0.031042 seconds and 4 git commands to generate.