Linux v4.5-rc6
This commit is contained in:
parent
87830ea3e1
commit
124d375e8c
@ -1,170 +0,0 @@
|
|||||||
From b5671c331cc2e78c83fc826a69dff461903c0fd5 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Laura Abbott <labbott@fedoraproject.org>
|
|
||||||
Date: Mon, 25 Jan 2016 15:10:02 -0800
|
|
||||||
Subject: [PATCHv2] vsock: Fix blocking ops call in prepare_to_wait
|
|
||||||
To: "David S. Miller" <davem@davemloft.net>
|
|
||||||
Cc: netdev@vger.kernel.org
|
|
||||||
Cc: linux-kernel@vger.kernel.org
|
|
||||||
To: Aditya Asarwade <asarwade@vmware.com>
|
|
||||||
To: Thomas Hellstrom <thellstrom@vmware.com>
|
|
||||||
To: Jorgen Hansen <jhansen@vmware.com>
|
|
||||||
|
|
||||||
We receoved a bug report from someone using vmware:
|
|
||||||
|
|
||||||
WARNING: CPU: 3 PID: 660 at kernel/sched/core.c:7389
|
|
||||||
__might_sleep+0x7d/0x90()
|
|
||||||
do not call blocking ops when !TASK_RUNNING; state=1 set at
|
|
||||||
[<ffffffff810fa68d>] prepare_to_wait+0x2d/0x90
|
|
||||||
Modules linked in: vmw_vsock_vmci_transport vsock snd_seq_midi
|
|
||||||
snd_seq_midi_event snd_ens1371 iosf_mbi gameport snd_rawmidi
|
|
||||||
snd_ac97_codec ac97_bus snd_seq coretemp snd_seq_device snd_pcm
|
|
||||||
snd_timer snd soundcore ppdev crct10dif_pclmul crc32_pclmul
|
|
||||||
ghash_clmulni_intel vmw_vmci vmw_balloon i2c_piix4 shpchp parport_pc
|
|
||||||
parport acpi_cpufreq nfsd auth_rpcgss nfs_acl lockd grace sunrpc btrfs
|
|
||||||
xor raid6_pq 8021q garp stp llc mrp crc32c_intel serio_raw mptspi vmwgfx
|
|
||||||
drm_kms_helper ttm drm scsi_transport_spi mptscsih e1000 ata_generic
|
|
||||||
mptbase pata_acpi
|
|
||||||
CPU: 3 PID: 660 Comm: vmtoolsd Not tainted
|
|
||||||
4.2.0-0.rc1.git3.1.fc23.x86_64 #1
|
|
||||||
Hardware name: VMware, Inc. VMware Virtual Platform/440BX Desktop
|
|
||||||
Reference Platform, BIOS 6.00 05/20/2014
|
|
||||||
0000000000000000 0000000049e617f3 ffff88006ac37ac8 ffffffff818641f5
|
|
||||||
0000000000000000 ffff88006ac37b20 ffff88006ac37b08 ffffffff810ab446
|
|
||||||
ffff880068009f40 ffffffff81c63bc0 0000000000000061 0000000000000000
|
|
||||||
Call Trace:
|
|
||||||
[<ffffffff818641f5>] dump_stack+0x4c/0x65
|
|
||||||
[<ffffffff810ab446>] warn_slowpath_common+0x86/0xc0
|
|
||||||
[<ffffffff810ab4d5>] warn_slowpath_fmt+0x55/0x70
|
|
||||||
[<ffffffff8112551d>] ? debug_lockdep_rcu_enabled+0x1d/0x20
|
|
||||||
[<ffffffff810fa68d>] ? prepare_to_wait+0x2d/0x90
|
|
||||||
[<ffffffff810fa68d>] ? prepare_to_wait+0x2d/0x90
|
|
||||||
[<ffffffff810da2bd>] __might_sleep+0x7d/0x90
|
|
||||||
[<ffffffff812163b3>] __might_fault+0x43/0xa0
|
|
||||||
[<ffffffff81430477>] copy_from_iter+0x87/0x2a0
|
|
||||||
[<ffffffffa039460a>] __qp_memcpy_to_queue+0x9a/0x1b0 [vmw_vmci]
|
|
||||||
[<ffffffffa0394740>] ? qp_memcpy_to_queue+0x20/0x20 [vmw_vmci]
|
|
||||||
[<ffffffffa0394757>] qp_memcpy_to_queue_iov+0x17/0x20 [vmw_vmci]
|
|
||||||
[<ffffffffa0394d50>] qp_enqueue_locked+0xa0/0x140 [vmw_vmci]
|
|
||||||
[<ffffffffa039593f>] vmci_qpair_enquev+0x4f/0xd0 [vmw_vmci]
|
|
||||||
[<ffffffffa04847bb>] vmci_transport_stream_enqueue+0x1b/0x20
|
|
||||||
[vmw_vsock_vmci_transport]
|
|
||||||
[<ffffffffa047ae05>] vsock_stream_sendmsg+0x2c5/0x320 [vsock]
|
|
||||||
[<ffffffff810fabd0>] ? wake_atomic_t_function+0x70/0x70
|
|
||||||
[<ffffffff81702af8>] sock_sendmsg+0x38/0x50
|
|
||||||
[<ffffffff81702ff4>] SYSC_sendto+0x104/0x190
|
|
||||||
[<ffffffff8126e25a>] ? vfs_read+0x8a/0x140
|
|
||||||
[<ffffffff817042ee>] SyS_sendto+0xe/0x10
|
|
||||||
[<ffffffff8186d9ae>] entry_SYSCALL_64_fastpath+0x12/0x76
|
|
||||||
|
|
||||||
transport->stream_enqueue may call copy_to_user so it should
|
|
||||||
not be called inside a prepare_to_wait. Narrow the scope of
|
|
||||||
the prepare_to_wait to avoid the bad call. This also applies
|
|
||||||
to vsock_stream_recvmsg as well.
|
|
||||||
|
|
||||||
Reported-by: Vinson Lee <vlee@freedesktop.org>
|
|
||||||
Tested-by: Vinson Lee <vlee@freedesktop.org>
|
|
||||||
Signed-off-by: Laura Abbott <labbott@fedoraproject.org>
|
|
||||||
---
|
|
||||||
v2: fix same issue in recvmsg path as well.
|
|
||||||
---
|
|
||||||
net/vmw_vsock/af_vsock.c | 19 ++++++-------------
|
|
||||||
1 file changed, 6 insertions(+), 13 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c
|
|
||||||
index 7fd1220..bbe65dc 100644
|
|
||||||
--- a/net/vmw_vsock/af_vsock.c
|
|
||||||
+++ b/net/vmw_vsock/af_vsock.c
|
|
||||||
@@ -1557,8 +1557,6 @@ static int vsock_stream_sendmsg(struct socket *sock, struct msghdr *msg,
|
|
||||||
if (err < 0)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
- prepare_to_wait(sk_sleep(sk), &wait, TASK_INTERRUPTIBLE);
|
|
||||||
-
|
|
||||||
while (total_written < len) {
|
|
||||||
ssize_t written;
|
|
||||||
|
|
||||||
@@ -1578,7 +1576,9 @@ static int vsock_stream_sendmsg(struct socket *sock, struct msghdr *msg,
|
|
||||||
goto out_wait;
|
|
||||||
|
|
||||||
release_sock(sk);
|
|
||||||
+ prepare_to_wait(sk_sleep(sk), &wait, TASK_INTERRUPTIBLE);
|
|
||||||
timeout = schedule_timeout(timeout);
|
|
||||||
+ finish_wait(sk_sleep(sk), &wait);
|
|
||||||
lock_sock(sk);
|
|
||||||
if (signal_pending(current)) {
|
|
||||||
err = sock_intr_errno(timeout);
|
|
||||||
@@ -1588,8 +1588,6 @@ static int vsock_stream_sendmsg(struct socket *sock, struct msghdr *msg,
|
|
||||||
goto out_wait;
|
|
||||||
}
|
|
||||||
|
|
||||||
- prepare_to_wait(sk_sleep(sk), &wait,
|
|
||||||
- TASK_INTERRUPTIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* These checks occur both as part of and after the loop
|
|
||||||
@@ -1635,7 +1633,6 @@ static int vsock_stream_sendmsg(struct socket *sock, struct msghdr *msg,
|
|
||||||
out_wait:
|
|
||||||
if (total_written > 0)
|
|
||||||
err = total_written;
|
|
||||||
- finish_wait(sk_sleep(sk), &wait);
|
|
||||||
out:
|
|
||||||
release_sock(sk);
|
|
||||||
return err;
|
|
||||||
@@ -1716,7 +1713,6 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
if (err < 0)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
- prepare_to_wait(sk_sleep(sk), &wait, TASK_INTERRUPTIBLE);
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
s64 ready = vsock_stream_has_data(vsk);
|
|
||||||
@@ -1727,7 +1723,7 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
*/
|
|
||||||
|
|
||||||
err = -ENOMEM;
|
|
||||||
- goto out_wait;
|
|
||||||
+ goto out;
|
|
||||||
} else if (ready > 0) {
|
|
||||||
ssize_t read;
|
|
||||||
|
|
||||||
@@ -1750,7 +1746,7 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
vsk, target, read,
|
|
||||||
!(flags & MSG_PEEK), &recv_data);
|
|
||||||
if (err < 0)
|
|
||||||
- goto out_wait;
|
|
||||||
+ goto out;
|
|
||||||
|
|
||||||
if (read >= target || flags & MSG_PEEK)
|
|
||||||
break;
|
|
||||||
@@ -1773,7 +1769,9 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
break;
|
|
||||||
|
|
||||||
release_sock(sk);
|
|
||||||
+ prepare_to_wait(sk_sleep(sk), &wait, TASK_INTERRUPTIBLE);
|
|
||||||
timeout = schedule_timeout(timeout);
|
|
||||||
+ finish_wait(sk_sleep(sk), &wait);
|
|
||||||
lock_sock(sk);
|
|
||||||
|
|
||||||
if (signal_pending(current)) {
|
|
||||||
@@ -1783,9 +1781,6 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
err = -EAGAIN;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
-
|
|
||||||
- prepare_to_wait(sk_sleep(sk), &wait,
|
|
||||||
- TASK_INTERRUPTIBLE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1816,8 +1811,6 @@ vsock_stream_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,
|
|
||||||
err = copied;
|
|
||||||
}
|
|
||||||
|
|
||||||
-out_wait:
|
|
||||||
- finish_wait(sk_sleep(sk), &wait);
|
|
||||||
out:
|
|
||||||
release_sock(sk);
|
|
||||||
return err;
|
|
||||||
--
|
|
||||||
2.5.0
|
|
||||||
|
|
@ -1,116 +0,0 @@
|
|||||||
From patchwork Wed Feb 24 17:34:43 2016
|
|
||||||
Content-Type: text/plain; charset="utf-8"
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Transfer-Encoding: 7bit
|
|
||||||
Subject: drm/nouveau: platform: Fix deferred probe
|
|
||||||
From: Thierry Reding <thierry.reding@gmail.com>
|
|
||||||
X-Patchwork-Id: 587554
|
|
||||||
Message-Id: <1456335283-22097-1-git-send-email-thierry.reding@gmail.com>
|
|
||||||
To: Ben Skeggs <bskeggs@redhat.com>
|
|
||||||
Cc: Alexandre Courbot <gnurou@gmail.com>, Nicolas Chauvet <kwizart@gmail.com>,
|
|
||||||
dri-devel@lists.freedesktop.org, linux-tegra@vger.kernel.org
|
|
||||||
Date: Wed, 24 Feb 2016 18:34:43 +0100
|
|
||||||
|
|
||||||
From: Thierry Reding <treding@nvidia.com>
|
|
||||||
|
|
||||||
The error cleanup paths aren't quite correct and will crash upon
|
|
||||||
deferred probe.
|
|
||||||
|
|
||||||
Cc: stable@vger.kernel.org # v4.3+
|
|
||||||
Signed-off-by: Thierry Reding <treding@nvidia.com>
|
|
||||||
Reviewed-by: Ben Skeggs <bskeggs@redhat.com>
|
|
||||||
Reviewed-by: Alexandre Courbot <acourbot@nvidia.com>
|
|
||||||
---
|
|
||||||
drivers/gpu/drm/nouveau/nouveau_platform.c | 2 +-
|
|
||||||
drivers/gpu/drm/nouveau/nvkm/engine/device/tegra.c | 40 ++++++++++++++++------
|
|
||||||
2 files changed, 30 insertions(+), 12 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/drivers/gpu/drm/nouveau/nouveau_platform.c b/drivers/gpu/drm/nouveau/nouveau_platform.c
|
|
||||||
index 8a70cec59bcd..2dfe58af12e4 100644
|
|
||||||
--- a/drivers/gpu/drm/nouveau/nouveau_platform.c
|
|
||||||
+++ b/drivers/gpu/drm/nouveau/nouveau_platform.c
|
|
||||||
@@ -24,7 +24,7 @@
|
|
||||||
static int nouveau_platform_probe(struct platform_device *pdev)
|
|
||||||
{
|
|
||||||
const struct nvkm_device_tegra_func *func;
|
|
||||||
- struct nvkm_device *device;
|
|
||||||
+ struct nvkm_device *device = NULL;
|
|
||||||
struct drm_device *drm;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/device/tegra.c b/drivers/gpu/drm/nouveau/nvkm/engine/device/tegra.c
|
|
||||||
index 7f8a42721eb2..e7e581d6a8ff 100644
|
|
||||||
--- a/drivers/gpu/drm/nouveau/nvkm/engine/device/tegra.c
|
|
||||||
+++ b/drivers/gpu/drm/nouveau/nvkm/engine/device/tegra.c
|
|
||||||
@@ -252,32 +252,40 @@ nvkm_device_tegra_new(const struct nvkm_device_tegra_func *func,
|
|
||||||
|
|
||||||
if (!(tdev = kzalloc(sizeof(*tdev), GFP_KERNEL)))
|
|
||||||
return -ENOMEM;
|
|
||||||
- *pdevice = &tdev->device;
|
|
||||||
+
|
|
||||||
tdev->func = func;
|
|
||||||
tdev->pdev = pdev;
|
|
||||||
tdev->irq = -1;
|
|
||||||
|
|
||||||
tdev->vdd = devm_regulator_get(&pdev->dev, "vdd");
|
|
||||||
- if (IS_ERR(tdev->vdd))
|
|
||||||
- return PTR_ERR(tdev->vdd);
|
|
||||||
+ if (IS_ERR(tdev->vdd)) {
|
|
||||||
+ ret = PTR_ERR(tdev->vdd);
|
|
||||||
+ goto free;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
tdev->rst = devm_reset_control_get(&pdev->dev, "gpu");
|
|
||||||
- if (IS_ERR(tdev->rst))
|
|
||||||
- return PTR_ERR(tdev->rst);
|
|
||||||
+ if (IS_ERR(tdev->rst)) {
|
|
||||||
+ ret = PTR_ERR(tdev->rst);
|
|
||||||
+ goto free;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
tdev->clk = devm_clk_get(&pdev->dev, "gpu");
|
|
||||||
- if (IS_ERR(tdev->clk))
|
|
||||||
- return PTR_ERR(tdev->clk);
|
|
||||||
+ if (IS_ERR(tdev->clk)) {
|
|
||||||
+ ret = PTR_ERR(tdev->clk);
|
|
||||||
+ goto free;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
tdev->clk_pwr = devm_clk_get(&pdev->dev, "pwr");
|
|
||||||
- if (IS_ERR(tdev->clk_pwr))
|
|
||||||
- return PTR_ERR(tdev->clk_pwr);
|
|
||||||
+ if (IS_ERR(tdev->clk_pwr)) {
|
|
||||||
+ ret = PTR_ERR(tdev->clk_pwr);
|
|
||||||
+ goto free;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
nvkm_device_tegra_probe_iommu(tdev);
|
|
||||||
|
|
||||||
ret = nvkm_device_tegra_power_up(tdev);
|
|
||||||
if (ret)
|
|
||||||
- return ret;
|
|
||||||
+ goto remove;
|
|
||||||
|
|
||||||
tdev->gpu_speedo = tegra_sku_info.gpu_speedo_value;
|
|
||||||
ret = nvkm_device_ctor(&nvkm_device_tegra_func, NULL, &pdev->dev,
|
|
||||||
@@ -285,9 +293,19 @@ nvkm_device_tegra_new(const struct nvkm_device_tegra_func *func,
|
|
||||||
cfg, dbg, detect, mmio, subdev_mask,
|
|
||||||
&tdev->device);
|
|
||||||
if (ret)
|
|
||||||
- return ret;
|
|
||||||
+ goto powerdown;
|
|
||||||
+
|
|
||||||
+ *pdevice = &tdev->device;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
+
|
|
||||||
+powerdown:
|
|
||||||
+ nvkm_device_tegra_power_down(tdev);
|
|
||||||
+remove:
|
|
||||||
+ nvkm_device_tegra_remove_iommu(tdev);
|
|
||||||
+free:
|
|
||||||
+ kfree(tdev);
|
|
||||||
+ return ret;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
int
|
|
2
gitrev
2
gitrev
@ -1 +1 @@
|
|||||||
81f70ba233d5f660e1ea5fe23260ee323af5d53a
|
fc77dbd34c5c99bce46d40a2491937c3bcbd10af
|
||||||
|
12
kernel.spec
12
kernel.spec
@ -40,7 +40,7 @@ Summary: The Linux kernel
|
|||||||
# For non-released -rc kernels, this will be appended after the rcX and
|
# For non-released -rc kernels, this will be appended after the rcX and
|
||||||
# gitX tags, so a 3 here would become part of release "0.rcX.gitX.3"
|
# gitX tags, so a 3 here would become part of release "0.rcX.gitX.3"
|
||||||
#
|
#
|
||||||
%global baserelease 2
|
%global baserelease 1
|
||||||
%global fedora_build %{baserelease}
|
%global fedora_build %{baserelease}
|
||||||
|
|
||||||
# base_sublevel is the kernel version we're starting with and patching
|
# base_sublevel is the kernel version we're starting with and patching
|
||||||
@ -65,7 +65,7 @@ Summary: The Linux kernel
|
|||||||
# The next upstream release sublevel (base_sublevel+1)
|
# The next upstream release sublevel (base_sublevel+1)
|
||||||
%define upstream_sublevel %(echo $((%{base_sublevel} + 1)))
|
%define upstream_sublevel %(echo $((%{base_sublevel} + 1)))
|
||||||
# The rc snapshot level
|
# The rc snapshot level
|
||||||
%define rcrev 5
|
%define rcrev 6
|
||||||
# The git snapshot level
|
# The git snapshot level
|
||||||
%define gitrev 0
|
%define gitrev 0
|
||||||
# Set rpm version accordingly
|
# Set rpm version accordingly
|
||||||
@ -506,8 +506,6 @@ Patch456: arm64-acpi-drop-expert-patch.patch
|
|||||||
# http://patchwork.ozlabs.org/patch/587554/
|
# http://patchwork.ozlabs.org/patch/587554/
|
||||||
Patch457: ARM-tegra-usb-no-reset.patch
|
Patch457: ARM-tegra-usb-no-reset.patch
|
||||||
|
|
||||||
Patch458: drm-nouveau-platform-Fix-deferred-probe.patch
|
|
||||||
|
|
||||||
Patch463: arm-i.MX6-Utilite-device-dtb.patch
|
Patch463: arm-i.MX6-Utilite-device-dtb.patch
|
||||||
|
|
||||||
Patch466: input-kill-stupid-messages.patch
|
Patch466: input-kill-stupid-messages.patch
|
||||||
@ -602,9 +600,6 @@ Patch645: cfg80211-wext-fix-message-ordering.patch
|
|||||||
#rhbz 1255325
|
#rhbz 1255325
|
||||||
Patch646: HID-sony-do-not-bail-out-when-the-sixaxis-refuses-th.patch
|
Patch646: HID-sony-do-not-bail-out-when-the-sixaxis-refuses-th.patch
|
||||||
|
|
||||||
#rhbz 1288684
|
|
||||||
Patch647: 0001-vsock-Fix-blocking-ops-call-in-prepare_to_wait.patch
|
|
||||||
|
|
||||||
#rhbz 1309658
|
#rhbz 1309658
|
||||||
Patch648: 0001-mm-CONFIG_NR_ZONES_EXTENDED.patch
|
Patch648: 0001-mm-CONFIG_NR_ZONES_EXTENDED.patch
|
||||||
|
|
||||||
@ -2130,6 +2125,9 @@ fi
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Feb 29 2016 Justin M. Forbes <jforbes@fedoraproject.org> - 4.5.0-0.rc6.git0.1
|
||||||
|
- Linux v4.5-rc6
|
||||||
|
|
||||||
* Mon Feb 29 2016 Josh Boyer <jwboyer@fedoraproject.org>
|
* Mon Feb 29 2016 Josh Boyer <jwboyer@fedoraproject.org>
|
||||||
- Enable DHT11 (rhbz 1312888)
|
- Enable DHT11 (rhbz 1312888)
|
||||||
- Fix erroneously installed .o files in python-perf subpackage (rhbz 1312102)
|
- Fix erroneously installed .o files in python-perf subpackage (rhbz 1312102)
|
||||||
|
2
sources
2
sources
@ -1,3 +1,3 @@
|
|||||||
9a78fa2eb6c68ca5a40ed5af08142599 linux-4.4.tar.xz
|
9a78fa2eb6c68ca5a40ed5af08142599 linux-4.4.tar.xz
|
||||||
dcbc8fe378a676d5d0dd208cf524e144 perf-man-4.4.tar.gz
|
dcbc8fe378a676d5d0dd208cf524e144 perf-man-4.4.tar.gz
|
||||||
426c5d4cc72504c364485d14e36bfaa8 patch-4.5-rc5.xz
|
cb386089b7af5ea8eab95b5975142529 patch-4.5-rc6.xz
|
||||||
|
Loading…
Reference in New Issue
Block a user