aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/plat-omap/include/plat/mailbox.h1
-rw-r--r--arch/arm/plat-omap/mailbox.c115
2 files changed, 9 insertions, 107 deletions
diff --git a/arch/arm/plat-omap/include/plat/mailbox.h b/arch/arm/plat-omap/include/plat/mailbox.h
index b7a6991814ec..319306a8f44a 100644
--- a/arch/arm/plat-omap/include/plat/mailbox.h
+++ b/arch/arm/plat-omap/include/plat/mailbox.h
@@ -8,7 +8,6 @@
8#include <linux/blkdev.h> 8#include <linux/blkdev.h>
9 9
10typedef u32 mbox_msg_t; 10typedef u32 mbox_msg_t;
11typedef void (mbox_receiver_t)(mbox_msg_t msg);
12struct omap_mbox; 11struct omap_mbox;
13 12
14typedef int __bitwise omap_mbox_irq_t; 13typedef int __bitwise omap_mbox_irq_t;
diff --git a/arch/arm/plat-omap/mailbox.c b/arch/arm/plat-omap/mailbox.c
index f82810eeb3f4..13ca2365f279 100644
--- a/arch/arm/plat-omap/mailbox.c
+++ b/arch/arm/plat-omap/mailbox.c
@@ -71,7 +71,7 @@ static inline int is_mbox_irq(struct omap_mbox *mbox, omap_mbox_irq_t irq)
71/* 71/*
72 * message sender 72 * message sender
73 */ 73 */
74static int __mbox_msg_send(struct omap_mbox *mbox, mbox_msg_t msg, void *arg) 74static int __mbox_msg_send(struct omap_mbox *mbox, mbox_msg_t msg)
75{ 75{
76 int ret = 0, i = 1000; 76 int ret = 0, i = 1000;
77 77
@@ -82,15 +82,7 @@ static int __mbox_msg_send(struct omap_mbox *mbox, mbox_msg_t msg, void *arg)
82 return -1; 82 return -1;
83 udelay(1); 83 udelay(1);
84 } 84 }
85
86 if (arg && mbox->txq->callback) {
87 ret = mbox->txq->callback(arg);
88 if (ret)
89 goto out;
90 }
91
92 mbox_fifo_write(mbox, msg); 85 mbox_fifo_write(mbox, msg);
93 out:
94 return ret; 86 return ret;
95} 87}
96 88
@@ -152,7 +144,7 @@ static void mbox_tx_work(struct work_struct *work)
152 144
153 tx_data = rq->special; 145 tx_data = rq->special;
154 146
155 ret = __mbox_msg_send(mbox, tx_data->msg, tx_data->arg); 147 ret = __mbox_msg_send(mbox, tx_data->msg);
156 if (ret) { 148 if (ret) {
157 enable_mbox_irq(mbox, IRQ_TX); 149 enable_mbox_irq(mbox, IRQ_TX);
158 spin_lock(q->queue_lock); 150 spin_lock(q->queue_lock);
@@ -180,11 +172,6 @@ static void mbox_rx_work(struct work_struct *work)
180 mbox_msg_t msg; 172 mbox_msg_t msg;
181 unsigned long flags; 173 unsigned long flags;
182 174
183 if (mbox->rxq->callback == NULL) {
184 sysfs_notify(&mbox->dev->kobj, NULL, "mbox");
185 return;
186 }
187
188 while (1) { 175 while (1) {
189 spin_lock_irqsave(q->queue_lock, flags); 176 spin_lock_irqsave(q->queue_lock, flags);
190 rq = blk_fetch_request(q); 177 rq = blk_fetch_request(q);
@@ -257,69 +244,6 @@ static irqreturn_t mbox_interrupt(int irq, void *p)
257 return IRQ_HANDLED; 244 return IRQ_HANDLED;
258} 245}
259 246
260/*
261 * sysfs files
262 */
263static ssize_t
264omap_mbox_write(struct device *dev, struct device_attribute *attr,
265 const char *buf, size_t count)
266{
267 int ret;
268 mbox_msg_t *p = (mbox_msg_t *)buf;
269 struct omap_mbox *mbox = dev_get_drvdata(dev);
270
271 for (; count >= sizeof(mbox_msg_t); count -= sizeof(mbox_msg_t)) {
272 ret = omap_mbox_msg_send(mbox, be32_to_cpu(*p), NULL);
273 if (ret)
274 return -EAGAIN;
275 p++;
276 }
277
278 return (size_t)((char *)p - buf);
279}
280
281static ssize_t
282omap_mbox_read(struct device *dev, struct device_attribute *attr, char *buf)
283{
284 unsigned long flags;
285 struct request *rq;
286 mbox_msg_t *p = (mbox_msg_t *) buf;
287 struct omap_mbox *mbox = dev_get_drvdata(dev);
288 struct request_queue *q = mbox->rxq->queue;
289
290 while (1) {
291 spin_lock_irqsave(q->queue_lock, flags);
292 rq = blk_fetch_request(q);
293 spin_unlock_irqrestore(q->queue_lock, flags);
294
295 if (!rq)
296 break;
297
298 *p = (mbox_msg_t)rq->special;
299
300 blk_end_request_all(rq, 0);
301
302 p++;
303 }
304
305 pr_debug("%02x %02x %02x %02x\n", buf[0], buf[1], buf[2], buf[3]);
306
307 return (size_t) ((char *)p - buf);
308}
309
310static DEVICE_ATTR(mbox, S_IRUGO | S_IWUSR, omap_mbox_read, omap_mbox_write);
311
312static ssize_t mbox_show(struct class *class, char *buf)
313{
314 return sprintf(buf, "mbox");
315}
316
317static CLASS_ATTR(mbox, S_IRUGO, mbox_show, NULL);
318
319static struct class omap_mbox_class = {
320 .name = "omap-mailbox",
321};
322
323static struct omap_mbox_queue *mbox_queue_alloc(struct omap_mbox *mbox, 247static struct omap_mbox_queue *mbox_queue_alloc(struct omap_mbox *mbox,
324 request_fn_proc *proc, 248 request_fn_proc *proc,
325 void (*work) (struct work_struct *)) 249 void (*work) (struct work_struct *))
@@ -353,7 +277,7 @@ static void mbox_queue_free(struct omap_mbox_queue *q)
353 kfree(q); 277 kfree(q);
354} 278}
355 279
356static int omap_mbox_init(struct omap_mbox *mbox) 280static int omap_mbox_startup(struct omap_mbox *mbox)
357{ 281{
358 int ret; 282 int ret;
359 struct omap_mbox_queue *mq; 283 struct omap_mbox_queue *mq;
@@ -436,7 +360,7 @@ struct omap_mbox *omap_mbox_get(const char *name)
436 360
437 read_unlock(&mboxes_lock); 361 read_unlock(&mboxes_lock);
438 362
439 ret = omap_mbox_init(mbox); 363 ret = omap_mbox_startup(mbox);
440 if (ret) 364 if (ret)
441 return ERR_PTR(-ENODEV); 365 return ERR_PTR(-ENODEV);
442 366
@@ -460,15 +384,6 @@ int omap_mbox_register(struct device *parent, struct omap_mbox *mbox)
460 if (mbox->next) 384 if (mbox->next)
461 return -EBUSY; 385 return -EBUSY;
462 386
463 mbox->dev = device_create(&omap_mbox_class,
464 parent, 0, mbox, "%s", mbox->name);
465 if (IS_ERR(mbox->dev))
466 return PTR_ERR(mbox->dev);
467
468 ret = device_create_file(mbox->dev, &dev_attr_mbox);
469 if (ret)
470 goto err_sysfs;
471
472 write_lock(&mboxes_lock); 387 write_lock(&mboxes_lock);
473 tmp = find_mboxes(mbox->name); 388 tmp = find_mboxes(mbox->name);
474 if (*tmp) { 389 if (*tmp) {
@@ -482,9 +397,6 @@ int omap_mbox_register(struct device *parent, struct omap_mbox *mbox)
482 return 0; 397 return 0;
483 398
484err_find: 399err_find:
485 device_remove_file(mbox->dev, &dev_attr_mbox);
486err_sysfs:
487 device_unregister(mbox->dev);
488 return ret; 400 return ret;
489} 401}
490EXPORT_SYMBOL(omap_mbox_register); 402EXPORT_SYMBOL(omap_mbox_register);
@@ -500,8 +412,6 @@ int omap_mbox_unregister(struct omap_mbox *mbox)
500 *tmp = mbox->next; 412 *tmp = mbox->next;
501 mbox->next = NULL; 413 mbox->next = NULL;
502 write_unlock(&mboxes_lock); 414 write_unlock(&mboxes_lock);
503 device_remove_file(mbox->dev, &dev_attr_mbox);
504 device_unregister(mbox->dev);
505 return 0; 415 return 0;
506 } 416 }
507 tmp = &(*tmp)->next; 417 tmp = &(*tmp)->next;
@@ -512,23 +422,16 @@ int omap_mbox_unregister(struct omap_mbox *mbox)
512} 422}
513EXPORT_SYMBOL(omap_mbox_unregister); 423EXPORT_SYMBOL(omap_mbox_unregister);
514 424
515static int __init omap_mbox_class_init(void) 425static int __init omap_mbox_init(void)
516{ 426{
517 int ret = class_register(&omap_mbox_class); 427 return 0;
518 if (!ret)
519 ret = class_create_file(&omap_mbox_class, &class_attr_mbox);
520
521 return ret;
522} 428}
429module_init(omap_mbox_init);
523 430
524static void __exit omap_mbox_class_exit(void) 431static void __exit omap_mbox_exit(void)
525{ 432{
526 class_remove_file(&omap_mbox_class, &class_attr_mbox);
527 class_unregister(&omap_mbox_class);
528} 433}
529 434module_exit(omap_mbox_exit);
530subsys_initcall(omap_mbox_class_init);
531module_exit(omap_mbox_class_exit);
532 435
533MODULE_LICENSE("GPL v2"); 436MODULE_LICENSE("GPL v2");
534MODULE_DESCRIPTION("omap mailbox: interrupt driven messaging"); 437MODULE_DESCRIPTION("omap mailbox: interrupt driven messaging");