aboutsummaryrefslogtreecommitdiff
path: root/include/linux/mailbox_client.h
blob: 53eb0784261b537dd922e2d350bd100075c65ffe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/*
 * Copyright (C) 2014 Linaro Ltd.
 * Author: Jassi Brar <jassisinghbrar@gmail.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

#ifndef __MAILBOX_CLIENT_H
#define __MAILBOX_CLIENT_H

#include <linux/of.h>

struct mbox_chan;

/**
 * struct mbox_client - User of a mailbox
 * @dev:		The client device
 * @chan_name:		The "controller:channel" this client wants
 * @rx_callback:	Atomic callback to provide client the data received
 * @tx_done:		Atomic callback to tell client of data transmission
 * @tx_block:		If the mbox_send_message should block until data is
 *			transmitted.
 * @tx_tout:		Max block period in ms before TX is assumed failure
 * @knows_txdone:	if the client could run the TX state machine. Usually
 *			if the client receives some ACK packet for transmission.
 *			Unused if the controller already has TX_Done/RTR IRQ.
 */
struct mbox_client {
	struct device *dev;
	const char *chan_name;
	void (*rx_callback)(struct mbox_client *cl, void *mssg);
	void (*tx_done)(struct mbox_client *cl, void *mssg, int r);
	bool tx_block;
	unsigned long tx_tout;
	bool knows_txdone;
};

struct mbox_chan *mbox_request_channel(const struct mbox_client *cl);
int mbox_send_message(struct mbox_chan *chan, void *mssg);
void mbox_client_txdone(struct mbox_chan *chan, int r);
void mbox_free_channel(struct mbox_chan *chan);

#endif /* __MAILBOX_CLIENT_H */