* [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL
@ 2018-08-04 0:40 Jia-Ju Bai
2018-08-04 0:54 ` Govindarajulu Varadarajan (gvaradar)
2018-08-04 20:08 ` David Miller
0 siblings, 2 replies; 3+ messages in thread
From: Jia-Ju Bai @ 2018-08-04 0:40 UTC (permalink / raw)
To: benve, _govind, pkaustub; +Cc: netdev, linux-kernel, Jia-Ju Bai
vnic_dev_register(), vnic_rq_alloc_bufs() and vnic_wq_alloc_bufs()
are never called in atomic context.
They call kzalloc() with GFP_ATOMIC, which is not necessary.
GFP_ATOMIC can be replaced with GFP_KERNEL.
This is found by a static analysis tool named DCNS written by myself.
Signed-off-by: Jia-Ju Bai <baijiaju1990@gmail.com>
---
drivers/net/ethernet/cisco/enic/vnic_dev.c | 2 +-
drivers/net/ethernet/cisco/enic/vnic_rq.c | 2 +-
drivers/net/ethernet/cisco/enic/vnic_wq.c | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/drivers/net/ethernet/cisco/enic/vnic_dev.c b/drivers/net/ethernet/cisco/enic/vnic_dev.c
index 76cdd4c9d11f..5c08c4519695 100644
--- a/drivers/net/ethernet/cisco/enic/vnic_dev.c
+++ b/drivers/net/ethernet/cisco/enic/vnic_dev.c
@@ -1071,7 +1071,7 @@ struct vnic_dev *vnic_dev_register(struct vnic_dev *vdev,
unsigned int num_bars)
{
if (!vdev) {
- vdev = kzalloc(sizeof(struct vnic_dev), GFP_ATOMIC);
+ vdev = kzalloc(sizeof(struct vnic_dev), GFP_KERNEL);
if (!vdev)
return NULL;
}
diff --git a/drivers/net/ethernet/cisco/enic/vnic_rq.c b/drivers/net/ethernet/cisco/enic/vnic_rq.c
index f8aa326d1d58..a3e7b003ada1 100644
--- a/drivers/net/ethernet/cisco/enic/vnic_rq.c
+++ b/drivers/net/ethernet/cisco/enic/vnic_rq.c
@@ -35,7 +35,7 @@ static int vnic_rq_alloc_bufs(struct vnic_rq *rq)
unsigned int blks = VNIC_RQ_BUF_BLKS_NEEDED(count);
for (i = 0; i < blks; i++) {
- rq->bufs[i] = kzalloc(VNIC_RQ_BUF_BLK_SZ(count), GFP_ATOMIC);
+ rq->bufs[i] = kzalloc(VNIC_RQ_BUF_BLK_SZ(count), GFP_KERNEL);
if (!rq->bufs[i])
return -ENOMEM;
}
diff --git a/drivers/net/ethernet/cisco/enic/vnic_wq.c b/drivers/net/ethernet/cisco/enic/vnic_wq.c
index 090cc65658a3..eb75891974df 100644
--- a/drivers/net/ethernet/cisco/enic/vnic_wq.c
+++ b/drivers/net/ethernet/cisco/enic/vnic_wq.c
@@ -35,7 +35,7 @@ static int vnic_wq_alloc_bufs(struct vnic_wq *wq)
unsigned int blks = VNIC_WQ_BUF_BLKS_NEEDED(count);
for (i = 0; i < blks; i++) {
- wq->bufs[i] = kzalloc(VNIC_WQ_BUF_BLK_SZ(count), GFP_ATOMIC);
+ wq->bufs[i] = kzalloc(VNIC_WQ_BUF_BLK_SZ(count), GFP_KERNEL);
if (!wq->bufs[i])
return -ENOMEM;
}
--
2.17.0
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL
2018-08-04 0:40 [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL Jia-Ju Bai
@ 2018-08-04 0:54 ` Govindarajulu Varadarajan (gvaradar)
2018-08-04 20:08 ` David Miller
1 sibling, 0 replies; 3+ messages in thread
From: Govindarajulu Varadarajan (gvaradar) @ 2018-08-04 0:54 UTC (permalink / raw)
To: baijiaju1990@gmail.com, _govind@gmx.com,
Christian Benvenuti (benve), Parvi Kaustubhi (pkaustub)
Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org
On Sat, 2018-08-04 at 08:40 +0800, Jia-Ju Bai wrote:
> vnic_dev_register(), vnic_rq_alloc_bufs() and vnic_wq_alloc_bufs()
> are never called in atomic context.
> They call kzalloc() with GFP_ATOMIC, which is not necessary.
> GFP_ATOMIC can be replaced with GFP_KERNEL.
>
> This is found by a static analysis tool named DCNS written by myself.
Looks good to me. Thanks you.
Acked-by: Govindarajulu Varadarajan <gvaradar@cisco.com>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL
2018-08-04 0:40 [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL Jia-Ju Bai
2018-08-04 0:54 ` Govindarajulu Varadarajan (gvaradar)
@ 2018-08-04 20:08 ` David Miller
1 sibling, 0 replies; 3+ messages in thread
From: David Miller @ 2018-08-04 20:08 UTC (permalink / raw)
To: baijiaju1990; +Cc: benve, _govind, pkaustub, netdev, linux-kernel
From: Jia-Ju Bai <baijiaju1990@gmail.com>
Date: Sat, 4 Aug 2018 08:40:09 +0800
> vnic_dev_register(), vnic_rq_alloc_bufs() and vnic_wq_alloc_bufs()
> are never called in atomic context.
> They call kzalloc() with GFP_ATOMIC, which is not necessary.
> GFP_ATOMIC can be replaced with GFP_KERNEL.
>
> This is found by a static analysis tool named DCNS written by myself.
>
> Signed-off-by: Jia-Ju Bai <baijiaju1990@gmail.com>
Applied to net-next, thanks.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2018-08-04 20:08 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-08-04 0:40 [PATCH] net: cisco: enic: Replace GFP_ATOMIC with GFP_KERNEL Jia-Ju Bai
2018-08-04 0:54 ` Govindarajulu Varadarajan (gvaradar)
2018-08-04 20:08 ` David Miller
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox