summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohan Hovold2016-08-10 12:58:42 +0200
committerGreg Kroah-Hartman2016-08-11 14:13:07 +0200
commita9dc1cf5b7b5ce8183249c2229ae0ab849525e37 (patch)
treeaef720d6ecae783f888b57fae29172108ad7f33a
parentgreybus: fix up copyright dates on arpc.h (diff)
downloadkernel-qcow2-linux-a9dc1cf5b7b5ce8183249c2229ae0ab849525e37.tar.gz
kernel-qcow2-linux-a9dc1cf5b7b5ce8183249c2229ae0ab849525e37.tar.xz
kernel-qcow2-linux-a9dc1cf5b7b5ce8183249c2229ae0ab849525e37.zip
greybus: hd/es2: add cport_connected callback and ARPC
Add a host-device cport_connected callback, which will be called after a connection has been created and that can be used by the host-device driver to make sure its internal state is updated to match the CPort attributes set by the SVC. This callback will eventually replace the cport_features_enable callback. Signed-off-by: Johan Hovold <johan@hovoldconsulting.com> Reviewed-by: Viresh Kumar <viresh.kumar@linaro.org> Acked-by: Sandeep Patil <sspatil@google.com> Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
-rw-r--r--drivers/staging/greybus/arpc.h6
-rw-r--r--drivers/staging/greybus/es2.c20
-rw-r--r--drivers/staging/greybus/hd.h1
3 files changed, 27 insertions, 0 deletions
diff --git a/drivers/staging/greybus/arpc.h b/drivers/staging/greybus/arpc.h
index 1bfb7db8efe3..8a9027101b37 100644
--- a/drivers/staging/greybus/arpc.h
+++ b/drivers/staging/greybus/arpc.h
@@ -77,9 +77,15 @@ struct arpc_response_message {
/* ARPC requests */
#define ARPC_TYPE_CPORT_RESET 0x00
+#define ARPC_TYPE_CPORT_CONNECTED 0x01
struct arpc_cport_reset_req {
__le16 cport_id;
} __packed;
+struct arpc_cport_connected_req {
+ __le16 cport_id;
+} __packed;
+
+
#endif /* __ARPC_H */
diff --git a/drivers/staging/greybus/es2.c b/drivers/staging/greybus/es2.c
index 955b37d0c4c6..9af9b73818f4 100644
--- a/drivers/staging/greybus/es2.c
+++ b/drivers/staging/greybus/es2.c
@@ -746,6 +746,25 @@ static int cport_disable(struct gb_host_device *hd, u16 cport_id)
return 0;
}
+static int es2_cport_connected(struct gb_host_device *hd, u16 cport_id)
+{
+ struct es2_ap_dev *es2 = hd_to_es2(hd);
+ struct device *dev = &es2->usb_dev->dev;
+ struct arpc_cport_connected_req req;
+ int ret;
+
+ req.cport_id = cpu_to_le16(cport_id);
+ ret = arpc_sync(es2, ARPC_TYPE_CPORT_CONNECTED, &req, sizeof(req),
+ NULL, ES2_ARPC_CPORT_TIMEOUT);
+ if (ret) {
+ dev_err(dev, "failed to set connected state for cport %u: %d\n",
+ cport_id, ret);
+ return ret;
+ }
+
+ return 0;
+}
+
static int latency_tag_enable(struct gb_host_device *hd, u16 cport_id)
{
int retval;
@@ -930,6 +949,7 @@ static struct gb_hd_driver es2_driver = {
.cport_release = es2_cport_release,
.cport_enable = cport_enable,
.cport_disable = cport_disable,
+ .cport_connected = es2_cport_connected,
.latency_tag_enable = latency_tag_enable,
.latency_tag_disable = latency_tag_disable,
.output = output,
diff --git a/drivers/staging/greybus/hd.h b/drivers/staging/greybus/hd.h
index 6ea5e28d9eb9..be818797d6c6 100644
--- a/drivers/staging/greybus/hd.h
+++ b/drivers/staging/greybus/hd.h
@@ -22,6 +22,7 @@ struct gb_hd_driver {
int (*cport_enable)(struct gb_host_device *hd, u16 cport_id,
unsigned long flags);
int (*cport_disable)(struct gb_host_device *hd, u16 cport_id);
+ int (*cport_connected)(struct gb_host_device *hd, u16 cport_id);
int (*cport_flush)(struct gb_host_device *hd, u16 cport_id);
int (*cport_ping)(struct gb_host_device *hd, u16 cport_id);
int (*message_send)(struct gb_host_device *hd, u16 dest_cport_id,