mirror of
https://github.com/torvalds/linux.git
synced 2024-12-25 20:32:22 +00:00
staging: vc04_services: no need to check debugfs return values
When calling debugfs functions, there is no need to ever check the return value. The function can work or not, but the code logic should never do something different based on this. Clean up the vchiq_arm code by not caring about the value of debugfs calls. This ends up removing a number of lines of code that are not needed. Cc: Stefan Wahren <stefan.wahren@i2se.com> Cc: Kees Cook <keescook@chromium.org> Cc: Dan Carpenter <dan.carpenter@oracle.com> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Keerthi Reddy <keerthigd4990@gmail.com> Cc: linux-rpi-kernel@lists.infradead.org Cc: linux-arm-kernel@lists.infradead.org Reviewed-by: Eric Anholt <eric@anholt.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
8a10ef4e60
commit
0723103f8b
@ -2018,7 +2018,6 @@ vchiq_open(struct inode *inode, struct file *file)
|
|||||||
vchiq_log_info(vchiq_arm_log_level, "vchiq_open");
|
vchiq_log_info(vchiq_arm_log_level, "vchiq_open");
|
||||||
switch (dev) {
|
switch (dev) {
|
||||||
case VCHIQ_MINOR: {
|
case VCHIQ_MINOR: {
|
||||||
int ret;
|
|
||||||
VCHIQ_STATE_T *state = vchiq_get_state();
|
VCHIQ_STATE_T *state = vchiq_get_state();
|
||||||
VCHIQ_INSTANCE_T instance;
|
VCHIQ_INSTANCE_T instance;
|
||||||
|
|
||||||
@ -2035,11 +2034,7 @@ vchiq_open(struct inode *inode, struct file *file)
|
|||||||
instance->state = state;
|
instance->state = state;
|
||||||
instance->pid = current->tgid;
|
instance->pid = current->tgid;
|
||||||
|
|
||||||
ret = vchiq_debugfs_add_instance(instance);
|
vchiq_debugfs_add_instance(instance);
|
||||||
if (ret != 0) {
|
|
||||||
kfree(instance);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
sema_init(&instance->insert_event, 0);
|
sema_init(&instance->insert_event, 0);
|
||||||
sema_init(&instance->remove_event, 0);
|
sema_init(&instance->remove_event, 0);
|
||||||
@ -3630,9 +3625,7 @@ static int vchiq_probe(struct platform_device *pdev)
|
|||||||
goto failed_device_create;
|
goto failed_device_create;
|
||||||
|
|
||||||
/* create debugfs entries */
|
/* create debugfs entries */
|
||||||
err = vchiq_debugfs_init();
|
vchiq_debugfs_init();
|
||||||
if (err != 0)
|
|
||||||
goto failed_debugfs_init;
|
|
||||||
|
|
||||||
vchiq_log_info(vchiq_arm_log_level,
|
vchiq_log_info(vchiq_arm_log_level,
|
||||||
"vchiq: initialised - version %d (min %d), device %d.%d",
|
"vchiq: initialised - version %d (min %d), device %d.%d",
|
||||||
@ -3645,8 +3638,6 @@ static int vchiq_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
failed_debugfs_init:
|
|
||||||
device_destroy(vchiq_class, vchiq_devid);
|
|
||||||
failed_device_create:
|
failed_device_create:
|
||||||
class_destroy(vchiq_class);
|
class_destroy(vchiq_class);
|
||||||
failed_class_create:
|
failed_class_create:
|
||||||
|
@ -158,15 +158,12 @@ static const struct file_operations debugfs_log_fops = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* create an entry under <debugfs>/vchiq/log for each log category */
|
/* create an entry under <debugfs>/vchiq/log for each log category */
|
||||||
static int vchiq_debugfs_create_log_entries(struct dentry *top)
|
static void vchiq_debugfs_create_log_entries(struct dentry *top)
|
||||||
{
|
{
|
||||||
struct dentry *dir;
|
struct dentry *dir;
|
||||||
size_t i;
|
size_t i;
|
||||||
int ret = 0;
|
|
||||||
|
|
||||||
dir = debugfs_create_dir("log", vchiq_debugfs_top());
|
dir = debugfs_create_dir("log", vchiq_debugfs_top());
|
||||||
if (!dir)
|
|
||||||
return -ENOMEM;
|
|
||||||
debugfs_info.log_categories = dir;
|
debugfs_info.log_categories = dir;
|
||||||
|
|
||||||
for (i = 0; i < n_log_entries; i++) {
|
for (i = 0; i < n_log_entries; i++) {
|
||||||
@ -177,14 +174,8 @@ static int vchiq_debugfs_create_log_entries(struct dentry *top)
|
|||||||
debugfs_info.log_categories,
|
debugfs_info.log_categories,
|
||||||
levp,
|
levp,
|
||||||
&debugfs_log_fops);
|
&debugfs_log_fops);
|
||||||
if (!dir) {
|
|
||||||
ret = -ENOMEM;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
vchiq_debugfs_log_entries[i].dir = dir;
|
vchiq_debugfs_log_entries[i].dir = dir;
|
||||||
}
|
}
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int debugfs_usecount_show(struct seq_file *f, void *offset)
|
static int debugfs_usecount_show(struct seq_file *f, void *offset)
|
||||||
@ -268,43 +259,22 @@ static const struct file_operations debugfs_trace_fops = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* add an instance (process) to the debugfs entries */
|
/* add an instance (process) to the debugfs entries */
|
||||||
int vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance)
|
void vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance)
|
||||||
{
|
{
|
||||||
char pidstr[16];
|
char pidstr[16];
|
||||||
struct dentry *top, *use_count, *trace;
|
struct dentry *top;
|
||||||
struct dentry *clients = vchiq_clients_top();
|
struct dentry *clients = vchiq_clients_top();
|
||||||
|
|
||||||
snprintf(pidstr, sizeof(pidstr), "%d",
|
snprintf(pidstr, sizeof(pidstr), "%d",
|
||||||
vchiq_instance_get_pid(instance));
|
vchiq_instance_get_pid(instance));
|
||||||
|
|
||||||
top = debugfs_create_dir(pidstr, clients);
|
top = debugfs_create_dir(pidstr, clients);
|
||||||
if (!top)
|
|
||||||
goto fail_top;
|
|
||||||
|
|
||||||
use_count = debugfs_create_file("use_count",
|
debugfs_create_file("use_count", 0444, top, instance,
|
||||||
0444, top,
|
|
||||||
instance,
|
|
||||||
&debugfs_usecount_fops);
|
&debugfs_usecount_fops);
|
||||||
if (!use_count)
|
debugfs_create_file("trace", 0644, top, instance, &debugfs_trace_fops);
|
||||||
goto fail_use_count;
|
|
||||||
|
|
||||||
trace = debugfs_create_file("trace",
|
|
||||||
0644, top,
|
|
||||||
instance,
|
|
||||||
&debugfs_trace_fops);
|
|
||||||
if (!trace)
|
|
||||||
goto fail_trace;
|
|
||||||
|
|
||||||
vchiq_instance_get_debugfs_node(instance)->dentry = top;
|
vchiq_instance_get_debugfs_node(instance)->dentry = top;
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
fail_trace:
|
|
||||||
debugfs_remove(use_count);
|
|
||||||
fail_use_count:
|
|
||||||
debugfs_remove(top);
|
|
||||||
fail_top:
|
|
||||||
return -ENOMEM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance)
|
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance)
|
||||||
@ -314,31 +284,13 @@ void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance)
|
|||||||
debugfs_remove_recursive(node->dentry);
|
debugfs_remove_recursive(node->dentry);
|
||||||
}
|
}
|
||||||
|
|
||||||
int vchiq_debugfs_init(void)
|
void vchiq_debugfs_init(void)
|
||||||
{
|
{
|
||||||
BUG_ON(debugfs_info.vchiq_cfg_dir != NULL);
|
|
||||||
|
|
||||||
debugfs_info.vchiq_cfg_dir = debugfs_create_dir("vchiq", NULL);
|
debugfs_info.vchiq_cfg_dir = debugfs_create_dir("vchiq", NULL);
|
||||||
if (debugfs_info.vchiq_cfg_dir == NULL)
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
debugfs_info.clients = debugfs_create_dir("clients",
|
debugfs_info.clients = debugfs_create_dir("clients",
|
||||||
vchiq_debugfs_top());
|
vchiq_debugfs_top());
|
||||||
if (!debugfs_info.clients)
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
if (vchiq_debugfs_create_log_entries(vchiq_debugfs_top()) != 0)
|
vchiq_debugfs_create_log_entries(vchiq_debugfs_top());
|
||||||
goto fail;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
fail:
|
|
||||||
vchiq_debugfs_deinit();
|
|
||||||
vchiq_log_error(vchiq_arm_log_level,
|
|
||||||
"%s: failed to create debugfs directory",
|
|
||||||
__func__);
|
|
||||||
|
|
||||||
return -ENOMEM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* remove all the debugfs entries */
|
/* remove all the debugfs entries */
|
||||||
@ -360,18 +312,16 @@ static struct dentry *vchiq_debugfs_top(void)
|
|||||||
|
|
||||||
#else /* CONFIG_DEBUG_FS */
|
#else /* CONFIG_DEBUG_FS */
|
||||||
|
|
||||||
int vchiq_debugfs_init(void)
|
void vchiq_debugfs_init(void)
|
||||||
{
|
{
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void vchiq_debugfs_deinit(void)
|
void vchiq_debugfs_deinit(void)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
int vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance)
|
void vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance)
|
||||||
{
|
{
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance)
|
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance)
|
||||||
|
@ -40,11 +40,11 @@ typedef struct vchiq_debugfs_node_struct {
|
|||||||
struct dentry *dentry;
|
struct dentry *dentry;
|
||||||
} VCHIQ_DEBUGFS_NODE_T;
|
} VCHIQ_DEBUGFS_NODE_T;
|
||||||
|
|
||||||
int vchiq_debugfs_init(void);
|
void vchiq_debugfs_init(void);
|
||||||
|
|
||||||
void vchiq_debugfs_deinit(void);
|
void vchiq_debugfs_deinit(void);
|
||||||
|
|
||||||
int vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance);
|
void vchiq_debugfs_add_instance(VCHIQ_INSTANCE_T instance);
|
||||||
|
|
||||||
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance);
|
void vchiq_debugfs_remove_instance(VCHIQ_INSTANCE_T instance);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user