qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [PATCH 4/4] rtl8139: fix Pointer to local outside scope


From: arei.gonglei
Subject: [Qemu-devel] [PATCH 4/4] rtl8139: fix Pointer to local outside scope
Date: Thu, 20 Nov 2014 13:57:14 +0800

From: Gonglei <address@hidden>

Coverity spot:
 Assigning: iov = struct iovec [3]({{buf, 12UL},
                       {(void *)dot1q_buf, 4UL},
                       {buf + 12, size - 12}})
 (address of temporary variable of type struct iovec [3]).
 out_of_scope: Temporary variable of type struct iovec [3] goes out of scope.

Pointer to local outside scope (RETURN_LOCAL)
use_invalid:
 Using iov, which points to an out-of-scope temporary variable of type struct 
iovec [3].

Signed-off-by: Gonglei <address@hidden>
---
 hw/net/rtl8139.c | 36 ++++++++++++------------------------
 1 file changed, 12 insertions(+), 24 deletions(-)

diff --git a/hw/net/rtl8139.c b/hw/net/rtl8139.c
index 8b8a1b1..426171b 100644
--- a/hw/net/rtl8139.c
+++ b/hw/net/rtl8139.c
@@ -1775,6 +1775,8 @@ static void rtl8139_transfer_frame(RTL8139State *s, 
uint8_t *buf, int size,
     int do_interrupt, const uint8_t *dot1q_buf)
 {
     struct iovec *iov = NULL;
+    size_t buf2_size;
+    uint8_t *buf2 = NULL;
 
     if (!size)
     {
@@ -1789,35 +1791,21 @@ static void rtl8139_transfer_frame(RTL8139State *s, 
uint8_t *buf, int size,
             { .iov_base = buf + ETHER_ADDR_LEN * 2,
                 .iov_len = size - ETHER_ADDR_LEN * 2 },
         };
-    }
 
-    if (TxLoopBack == (s->TxConfig & TxLoopBack))
-    {
-        size_t buf2_size;
-        uint8_t *buf2;
-
-        if (iov) {
-            buf2_size = iov_size(iov, 3);
-            buf2 = g_malloc(buf2_size);
-            iov_to_buf(iov, 3, 0, buf2, buf2_size);
-            buf = buf2;
-        }
+        buf2_size = iov_size(iov, 3);
+        buf2 = g_malloc(buf2_size);
+        iov_to_buf(iov, 3, 0, buf2, buf2_size);
+        buf = buf2;
+    }
 
+    if (TxLoopBack == (s->TxConfig & TxLoopBack)) {
         DPRINTF("+++ transmit loopback mode\n");
         rtl8139_do_receive(qemu_get_queue(s->nic), buf, size, do_interrupt);
-
-        if (iov) {
-            g_free(buf2);
-        }
-    }
-    else
-    {
-        if (iov) {
-            qemu_sendv_packet(qemu_get_queue(s->nic), iov, 3);
-        } else {
-            qemu_send_packet(qemu_get_queue(s->nic), buf, size);
-        }
+    } else {
+        qemu_send_packet(qemu_get_queue(s->nic), buf, size);
     }
+
+    g_free(buf2);
 }
 
 static int rtl8139_transmit_one(RTL8139State *s, int descriptor)
-- 
1.7.12.4




reply via email to

[Prev in Thread] Current Thread [Next in Thread]