greybus: move copy of incoming request data
authorAlex Elder <elder@linaro.org>
Tue, 2 Dec 2014 14:30:28 +0000 (08:30 -0600)
committerGreg Kroah-Hartman <greg@kroah.com>
Tue, 2 Dec 2014 22:35:33 +0000 (14:35 -0800)
Currently incoming request data is copied into a request message
buffer in gb_connection_recv_request().  Move that--along with the
assignment of the message id--into gb_operation_create_incoming().

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Greg Kroah-Hartman <greg@kroah.com>
drivers/staging/greybus/operation.c

index d973b57dc6931ac92e6d469e4d66d7fb53f9f9aa..1e0ce7d98618f7cb6eb05e0a9a573a681908bdee 100644 (file)
@@ -465,11 +465,19 @@ struct gb_operation *gb_operation_create(struct gb_connection *connection,
 
 static struct gb_operation *
 gb_operation_create_incoming(struct gb_connection *connection,
-                                       u8 type, size_t request_size,
-                                       size_t response_size)
+                                       u16 operation_id, u8 type,
+                                       void *data, size_t request_size)
 {
-       return gb_operation_create_common(connection, false, type,
-                                       request_size, response_size);
+       struct gb_operation *operation;
+
+       operation = gb_operation_create_common(connection, false, type,
+                                               request_size, 0);
+       if (operation) {
+               operation->id = operation_id;
+               memcpy(operation->request->header, data, request_size);
+       }
+
+       return operation;
 }
 
 /*
@@ -622,13 +630,12 @@ static void gb_connection_recv_request(struct gb_connection *connection,
 {
        struct gb_operation *operation;
 
-       operation = gb_operation_create_incoming(connection, type, size, 0);
+       operation = gb_operation_create_incoming(connection, operation_id,
+                                               type, data, size);
        if (!operation) {
                gb_connection_err(connection, "can't create operation");
                return;         /* XXX Respond with pre-allocated ENOMEM */
        }
-       operation->id = operation_id;
-       memcpy(operation->request->header, data, size);
 
        /* XXX Right now this will just complete the operation */
        if (gb_operation_result_set(operation, -ENOSYS))