浏览代码

OMAP: mailbox: send message in process context

Schedule the Tasklet to send only when mailbox fifo is full and there are
pending messages in kfifo, else send the message directly in the Process
context. This would avoid needless scheduling of Tasklet for every message
transfer

Signed-off-by: Hari Kanigeri <h-kanigeri2@ti.com>
Acked-by: Hiroshi Doyu <hiroshi.doyu@nokia.com>
Kanigeri, Hari 14 年之前
父节点
当前提交
a42743c26a
共有 1 个文件被更改,包括 7 次插入2 次删除
  1. 7 2
      arch/arm/plat-omap/mailbox.c

+ 7 - 2
arch/arm/plat-omap/mailbox.c

@@ -92,20 +92,25 @@ int omap_mbox_msg_send(struct omap_mbox *mbox, mbox_msg_t msg)
 	struct omap_mbox_queue *mq = mbox->txq;
 	struct omap_mbox_queue *mq = mbox->txq;
 	int ret = 0, len;
 	int ret = 0, len;
 
 
-	spin_lock(&mq->lock);
+	spin_lock_bh(&mq->lock);
 
 
 	if (kfifo_avail(&mq->fifo) < sizeof(msg)) {
 	if (kfifo_avail(&mq->fifo) < sizeof(msg)) {
 		ret = -ENOMEM;
 		ret = -ENOMEM;
 		goto out;
 		goto out;
 	}
 	}
 
 
+	if (kfifo_is_empty(&mq->fifo) && !__mbox_poll_for_space(mbox)) {
+		mbox_fifo_write(mbox, msg);
+		goto out;
+	}
+
 	len = kfifo_in(&mq->fifo, (unsigned char *)&msg, sizeof(msg));
 	len = kfifo_in(&mq->fifo, (unsigned char *)&msg, sizeof(msg));
 	WARN_ON(len != sizeof(msg));
 	WARN_ON(len != sizeof(msg));
 
 
 	tasklet_schedule(&mbox->txq->tasklet);
 	tasklet_schedule(&mbox->txq->tasklet);
 
 
 out:
 out:
-	spin_unlock(&mq->lock);
+	spin_unlock_bh(&mq->lock);
 	return ret;
 	return ret;
 }
 }
 EXPORT_SYMBOL(omap_mbox_msg_send);
 EXPORT_SYMBOL(omap_mbox_msg_send);