mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2025-09-30 07:28:26 -04:00
Update Linux CVE patches
This commit is contained in:
parent
12b63c12b7
commit
3989a1b20b
958 changed files with 21074 additions and 397 deletions
63
Patches/Linux_CVEs/CVE-2017-12146/ANY/0.patch
Normal file
63
Patches/Linux_CVEs/CVE-2017-12146/ANY/0.patch
Normal file
|
@ -0,0 +1,63 @@
|
|||
From 6265539776a0810b7ce6398c27866ddb9c6bd154 Mon Sep 17 00:00:00 2001
|
||||
From: Adrian Salido <salidoa@google.com>
|
||||
Date: Tue, 25 Apr 2017 16:55:26 -0700
|
||||
Subject: driver core: platform: fix race condition with driver_override
|
||||
|
||||
The driver_override implementation is susceptible to race condition when
|
||||
different threads are reading vs storing a different driver override.
|
||||
Add locking to avoid race condition.
|
||||
|
||||
Fixes: 3d713e0e382e ("driver core: platform: add device binding path 'driver_override'")
|
||||
Cc: stable@vger.kernel.org
|
||||
Signed-off-by: Adrian Salido <salidoa@google.com>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
---
|
||||
drivers/base/platform.c | 11 +++++++++--
|
||||
1 file changed, 9 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/base/platform.c b/drivers/base/platform.c
|
||||
index a102152..97332d0 100644
|
||||
--- a/drivers/base/platform.c
|
||||
+++ b/drivers/base/platform.c
|
||||
@@ -866,7 +866,7 @@ static ssize_t driver_override_store(struct device *dev,
|
||||
const char *buf, size_t count)
|
||||
{
|
||||
struct platform_device *pdev = to_platform_device(dev);
|
||||
- char *driver_override, *old = pdev->driver_override, *cp;
|
||||
+ char *driver_override, *old, *cp;
|
||||
|
||||
if (count > PATH_MAX)
|
||||
return -EINVAL;
|
||||
@@ -879,12 +879,15 @@ static ssize_t driver_override_store(struct device *dev,
|
||||
if (cp)
|
||||
*cp = '\0';
|
||||
|
||||
+ device_lock(dev);
|
||||
+ old = pdev->driver_override;
|
||||
if (strlen(driver_override)) {
|
||||
pdev->driver_override = driver_override;
|
||||
} else {
|
||||
kfree(driver_override);
|
||||
pdev->driver_override = NULL;
|
||||
}
|
||||
+ device_unlock(dev);
|
||||
|
||||
kfree(old);
|
||||
|
||||
@@ -895,8 +898,12 @@ static ssize_t driver_override_show(struct device *dev,
|
||||
struct device_attribute *attr, char *buf)
|
||||
{
|
||||
struct platform_device *pdev = to_platform_device(dev);
|
||||
+ ssize_t len;
|
||||
|
||||
- return sprintf(buf, "%s\n", pdev->driver_override);
|
||||
+ device_lock(dev);
|
||||
+ len = sprintf(buf, "%s\n", pdev->driver_override);
|
||||
+ device_unlock(dev);
|
||||
+ return len;
|
||||
}
|
||||
static DEVICE_ATTR_RW(driver_override);
|
||||
|
||||
--
|
||||
cgit v1.1
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue