|
@@ -780,16 +780,20 @@ static int rproc_start_subdevices(struct rproc *rproc)
|
|
|
int ret;
|
|
|
|
|
|
list_for_each_entry(subdev, &rproc->subdevs, node) {
|
|
|
- ret = subdev->start(subdev);
|
|
|
- if (ret)
|
|
|
- goto unroll_registration;
|
|
|
+ if (subdev->start) {
|
|
|
+ ret = subdev->start(subdev);
|
|
|
+ if (ret)
|
|
|
+ goto unroll_registration;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
unroll_registration:
|
|
|
- list_for_each_entry_continue_reverse(subdev, &rproc->subdevs, node)
|
|
|
- subdev->stop(subdev, true);
|
|
|
+ list_for_each_entry_continue_reverse(subdev, &rproc->subdevs, node) {
|
|
|
+ if (subdev->stop)
|
|
|
+ subdev->stop(subdev, true);
|
|
|
+ }
|
|
|
|
|
|
return ret;
|
|
|
}
|
|
@@ -798,8 +802,10 @@ static void rproc_stop_subdevices(struct rproc *rproc, bool crashed)
|
|
|
{
|
|
|
struct rproc_subdev *subdev;
|
|
|
|
|
|
- list_for_each_entry_reverse(subdev, &rproc->subdevs, node)
|
|
|
- subdev->stop(subdev, crashed);
|
|
|
+ list_for_each_entry_reverse(subdev, &rproc->subdevs, node) {
|
|
|
+ if (subdev->stop)
|
|
|
+ subdev->stop(subdev, crashed);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
/**
|