Commit b7133d6f authored by Bjorn Andersson's avatar Bjorn Andersson Committed by Jassi Brar

mailbox: Make startup and shutdown ops optional

Some mailbox hardware doesn't have to perform any additional operations
on startup of shutdown, so make these optional.
Signed-off-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: default avatarJassi Brar <jaswinder.singh@linaro.org>
parent 63f700aa
...@@ -355,11 +355,14 @@ struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index) ...@@ -355,11 +355,14 @@ struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index)
spin_unlock_irqrestore(&chan->lock, flags); spin_unlock_irqrestore(&chan->lock, flags);
ret = chan->mbox->ops->startup(chan); if (chan->mbox->ops->startup) {
if (ret) { ret = chan->mbox->ops->startup(chan);
dev_err(dev, "Unable to startup the chan (%d)\n", ret);
mbox_free_channel(chan); if (ret) {
chan = ERR_PTR(ret); dev_err(dev, "Unable to startup the chan (%d)\n", ret);
mbox_free_channel(chan);
chan = ERR_PTR(ret);
}
} }
mutex_unlock(&con_mutex); mutex_unlock(&con_mutex);
...@@ -408,7 +411,8 @@ void mbox_free_channel(struct mbox_chan *chan) ...@@ -408,7 +411,8 @@ void mbox_free_channel(struct mbox_chan *chan)
if (!chan || !chan->cl) if (!chan || !chan->cl)
return; return;
chan->mbox->ops->shutdown(chan); if (chan->mbox->ops->shutdown)
chan->mbox->ops->shutdown(chan);
/* The queued TX requests are simply aborted, no callbacks are made */ /* The queued TX requests are simply aborted, no callbacks are made */
spin_lock_irqsave(&chan->lock, flags); spin_lock_irqsave(&chan->lock, flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment