blob: 65229a45590f159d73d4c7f1e30e556f4a40e8e5 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Jassi Brar2b6d83e2014-06-12 22:31:19 +05302/*
3 * Copyright (C) 2013-2014 Linaro Ltd.
4 * Author: Jassi Brar <jassisinghbrar@gmail.com>
Jassi Brar2b6d83e2014-06-12 22:31:19 +05305 */
6
7#ifndef __MAILBOX_CLIENT_H
8#define __MAILBOX_CLIENT_H
9
10#include <linux/of.h>
11#include <linux/device.h>
12
13struct mbox_chan;
14
15/**
16 * struct mbox_client - User of a mailbox
17 * @dev: The client device
18 * @tx_block: If the mbox_send_message should block until data is
19 * transmitted.
20 * @tx_tout: Max block period in ms before TX is assumed failure
21 * @knows_txdone: If the client could run the TX state machine. Usually
22 * if the client receives some ACK packet for transmission.
23 * Unused if the controller already has TX_Done/RTR IRQ.
24 * @rx_callback: Atomic callback to provide client the data received
Sudeep Holla97b0c7b2014-11-11 18:33:01 +000025 * @tx_prepare: Atomic callback to ask client to prepare the payload
26 * before initiating the transmission if required.
Jassi Brar2b6d83e2014-06-12 22:31:19 +053027 * @tx_done: Atomic callback to tell client of data transmission
28 */
29struct mbox_client {
30 struct device *dev;
31 bool tx_block;
32 unsigned long tx_tout;
33 bool knows_txdone;
34
35 void (*rx_callback)(struct mbox_client *cl, void *mssg);
Sudeep Holla97b0c7b2014-11-11 18:33:01 +000036 void (*tx_prepare)(struct mbox_client *cl, void *mssg);
Jassi Brar2b6d83e2014-06-12 22:31:19 +053037 void (*tx_done)(struct mbox_client *cl, void *mssg, int r);
38};
39
Lee Jonesdfabde22015-05-11 17:08:50 +010040struct mbox_chan *mbox_request_channel_byname(struct mbox_client *cl,
41 const char *name);
Jassi Brar2b6d83e2014-06-12 22:31:19 +053042struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index);
43int mbox_send_message(struct mbox_chan *chan, void *mssg);
Thierry Redinga8803d72018-11-28 10:54:10 +010044int mbox_flush(struct mbox_chan *chan, unsigned long timeout);
Jassi Brar2b6d83e2014-06-12 22:31:19 +053045void mbox_client_txdone(struct mbox_chan *chan, int r); /* atomic */
46bool mbox_client_peek_data(struct mbox_chan *chan); /* atomic */
47void mbox_free_channel(struct mbox_chan *chan); /* may sleep */
48
49#endif /* __MAILBOX_CLIENT_H */