diff options
author | Bjorn Andersson <bjorn.andersson@linaro.org> | 2017-05-27 16:14:02 -0700 |
---|---|---|
committer | Jassi Brar <jaswinder.singh@linaro.org> | 2017-06-14 17:47:09 +0530 |
commit | b7133d6fcd9a9eb4633357d4a27430d4e0c794ad (patch) | |
tree | a71d681809d8d253baa92b38ede830fda74998f6 /drivers/mailbox | |
parent | 63f700aab4c11d46626de3cd051dae56cf7e9056 (diff) | |
download | op-kernel-dev-b7133d6fcd9a9eb4633357d4a27430d4e0c794ad.zip op-kernel-dev-b7133d6fcd9a9eb4633357d4a27430d4e0c794ad.tar.gz |
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: Bjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: Jassi Brar <jaswinder.singh@linaro.org>
Diffstat (limited to 'drivers/mailbox')
-rw-r--r-- | drivers/mailbox/mailbox.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/drivers/mailbox/mailbox.c b/drivers/mailbox/mailbox.c index 9dfbf7e..537f4f6 100644 --- a/drivers/mailbox/mailbox.c +++ b/drivers/mailbox/mailbox.c @@ -355,11 +355,14 @@ struct mbox_chan *mbox_request_channel(struct mbox_client *cl, int index) spin_unlock_irqrestore(&chan->lock, flags); - ret = chan->mbox->ops->startup(chan); - if (ret) { - dev_err(dev, "Unable to startup the chan (%d)\n", ret); - mbox_free_channel(chan); - chan = ERR_PTR(ret); + if (chan->mbox->ops->startup) { + ret = chan->mbox->ops->startup(chan); + + if (ret) { + dev_err(dev, "Unable to startup the chan (%d)\n", ret); + mbox_free_channel(chan); + chan = ERR_PTR(ret); + } } mutex_unlock(&con_mutex); @@ -408,7 +411,8 @@ void mbox_free_channel(struct mbox_chan *chan) if (!chan || !chan->cl) 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 */ spin_lock_irqsave(&chan->lock, flags); |