* [PATCH V2 0/2] limit xen vnic max queues number to online cpus number
@ 2015-10-23 9:17 Joe Jin
2015-10-23 9:18 ` [PATCH V2 1/2] xen-netback: limit xen vif max queues number to online cpus Joe Jin
2015-10-23 9:19 ` [PATCH V2 2/2] xen-netfront: limit vnic max_queues " Joe Jin
0 siblings, 2 replies; 5+ messages in thread
From: Joe Jin @ 2015-10-23 9:17 UTC (permalink / raw)
To: wei.liu2, Ian Campbell, Boris Ostrovsky, Konrad Rzeszutek Wilk,
David S. Miller, Jan Beulich
Cc: netdev, xen-devel
Currently xen vnic allowed to create lots of queues by set module param
max_queues(both netback and netfront), when queues number larger than
cpus number, it does not help for performance but need more cpu time.
This patchset limit netback and netfront max queues number to online
cpus number.
Joe Jin (2):
xen-netback: limit xen vif max queues number to online cpus
xen-netfront: limit vnic max_queues number to online cpus
---
Changes in v2:
- Replace param_get_int to param_get_uint.
- Use '%u' for unsigned int when print.
- Replace EINVAL to ERANGE when out of range [0-CPUs].
- Reset the perm of max_queues on sysfs to 0644.
drivers/net/xen-netback/netback.c | 28 ++++++++++++++++++++++------
drivers/net/xen-netfront.c | 28 ++++++++++++++++++++++------
2 files changed, 44 insertions(+), 12 deletions(-)
^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH V2 1/2] xen-netback: limit xen vif max queues number to online cpus
2015-10-23 9:17 [PATCH V2 0/2] limit xen vnic max queues number to online cpus number Joe Jin
@ 2015-10-23 9:18 ` Joe Jin
2015-10-23 9:19 ` [PATCH V2 2/2] xen-netfront: limit vnic max_queues " Joe Jin
1 sibling, 0 replies; 5+ messages in thread
From: Joe Jin @ 2015-10-23 9:18 UTC (permalink / raw)
To: wei.liu2, Ian Campbell, Boris Ostrovsky, Konrad Rzeszutek Wilk,
David S. Miller, Jan Beulich
Cc: netdev, xen-devel
Should not allocate xen vif queues number more than online cpus.
Signed-off-by: Joe Jin <joe.jin@oracle.com>
Cc: Jan Beulich <JBeulich@suse.com>
Cc: Wei Liu <wei.liu2@citrix.com>
Cc: Ian Campbell <ian.campbell@citrix.com>
Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
---
drivers/net/xen-netback/netback.c | 28 ++++++++++++++++++++++------
1 files changed, 22 insertions(+), 6 deletions(-)
diff --git a/drivers/net/xen-netback/netback.c b/drivers/net/xen-netback/netback.c
index ec98d43..021dcb0 100644
--- a/drivers/net/xen-netback/netback.c
+++ b/drivers/net/xen-netback/netback.c
@@ -68,7 +68,9 @@ unsigned int rx_stall_timeout_msecs = 60000;
module_param(rx_stall_timeout_msecs, uint, 0444);
unsigned int xenvif_max_queues;
-module_param_named(max_queues, xenvif_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,
+ &xenvif_max_queues, 0644);
MODULE_PARM_DESC(max_queues,
"Maximum number of queues per virtual interface");
@@ -107,6 +109,20 @@ static struct xen_netif_rx_response *make_rx_response(struct xenvif_queue *queue
u16 size,
u16 flags);
+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_info("max_queues %u is out of range [0 - %u]!\n",
+ max_queues, cpus);
+ return -ERANGE;
+ }
+
+ return param_set_uint(val, kp);
+}
+
static inline unsigned long idx_to_pfn(struct xenvif_queue *queue,
u16 idx)
{
@@ -2110,15 +2126,15 @@ int xenvif_dealloc_kthread(void *data)
static int __init netback_init(void)
{
int rc = 0;
+ unsigned int cpus = num_online_cpus();
if (!xen_domain())
return -ENODEV;
- /* Allow as many queues as there are CPUs if user has not
- * specified a value.
- */
- if (xenvif_max_queues == 0)
- xenvif_max_queues = num_online_cpus();
+ /* Allow at most as many queues as CPUs. */
+ if (xenvif_max_queues == 0 || xenvif_max_queues > cpus)
+ xenvif_max_queues = cpus;
+ pr_info("vif max_queues: %u\n", xenvif_max_queues);
if (fatal_skb_slots < XEN_NETBK_LEGACY_SLOTS_MAX) {
pr_info("fatal_skb_slots too small (%d), bump it to XEN_NETBK_LEGACY_SLOTS_MAX (%d)\n",
--
1.7.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH V2 2/2] xen-netfront: limit vnic max_queues number to online cpus
2015-10-23 9:17 [PATCH V2 0/2] limit xen vnic max queues number to online cpus number Joe Jin
2015-10-23 9:18 ` [PATCH V2 1/2] xen-netback: limit xen vif max queues number to online cpus Joe Jin
@ 2015-10-23 9:19 ` Joe Jin
2015-10-23 9:30 ` Jan Beulich
1 sibling, 1 reply; 5+ messages in thread
From: Joe Jin @ 2015-10-23 9:19 UTC (permalink / raw)
To: wei.liu2, Ian Campbell, Boris Ostrovsky, Konrad Rzeszutek Wilk,
David S. Miller, Jan Beulich
Cc: netdev, xen-devel
Should not allocate vnic queues number more than online cpus.
Signed-off-by: Joe Jin <joe.jin@oracle.com>
Cc: Jan Beulich <JBeulich@suse.com>
Cc: Wei Liu <wei.liu2@citrix.com>
Cc: Ian Campbell <ian.campbell@citrix.com>
Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@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 [0 - %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
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH V2 2/2] xen-netfront: limit vnic max_queues number to online cpus
2015-10-23 9:19 ` [PATCH V2 2/2] xen-netfront: limit vnic max_queues " Joe Jin
@ 2015-10-23 9:30 ` Jan Beulich
2015-10-23 9:39 ` Joe Jin
0 siblings, 1 reply; 5+ messages in thread
From: Jan Beulich @ 2015-10-23 9:30 UTC (permalink / raw)
To: Joe Jin
Cc: Ian Campbell, wei.liu2, David S. Miller, xen-devel,
Boris Ostrovsky, Konrad Rzeszutek Wilk, netdev
>>> On 23.10.15 at 11:19, <joe.jin@oracle.com> wrote:
>
> @@ -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 [0 - %u]!\n",
I suppose you mean "...[1 - %u]!\n" here?
Jan
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH V2 2/2] xen-netfront: limit vnic max_queues number to online cpus
2015-10-23 9:30 ` Jan Beulich
@ 2015-10-23 9:39 ` Joe Jin
0 siblings, 0 replies; 5+ messages in thread
From: Joe Jin @ 2015-10-23 9:39 UTC (permalink / raw)
To: Jan Beulich
Cc: Ian Campbell, wei.liu2, David S. Miller, xen-devel,
Boris Ostrovsky, Konrad Rzeszutek Wilk, netdev
On 10/23/2015 05:30 PM, Jan Beulich wrote:
>>>> On 23.10.15 at 11:19, <joe.jin@oracle.com> wrote:
>>
>> @@ -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 [0 - %u]!\n",
>
> I suppose you mean "...[1 - %u]!\n" here?
Yes you are right, you catch my fault again :)
Thanks so much, will resend new later.
Regards,
Joe
> Jan
>
--
Oracle <http://www.oracle.com>
Joe Jin | Software Development Director | +8610.6106.5624
ORACLE | Linux and Virtualization
No. 24 Zhongguancun Software Park, Haidian District | 100193 Beijing
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2015-10-23 9:39 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-10-23 9:17 [PATCH V2 0/2] limit xen vnic max queues number to online cpus number Joe Jin
2015-10-23 9:18 ` [PATCH V2 1/2] xen-netback: limit xen vif max queues number to online cpus Joe Jin
2015-10-23 9:19 ` [PATCH V2 2/2] xen-netfront: limit vnic max_queues " Joe Jin
2015-10-23 9:30 ` Jan Beulich
2015-10-23 9:39 ` Joe Jin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).