Skip to content

Commit 67bc809

Browse files
arndbjenswi-linaro
authored andcommitted
optee: simplify i2c access
Storing a bogus i2c_client structure on the stack adds overhead and causes a compile-time warning: drivers/tee/optee/rpc.c:493:6: error: stack frame size of 1056 bytes in function 'optee_handle_rpc' [-Werror,-Wframe-larger-than=] void optee_handle_rpc(struct tee_context *ctx, struct optee_rpc_param *param, Change the implementation of handle_rpc_func_cmd_i2c_transfer() to open-code the i2c_transfer() call, which makes it easier to read and avoids the warning. Fixes: c05210a ("drivers: optee: allow op-tee to access devices on the i2c bus") Tested-by: Jorge Ramirez-Ortiz <[email protected]> Signed-off-by: Arnd Bergmann <[email protected]> Signed-off-by: Jens Wiklander <[email protected]>
1 parent e71ba94 commit 67bc809

File tree

1 file changed

+16
-15
lines changed

1 file changed

+16
-15
lines changed

drivers/tee/optee/rpc.c

Lines changed: 16 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -54,8 +54,9 @@ static void handle_rpc_func_cmd_get_time(struct optee_msg_arg *arg)
5454
static void handle_rpc_func_cmd_i2c_transfer(struct tee_context *ctx,
5555
struct optee_msg_arg *arg)
5656
{
57-
struct i2c_client client = { 0 };
5857
struct tee_param *params;
58+
struct i2c_adapter *adapter;
59+
struct i2c_msg msg = { };
5960
size_t i;
6061
int ret = -EOPNOTSUPP;
6162
u8 attr[] = {
@@ -85,48 +86,48 @@ static void handle_rpc_func_cmd_i2c_transfer(struct tee_context *ctx,
8586
goto bad;
8687
}
8788

88-
client.adapter = i2c_get_adapter(params[0].u.value.b);
89-
if (!client.adapter)
89+
adapter = i2c_get_adapter(params[0].u.value.b);
90+
if (!adapter)
9091
goto bad;
9192

9293
if (params[1].u.value.a & OPTEE_MSG_RPC_CMD_I2C_FLAGS_TEN_BIT) {
93-
if (!i2c_check_functionality(client.adapter,
94+
if (!i2c_check_functionality(adapter,
9495
I2C_FUNC_10BIT_ADDR)) {
95-
i2c_put_adapter(client.adapter);
96+
i2c_put_adapter(adapter);
9697
goto bad;
9798
}
9899

99-
client.flags = I2C_CLIENT_TEN;
100+
msg.flags = I2C_M_TEN;
100101
}
101102

102-
client.addr = params[0].u.value.c;
103-
snprintf(client.name, I2C_NAME_SIZE, "i2c%d", client.adapter->nr);
103+
msg.addr = params[0].u.value.c;
104+
msg.buf = params[2].u.memref.shm->kaddr;
105+
msg.len = params[2].u.memref.size;
104106

105107
switch (params[0].u.value.a) {
106108
case OPTEE_MSG_RPC_CMD_I2C_TRANSFER_RD:
107-
ret = i2c_master_recv(&client, params[2].u.memref.shm->kaddr,
108-
params[2].u.memref.size);
109+
msg.flags |= I2C_M_RD;
109110
break;
110111
case OPTEE_MSG_RPC_CMD_I2C_TRANSFER_WR:
111-
ret = i2c_master_send(&client, params[2].u.memref.shm->kaddr,
112-
params[2].u.memref.size);
113112
break;
114113
default:
115-
i2c_put_adapter(client.adapter);
114+
i2c_put_adapter(adapter);
116115
goto bad;
117116
}
118117

118+
ret = i2c_transfer(adapter, &msg, 1);
119+
119120
if (ret < 0) {
120121
arg->ret = TEEC_ERROR_COMMUNICATION;
121122
} else {
122-
params[3].u.value.a = ret;
123+
params[3].u.value.a = msg.len;
123124
if (optee_to_msg_param(arg->params, arg->num_params, params))
124125
arg->ret = TEEC_ERROR_BAD_PARAMETERS;
125126
else
126127
arg->ret = TEEC_SUCCESS;
127128
}
128129

129-
i2c_put_adapter(client.adapter);
130+
i2c_put_adapter(adapter);
130131
kfree(params);
131132
return;
132133
bad:

0 commit comments

Comments
 (0)