diff options
author | Sudip Mukherjee <sudipm.mukherjee@gmail.com> | 2015-07-20 17:27:21 +0530 |
---|---|---|
committer | Sasha Levin <alexander.levin@verizon.com> | 2016-10-02 12:15:43 -0400 |
commit | 71ec65c7f9c70ea5c3f292c204630da527eb4745 (patch) | |
tree | 02546a930b199b12046a09fe8e654eae85db51a5 | |
parent | dcd66549e041495acee1d6569fe9989fb5291407 (diff) | |
download | linux-stable-security-linux-3.4.y-security.tar.gz |
auxdisplay: ks0108: fix refcountlinux-3.4.y-security
commit bab383de3b84e584b0f09227151020b2a43dc34c upstream.
parport_find_base() will implicitly do parport_get_port() which
increases the refcount. Then parport_register_device() will again
increment the refcount. But while unloading the module we are only
doing parport_unregister_device() decrementing the refcount only once.
We add an parport_put_port() to neutralize the effect of
parport_get_port().
Signed-off-by: Sudip Mukherjee <sudip@vectorindia.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Zefan Li <lizefan@huawei.com>
Signed-off-by: Sasha Levin <alexander.levin@verizon.com>
-rw-r--r-- | drivers/auxdisplay/ks0108.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/auxdisplay/ks0108.c b/drivers/auxdisplay/ks0108.c index 5b93852392b8c3..0d752851a1eef8 100644 --- a/drivers/auxdisplay/ks0108.c +++ b/drivers/auxdisplay/ks0108.c @@ -139,6 +139,7 @@ static int __init ks0108_init(void) ks0108_pardevice = parport_register_device(ks0108_parport, KS0108_NAME, NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL); + parport_put_port(ks0108_parport); if (ks0108_pardevice == NULL) { printk(KERN_ERR KS0108_NAME ": ERROR: " "parport didn't register new device\n"); |