greybus: connection: add api to {en,dis}able unipro fct flow
authorFabien Parent <fparent@baylibre.com>
Tue, 23 Feb 2016 17:46:08 +0000 (18:46 +0100)
committerGreg Kroah-Hartman <gregkh@google.com>
Thu, 25 Feb 2016 01:21:58 +0000 (17:21 -0800)
In order to support mailbox-free control cport init on the bridges the AP must
be able to enable/disable the flow of unipro fct tokens. Add a new API that
will enable or disable on APBA the flow of fct tokens.

Reviewed-by: Johan Hovold <johan@hovoldconsulting.com>
Signed-off-by: Fabien Parent <fparent@baylibre.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/connection.c
drivers/staging/greybus/hd.h

index 4f5e2adfa8c4eb6c1232f66b9dadf9358f2aa2fc..4ae7153ff863971f221f38fe68bb0e5be136ec67 100644 (file)
@@ -274,6 +274,34 @@ static void gb_connection_hd_cport_disable(struct gb_connection *connection)
        hd->driver->cport_disable(hd, connection->hd_cport_id);
 }
 
+static int gb_connection_hd_fct_flow_enable(struct gb_connection *connection)
+{
+       struct gb_host_device *hd = connection->hd;
+       int ret;
+
+       if (!hd->driver->fct_flow_enable)
+               return 0;
+
+       ret = hd->driver->fct_flow_enable(hd, connection->hd_cport_id);
+       if (ret) {
+               dev_err(&hd->dev, "%s: failed to enable FCT flow: %d\n",
+                       connection->name, ret);
+               return ret;
+       }
+
+       return 0;
+}
+
+static void gb_connection_hd_fct_flow_disable(struct gb_connection *connection)
+{
+       struct gb_host_device *hd = connection->hd;
+
+       if (!hd->driver->fct_flow_disable)
+               return;
+
+       hd->driver->fct_flow_disable(hd, connection->hd_cport_id);
+}
+
 /*
  * Request the SVC to create a connection from AP's cport to interface's
  * cport.
index e11359b145e641823f967b1001269fefe9791e23..eaddfc9befd645d63e9b322d9704acaf200ec7e3 100644 (file)
@@ -25,6 +25,8 @@ struct gb_hd_driver {
        int (*latency_tag_disable)(struct gb_host_device *hd, u16 cport_id);
        int (*output)(struct gb_host_device *hd, void *req, u16 size, u8 cmd,
                      bool async);
+       int (*fct_flow_enable)(struct gb_host_device *hd, u16 cport_id);
+       int (*fct_flow_disable)(struct gb_host_device *hd, u16 cport_id);
 };
 
 struct gb_host_device {