Commit 0a9c4d70 authored by Alex Elder's avatar Alex Elder Committed by Greg Kroah-Hartman

greybus: switch cport id used for sends

In talking with Perry today I learned that the CPort id expected to
supplied over the HSIC interface to the APB is different from the
way I understood it.

My understanding was that the CPort id to supply always specified
the CPort id on the other end of a connection.  However, Perry says
the mapping between local CPort id and remote CPort id (and device
id) is done by the host UniPro interface.

So whether sending or receiving data, the CPort id that the Greybus
code should supply to the AP Bridge is the one representing the AP
side of a connection.

This patch fixes this.  The receive side already used that CPort id;
it's only the sending code that needed to be changed.
Signed-off-by: default avatarAlex Elder <elder@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent 7de3e650
...@@ -190,7 +190,7 @@ static struct urb *next_free_urb(struct es1_ap_dev *es1, gfp_t gfp_mask) ...@@ -190,7 +190,7 @@ static struct urb *next_free_urb(struct es1_ap_dev *es1, gfp_t gfp_mask)
* error otherwise. If the caller wishes to cancel the in-flight * error otherwise. If the caller wishes to cancel the in-flight
* buffer, it must supply the returned cookie to the cancel routine. * buffer, it must supply the returned cookie to the cancel routine.
*/ */
static void *buffer_send(struct greybus_host_device *hd, u16 dest_cport_id, static void *buffer_send(struct greybus_host_device *hd, u16 cport_id,
void *buffer, size_t buffer_size, gfp_t gfp_mask) void *buffer, size_t buffer_size, gfp_t gfp_mask)
{ {
struct es1_ap_dev *es1 = hd_to_es1(hd); struct es1_ap_dev *es1 = hd_to_es1(hd);
...@@ -216,17 +216,16 @@ static void *buffer_send(struct greybus_host_device *hd, u16 dest_cport_id, ...@@ -216,17 +216,16 @@ static void *buffer_send(struct greybus_host_device *hd, u16 dest_cport_id,
* of where the data should be sent. Do one last check of * of where the data should be sent. Do one last check of
* the target CPort id before filling it in. * the target CPort id before filling it in.
*/ */
if (dest_cport_id == CPORT_ID_BAD) { if (cport_id == CPORT_ID_BAD) {
pr_err("request to send inbound data buffer\n"); pr_err("request to send inbound data buffer\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
if (dest_cport_id > (u16)U8_MAX) { if (cport_id > (u16)U8_MAX) {
pr_err("dest_cport_id (%hd) is out of range for ES1\n", pr_err("cport_id (%hd) is out of range for ES1\n", cport_id);
dest_cport_id);
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
/* OK, the destination is fine; record it in the transfer buffer */ /* OK, the destination is fine; record it in the transfer buffer */
*transfer_buffer = dest_cport_id; *transfer_buffer = cport_id;
/* Find a free urb */ /* Find a free urb */
urb = next_free_urb(es1, gfp_mask); urb = next_free_urb(es1, gfp_mask);
...@@ -393,8 +392,8 @@ static void cport_in_callback(struct urb *urb) ...@@ -393,8 +392,8 @@ static void cport_in_callback(struct urb *urb)
} }
/* /*
* The CPort number is the first byte of the data stream, the rest of * Our CPort number is the first byte of the data stream,
* the stream is "real" data * the rest of the stream is "real" data
*/ */
data = urb->transfer_buffer; data = urb->transfer_buffer;
cport_id = (u16)data[0]; cport_id = (u16)data[0];
......
...@@ -167,13 +167,12 @@ static int gb_message_send(struct gb_message *message) ...@@ -167,13 +167,12 @@ static int gb_message_send(struct gb_message *message)
{ {
size_t message_size = sizeof(*message->header) + message->payload_size; size_t message_size = sizeof(*message->header) + message->payload_size;
struct gb_connection *connection = message->operation->connection; struct gb_connection *connection = message->operation->connection;
u16 dest_cport_id = connection->interface_cport_id;
int ret = 0; int ret = 0;
void *cookie; void *cookie;
mutex_lock(&gb_message_mutex); mutex_lock(&gb_message_mutex);
cookie = connection->hd->driver->buffer_send(connection->hd, cookie = connection->hd->driver->buffer_send(connection->hd,
dest_cport_id, connection->hd_cport_id,
message->header, message->header,
message_size, message_size,
GFP_KERNEL); GFP_KERNEL);
......
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