提交 b7c8921b 编写于 作者: S Stephen Hemminger 提交者: Arnaldo Carvalho de Melo

[PKTGEN]: Sleeping function called under lock

pktgen is calling kmalloc GFP_KERNEL and vmalloc with lock held.
The simplest fix is to turn the lock into a semaphore, since the
thread lock is only used for admin control from user context.
Signed-off-by: NStephen Hemminger <shemminger@osdl.org>
Signed-off-by: NRobert Olsson <robert.olsson@its.uu.se>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
Signed-off-by: NArnaldo Carvalho de Melo <acme@mandriva.com>
上级 670c02c2
...@@ -177,8 +177,8 @@ ...@@ -177,8 +177,8 @@
#define T_REMDEV (1<<3) /* Remove all devs */ #define T_REMDEV (1<<3) /* Remove all devs */
/* Locks */ /* Locks */
#define thread_lock() spin_lock(&_thread_lock) #define thread_lock() down(&pktgen_sem)
#define thread_unlock() spin_unlock(&_thread_lock) #define thread_unlock() up(&pktgen_sem)
/* If lock -- can be removed after some work */ /* If lock -- can be removed after some work */
#define if_lock(t) spin_lock(&(t->if_lock)); #define if_lock(t) spin_lock(&(t->if_lock));
...@@ -503,7 +503,7 @@ static int pg_delay_d = 0; ...@@ -503,7 +503,7 @@ static int pg_delay_d = 0;
static int pg_clone_skb_d = 0; static int pg_clone_skb_d = 0;
static int debug = 0; static int debug = 0;
static DEFINE_SPINLOCK(_thread_lock); static DECLARE_MUTEX(pktgen_sem);
static struct pktgen_thread *pktgen_threads = NULL; static struct pktgen_thread *pktgen_threads = NULL;
static char module_fname[128]; static char module_fname[128];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册