aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-omap/mailbox.c
diff options
context:
space:
mode:
authorKanigeri, Hari <h-kanigeri2@ti.com>2010-11-29 15:24:13 -0500
committerHari Kanigeri <h-kanigeri2@ti.com>2010-12-02 06:43:16 -0500
commita42743c26a53a2a5f2b2018a9659ab3fb604d5bc (patch)
treef25f038eeed91eb7b9e66ad9cc2b071657823837 /arch/arm/plat-omap/mailbox.c
parentab66ac3007cb3e59fe80dfcf36aff243d3008cb9 (diff)
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>
Diffstat (limited to 'arch/arm/plat-omap/mailbox.c')
-rw-r--r--arch/arm/plat-omap/mailbox.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/arch/arm/plat-omap/mailbox.c b/arch/arm/plat-omap/mailbox.c
index d9aa87c0a921..cc58b44325f2 100644
--- a/arch/arm/plat-omap/mailbox.c
+++ b/arch/arm/plat-omap/mailbox.c
@@ -92,20 +92,25 @@ int omap_mbox_msg_send(struct omap_mbox *mbox, mbox_msg_t msg)
92 struct omap_mbox_queue *mq = mbox->txq; 92 struct omap_mbox_queue *mq = mbox->txq;
93 int ret = 0, len; 93 int ret = 0, len;
94 94
95 spin_lock(&mq->lock); 95 spin_lock_bh(&mq->lock);
96 96
97 if (kfifo_avail(&mq->fifo) < sizeof(msg)) { 97 if (kfifo_avail(&mq->fifo) < sizeof(msg)) {
98 ret = -ENOMEM; 98 ret = -ENOMEM;
99 goto out; 99 goto out;
100 } 100 }
101 101
102 if (kfifo_is_empty(&mq->fifo) && !__mbox_poll_for_space(mbox)) {
103 mbox_fifo_write(mbox, msg);
104 goto out;
105 }
106
102 len = kfifo_in(&mq->fifo, (unsigned char *)&msg, sizeof(msg)); 107 len = kfifo_in(&mq->fifo, (unsigned char *)&msg, sizeof(msg));
103 WARN_ON(len != sizeof(msg)); 108 WARN_ON(len != sizeof(msg));
104 109
105 tasklet_schedule(&mbox->txq->tasklet); 110 tasklet_schedule(&mbox->txq->tasklet);
106 111
107out: 112out:
108 spin_unlock(&mq->lock); 113 spin_unlock_bh(&mq->lock);
109 return ret; 114 return ret;
110} 115}
111EXPORT_SYMBOL(omap_mbox_msg_send); 116EXPORT_SYMBOL(omap_mbox_msg_send);