forked from Minki/linux
remoteproc: Drop wait in __rproc_boot()
In the event that rproc_boot() is called before the firmware loaded completion has been flagged it will wait with the mutex held, obstructing the request_firmware_nowait() callback from completing the wait. As rproc_fw_config_virtio() has been reduced to only triggering auto-boot there is no longer a reason for waiting in rproc_boot(), so drop this. Cc: Sarangdhar Joshi <spjoshi@codeaurora.org> Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
This commit is contained in:
parent
394c62000a
commit
2bfc311a57
@ -972,7 +972,7 @@ static void rproc_fw_config_virtio(const struct firmware *fw, void *context)
|
|||||||
|
|
||||||
/* if rproc is marked always-on, request it to boot */
|
/* if rproc is marked always-on, request it to boot */
|
||||||
if (rproc->auto_boot)
|
if (rproc->auto_boot)
|
||||||
rproc_boot_nowait(rproc);
|
rproc_boot(rproc);
|
||||||
|
|
||||||
release_firmware(fw);
|
release_firmware(fw);
|
||||||
/* allow rproc_del() contexts, if any, to proceed */
|
/* allow rproc_del() contexts, if any, to proceed */
|
||||||
@ -1070,7 +1070,6 @@ static void rproc_crash_handler_work(struct work_struct *work)
|
|||||||
/**
|
/**
|
||||||
* __rproc_boot() - boot a remote processor
|
* __rproc_boot() - boot a remote processor
|
||||||
* @rproc: handle of a remote processor
|
* @rproc: handle of a remote processor
|
||||||
* @wait: wait for rproc registration completion
|
|
||||||
*
|
*
|
||||||
* Boot a remote processor (i.e. load its firmware, power it on, ...).
|
* Boot a remote processor (i.e. load its firmware, power it on, ...).
|
||||||
*
|
*
|
||||||
@ -1079,7 +1078,7 @@ static void rproc_crash_handler_work(struct work_struct *work)
|
|||||||
*
|
*
|
||||||
* Returns 0 on success, and an appropriate error value otherwise.
|
* Returns 0 on success, and an appropriate error value otherwise.
|
||||||
*/
|
*/
|
||||||
static int __rproc_boot(struct rproc *rproc, bool wait)
|
static int __rproc_boot(struct rproc *rproc)
|
||||||
{
|
{
|
||||||
const struct firmware *firmware_p;
|
const struct firmware *firmware_p;
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
@ -1113,10 +1112,6 @@ static int __rproc_boot(struct rproc *rproc, bool wait)
|
|||||||
goto downref_rproc;
|
goto downref_rproc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if rproc virtio is not yet configured, wait */
|
|
||||||
if (wait)
|
|
||||||
wait_for_completion(&rproc->firmware_loading_complete);
|
|
||||||
|
|
||||||
ret = rproc_fw_boot(rproc, firmware_p);
|
ret = rproc_fw_boot(rproc, firmware_p);
|
||||||
|
|
||||||
release_firmware(firmware_p);
|
release_firmware(firmware_p);
|
||||||
@ -1135,21 +1130,10 @@ unlock_mutex:
|
|||||||
*/
|
*/
|
||||||
int rproc_boot(struct rproc *rproc)
|
int rproc_boot(struct rproc *rproc)
|
||||||
{
|
{
|
||||||
return __rproc_boot(rproc, true);
|
return __rproc_boot(rproc);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(rproc_boot);
|
EXPORT_SYMBOL(rproc_boot);
|
||||||
|
|
||||||
/**
|
|
||||||
* rproc_boot_nowait() - boot a remote processor
|
|
||||||
* @rproc: handle of a remote processor
|
|
||||||
*
|
|
||||||
* Same as rproc_boot() but don't wait for rproc registration completion
|
|
||||||
*/
|
|
||||||
int rproc_boot_nowait(struct rproc *rproc)
|
|
||||||
{
|
|
||||||
return __rproc_boot(rproc, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* rproc_shutdown() - power off the remote processor
|
* rproc_shutdown() - power off the remote processor
|
||||||
* @rproc: the remote processor
|
* @rproc: the remote processor
|
||||||
|
Loading…
Reference in New Issue
Block a user