Răsfoiți Sursa

[CONNECTOR]: Return proper error code in cn_call_callback()

Error code should be set to EINVAL instead of ENODEV if !queue_work().
There's another call of queue_work() which may set err to EINVAL.

Signed-off-by: Li Zefan <lizf@cn.fujitsu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Li Zefan 17 ani în urmă
părinte
comite
134d99e302
1 a modificat fișierele cu 2 adăugiri și 0 ștergeri
  1. 2 0
      drivers/connector/connector.c

+ 2 - 0
drivers/connector/connector.c

@@ -145,6 +145,8 @@ static int cn_call_callback(struct cn_msg *msg, void (*destruct_data)(void *), v
 				if (queue_work(dev->cbdev->cn_queue,
 				if (queue_work(dev->cbdev->cn_queue,
 							&__cbq->work))
 							&__cbq->work))
 					err = 0;
 					err = 0;
+				else
+					err = -EINVAL;
 			} else {
 			} else {
 				struct cn_callback_data *d;
 				struct cn_callback_data *d;