summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2020-01-10 22:25:24 +0100
committerLinus Torvalds <torvalds@linux-foundation.org>2020-01-10 22:25:24 +0100
commit9fb7007de8a2a80e4b55a850311fca10de62f1b5 (patch)
tree385d22388e16847c4fc6c4694099ffd374f1012d /fs
parentMerge tag 'staging-5.5-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/... (diff)
parentchardev: Avoid potential use-after-free in 'chrdev_open()' (diff)
downloadlinux-9fb7007de8a2a80e4b55a850311fca10de62f1b5.tar.xz
linux-9fb7007de8a2a80e4b55a850311fca10de62f1b5.zip
Merge tag 'char-misc-5.5-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc
Pull char/misc fix from Greg KH: "Here is a single fix, for the chrdev core, for 5.5-rc6 There's been a long-standing race condition triggered by syzbot, and occasionally real people, in the chrdev open() path. Will finally took the time to track it down and fix it for real before the holidays. Here's that one patch, it's been in linux-next for a while with no reported issues and it does fix the reported problem" * tag 'char-misc-5.5-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: chardev: Avoid potential use-after-free in 'chrdev_open()'
Diffstat (limited to 'fs')
-rw-r--r--fs/char_dev.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/char_dev.c b/fs/char_dev.c
index 00dfe17871ac..c5e6eff5a381 100644
--- a/fs/char_dev.c
+++ b/fs/char_dev.c
@@ -352,7 +352,7 @@ static struct kobject *cdev_get(struct cdev *p)
if (owner && !try_module_get(owner))
return NULL;
- kobj = kobject_get(&p->kobj);
+ kobj = kobject_get_unless_zero(&p->kobj);
if (!kobj)
module_put(owner);
return kobj;