Commit e51f1d1a authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman

greybus: uart-gb: convert to use gb_operation_sync

This converts the UART protocol driver to use gb_operation_sync,
removing lots of places where the create/send/destroy pattern was being
used to send greybus messages.
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
Reviewed-by: default avatarAlex Elder <elder@linaro.org>
parent ac3d2493
...@@ -137,146 +137,82 @@ static atomic_t reference_count = ATOMIC_INIT(0); ...@@ -137,146 +137,82 @@ static atomic_t reference_count = ATOMIC_INIT(0);
*/ */
static int get_version(struct gb_tty *tty) static int get_version(struct gb_tty *tty)
{ {
struct gb_operation *operation; struct gb_uart_proto_version_response response;
struct gb_uart_proto_version_response *response;
int ret; int ret;
operation = gb_operation_create(tty->connection, ret = gb_operation_sync(tty->connection,
GB_UART_REQ_PROTOCOL_VERSION, GB_UART_REQ_PROTOCOL_VERSION,
0, sizeof(*response)); NULL, 0, &response, sizeof(response));
if (!operation) if (ret)
return -ENOMEM; return ret;
/* Synchronous operation--no callback */
ret = gb_operation_request_send(operation, NULL);
if (ret) {
pr_err("version operation failed (%d)\n", ret);
goto out;
}
response = operation->response->payload; if (response.major > GB_UART_VERSION_MAJOR) {
if (response->major > GB_UART_VERSION_MAJOR) {
pr_err("unsupported major version (%hhu > %hhu)\n", pr_err("unsupported major version (%hhu > %hhu)\n",
response->major, GB_UART_VERSION_MAJOR); response.major, GB_UART_VERSION_MAJOR);
ret = -ENOTSUPP; return -ENOTSUPP;
goto out;
} }
tty->version_major = response->major; tty->version_major = response.major;
tty->version_minor = response->minor; tty->version_minor = response.minor;
pr_debug("%s: version_major = %u version_minor = %u\n", pr_debug("%s: version_major = %u version_minor = %u\n",
__func__, tty->version_major, tty->version_minor); __func__, tty->version_major, tty->version_minor);
out: return 0;
gb_operation_destroy(operation);
return ret;
} }
static int send_data(struct gb_tty *tty, u16 size, const u8 *data) static int send_data(struct gb_tty *tty, u16 size, const u8 *data)
{ {
struct gb_connection *connection = tty->connection;
struct gb_operation *operation;
struct gb_uart_send_data_request *request; struct gb_uart_send_data_request *request;
int retval; int retval;
if (!data || !size) if (!data || !size)
return 0; return 0;
operation = gb_operation_create(connection, GB_UART_REQ_SEND_DATA, request = kmalloc(sizeof(*request) + size, GFP_KERNEL);
sizeof(*request) + size, 0); if (!request)
if (!operation)
return -ENOMEM; return -ENOMEM;
request = operation->request->payload;
request->size = cpu_to_le16(size); request->size = cpu_to_le16(size);
memcpy(&request->data[0], data, size); memcpy(&request->data[0], data, size);
retval = gb_operation_sync(tty->connection, GB_UART_REQ_SEND_DATA,
request, sizeof(*request) + size, NULL, 0);
/* Synchronous operation--no callback */ kfree(request);
retval = gb_operation_request_send(operation, NULL);
if (retval)
dev_err(&connection->dev,
"send data operation failed (%d)\n", retval);
gb_operation_destroy(operation);
return retval; return retval;
} }
static int send_line_coding(struct gb_tty *tty, static int send_line_coding(struct gb_tty *tty,
struct gb_serial_line_coding *line_coding) struct gb_serial_line_coding *line_coding)
{ {
struct gb_connection *connection = tty->connection; struct gb_uart_set_line_coding_request request;
struct gb_operation *operation;
struct gb_uart_set_line_coding_request *request;
int retval;
operation = gb_operation_create(connection, GB_UART_REQ_SET_LINE_CODING,
sizeof(*request), 0);
if (!operation)
return -ENOMEM;
request = operation->request->payload;
memcpy(&request->line_coding, line_coding, sizeof(*line_coding));
/* Synchronous operation--no callback */
retval = gb_operation_request_send(operation, NULL);
if (retval)
dev_err(&connection->dev,
"send line coding operation failed (%d)\n", retval);
gb_operation_destroy(operation);
return retval; memcpy(&request.line_coding, line_coding, sizeof(*line_coding));
return gb_operation_sync(tty->connection, GB_UART_REQ_SET_LINE_CODING,
&request, sizeof(request), NULL, 0);
} }
static int send_control(struct gb_tty *tty, u16 control) static int send_control(struct gb_tty *tty, u16 control)
{ {
struct gb_connection *connection = tty->connection; struct gb_uart_set_control_line_state_request request;
struct gb_operation *operation;
struct gb_uart_set_control_line_state_request *request;
int retval;
operation = gb_operation_create(connection,
GB_UART_REQ_SET_CONTROL_LINE_STATE,
sizeof(*request), 0);
if (!operation)
return -ENOMEM;
request = operation->request->payload;
request->control = cpu_to_le16(control);
/* Synchronous operation--no callback */ request.control = cpu_to_le16(control);
retval = gb_operation_request_send(operation, NULL); return gb_operation_sync(tty->connection,
if (retval) GB_UART_REQ_SET_CONTROL_LINE_STATE,
dev_err(&connection->dev, &request, sizeof(request), NULL, 0);
"send control operation failed (%d)\n", retval);
gb_operation_destroy(operation);
return retval;
} }
static int send_break(struct gb_tty *tty, u8 state) static int send_break(struct gb_tty *tty, u8 state)
{ {
struct gb_connection *connection = tty->connection; struct gb_uart_set_break_request request;
struct gb_operation *operation;
struct gb_uart_set_break_request *request;
int retval;
if ((state != 0) && (state != 1)) { if ((state != 0) && (state != 1)) {
dev_err(&connection->dev, "invalid break state of %d\n", state); dev_err(&tty->connection->dev,
"invalid break state of %d\n", state);
return -EINVAL; return -EINVAL;
} }
operation = gb_operation_create(connection, GB_UART_REQ_SET_BREAK, request.state = state;
sizeof(*request), 0); return gb_operation_sync(tty->connection, GB_UART_REQ_SET_BREAK,
if (!operation) &request, sizeof(request), NULL, 0);
return -ENOMEM;
request = operation->request->payload;
request->state = state;
/* Synchronous operation--no callback */
retval = gb_operation_request_send(operation, NULL);
if (retval)
dev_err(&connection->dev,
"send break operation failed (%d)\n", retval);
gb_operation_destroy(operation);
return retval;
} }
......
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