Commit 00ad6975 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

greybus: connection: move CPort Buffer configuration out of svc helpers

The CPort Buffer configuration in the host-device needs to match the
CPort feature flags set by the SVC, but they need not always be
configured at the same point in time.

This will be used when implementing proper connection tear down.
Reviewed-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent e2efe1bb
...@@ -345,7 +345,7 @@ gb_connection_svc_connection_create(struct gb_connection *connection) ...@@ -345,7 +345,7 @@ gb_connection_svc_connection_create(struct gb_connection *connection)
int ret; int ret;
if (gb_connection_is_static(connection)) if (gb_connection_is_static(connection))
return gb_connection_hd_cport_features_enable(connection); return 0;
intf = connection->intf; intf = connection->intf;
...@@ -373,23 +373,12 @@ gb_connection_svc_connection_create(struct gb_connection *connection) ...@@ -373,23 +373,12 @@ gb_connection_svc_connection_create(struct gb_connection *connection)
return ret; return ret;
} }
ret = gb_connection_hd_cport_features_enable(connection);
if (ret) {
gb_svc_connection_destroy(hd->svc, hd->svc->ap_intf_id,
connection->hd_cport_id,
intf->interface_id,
connection->intf_cport_id);
return ret;
}
return 0; return 0;
} }
static void static void
gb_connection_svc_connection_destroy(struct gb_connection *connection) gb_connection_svc_connection_destroy(struct gb_connection *connection)
{ {
gb_connection_hd_cport_features_disable(connection);
if (gb_connection_is_static(connection)) if (gb_connection_is_static(connection))
return; return;
...@@ -557,6 +546,10 @@ static int _gb_connection_enable(struct gb_connection *connection, bool rx) ...@@ -557,6 +546,10 @@ static int _gb_connection_enable(struct gb_connection *connection, bool rx)
if (ret) if (ret)
goto err_hd_cport_disable; goto err_hd_cport_disable;
ret = gb_connection_hd_cport_features_enable(connection);
if (ret)
goto err_svc_connection_destroy;
spin_lock_irq(&connection->lock); spin_lock_irq(&connection->lock);
if (connection->handler && rx) if (connection->handler && rx)
connection->state = GB_CONNECTION_STATE_ENABLED; connection->state = GB_CONNECTION_STATE_ENABLED;
...@@ -576,6 +569,8 @@ static int _gb_connection_enable(struct gb_connection *connection, bool rx) ...@@ -576,6 +569,8 @@ static int _gb_connection_enable(struct gb_connection *connection, bool rx)
gb_connection_cancel_operations(connection, -ESHUTDOWN); gb_connection_cancel_operations(connection, -ESHUTDOWN);
spin_unlock_irq(&connection->lock); spin_unlock_irq(&connection->lock);
gb_connection_hd_cport_features_disable(connection);
err_svc_connection_destroy:
gb_connection_svc_connection_destroy(connection); gb_connection_svc_connection_destroy(connection);
err_hd_cport_disable: err_hd_cport_disable:
gb_connection_hd_cport_disable(connection); gb_connection_hd_cport_disable(connection);
...@@ -654,6 +649,7 @@ void gb_connection_disable(struct gb_connection *connection) ...@@ -654,6 +649,7 @@ void gb_connection_disable(struct gb_connection *connection)
gb_connection_cancel_operations(connection, -ESHUTDOWN); gb_connection_cancel_operations(connection, -ESHUTDOWN);
spin_unlock_irq(&connection->lock); spin_unlock_irq(&connection->lock);
gb_connection_hd_cport_features_disable(connection);
gb_connection_svc_connection_destroy(connection); gb_connection_svc_connection_destroy(connection);
gb_connection_hd_cport_disable(connection); gb_connection_hd_cport_disable(connection);
...@@ -675,6 +671,7 @@ void gb_connection_disable_forced(struct gb_connection *connection) ...@@ -675,6 +671,7 @@ void gb_connection_disable_forced(struct gb_connection *connection)
gb_connection_cancel_operations(connection, -ESHUTDOWN); gb_connection_cancel_operations(connection, -ESHUTDOWN);
spin_unlock_irq(&connection->lock); spin_unlock_irq(&connection->lock);
gb_connection_hd_cport_features_disable(connection);
gb_connection_svc_connection_destroy(connection); gb_connection_svc_connection_destroy(connection);
gb_connection_hd_cport_disable(connection); gb_connection_hd_cport_disable(connection);
......
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