Re: [TRIVIAL] Error checks omitted in init_tmpfs() in mm/tiny-shmem.c
From: Hareesh Nagarajan
Date: Mon Oct 24 2005 - 03:56:57 EST
Matt Mackall wrote:
On Mon, Oct 24, 2005 at 12:29:45AM -0500, Hareesh Nagarajan wrote:
The existing code in init_tmpfs() in mm/tiny-shmem.c does not handle the
cases when the calls to register_filesystem() and kern_mount() fail.
This patch adds those checks.
Hmm. Did you actually encounter this?
No, I haven't. I was just reading the source code when I chanced upon
these trivial error checking omissions.
I'd rather use BUG_ON. Passing up errors is only useful when the code
above can and will do something useful with the information.
[ Snip ]
And what could the higher level, which is simply looping through init
functions, do to handle the error? Retry? Print a warning? Better to
stop everything outright when we encounter a problem we expect should
never happen so it doesn't go by undiagnosed.
Makes sense. New patch attached.
Signed-off-by: Hareesh Nagarajan <hnagar2@xxxxxxxxx>
--- linux-2.6.13.4/mm/tiny-shmem.c 2005-10-10 13:54:29.000000000 -0500
+++ linux-2.6.13.4-edit/mm/tiny-shmem.c 2005-10-24 03:43:38.614071000 -0500
@@ -31,12 +31,18 @@
static int __init init_tmpfs(void)
{
- register_filesystem(&tmpfs_fs_type);
+ int error;
+
+ error = register_filesystem(&tmpfs_fs_type);
+ BUG_ON(error);
+
#ifdef CONFIG_TMPFS
devfs_mk_dir("shm");
#endif
shm_mnt = kern_mount(&tmpfs_fs_type);
- return 0;
+ BUG_ON(IS_ERR(shm_mnt));
+
+ return error;
}
module_init(init_tmpfs)