forked from mirrors/linux
		
	veth: try harder when allocating queue memory
struct veth_rq is pretty large, 832B total without debug
options enabled. Since commit under Fixes we try to pre-allocate
enough queues for every possible CPU. Miao Wang reports that
this may lead to order-5 allocations which will fail in production.
Let the allocation fallback to vmalloc() and try harder.
These are the same flags we pass to netdev queue allocation.
Reported-and-tested-by: Miao Wang <shankerwangmiao@gmail.com>
Fixes: 9d3684c24a ("veth: create by default nr_possible_cpus queues")
Link: https://lore.kernel.org/all/5F52CAE2-2FB7-4712-95F1-3312FBBFA8DD@gmail.com/
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Link: https://lore.kernel.org/r/20240223235908.693010-1-kuba@kernel.org
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
			
			
This commit is contained in:
		
							parent
							
								
									237274fa21
								
							
						
					
					
						commit
						1ce7d306ea
					
				
					 1 changed files with 3 additions and 2 deletions
				
			
		|  | @ -1461,7 +1461,8 @@ static int veth_alloc_queues(struct net_device *dev) | ||||||
| 	struct veth_priv *priv = netdev_priv(dev); | 	struct veth_priv *priv = netdev_priv(dev); | ||||||
| 	int i; | 	int i; | ||||||
| 
 | 
 | ||||||
| 	priv->rq = kcalloc(dev->num_rx_queues, sizeof(*priv->rq), GFP_KERNEL_ACCOUNT); | 	priv->rq = kvcalloc(dev->num_rx_queues, sizeof(*priv->rq), | ||||||
|  | 			    GFP_KERNEL_ACCOUNT | __GFP_RETRY_MAYFAIL); | ||||||
| 	if (!priv->rq) | 	if (!priv->rq) | ||||||
| 		return -ENOMEM; | 		return -ENOMEM; | ||||||
| 
 | 
 | ||||||
|  | @ -1477,7 +1478,7 @@ static void veth_free_queues(struct net_device *dev) | ||||||
| { | { | ||||||
| 	struct veth_priv *priv = netdev_priv(dev); | 	struct veth_priv *priv = netdev_priv(dev); | ||||||
| 
 | 
 | ||||||
| 	kfree(priv->rq); | 	kvfree(priv->rq); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int veth_dev_init(struct net_device *dev) | static int veth_dev_init(struct net_device *dev) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Jakub Kicinski
						Jakub Kicinski