• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2013-2014 Linaro Ltd.
3  * Author: Jassi Brar <jassisinghbrar@gmail.com>
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation.
8  */
9 
10 #ifndef __MAILBOX_CLIENT_H
11 #define __MAILBOX_CLIENT_H
12 
13 #include <linux/of.h>
14 #include <linux/device.h>
15 
16 struct mbox_chan;
17 
18 /**
19  * struct mbox_client - User of a mailbox
20  * @dev:		The client device
21  * @tx_block:		If the mbox_send_message should block until data is
22  *			transmitted.
23  * @tx_tout:		Max block period in ms before TX is assumed failure
24  * @knows_txdone:	If the client could run the TX state machine. Usually
25  *			if the client receives some ACK packet for transmission.
26  *			Unused if the controller already has TX_Done/RTR IRQ.
27  * @rx_callback:	Atomic callback to provide client the data received
28  * @tx_done:		Atomic callback to tell client of data transmission
29  */
30 struct mbox_client {
31 	struct device *dev;
32 	bool tx_block;
33 	unsigned long tx_tout;
34 	bool knows_txdone;
35 
36 	void (*rx_callback)(struct mbox_client *cl, void *mssg);
37 	void (*tx_done)(struct mbox_client *cl, void *mssg, int r);
38 };
39 
40 struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index);
41 int mbox_send_message(struct mbox_chan *chan, void *mssg);
42 void mbox_client_txdone(struct mbox_chan *chan, int r); /* atomic */
43 bool mbox_client_peek_data(struct mbox_chan *chan); /* atomic */
44 void mbox_free_channel(struct mbox_chan *chan); /* may sleep */
45 
46 #endif /* __MAILBOX_CLIENT_H */
47