提交 ddf19d20 编写于 作者: W Waldemar Rymarkiewicz 提交者: Samuel Ortiz

NFC: pn533: Simplify __pn533_send_frame_async

In all cases (send_cmd_async, send_data_async and send_sync)
pn533_send_async_complete() handles all responses internally,
so there is no need to pass this as a callback.

Cmd context is passed to __pn533_send_frame_async in all the
cases as well. It's already kept in struct pn533 which is
available all the time the device is attached. So we can make
use of it instead.

Therefore, cmd_complete and cmd_complete_arg are no needed any more.
Signed-off-by: NWaldemar Rymarkiewicz <waldemar.rymarkiewicz@tieto.com>
Signed-off-by: NSamuel Ortiz <sameo@linux.intel.com>
上级 140ef7f6
...@@ -330,8 +330,6 @@ struct pn533 { ...@@ -330,8 +330,6 @@ struct pn533 {
int wq_in_error; int wq_in_error;
int cancel_listen; int cancel_listen;
pn533_cmd_complete_t cmd_complete;
void *cmd_complete_arg;
void *cmd_complete_mi_arg; void *cmd_complete_mi_arg;
struct mutex cmd_lock; struct mutex cmd_lock;
struct pn533_cmd *cmd; struct pn533_cmd *cmd;
...@@ -506,13 +504,14 @@ static bool pn533_rx_frame_is_cmd_response(struct pn533 *dev, void *frame) ...@@ -506,13 +504,14 @@ static bool pn533_rx_frame_is_cmd_response(struct pn533 *dev, void *frame)
PN533_CMD_RESPONSE(dev->cmd->code)); PN533_CMD_RESPONSE(dev->cmd->code));
} }
static int pn533_send_async_complete(struct pn533 *dev);
static void pn533_wq_cmd_complete(struct work_struct *work) static void pn533_wq_cmd_complete(struct work_struct *work)
{ {
struct pn533 *dev = container_of(work, struct pn533, cmd_complete_work); struct pn533 *dev = container_of(work, struct pn533, cmd_complete_work);
int rc; int rc;
rc = dev->cmd_complete(dev, dev->cmd_complete_arg, dev->wq_in_error); rc = pn533_send_async_complete(dev);
if (rc != -EINPROGRESS) if (rc != -EINPROGRESS)
queue_work(dev->wq, &dev->cmd_work); queue_work(dev->wq, &dev->cmd_work);
} }
...@@ -643,15 +642,10 @@ static int pn533_send_ack(struct pn533 *dev, gfp_t flags) ...@@ -643,15 +642,10 @@ static int pn533_send_ack(struct pn533 *dev, gfp_t flags)
static int __pn533_send_frame_async(struct pn533 *dev, static int __pn533_send_frame_async(struct pn533 *dev,
struct sk_buff *out, struct sk_buff *out,
struct sk_buff *in, struct sk_buff *in,
int in_len, int in_len)
pn533_cmd_complete_t cmd_complete,
void *arg)
{ {
int rc; int rc;
dev->cmd_complete = cmd_complete;
dev->cmd_complete_arg = arg;
dev->out_urb->transfer_buffer = out->data; dev->out_urb->transfer_buffer = out->data;
dev->out_urb->transfer_buffer_length = out->len; dev->out_urb->transfer_buffer_length = out->len;
...@@ -692,9 +686,10 @@ static void pn533_build_cmd_frame(struct pn533 *dev, u8 cmd_code, ...@@ -692,9 +686,10 @@ static void pn533_build_cmd_frame(struct pn533 *dev, u8 cmd_code,
ops->tx_frame_finish(skb->data); ops->tx_frame_finish(skb->data);
} }
static int pn533_send_async_complete(struct pn533 *dev, void *arg, int status) static int pn533_send_async_complete(struct pn533 *dev)
{ {
struct pn533_cmd *cmd = arg; struct pn533_cmd *cmd = dev->cmd;
int status = dev->wq_in_error;
struct sk_buff *req = cmd->req; struct sk_buff *req = cmd->req;
struct sk_buff *resp = cmd->resp; struct sk_buff *resp = cmd->resp;
...@@ -749,8 +744,7 @@ static int __pn533_send_async(struct pn533 *dev, u8 cmd_code, ...@@ -749,8 +744,7 @@ static int __pn533_send_async(struct pn533 *dev, u8 cmd_code,
mutex_lock(&dev->cmd_lock); mutex_lock(&dev->cmd_lock);
if (!dev->cmd_pending) { if (!dev->cmd_pending) {
rc = __pn533_send_frame_async(dev, req, resp, resp_len, rc = __pn533_send_frame_async(dev, req, resp, resp_len);
pn533_send_async_complete, cmd);
if (rc) if (rc)
goto error; goto error;
...@@ -859,8 +853,7 @@ static int pn533_send_cmd_direct_async(struct pn533 *dev, u8 cmd_code, ...@@ -859,8 +853,7 @@ static int pn533_send_cmd_direct_async(struct pn533 *dev, u8 cmd_code,
pn533_build_cmd_frame(dev, cmd_code, req); pn533_build_cmd_frame(dev, cmd_code, req);
rc = __pn533_send_frame_async(dev, req, resp, resp_len, rc = __pn533_send_frame_async(dev, req, resp, resp_len);
pn533_send_async_complete, cmd);
if (rc < 0) { if (rc < 0) {
dev_kfree_skb(resp); dev_kfree_skb(resp);
kfree(cmd); kfree(cmd);
...@@ -891,8 +884,7 @@ static void pn533_wq_cmd(struct work_struct *work) ...@@ -891,8 +884,7 @@ static void pn533_wq_cmd(struct work_struct *work)
mutex_unlock(&dev->cmd_lock); mutex_unlock(&dev->cmd_lock);
rc = __pn533_send_frame_async(dev, cmd->req, cmd->resp, cmd->resp_len, rc = __pn533_send_frame_async(dev, cmd->req, cmd->resp, cmd->resp_len);
pn533_send_async_complete, cmd);
if (rc < 0) { if (rc < 0) {
dev_kfree_skb(cmd->req); dev_kfree_skb(cmd->req);
dev_kfree_skb(cmd->resp); dev_kfree_skb(cmd->resp);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册