]> rtime.felk.cvut.cz Git - lisovros/qemu_apohw.git/commitdiff
slirp: Clean up net_slirp_hostfwd_remove()'s use of get_str_sep()
authorMarkus Armbruster <armbru@redhat.com>
Wed, 16 Nov 2011 14:45:59 +0000 (15:45 +0100)
committerStefan Hajnoczi <stefanha@linux.vnet.ibm.com>
Tue, 22 Nov 2011 11:11:23 +0000 (11:11 +0000)
get_str_sep() can fail, but net_slirp_hostfwd_remove() doesn't check.
Works, because it initializes buf[] to "", which get_str_sep() doesn't
touch when it fails.  Coverity doesn't like it, and neither do I.

Change it to work exactly like slirp_hostfwd().

Acked-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@linux.vnet.ibm.com>
net/slirp.c

index c6cda5dcb2b8cb22661a023246585e43bdcd0fb2..6646ecb1c800d31b2e80cdb6f5855b254cfd1006 100644 (file)
@@ -305,7 +305,7 @@ void net_slirp_hostfwd_remove(Monitor *mon, const QDict *qdict)
 {
     struct in_addr host_addr = { .s_addr = INADDR_ANY };
     int host_port;
-    char buf[256] = "";
+    char buf[256];
     const char *src_str, *p;
     SlirpState *s;
     int is_udp = 0;
@@ -325,11 +325,10 @@ void net_slirp_hostfwd_remove(Monitor *mon, const QDict *qdict)
         return;
     }
 
-    if (!src_str || !src_str[0])
-        goto fail_syntax;
-
     p = src_str;
-    get_str_sep(buf, sizeof(buf), &p, ':');
+    if (!p || get_str_sep(buf, sizeof(buf), &p, ':') < 0) {
+        goto fail_syntax;
+    }
 
     if (!strcmp(buf, "tcp") || buf[0] == '\0') {
         is_udp = 0;