vhost: debug vhost-user command needs better error checking on the syntax (VPP-916) 71/7771/2
authorSteven <sluong@cisco.com>
Fri, 21 Jul 2017 23:38:41 +0000 (16:38 -0700)
committerDamjan Marion <dmarion.lists@gmail.com>
Thu, 27 Jul 2017 08:12:31 +0000 (08:12 +0000)
The syntax for debug vhost-user is
debug vhost-user <on | off>

However, currently the code does not reject the invalid command such as below
debug vhost-user
debug vhost-user on blah
debug vhost-user off blah

The fix is to enforece the correct syntax and reject the command when invalid
option is entered.

Change-Id: I1a04ae8ddb6dd299aa6d15b043362964e685ddde
Signed-off-by: Steven <sluong@cisco.com>
(cherry picked from commit 6a4de2764d9e6cadf36af824dddb3f33c2d6dc7e)

src/vnet/devices/virtio/vhost-user.c

index 2e2b49c..82f7653 100644 (file)
@@ -3540,22 +3540,43 @@ debug_vhost_user_command_fn (vlib_main_t * vm,
   unformat_input_t _line_input, *line_input = &_line_input;
   clib_error_t *error = NULL;
   vhost_user_main_t *vum = &vhost_user_main;
+  u8 onoff = 0;
+  u8 input_found = 0;
 
   /* Get a line of input. */
   if (!unformat_user (input, unformat_line_input, line_input))
-    return 0;
+    return clib_error_return (0, "missing argument");
 
   while (unformat_check_input (line_input) != UNFORMAT_END_OF_INPUT)
     {
+      if (input_found)
+       {
+         error = clib_error_return (0, "unknown input `%U'",
+                                    format_unformat_error, line_input);
+         goto done;
+       }
+
       if (unformat (line_input, "on"))
-       vum->debug = 1;
+       {
+         input_found = 1;
+         onoff = 1;
+       }
       else if (unformat (line_input, "off"))
-       vum->debug = 0;
+       {
+         input_found = 1;
+         onoff = 0;
+       }
       else
-       error = clib_error_return (0, "unknown input `%U'",
-                                  format_unformat_error, line_input);
+       {
+         error = clib_error_return (0, "unknown input `%U'",
+                                    format_unformat_error, line_input);
+         goto done;
+       }
     }
 
+  vum->debug = onoff;
+
+done:
   unformat_free (line_input);
 
   return error;