提交 e9670aba 编写于 作者: C Chaehyun Lim 提交者: Greg Kroah-Hartman

staging: wilc1000: wilc_msgqueue: use standard struct list_head

This patch uses standard struct list_head in struct message and
message_queue instead of custom linked list.
Signed-off-by: NChaehyun Lim <chaehyun.lim@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 c8a06381
...@@ -15,7 +15,7 @@ int wilc_mq_create(struct message_queue *mq) ...@@ -15,7 +15,7 @@ int wilc_mq_create(struct message_queue *mq)
{ {
spin_lock_init(&mq->lock); spin_lock_init(&mq->lock);
sema_init(&mq->sem, 0); sema_init(&mq->sem, 0);
mq->msg_list = NULL; INIT_LIST_HEAD(&mq->msg_list);
mq->recv_count = 0; mq->recv_count = 0;
mq->exiting = false; mq->exiting = false;
return 0; return 0;
...@@ -29,6 +29,8 @@ int wilc_mq_create(struct message_queue *mq) ...@@ -29,6 +29,8 @@ int wilc_mq_create(struct message_queue *mq)
*/ */
int wilc_mq_destroy(struct message_queue *mq) int wilc_mq_destroy(struct message_queue *mq)
{ {
struct message *msg;
mq->exiting = true; mq->exiting = true;
/* Release any waiting receiver thread. */ /* Release any waiting receiver thread. */
...@@ -37,11 +39,10 @@ int wilc_mq_destroy(struct message_queue *mq) ...@@ -37,11 +39,10 @@ int wilc_mq_destroy(struct message_queue *mq)
mq->recv_count--; mq->recv_count--;
} }
while (mq->msg_list) { while (!list_empty(&mq->msg_list)) {
struct message *msg = mq->msg_list->next; msg = list_first_entry(&mq->msg_list, struct message, list);
list_del(&msg->list);
kfree(mq->msg_list); kfree(msg->buf);
mq->msg_list = msg;
} }
return 0; return 0;
...@@ -75,7 +76,7 @@ int wilc_mq_send(struct message_queue *mq, ...@@ -75,7 +76,7 @@ int wilc_mq_send(struct message_queue *mq,
return -ENOMEM; return -ENOMEM;
new_msg->len = send_buf_size; new_msg->len = send_buf_size;
new_msg->next = NULL; INIT_LIST_HEAD(&new_msg->list);
new_msg->buf = kmemdup(send_buf, send_buf_size, GFP_ATOMIC); new_msg->buf = kmemdup(send_buf, send_buf_size, GFP_ATOMIC);
if (!new_msg->buf) { if (!new_msg->buf) {
kfree(new_msg); kfree(new_msg);
...@@ -85,16 +86,7 @@ int wilc_mq_send(struct message_queue *mq, ...@@ -85,16 +86,7 @@ int wilc_mq_send(struct message_queue *mq,
spin_lock_irqsave(&mq->lock, flags); spin_lock_irqsave(&mq->lock, flags);
/* add it to the message queue */ /* add it to the message queue */
if (!mq->msg_list) { list_add_tail(&new_msg->list, &mq->msg_list);
mq->msg_list = new_msg;
} else {
struct message *tail_msg = mq->msg_list;
while (tail_msg->next)
tail_msg = tail_msg->next;
tail_msg->next = new_msg;
}
spin_unlock_irqrestore(&mq->lock, flags); spin_unlock_irqrestore(&mq->lock, flags);
...@@ -132,13 +124,13 @@ int wilc_mq_recv(struct message_queue *mq, ...@@ -132,13 +124,13 @@ int wilc_mq_recv(struct message_queue *mq,
down(&mq->sem); down(&mq->sem);
spin_lock_irqsave(&mq->lock, flags); spin_lock_irqsave(&mq->lock, flags);
msg = mq->msg_list; if (list_empty(&mq->msg_list)) {
if (!msg) {
spin_unlock_irqrestore(&mq->lock, flags); spin_unlock_irqrestore(&mq->lock, flags);
PRINT_ER("msg is null\n"); PRINT_ER("msg is null\n");
return -EFAULT; return -EFAULT;
} }
/* check buffer size */ /* check buffer size */
msg = list_first_entry(&mq->msg_list, struct message, list);
if (recv_buf_size < msg->len) { if (recv_buf_size < msg->len) {
spin_unlock_irqrestore(&mq->lock, flags); spin_unlock_irqrestore(&mq->lock, flags);
up(&mq->sem); up(&mq->sem);
...@@ -151,7 +143,7 @@ int wilc_mq_recv(struct message_queue *mq, ...@@ -151,7 +143,7 @@ int wilc_mq_recv(struct message_queue *mq,
memcpy(recv_buf, msg->buf, msg->len); memcpy(recv_buf, msg->buf, msg->len);
*recv_len = msg->len; *recv_len = msg->len;
mq->msg_list = msg->next; list_del(&msg->list);
kfree(msg->buf); kfree(msg->buf);
kfree(msg); kfree(msg);
......
...@@ -2,11 +2,12 @@ ...@@ -2,11 +2,12 @@
#define __WILC_MSG_QUEUE_H__ #define __WILC_MSG_QUEUE_H__
#include <linux/semaphore.h> #include <linux/semaphore.h>
#include <linux/list.h>
struct message { struct message {
void *buf; void *buf;
u32 len; u32 len;
struct message *next; struct list_head list;
}; };
struct message_queue { struct message_queue {
...@@ -14,7 +15,7 @@ struct message_queue { ...@@ -14,7 +15,7 @@ struct message_queue {
spinlock_t lock; spinlock_t lock;
bool exiting; bool exiting;
u32 recv_count; u32 recv_count;
struct message *msg_list; struct list_head msg_list;
}; };
int wilc_mq_create(struct message_queue *mq); int wilc_mq_create(struct message_queue *mq);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册