Should not allocate vnic queues number more than online cpus.

Signed-off-by: Joe Jin <joe....@oracle.com>
Cc: Jan Beulich <jbeul...@suse.com>
Cc: Wei Liu <wei.l...@citrix.com>
Cc: Ian Campbell <ian.campb...@citrix.com>
Cc: Boris Ostrovsky <boris.ostrov...@oracle.com>
Cc: Konrad Rzeszutek Wilk <konrad.w...@oracle.com>
---
 drivers/net/xen-netfront.c |   28 ++++++++++++++++++++++------
 1 files changed, 22 insertions(+), 6 deletions(-)

diff --git a/drivers/net/xen-netfront.c b/drivers/net/xen-netfront.c
index f821a97..5cc2f4a 100644
--- a/drivers/net/xen-netfront.c
+++ b/drivers/net/xen-netfront.c
@@ -58,7 +58,9 @@
 
 /* Module parameters */
 static unsigned int xennet_max_queues;
-module_param_named(max_queues, xennet_max_queues, uint, 0644);
+static int xennet_set_max_queues(const char *val, struct kernel_param *kp);
+module_param_call(max_queues, xennet_set_max_queues, param_get_uint,
+                 &xennet_max_queues, 0644);
 MODULE_PARM_DESC(max_queues,
                 "Maximum number of queues per virtual interface");
 
@@ -164,6 +166,19 @@ struct netfront_rx_info {
        struct xen_netif_extra_info extras[XEN_NETIF_EXTRA_TYPE_MAX - 1];
 };
 
+static int xennet_set_max_queues(const char *val, struct kernel_param *kp)
+{
+       unsigned int cpus = num_online_cpus();
+       unsigned int max_queues = simple_strtoul(val, NULL, 10);
+
+       if (max_queues == 0 || max_queues > cpus) {
+               pr_err("max_queues %u is out of range [1 - %u]!\n", 
+                      max_queues, cpus);
+               return -ERANGE;
+       }
+       return param_set_uint(val, kp);
+}
+
 static void skb_entry_set_link(union skb_entry *list, unsigned short id)
 {
        list->link = id;
@@ -2126,6 +2141,8 @@ static struct xenbus_driver netfront_driver = {
 
 static int __init netif_init(void)
 {
+       unsigned int cpus = num_online_cpus();
+
        if (!xen_domain())
                return -ENODEV;
 
@@ -2134,11 +2151,10 @@ static int __init netif_init(void)
 
        pr_info("Initialising Xen virtual ethernet driver\n");
 
-       /* Allow as many queues as there are CPUs if user has not
-        * specified a value.
-        */
-       if (xennet_max_queues == 0)
-               xennet_max_queues = num_online_cpus();
+       /* Allow at most as many queues as there are CPUs. */
+       if (xennet_max_queues == 0 || xennet_max_queues > cpus)
+               xennet_max_queues = cpus;
+       pr_info("max_queues: %d\n", xennet_max_queues);
 
        return xenbus_register_frontend(&netfront_driver);
 }
-- 
1.7.1




_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xen.org
http://lists.xen.org/xen-devel

Reply via email to