Skip to content

Commit

Permalink
mailbox: add tx_prepare client callback
Browse files Browse the repository at this point in the history
If the mailbox controller expects the payload is in place before
initiating the transmit, then it's impossible to reuse the list
maintained by core mailbox code currently. Maintaining another list
for sending the message in the controller seems totally unnecessary
as core mailbox library already provides that feature.

This patch introduces tx_prepare callback in mbox_client which
can be used by the core mailbox library before initiating the
transaction through mbox->ops->send_data. The client driver can
implement this callback to ensure the payload is copied to the
shared memory.

Signed-off-by: Sudeep Holla <[email protected]>
Cc: Arnd Bergmann <[email protected]>
Signed-off-by: Jassi Brar <[email protected]>
  • Loading branch information
sudeep-holla authored and JassiBrar committed Nov 27, 2014
1 parent 52a4930 commit 97b0c7b
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 0 deletions.
2 changes: 2 additions & 0 deletions drivers/mailbox/mailbox.c
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,8 @@ static void msg_submit(struct mbox_chan *chan)

data = chan->msg_data[idx];

if (chan->cl->tx_prepare)
chan->cl->tx_prepare(chan->cl, data);
/* Try to submit a message to the MBOX controller */
err = chan->mbox->ops->send_data(chan, data);
if (!err) {
Expand Down
3 changes: 3 additions & 0 deletions include/linux/mailbox_client.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ struct mbox_chan;
* if the client receives some ACK packet for transmission.
* Unused if the controller already has TX_Done/RTR IRQ.
* @rx_callback: Atomic callback to provide client the data received
* @tx_prepare: Atomic callback to ask client to prepare the payload
* before initiating the transmission if required.
* @tx_done: Atomic callback to tell client of data transmission
*/
struct mbox_client {
Expand All @@ -34,6 +36,7 @@ struct mbox_client {
bool knows_txdone;

void (*rx_callback)(struct mbox_client *cl, void *mssg);
void (*tx_prepare)(struct mbox_client *cl, void *mssg);
void (*tx_done)(struct mbox_client *cl, void *mssg, int r);
};

Expand Down

0 comments on commit 97b0c7b

Please sign in to comment.