Commit 49fa9157 authored by Nicolas Saenz Julienne's avatar Nicolas Saenz Julienne Committed by Greg Kroah-Hartman

staging: vchiq_core: rework vchiq_get_config

The function is overly complicated for what it's ultimately achieving.
It's simply filling up a structure.
Signed-off-by: default avatarNicolas Saenz Julienne <nsaenzjulienne@suse.de>
Acked-by: default avatarStefan Wahren <stefan.wahren@i2se.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b3885feb
...@@ -1480,14 +1480,12 @@ vchiq_ioctl(struct file *file, unsigned int cmd, unsigned long arg) ...@@ -1480,14 +1480,12 @@ vchiq_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
ret = -EINVAL; ret = -EINVAL;
break; break;
} }
status = vchiq_get_config(instance, args.config_size, &config);
if (status == VCHIQ_SUCCESS) { vchiq_get_config(&config);
if (copy_to_user((void __user *)args.pconfig, if (copy_to_user(args.pconfig, &config, args.config_size)) {
&config, args.config_size) != 0) {
ret = -EFAULT; ret = -EFAULT;
break; break;
} }
}
} break; } break;
case VCHIQ_IOC_SET_SERVICE_OPTION: { case VCHIQ_IOC_SET_SERVICE_OPTION: {
......
...@@ -3583,28 +3583,14 @@ vchiq_get_peer_version(VCHIQ_SERVICE_HANDLE_T handle, short *peer_version) ...@@ -3583,28 +3583,14 @@ vchiq_get_peer_version(VCHIQ_SERVICE_HANDLE_T handle, short *peer_version)
return status; return status;
} }
VCHIQ_STATUS_T void vchiq_get_config(VCHIQ_CONFIG_T *config)
vchiq_get_config(VCHIQ_INSTANCE_T instance, {
int config_size, VCHIQ_CONFIG_T *pconfig) config->max_msg_size = VCHIQ_MAX_MSG_SIZE;
{ config->bulk_threshold = VCHIQ_MAX_MSG_SIZE;
VCHIQ_CONFIG_T config; config->max_outstanding_bulks = VCHIQ_NUM_SERVICE_BULKS;
config->max_services = VCHIQ_MAX_SERVICES;
(void)instance; config->version = VCHIQ_VERSION;
config->version_min = VCHIQ_VERSION_MIN;
config.max_msg_size = VCHIQ_MAX_MSG_SIZE;
config.bulk_threshold = VCHIQ_MAX_MSG_SIZE;
config.max_outstanding_bulks = VCHIQ_NUM_SERVICE_BULKS;
config.max_services = VCHIQ_MAX_SERVICES;
config.version = VCHIQ_VERSION;
config.version_min = VCHIQ_VERSION_MIN;
if (config_size > sizeof(VCHIQ_CONFIG_T))
return VCHIQ_ERROR;
memcpy(pconfig, &config,
min(config_size, (int)(sizeof(VCHIQ_CONFIG_T))));
return VCHIQ_SUCCESS;
} }
VCHIQ_STATUS_T VCHIQ_STATUS_T
......
...@@ -164,8 +164,7 @@ extern VCHIQ_STATUS_T vchiq_bulk_receive_handle(VCHIQ_SERVICE_HANDLE_T service, ...@@ -164,8 +164,7 @@ extern VCHIQ_STATUS_T vchiq_bulk_receive_handle(VCHIQ_SERVICE_HANDLE_T service,
extern int vchiq_get_client_id(VCHIQ_SERVICE_HANDLE_T service); extern int vchiq_get_client_id(VCHIQ_SERVICE_HANDLE_T service);
extern void *vchiq_get_service_userdata(VCHIQ_SERVICE_HANDLE_T service); extern void *vchiq_get_service_userdata(VCHIQ_SERVICE_HANDLE_T service);
extern int vchiq_get_service_fourcc(VCHIQ_SERVICE_HANDLE_T service); extern int vchiq_get_service_fourcc(VCHIQ_SERVICE_HANDLE_T service);
extern VCHIQ_STATUS_T vchiq_get_config(VCHIQ_INSTANCE_T instance, extern void vchiq_get_config(VCHIQ_CONFIG_T *config);
int config_size, VCHIQ_CONFIG_T *pconfig);
extern VCHIQ_STATUS_T vchiq_set_service_option(VCHIQ_SERVICE_HANDLE_T service, extern VCHIQ_STATUS_T vchiq_set_service_option(VCHIQ_SERVICE_HANDLE_T service,
VCHIQ_SERVICE_OPTION_T option, int value); VCHIQ_SERVICE_OPTION_T option, int value);
......
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