Commit d1a8c36e authored by Viresh Kumar's avatar Viresh Kumar Committed by Greg Kroah-Hartman

greybus: svc: disable connection after all its users are gone

gb_svc_del() can be called during removal of gb-es2.ko module as well,
and in that case we would like to properly shutdown all modules and
interfaces as USB is still alive.

This requires that we don't disable the svc connection, at least for tx,
as that will be used while removing modules and interfaces.

Disable only rx to begin with, as we shouldn't be handling any requests
from the SVC. Disable tx only after all the users of svc connection are
gone.

Tested on EVT 2.0 by remove gb-es2.ko module. There are still few
errors, specially while quiescing the connections (-22), but not that
many.
Signed-off-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent d9e4c4ee
...@@ -1456,7 +1456,7 @@ static void gb_svc_remove_modules(struct gb_svc *svc) ...@@ -1456,7 +1456,7 @@ static void gb_svc_remove_modules(struct gb_svc *svc)
void gb_svc_del(struct gb_svc *svc) void gb_svc_del(struct gb_svc *svc)
{ {
gb_connection_disable(svc->connection); gb_connection_disable_rx(svc->connection);
/* /*
* The SVC device and input device may have been registered * The SVC device and input device may have been registered
...@@ -1473,6 +1473,8 @@ void gb_svc_del(struct gb_svc *svc) ...@@ -1473,6 +1473,8 @@ void gb_svc_del(struct gb_svc *svc)
flush_workqueue(svc->wq); flush_workqueue(svc->wq);
gb_svc_remove_modules(svc); gb_svc_remove_modules(svc);
gb_connection_disable(svc->connection);
} }
void gb_svc_put(struct gb_svc *svc) void gb_svc_put(struct gb_svc *svc)
......
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