Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e9670aba authored by Chaehyun Lim's avatar Chaehyun Lim Committed by Greg Kroah-Hartman
Browse files

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: default avatarChaehyun Lim <chaehyun.lim@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c8a06381
Loading
Loading
Loading
Loading
+12 −20
Original line number Original line Diff line number Diff line
@@ -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)
 */
 */
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)
		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,
		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,
	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,
	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,
	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);
+3 −2
Original line number Original line Diff line number Diff line
@@ -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 {
	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);