mirror of
https://git.yoctoproject.org/meta-ti
synced 2026-04-20 19:53:43 +00:00
linux-ti33x-psp 3.2: update to 3.2.23
Regenerate all beaglebone patches and add one vfs tracer patch for powertop Signed-off-by: Koen Kooi <koen@dominion.thruhere.net> Signed-off-by: Denys Dmytriyenko <denys@ti.com>
This commit is contained in:
committed by
Denys Dmytriyenko
parent
ced11b6121
commit
f95b2e51ea
@@ -4,7 +4,7 @@ require conf/machine/include/soc-family.inc
|
||||
require conf/machine/include/tune-cortexa8.inc
|
||||
PREFERRED_PROVIDER_virtual/kernel = "linux-ti33x-psp"
|
||||
# Increase this everytime you change something in the kernel
|
||||
MACHINE_KERNEL_PR = "r13"
|
||||
MACHINE_KERNEL_PR = "r14"
|
||||
|
||||
KERNEL_IMAGETYPE = "uImage"
|
||||
|
||||
|
||||
@@ -0,0 +1,37 @@
|
||||
From ea62444a6898324ec9aeb8799a8fd518073fe5a8 Mon Sep 17 00:00:00 2001
|
||||
From: Lars-Peter Clausen <lars@metafoo.de>
|
||||
Date: Tue, 5 Jun 2012 18:16:31 +0200
|
||||
Subject: [PATCH 01/46] staging:iio:ad7606: Re-add missing scale attribute
|
||||
|
||||
commit 279bf2e57c30c9a4482b2b6ede11b31c41e35e78 upstream.
|
||||
|
||||
Commit 50ac23be ("staging:iio:adc:ad7606 add local define for chan_spec
|
||||
structures.") accidentally removed the scale info_mask flag. This patch
|
||||
adds it back again.
|
||||
|
||||
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
|
||||
Acked-by: Jonathan Cameron <jic23@kernel.org>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
[bwh: Backported to 3.2:
|
||||
- info_mask was completely gone rather than set to another flag
|
||||
- IIO_CHAN_INFO_SCALE_SHARED_BIT was not defined; write it out as a shift]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/staging/iio/adc/ad7606_core.c | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/drivers/staging/iio/adc/ad7606_core.c b/drivers/staging/iio/adc/ad7606_core.c
|
||||
index 54423ab..2ee187f 100644
|
||||
--- a/drivers/staging/iio/adc/ad7606_core.c
|
||||
+++ b/drivers/staging/iio/adc/ad7606_core.c
|
||||
@@ -241,6 +241,7 @@ static const struct attribute_group ad7606_attribute_group = {
|
||||
.indexed = 1, \
|
||||
.channel = num, \
|
||||
.address = num, \
|
||||
+ .info_mask = (1 << IIO_CHAN_INFO_SCALE_SHARED), \
|
||||
.scan_index = num, \
|
||||
.scan_type = IIO_ST('s', 16, 16, 0), \
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,51 @@
|
||||
From 510150c1fa93796d65a9b598a8e1509629f5d84e Mon Sep 17 00:00:00 2001
|
||||
From: Olaf Hering <olaf@aepfle.de>
|
||||
Date: Thu, 31 May 2012 16:40:06 +0200
|
||||
Subject: [PATCH 02/46] Tools: hv: verify origin of netlink connector message
|
||||
|
||||
commit bcc2c9c3fff859e0eb019fe6fec26f9b8eba795c upstream.
|
||||
|
||||
The SuSE security team suggested to use recvfrom instead of recv to be
|
||||
certain that the connector message is originated from kernel.
|
||||
|
||||
CVE-2012-2669
|
||||
|
||||
Signed-off-by: Olaf Hering <olaf@aepfle.de>
|
||||
Signed-off-by: Marcus Meissner <meissner@suse.de>
|
||||
Signed-off-by: Sebastian Krahmer <krahmer@suse.de>
|
||||
Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
tools/hv/hv_kvp_daemon.c | 10 +++++++---
|
||||
1 file changed, 7 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/tools/hv/hv_kvp_daemon.c b/tools/hv/hv_kvp_daemon.c
|
||||
index 11224ed..323d4d9 100644
|
||||
--- a/tools/hv/hv_kvp_daemon.c
|
||||
+++ b/tools/hv/hv_kvp_daemon.c
|
||||
@@ -384,14 +384,18 @@ int main(void)
|
||||
pfd.fd = fd;
|
||||
|
||||
while (1) {
|
||||
+ struct sockaddr *addr_p = (struct sockaddr *) &addr;
|
||||
+ socklen_t addr_l = sizeof(addr);
|
||||
pfd.events = POLLIN;
|
||||
pfd.revents = 0;
|
||||
poll(&pfd, 1, -1);
|
||||
|
||||
- len = recv(fd, kvp_recv_buffer, sizeof(kvp_recv_buffer), 0);
|
||||
+ len = recvfrom(fd, kvp_recv_buffer, sizeof(kvp_recv_buffer), 0,
|
||||
+ addr_p, &addr_l);
|
||||
|
||||
- if (len < 0) {
|
||||
- syslog(LOG_ERR, "recv failed; error:%d", len);
|
||||
+ if (len < 0 || addr.nl_pid) {
|
||||
+ syslog(LOG_ERR, "recvfrom failed; pid:%u error:%d %s",
|
||||
+ addr.nl_pid, errno, strerror(errno));
|
||||
close(fd);
|
||||
return -1;
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,166 @@
|
||||
From 081ba8d6f6253982766e17b90992c1002c31acb0 Mon Sep 17 00:00:00 2001
|
||||
From: Chen Gong <gong.chen@linux.intel.com>
|
||||
Date: Tue, 8 May 2012 20:40:12 -0300
|
||||
Subject: [PATCH 03/46] edac: avoid mce decoding crash after edac driver
|
||||
unloaded
|
||||
|
||||
commit e35fca4791fcdd43dc1fd769797df40c562ab491 upstream.
|
||||
|
||||
Some edac drivers register themselves as mce decoders via
|
||||
notifier_chain. But in current notifier_chain implementation logic,
|
||||
it doesn't accept same notifier registered twice. If so, it will be
|
||||
wrong when adding/removing the element from the list. For example,
|
||||
on one SandyBridge platform, remove module sb_edac and then trigger
|
||||
one error, it will hit oops because it has no mce decoder registered
|
||||
but related notifier_chain still points to an invalid callback
|
||||
function. Here is an example:
|
||||
|
||||
Call Trace:
|
||||
[<ffffffff8150ef6a>] atomic_notifier_call_chain+0x1a/0x20
|
||||
[<ffffffff8102b936>] mce_log+0x46/0x180
|
||||
[<ffffffff8102eaea>] apei_mce_report_mem_error+0x4a/0x60
|
||||
[<ffffffff812e19d2>] ghes_do_proc+0x192/0x210
|
||||
[<ffffffff812e2066>] ghes_proc+0x46/0x70
|
||||
[<ffffffff812e20d8>] ghes_notify_sci+0x48/0x80
|
||||
[<ffffffff8150ef05>] notifier_call_chain+0x55/0x80
|
||||
[<ffffffff81076f1a>] __blocking_notifier_call_chain+0x5a/0x80
|
||||
[<ffffffff812aea11>] ? acpi_os_wait_events_complete+0x23/0x23
|
||||
[<ffffffff81076f56>] blocking_notifier_call_chain+0x16/0x20
|
||||
[<ffffffff812ddc4d>] acpi_hed_notify+0x19/0x1b
|
||||
[<ffffffff812b16bd>] acpi_device_notify+0x19/0x1b
|
||||
[<ffffffff812beb38>] acpi_ev_notify_dispatch+0x67/0x7f
|
||||
[<ffffffff812aea3a>] acpi_os_execute_deferred+0x29/0x36
|
||||
[<ffffffff81069dc2>] process_one_work+0x132/0x450
|
||||
[<ffffffff8106bbcb>] worker_thread+0x17b/0x3c0
|
||||
[<ffffffff8106ba50>] ? manage_workers+0x120/0x120
|
||||
[<ffffffff81070aee>] kthread+0x9e/0xb0
|
||||
[<ffffffff81514724>] kernel_thread_helper+0x4/0x10
|
||||
[<ffffffff81070a50>] ? kthread_freezable_should_stop+0x70/0x70
|
||||
[<ffffffff81514720>] ? gs_change+0x13/0x13
|
||||
Code: f3 49 89 d4 45 85 ed 4d 89 c6 48 8b 0f 74 48 48 85 c9 75 17 eb 41
|
||||
0f 1f 80 00 00 00 00 41 83 ed 01 4c 89 f9 74 22 4d 85 ff 74 1d <4c> 8b
|
||||
79 08 4c 89 e2 48 89 de 48 89 cf ff 11 4d 85 f6 74 04 41
|
||||
RIP [<ffffffff8150eef6>] notifier_call_chain+0x46/0x80
|
||||
RSP <ffff88042868fb20>
|
||||
CR2: ffffffffa01af838
|
||||
---[ end trace 0100930068e73e6f ]---
|
||||
BUG: unable to handle kernel paging request at fffffffffffffff8
|
||||
IP: [<ffffffff810705b0>] kthread_data+0x10/0x20
|
||||
PGD 1a0d067 PUD 1a0e067 PMD 0
|
||||
Oops: 0000 [#2] SMP
|
||||
|
||||
Only i7core_edac and sb_edac have such issues because they have more
|
||||
than one memory controller which means they have to register mce
|
||||
decoder many times.
|
||||
|
||||
Signed-off-by: Chen Gong <gong.chen@linux.intel.com>
|
||||
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
|
||||
[bwh: Backported to 3.2: drivers call atomic_notifier_chain_{,un}register()
|
||||
directly]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/edac/i7core_edac.c | 15 ++++-----------
|
||||
drivers/edac/sb_edac.c | 10 ++++------
|
||||
2 files changed, 8 insertions(+), 17 deletions(-)
|
||||
|
||||
diff --git a/drivers/edac/i7core_edac.c b/drivers/edac/i7core_edac.c
|
||||
index 70ad892..b3ccefa 100644
|
||||
--- a/drivers/edac/i7core_edac.c
|
||||
+++ b/drivers/edac/i7core_edac.c
|
||||
@@ -1932,12 +1932,6 @@ static int i7core_mce_check_error(struct notifier_block *nb, unsigned long val,
|
||||
if (mce->bank != 8)
|
||||
return NOTIFY_DONE;
|
||||
|
||||
-#ifdef CONFIG_SMP
|
||||
- /* Only handle if it is the right mc controller */
|
||||
- if (mce->socketid != pvt->i7core_dev->socket)
|
||||
- return NOTIFY_DONE;
|
||||
-#endif
|
||||
-
|
||||
smp_rmb();
|
||||
if ((pvt->mce_out + 1) % MCE_LOG_LEN == pvt->mce_in) {
|
||||
smp_wmb();
|
||||
@@ -2234,8 +2228,6 @@ static void i7core_unregister_mci(struct i7core_dev *i7core_dev)
|
||||
if (pvt->enable_scrub)
|
||||
disable_sdram_scrub_setting(mci);
|
||||
|
||||
- atomic_notifier_chain_unregister(&x86_mce_decoder_chain, &i7_mce_dec);
|
||||
-
|
||||
/* Disable EDAC polling */
|
||||
i7core_pci_ctl_release(pvt);
|
||||
|
||||
@@ -2336,8 +2328,6 @@ static int i7core_register_mci(struct i7core_dev *i7core_dev)
|
||||
/* DCLK for scrub rate setting */
|
||||
pvt->dclk_freq = get_dclk_freq();
|
||||
|
||||
- atomic_notifier_chain_register(&x86_mce_decoder_chain, &i7_mce_dec);
|
||||
-
|
||||
return 0;
|
||||
|
||||
fail0:
|
||||
@@ -2481,8 +2471,10 @@ static int __init i7core_init(void)
|
||||
|
||||
pci_rc = pci_register_driver(&i7core_driver);
|
||||
|
||||
- if (pci_rc >= 0)
|
||||
+ if (pci_rc >= 0) {
|
||||
+ atomic_notifier_chain_register(&x86_mce_decoder_chain, &i7_mce_dec);
|
||||
return 0;
|
||||
+ }
|
||||
|
||||
i7core_printk(KERN_ERR, "Failed to register device with error %d.\n",
|
||||
pci_rc);
|
||||
@@ -2498,6 +2490,7 @@ static void __exit i7core_exit(void)
|
||||
{
|
||||
debugf2("MC: " __FILE__ ": %s()\n", __func__);
|
||||
pci_unregister_driver(&i7core_driver);
|
||||
+ atomic_notifier_chain_unregister(&x86_mce_decoder_chain, &i7_mce_dec);
|
||||
}
|
||||
|
||||
module_init(i7core_init);
|
||||
diff --git a/drivers/edac/sb_edac.c b/drivers/edac/sb_edac.c
|
||||
index 7a402bf..18a1293 100644
|
||||
--- a/drivers/edac/sb_edac.c
|
||||
+++ b/drivers/edac/sb_edac.c
|
||||
@@ -1661,9 +1661,6 @@ static void sbridge_unregister_mci(struct sbridge_dev *sbridge_dev)
|
||||
debugf0("MC: " __FILE__ ": %s(): mci = %p, dev = %p\n",
|
||||
__func__, mci, &sbridge_dev->pdev[0]->dev);
|
||||
|
||||
- atomic_notifier_chain_unregister(&x86_mce_decoder_chain,
|
||||
- &sbridge_mce_dec);
|
||||
-
|
||||
/* Remove MC sysfs nodes */
|
||||
edac_mc_del_mc(mci->dev);
|
||||
|
||||
@@ -1731,8 +1728,6 @@ static int sbridge_register_mci(struct sbridge_dev *sbridge_dev)
|
||||
goto fail0;
|
||||
}
|
||||
|
||||
- atomic_notifier_chain_register(&x86_mce_decoder_chain,
|
||||
- &sbridge_mce_dec);
|
||||
return 0;
|
||||
|
||||
fail0:
|
||||
@@ -1861,8 +1856,10 @@ static int __init sbridge_init(void)
|
||||
|
||||
pci_rc = pci_register_driver(&sbridge_driver);
|
||||
|
||||
- if (pci_rc >= 0)
|
||||
+ if (pci_rc >= 0) {
|
||||
+ atomic_notifier_chain_register(&x86_mce_decoder_chain, &sbridge_mce_dec);
|
||||
return 0;
|
||||
+ }
|
||||
|
||||
sbridge_printk(KERN_ERR, "Failed to register device with error %d.\n",
|
||||
pci_rc);
|
||||
@@ -1878,6 +1875,7 @@ static void __exit sbridge_exit(void)
|
||||
{
|
||||
debugf2("MC: " __FILE__ ": %s()\n", __func__);
|
||||
pci_unregister_driver(&sbridge_driver);
|
||||
+ atomic_notifier_chain_unregister(&x86_mce_decoder_chain, &sbridge_mce_dec);
|
||||
}
|
||||
|
||||
module_init(sbridge_init);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,72 @@
|
||||
From 28a0aa72b2ef00a665564ea05846ad22cb3f18ee Mon Sep 17 00:00:00 2001
|
||||
From: Peter Korsgaard <jacmet@sunsite.dk>
|
||||
Date: Tue, 12 Jun 2012 08:27:04 +0800
|
||||
Subject: [PATCH 04/46] hwrng: atmel-rng - fix data valid check
|
||||
|
||||
commit c475c06f4bb689d6ad87d7512e036d6dface3160 upstream.
|
||||
|
||||
Brown paper bag: Data valid is LSB of the ISR (status register), and NOT
|
||||
of ODATA (current random data word)!
|
||||
|
||||
With this, rngtest is a lot happier. Before:
|
||||
|
||||
rngtest 3
|
||||
Copyright (c) 2004 by Henrique de Moraes Holschuh
|
||||
This is free software; see the source for copying conditions. There is NO warr.
|
||||
|
||||
rngtest: starting FIPS tests...
|
||||
rngtest: bits received from input: 20000032
|
||||
rngtest: FIPS 140-2 successes: 3
|
||||
rngtest: FIPS 140-2 failures: 997
|
||||
rngtest: FIPS 140-2(2001-10-10) Monobit: 604
|
||||
rngtest: FIPS 140-2(2001-10-10) Poker: 996
|
||||
rngtest: FIPS 140-2(2001-10-10) Runs: 36
|
||||
rngtest: FIPS 140-2(2001-10-10) Long run: 0
|
||||
rngtest: FIPS 140-2(2001-10-10) Continuous run: 117
|
||||
rngtest: input channel speed: (min=622.371; avg=23682.481; max=28224.350)Kibitss
|
||||
rngtest: FIPS tests speed: (min=12.361; avg=12.718; max=12.861)Mibits/s
|
||||
rngtest: Program run time: 2331696 microsecondsx
|
||||
|
||||
After:
|
||||
rngtest 3
|
||||
Copyright (c) 2004 by Henrique de Moraes Holschuh
|
||||
This is free software; see the source for copying conditions. There is NO warr.
|
||||
|
||||
rngtest: starting FIPS tests...
|
||||
rngtest: bits received from input: 20000032
|
||||
rngtest: FIPS 140-2 successes: 999
|
||||
rngtest: FIPS 140-2 failures: 1
|
||||
rngtest: FIPS 140-2(2001-10-10) Monobit: 0
|
||||
rngtest: FIPS 140-2(2001-10-10) Poker: 0
|
||||
rngtest: FIPS 140-2(2001-10-10) Runs: 1
|
||||
rngtest: FIPS 140-2(2001-10-10) Long run: 0
|
||||
rngtest: FIPS 140-2(2001-10-10) Continuous run: 0
|
||||
rngtest: input channel speed: (min=777.363; avg=43588.270; max=47870.711)Kibitss
|
||||
rngtest: FIPS tests speed: (min=11.943; avg=12.716; max=12.844)Mibits/s
|
||||
rngtest: Program run time: 1955282 microseconds
|
||||
|
||||
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
|
||||
Reported-by: George Pontis <GPontis@z9.com>
|
||||
Acked-by: Nicolas Ferre <nicolas.ferre@atmel.com>
|
||||
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/char/hw_random/atmel-rng.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/char/hw_random/atmel-rng.c b/drivers/char/hw_random/atmel-rng.c
|
||||
index 0477982..1b5675b 100644
|
||||
--- a/drivers/char/hw_random/atmel-rng.c
|
||||
+++ b/drivers/char/hw_random/atmel-rng.c
|
||||
@@ -34,7 +34,7 @@ static int atmel_trng_read(struct hwrng *rng, void *buf, size_t max,
|
||||
u32 *data = buf;
|
||||
|
||||
/* data ready? */
|
||||
- if (readl(trng->base + TRNG_ODATA) & 1) {
|
||||
+ if (readl(trng->base + TRNG_ISR) & 1) {
|
||||
*data = readl(trng->base + TRNG_ODATA);
|
||||
/*
|
||||
ensure data ready is only set again AFTER the next data
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,32 @@
|
||||
From 4f4723008a7461c6840e643bc66fcd92bfbf26b3 Mon Sep 17 00:00:00 2001
|
||||
From: Lubomir Schmidt <gentoo.lubomir@googlemail.com>
|
||||
Date: Fri, 15 Jun 2012 15:12:17 -0500
|
||||
Subject: [PATCH 05/46] staging: r8712u: Add new USB IDs
|
||||
|
||||
commit 3026b0e942c65c65c8fc80d391d004228b52b916 upstream.
|
||||
|
||||
There are two new devices for this driver.
|
||||
|
||||
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/staging/rtl8712/usb_intf.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/drivers/staging/rtl8712/usb_intf.c b/drivers/staging/rtl8712/usb_intf.c
|
||||
index ec41d38..f4b738f 100644
|
||||
--- a/drivers/staging/rtl8712/usb_intf.c
|
||||
+++ b/drivers/staging/rtl8712/usb_intf.c
|
||||
@@ -102,6 +102,8 @@ static struct usb_device_id rtl871x_usb_id_tbl[] = {
|
||||
/* - */
|
||||
{USB_DEVICE(0x20F4, 0x646B)},
|
||||
{USB_DEVICE(0x083A, 0xC512)},
|
||||
+ {USB_DEVICE(0x25D4, 0x4CA1)},
|
||||
+ {USB_DEVICE(0x25D4, 0x4CAB)},
|
||||
|
||||
/* RTL8191SU */
|
||||
/* Realtek */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
From d94e9fcf553861cd10a1780c6aeaa6a4419ba5ce Mon Sep 17 00:00:00 2001
|
||||
From: Henrik Rydberg <rydberg@euromail.se>
|
||||
Date: Thu, 7 Jun 2012 04:54:29 -0400
|
||||
Subject: [PATCH 06/46] hwmon: (applesmc) Limit key length in warning messages
|
||||
|
||||
commit ac852edb47b15900886ba2564eeeb13b3b526e3e upstream.
|
||||
|
||||
Key lookups may call read_smc() with a fixed-length key string,
|
||||
and if the lookup fails, trailing stack content may appear in the
|
||||
kernel log. Fixed with this patch.
|
||||
|
||||
Signed-off-by: Henrik Rydberg <rydberg@euromail.se>
|
||||
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/hwmon/applesmc.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/hwmon/applesmc.c b/drivers/hwmon/applesmc.c
|
||||
index 4c07436..d99aa84 100644
|
||||
--- a/drivers/hwmon/applesmc.c
|
||||
+++ b/drivers/hwmon/applesmc.c
|
||||
@@ -215,7 +215,7 @@ static int read_smc(u8 cmd, const char *key, u8 *buffer, u8 len)
|
||||
int i;
|
||||
|
||||
if (send_command(cmd) || send_argument(key)) {
|
||||
- pr_warn("%s: read arg fail\n", key);
|
||||
+ pr_warn("%.4s: read arg fail\n", key);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
@@ -223,7 +223,7 @@ static int read_smc(u8 cmd, const char *key, u8 *buffer, u8 len)
|
||||
|
||||
for (i = 0; i < len; i++) {
|
||||
if (__wait_status(0x05)) {
|
||||
- pr_warn("%s: read data fail\n", key);
|
||||
+ pr_warn("%.4s: read data fail\n", key);
|
||||
return -EIO;
|
||||
}
|
||||
buffer[i] = inb(APPLESMC_DATA_PORT);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,218 @@
|
||||
From 8bf1709b6925d4e05120bdfed73992d50e7f11bf Mon Sep 17 00:00:00 2001
|
||||
From: Andrea Arcangeli <aarcange@redhat.com>
|
||||
Date: Tue, 29 May 2012 15:06:49 -0700
|
||||
Subject: [PATCH 07/46] mm: pmd_read_atomic: fix 32bit PAE pmd walk vs
|
||||
pmd_populate SMP race condition
|
||||
|
||||
commit 26c191788f18129af0eb32a358cdaea0c7479626 upstream.
|
||||
|
||||
When holding the mmap_sem for reading, pmd_offset_map_lock should only
|
||||
run on a pmd_t that has been read atomically from the pmdp pointer,
|
||||
otherwise we may read only half of it leading to this crash.
|
||||
|
||||
PID: 11679 TASK: f06e8000 CPU: 3 COMMAND: "do_race_2_panic"
|
||||
#0 [f06a9dd8] crash_kexec at c049b5ec
|
||||
#1 [f06a9e2c] oops_end at c083d1c2
|
||||
#2 [f06a9e40] no_context at c0433ded
|
||||
#3 [f06a9e64] bad_area_nosemaphore at c043401a
|
||||
#4 [f06a9e6c] __do_page_fault at c0434493
|
||||
#5 [f06a9eec] do_page_fault at c083eb45
|
||||
#6 [f06a9f04] error_code (via page_fault) at c083c5d5
|
||||
EAX: 01fb470c EBX: fff35000 ECX: 00000003 EDX: 00000100 EBP:
|
||||
00000000
|
||||
DS: 007b ESI: 9e201000 ES: 007b EDI: 01fb4700 GS: 00e0
|
||||
CS: 0060 EIP: c083bc14 ERR: ffffffff EFLAGS: 00010246
|
||||
#7 [f06a9f38] _spin_lock at c083bc14
|
||||
#8 [f06a9f44] sys_mincore at c0507b7d
|
||||
#9 [f06a9fb0] system_call at c083becd
|
||||
start len
|
||||
EAX: ffffffda EBX: 9e200000 ECX: 00001000 EDX: 6228537f
|
||||
DS: 007b ESI: 00000000 ES: 007b EDI: 003d0f00
|
||||
SS: 007b ESP: 62285354 EBP: 62285388 GS: 0033
|
||||
CS: 0073 EIP: 00291416 ERR: 000000da EFLAGS: 00000286
|
||||
|
||||
This should be a longstanding bug affecting x86 32bit PAE without THP.
|
||||
Only archs with 64bit large pmd_t and 32bit unsigned long should be
|
||||
affected.
|
||||
|
||||
With THP enabled the barrier() in pmd_none_or_trans_huge_or_clear_bad()
|
||||
would partly hide the bug when the pmd transition from none to stable,
|
||||
by forcing a re-read of the *pmd in pmd_offset_map_lock, but when THP is
|
||||
enabled a new set of problem arises by the fact could then transition
|
||||
freely in any of the none, pmd_trans_huge or pmd_trans_stable states.
|
||||
So making the barrier in pmd_none_or_trans_huge_or_clear_bad()
|
||||
unconditional isn't good idea and it would be a flakey solution.
|
||||
|
||||
This should be fully fixed by introducing a pmd_read_atomic that reads
|
||||
the pmd in order with THP disabled, or by reading the pmd atomically
|
||||
with cmpxchg8b with THP enabled.
|
||||
|
||||
Luckily this new race condition only triggers in the places that must
|
||||
already be covered by pmd_none_or_trans_huge_or_clear_bad() so the fix
|
||||
is localized there but this bug is not related to THP.
|
||||
|
||||
NOTE: this can trigger on x86 32bit systems with PAE enabled with more
|
||||
than 4G of ram, otherwise the high part of the pmd will never risk to be
|
||||
truncated because it would be zero at all times, in turn so hiding the
|
||||
SMP race.
|
||||
|
||||
This bug was discovered and fully debugged by Ulrich, quote:
|
||||
|
||||
----
|
||||
[..]
|
||||
pmd_none_or_trans_huge_or_clear_bad() loads the content of edx and
|
||||
eax.
|
||||
|
||||
496 static inline int pmd_none_or_trans_huge_or_clear_bad(pmd_t
|
||||
*pmd)
|
||||
497 {
|
||||
498 /* depend on compiler for an atomic pmd read */
|
||||
499 pmd_t pmdval = *pmd;
|
||||
|
||||
// edi = pmd pointer
|
||||
0xc0507a74 <sys_mincore+548>: mov 0x8(%esp),%edi
|
||||
...
|
||||
// edx = PTE page table high address
|
||||
0xc0507a84 <sys_mincore+564>: mov 0x4(%edi),%edx
|
||||
...
|
||||
// eax = PTE page table low address
|
||||
0xc0507a8e <sys_mincore+574>: mov (%edi),%eax
|
||||
|
||||
[..]
|
||||
|
||||
Please note that the PMD is not read atomically. These are two "mov"
|
||||
instructions where the high order bits of the PMD entry are fetched
|
||||
first. Hence, the above machine code is prone to the following race.
|
||||
|
||||
- The PMD entry {high|low} is 0x0000000000000000.
|
||||
The "mov" at 0xc0507a84 loads 0x00000000 into edx.
|
||||
|
||||
- A page fault (on another CPU) sneaks in between the two "mov"
|
||||
instructions and instantiates the PMD.
|
||||
|
||||
- The PMD entry {high|low} is now 0x00000003fda38067.
|
||||
The "mov" at 0xc0507a8e loads 0xfda38067 into eax.
|
||||
----
|
||||
|
||||
Reported-by: Ulrich Obergfell <uobergfe@redhat.com>
|
||||
Signed-off-by: Andrea Arcangeli <aarcange@redhat.com>
|
||||
Cc: Mel Gorman <mgorman@suse.de>
|
||||
Cc: Hugh Dickins <hughd@google.com>
|
||||
Cc: Larry Woodman <lwoodman@redhat.com>
|
||||
Cc: Petr Matousek <pmatouse@redhat.com>
|
||||
Cc: Rik van Riel <riel@redhat.com>
|
||||
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
|
||||
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/x86/include/asm/pgtable-3level.h | 50 +++++++++++++++++++++++++++++++++
|
||||
include/asm-generic/pgtable.h | 22 +++++++++++++--
|
||||
2 files changed, 70 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/arch/x86/include/asm/pgtable-3level.h b/arch/x86/include/asm/pgtable-3level.h
|
||||
index effff47..43876f1 100644
|
||||
--- a/arch/x86/include/asm/pgtable-3level.h
|
||||
+++ b/arch/x86/include/asm/pgtable-3level.h
|
||||
@@ -31,6 +31,56 @@ static inline void native_set_pte(pte_t *ptep, pte_t pte)
|
||||
ptep->pte_low = pte.pte_low;
|
||||
}
|
||||
|
||||
+#define pmd_read_atomic pmd_read_atomic
|
||||
+/*
|
||||
+ * pte_offset_map_lock on 32bit PAE kernels was reading the pmd_t with
|
||||
+ * a "*pmdp" dereference done by gcc. Problem is, in certain places
|
||||
+ * where pte_offset_map_lock is called, concurrent page faults are
|
||||
+ * allowed, if the mmap_sem is hold for reading. An example is mincore
|
||||
+ * vs page faults vs MADV_DONTNEED. On the page fault side
|
||||
+ * pmd_populate rightfully does a set_64bit, but if we're reading the
|
||||
+ * pmd_t with a "*pmdp" on the mincore side, a SMP race can happen
|
||||
+ * because gcc will not read the 64bit of the pmd atomically. To fix
|
||||
+ * this all places running pmd_offset_map_lock() while holding the
|
||||
+ * mmap_sem in read mode, shall read the pmdp pointer using this
|
||||
+ * function to know if the pmd is null nor not, and in turn to know if
|
||||
+ * they can run pmd_offset_map_lock or pmd_trans_huge or other pmd
|
||||
+ * operations.
|
||||
+ *
|
||||
+ * Without THP if the mmap_sem is hold for reading, the
|
||||
+ * pmd can only transition from null to not null while pmd_read_atomic runs.
|
||||
+ * So there's no need of literally reading it atomically.
|
||||
+ *
|
||||
+ * With THP if the mmap_sem is hold for reading, the pmd can become
|
||||
+ * THP or null or point to a pte (and in turn become "stable") at any
|
||||
+ * time under pmd_read_atomic, so it's mandatory to read it atomically
|
||||
+ * with cmpxchg8b.
|
||||
+ */
|
||||
+#ifndef CONFIG_TRANSPARENT_HUGEPAGE
|
||||
+static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
+{
|
||||
+ pmdval_t ret;
|
||||
+ u32 *tmp = (u32 *)pmdp;
|
||||
+
|
||||
+ ret = (pmdval_t) (*tmp);
|
||||
+ if (ret) {
|
||||
+ /*
|
||||
+ * If the low part is null, we must not read the high part
|
||||
+ * or we can end up with a partial pmd.
|
||||
+ */
|
||||
+ smp_rmb();
|
||||
+ ret |= ((pmdval_t)*(tmp + 1)) << 32;
|
||||
+ }
|
||||
+
|
||||
+ return (pmd_t) { ret };
|
||||
+}
|
||||
+#else /* CONFIG_TRANSPARENT_HUGEPAGE */
|
||||
+static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
+{
|
||||
+ return (pmd_t) { atomic64_read((atomic64_t *)pmdp) };
|
||||
+}
|
||||
+#endif /* CONFIG_TRANSPARENT_HUGEPAGE */
|
||||
+
|
||||
static inline void native_set_pte_atomic(pte_t *ptep, pte_t pte)
|
||||
{
|
||||
set_64bit((unsigned long long *)(ptep), native_pte_val(pte));
|
||||
diff --git a/include/asm-generic/pgtable.h b/include/asm-generic/pgtable.h
|
||||
index a03c098..831924a 100644
|
||||
--- a/include/asm-generic/pgtable.h
|
||||
+++ b/include/asm-generic/pgtable.h
|
||||
@@ -445,6 +445,18 @@ static inline int pmd_write(pmd_t pmd)
|
||||
#endif /* __HAVE_ARCH_PMD_WRITE */
|
||||
#endif /* CONFIG_TRANSPARENT_HUGEPAGE */
|
||||
|
||||
+#ifndef pmd_read_atomic
|
||||
+static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
+{
|
||||
+ /*
|
||||
+ * Depend on compiler for an atomic pmd read. NOTE: this is
|
||||
+ * only going to work, if the pmdval_t isn't larger than
|
||||
+ * an unsigned long.
|
||||
+ */
|
||||
+ return *pmdp;
|
||||
+}
|
||||
+#endif
|
||||
+
|
||||
/*
|
||||
* This function is meant to be used by sites walking pagetables with
|
||||
* the mmap_sem hold in read mode to protect against MADV_DONTNEED and
|
||||
@@ -458,11 +470,17 @@ static inline int pmd_write(pmd_t pmd)
|
||||
* undefined so behaving like if the pmd was none is safe (because it
|
||||
* can return none anyway). The compiler level barrier() is critically
|
||||
* important to compute the two checks atomically on the same pmdval.
|
||||
+ *
|
||||
+ * For 32bit kernels with a 64bit large pmd_t this automatically takes
|
||||
+ * care of reading the pmd atomically to avoid SMP race conditions
|
||||
+ * against pmd_populate() when the mmap_sem is hold for reading by the
|
||||
+ * caller (a special atomic read not done by "gcc" as in the generic
|
||||
+ * version above, is also needed when THP is disabled because the page
|
||||
+ * fault can populate the pmd from under us).
|
||||
*/
|
||||
static inline int pmd_none_or_trans_huge_or_clear_bad(pmd_t *pmd)
|
||||
{
|
||||
- /* depend on compiler for an atomic pmd read */
|
||||
- pmd_t pmdval = *pmd;
|
||||
+ pmd_t pmdval = pmd_read_atomic(pmd);
|
||||
/*
|
||||
* The barrier will stabilize the pmdval in a register or on
|
||||
* the stack so that it will stop changing under the code.
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,125 @@
|
||||
From dcfb4634621189a74522dee4d0dab8b5c1786b02 Mon Sep 17 00:00:00 2001
|
||||
From: Andrea Arcangeli <aarcange@redhat.com>
|
||||
Date: Wed, 20 Jun 2012 12:52:57 -0700
|
||||
Subject: [PATCH 08/46] thp: avoid atomic64_read in pmd_read_atomic for 32bit
|
||||
PAE
|
||||
|
||||
commit e4eed03fd06578571c01d4f1478c874bb432c815 upstream.
|
||||
|
||||
In the x86 32bit PAE CONFIG_TRANSPARENT_HUGEPAGE=y case while holding the
|
||||
mmap_sem for reading, cmpxchg8b cannot be used to read pmd contents under
|
||||
Xen.
|
||||
|
||||
So instead of dealing only with "consistent" pmdvals in
|
||||
pmd_none_or_trans_huge_or_clear_bad() (which would be conceptually
|
||||
simpler) we let pmd_none_or_trans_huge_or_clear_bad() deal with pmdvals
|
||||
where the low 32bit and high 32bit could be inconsistent (to avoid having
|
||||
to use cmpxchg8b).
|
||||
|
||||
The only guarantee we get from pmd_read_atomic is that if the low part of
|
||||
the pmd was found null, the high part will be null too (so the pmd will be
|
||||
considered unstable). And if the low part of the pmd is found "stable"
|
||||
later, then it means the whole pmd was read atomically (because after a
|
||||
pmd is stable, neither MADV_DONTNEED nor page faults can alter it anymore,
|
||||
and we read the high part after the low part).
|
||||
|
||||
In the 32bit PAE x86 case, it is enough to read the low part of the pmdval
|
||||
atomically to declare the pmd as "stable" and that's true for THP and no
|
||||
THP, furthermore in the THP case we also have a barrier() that will
|
||||
prevent any inconsistent pmdvals to be cached by a later re-read of the
|
||||
*pmd.
|
||||
|
||||
Signed-off-by: Andrea Arcangeli <aarcange@redhat.com>
|
||||
Cc: Jonathan Nieder <jrnieder@gmail.com>
|
||||
Cc: Ulrich Obergfell <uobergfe@redhat.com>
|
||||
Cc: Mel Gorman <mgorman@suse.de>
|
||||
Cc: Hugh Dickins <hughd@google.com>
|
||||
Cc: Larry Woodman <lwoodman@redhat.com>
|
||||
Cc: Petr Matousek <pmatouse@redhat.com>
|
||||
Cc: Rik van Riel <riel@redhat.com>
|
||||
Cc: Jan Beulich <jbeulich@suse.com>
|
||||
Cc: KOSAKI Motohiro <kosaki.motohiro@gmail.com>
|
||||
Tested-by: Andrew Jones <drjones@redhat.com>
|
||||
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
|
||||
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/x86/include/asm/pgtable-3level.h | 30 +++++++++++++++++-------------
|
||||
include/asm-generic/pgtable.h | 10 ++++++++++
|
||||
2 files changed, 27 insertions(+), 13 deletions(-)
|
||||
|
||||
diff --git a/arch/x86/include/asm/pgtable-3level.h b/arch/x86/include/asm/pgtable-3level.h
|
||||
index 43876f1..cb00ccc 100644
|
||||
--- a/arch/x86/include/asm/pgtable-3level.h
|
||||
+++ b/arch/x86/include/asm/pgtable-3level.h
|
||||
@@ -47,16 +47,26 @@ static inline void native_set_pte(pte_t *ptep, pte_t pte)
|
||||
* they can run pmd_offset_map_lock or pmd_trans_huge or other pmd
|
||||
* operations.
|
||||
*
|
||||
- * Without THP if the mmap_sem is hold for reading, the
|
||||
- * pmd can only transition from null to not null while pmd_read_atomic runs.
|
||||
- * So there's no need of literally reading it atomically.
|
||||
+ * Without THP if the mmap_sem is hold for reading, the pmd can only
|
||||
+ * transition from null to not null while pmd_read_atomic runs. So
|
||||
+ * we can always return atomic pmd values with this function.
|
||||
*
|
||||
* With THP if the mmap_sem is hold for reading, the pmd can become
|
||||
- * THP or null or point to a pte (and in turn become "stable") at any
|
||||
- * time under pmd_read_atomic, so it's mandatory to read it atomically
|
||||
- * with cmpxchg8b.
|
||||
+ * trans_huge or none or point to a pte (and in turn become "stable")
|
||||
+ * at any time under pmd_read_atomic. We could read it really
|
||||
+ * atomically here with a atomic64_read for the THP enabled case (and
|
||||
+ * it would be a whole lot simpler), but to avoid using cmpxchg8b we
|
||||
+ * only return an atomic pmdval if the low part of the pmdval is later
|
||||
+ * found stable (i.e. pointing to a pte). And we're returning a none
|
||||
+ * pmdval if the low part of the pmd is none. In some cases the high
|
||||
+ * and low part of the pmdval returned may not be consistent if THP is
|
||||
+ * enabled (the low part may point to previously mapped hugepage,
|
||||
+ * while the high part may point to a more recently mapped hugepage),
|
||||
+ * but pmd_none_or_trans_huge_or_clear_bad() only needs the low part
|
||||
+ * of the pmd to be read atomically to decide if the pmd is unstable
|
||||
+ * or not, with the only exception of when the low part of the pmd is
|
||||
+ * zero in which case we return a none pmd.
|
||||
*/
|
||||
-#ifndef CONFIG_TRANSPARENT_HUGEPAGE
|
||||
static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
{
|
||||
pmdval_t ret;
|
||||
@@ -74,12 +84,6 @@ static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
|
||||
return (pmd_t) { ret };
|
||||
}
|
||||
-#else /* CONFIG_TRANSPARENT_HUGEPAGE */
|
||||
-static inline pmd_t pmd_read_atomic(pmd_t *pmdp)
|
||||
-{
|
||||
- return (pmd_t) { atomic64_read((atomic64_t *)pmdp) };
|
||||
-}
|
||||
-#endif /* CONFIG_TRANSPARENT_HUGEPAGE */
|
||||
|
||||
static inline void native_set_pte_atomic(pte_t *ptep, pte_t pte)
|
||||
{
|
||||
diff --git a/include/asm-generic/pgtable.h b/include/asm-generic/pgtable.h
|
||||
index 831924a..bc00876 100644
|
||||
--- a/include/asm-generic/pgtable.h
|
||||
+++ b/include/asm-generic/pgtable.h
|
||||
@@ -484,6 +484,16 @@ static inline int pmd_none_or_trans_huge_or_clear_bad(pmd_t *pmd)
|
||||
/*
|
||||
* The barrier will stabilize the pmdval in a register or on
|
||||
* the stack so that it will stop changing under the code.
|
||||
+ *
|
||||
+ * When CONFIG_TRANSPARENT_HUGEPAGE=y on x86 32bit PAE,
|
||||
+ * pmd_read_atomic is allowed to return a not atomic pmdval
|
||||
+ * (for example pointing to an hugepage that has never been
|
||||
+ * mapped in the pmd). The below checks will only care about
|
||||
+ * the low part of the pmd with 32bit PAE x86 anyway, with the
|
||||
+ * exception of pmd_none(). So the important thing is that if
|
||||
+ * the low part of the pmd is found null, the high part will
|
||||
+ * be also null or the pmd_none() check below would be
|
||||
+ * confused.
|
||||
*/
|
||||
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
||||
barrier();
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,71 @@
|
||||
From c1a7e61b722c55f0bbbe234d8f16ab19882a0c6b Mon Sep 17 00:00:00 2001
|
||||
From: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
|
||||
Date: Wed, 20 Jun 2012 12:52:57 -0700
|
||||
Subject: [PATCH 09/46] nilfs2: ensure proper cache clearing for gc-inodes
|
||||
|
||||
commit fbb24a3a915f105016f1c828476be11aceac8504 upstream.
|
||||
|
||||
A gc-inode is a pseudo inode used to buffer the blocks to be moved by
|
||||
garbage collection.
|
||||
|
||||
Block caches of gc-inodes must be cleared every time a garbage collection
|
||||
function (nilfs_clean_segments) completes. Otherwise, stale blocks
|
||||
buffered in the caches may be wrongly reused in successive calls of the GC
|
||||
function.
|
||||
|
||||
For user files, this is not a problem because their gc-inodes are
|
||||
distinguished by a checkpoint number as well as an inode number. They
|
||||
never buffer different blocks if either an inode number, a checkpoint
|
||||
number, or a block offset differs.
|
||||
|
||||
However, gc-inodes of sufile, cpfile and DAT file can store different data
|
||||
for the same block offset. Thus, the nilfs_clean_segments function can
|
||||
move incorrect block for these meta-data files if an old block is cached.
|
||||
I found this is really causing meta-data corruption in nilfs.
|
||||
|
||||
This fixes the issue by ensuring cache clear of gc-inodes and resolves
|
||||
reported GC problems including checkpoint file corruption, b-tree
|
||||
corruption, and the following warning during GC.
|
||||
|
||||
nilfs_palloc_freev: entry number 307234 already freed.
|
||||
...
|
||||
|
||||
Signed-off-by: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
|
||||
Tested-by: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
|
||||
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
|
||||
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/nilfs2/gcinode.c | 2 ++
|
||||
fs/nilfs2/segment.c | 2 ++
|
||||
2 files changed, 4 insertions(+)
|
||||
|
||||
diff --git a/fs/nilfs2/gcinode.c b/fs/nilfs2/gcinode.c
|
||||
index 08a07a2..57ceaf3 100644
|
||||
--- a/fs/nilfs2/gcinode.c
|
||||
+++ b/fs/nilfs2/gcinode.c
|
||||
@@ -191,6 +191,8 @@ void nilfs_remove_all_gcinodes(struct the_nilfs *nilfs)
|
||||
while (!list_empty(head)) {
|
||||
ii = list_first_entry(head, struct nilfs_inode_info, i_dirty);
|
||||
list_del_init(&ii->i_dirty);
|
||||
+ truncate_inode_pages(&ii->vfs_inode.i_data, 0);
|
||||
+ nilfs_btnode_cache_clear(&ii->i_btnode_cache);
|
||||
iput(&ii->vfs_inode);
|
||||
}
|
||||
}
|
||||
diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c
|
||||
index bb24ab6..6f24e67 100644
|
||||
--- a/fs/nilfs2/segment.c
|
||||
+++ b/fs/nilfs2/segment.c
|
||||
@@ -2309,6 +2309,8 @@ nilfs_remove_written_gcinodes(struct the_nilfs *nilfs, struct list_head *head)
|
||||
if (!test_bit(NILFS_I_UPDATED, &ii->i_state))
|
||||
continue;
|
||||
list_del_init(&ii->i_dirty);
|
||||
+ truncate_inode_pages(&ii->vfs_inode.i_data, 0);
|
||||
+ nilfs_btnode_cache_clear(&ii->i_btnode_cache);
|
||||
iput(&ii->vfs_inode);
|
||||
}
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,130 @@
|
||||
From 4c0724b407a2c71dbb932d74363e386f798dca61 Mon Sep 17 00:00:00 2001
|
||||
From: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Date: Tue, 3 Apr 2012 17:58:35 +0100
|
||||
Subject: [PATCH 10/46] drm/i915: Finish any pending operations on the
|
||||
framebuffer before disabling
|
||||
|
||||
Similar to the case where we are changing from one framebuffer to
|
||||
another, we need to be sure that there are no pending WAIT_FOR_EVENTs on
|
||||
the pipe for the current framebuffer before switching. If we disable the
|
||||
pipe, and then try to execute a WAIT_FOR_EVENT it will block
|
||||
indefinitely and cause a GPU hang.
|
||||
|
||||
We attempted to fix this in commit 85345517fe6d4de27b0d6ca19fef9d28ac947c4a
|
||||
(drm/i915: Retire any pending operations on the old scanout when switching)
|
||||
for the case of mode switching, but this leaves the condition where we
|
||||
are switching off the pipe vulnerable.
|
||||
|
||||
There still remains the race condition were a display may be unplugged,
|
||||
switched off by the core, a uevent sent to notify the DDX and the DDX
|
||||
may issue a WAIT_FOR_EVENT before it processes the uevent. This window
|
||||
does not exist if the pipe is only switched off in response to the
|
||||
uevent. Time to make sure that is so...
|
||||
|
||||
Reported-by: Francis Leblanc <Francis.Leblanc-Lebeau@verint.com>
|
||||
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=36515
|
||||
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=45413
|
||||
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Reviewed-by: Eugeni Dodonov <eugeni.dodonov@intel.com>
|
||||
[danvet: fixup spelling in comment, noticed by Eugeni.]
|
||||
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
(cherry picked from commit 14667a4bde4361b7ac420d68a2e9e9b9b2df5231)
|
||||
Signed-off-by: Timo Aaltonen <timo.aaltonen@canonical.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/intel_display.c | 65 ++++++++++++++++++++++++----------
|
||||
1 file changed, 46 insertions(+), 19 deletions(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
|
||||
index 5c1cdb8..6aa7716 100644
|
||||
--- a/drivers/gpu/drm/i915/intel_display.c
|
||||
+++ b/drivers/gpu/drm/i915/intel_display.c
|
||||
@@ -2187,6 +2187,33 @@ intel_pipe_set_base_atomic(struct drm_crtc *crtc, struct drm_framebuffer *fb,
|
||||
}
|
||||
|
||||
static int
|
||||
+intel_finish_fb(struct drm_framebuffer *old_fb)
|
||||
+{
|
||||
+ struct drm_i915_gem_object *obj = to_intel_framebuffer(old_fb)->obj;
|
||||
+ struct drm_i915_private *dev_priv = obj->base.dev->dev_private;
|
||||
+ bool was_interruptible = dev_priv->mm.interruptible;
|
||||
+ int ret;
|
||||
+
|
||||
+ wait_event(dev_priv->pending_flip_queue,
|
||||
+ atomic_read(&dev_priv->mm.wedged) ||
|
||||
+ atomic_read(&obj->pending_flip) == 0);
|
||||
+
|
||||
+ /* Big Hammer, we also need to ensure that any pending
|
||||
+ * MI_WAIT_FOR_EVENT inside a user batch buffer on the
|
||||
+ * current scanout is retired before unpinning the old
|
||||
+ * framebuffer.
|
||||
+ *
|
||||
+ * This should only fail upon a hung GPU, in which case we
|
||||
+ * can safely continue.
|
||||
+ */
|
||||
+ dev_priv->mm.interruptible = false;
|
||||
+ ret = i915_gem_object_finish_gpu(obj);
|
||||
+ dev_priv->mm.interruptible = was_interruptible;
|
||||
+
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+static int
|
||||
intel_pipe_set_base(struct drm_crtc *crtc, int x, int y,
|
||||
struct drm_framebuffer *old_fb)
|
||||
{
|
||||
@@ -2224,25 +2251,8 @@ intel_pipe_set_base(struct drm_crtc *crtc, int x, int y,
|
||||
return ret;
|
||||
}
|
||||
|
||||
- if (old_fb) {
|
||||
- struct drm_i915_private *dev_priv = dev->dev_private;
|
||||
- struct drm_i915_gem_object *obj = to_intel_framebuffer(old_fb)->obj;
|
||||
-
|
||||
- wait_event(dev_priv->pending_flip_queue,
|
||||
- atomic_read(&dev_priv->mm.wedged) ||
|
||||
- atomic_read(&obj->pending_flip) == 0);
|
||||
-
|
||||
- /* Big Hammer, we also need to ensure that any pending
|
||||
- * MI_WAIT_FOR_EVENT inside a user batch buffer on the
|
||||
- * current scanout is retired before unpinning the old
|
||||
- * framebuffer.
|
||||
- *
|
||||
- * This should only fail upon a hung GPU, in which case we
|
||||
- * can safely continue.
|
||||
- */
|
||||
- ret = i915_gem_object_finish_gpu(obj);
|
||||
- (void) ret;
|
||||
- }
|
||||
+ if (old_fb)
|
||||
+ intel_finish_fb(old_fb);
|
||||
|
||||
ret = intel_pipe_set_base_atomic(crtc, crtc->fb, x, y,
|
||||
LEAVE_ATOMIC_MODE_SET);
|
||||
@@ -3312,6 +3322,23 @@ static void intel_crtc_disable(struct drm_crtc *crtc)
|
||||
struct drm_crtc_helper_funcs *crtc_funcs = crtc->helper_private;
|
||||
struct drm_device *dev = crtc->dev;
|
||||
|
||||
+ /* Flush any pending WAITs before we disable the pipe. Note that
|
||||
+ * we need to drop the struct_mutex in order to acquire it again
|
||||
+ * during the lowlevel dpms routines around a couple of the
|
||||
+ * operations. It does not look trivial nor desirable to move
|
||||
+ * that locking higher. So instead we leave a window for the
|
||||
+ * submission of further commands on the fb before we can actually
|
||||
+ * disable it. This race with userspace exists anyway, and we can
|
||||
+ * only rely on the pipe being disabled by userspace after it
|
||||
+ * receives the hotplug notification and has flushed any pending
|
||||
+ * batches.
|
||||
+ */
|
||||
+ if (crtc->fb) {
|
||||
+ mutex_lock(&dev->struct_mutex);
|
||||
+ intel_finish_fb(crtc->fb);
|
||||
+ mutex_unlock(&dev->struct_mutex);
|
||||
+ }
|
||||
+
|
||||
crtc_funcs->dpms(crtc, DRM_MODE_DPMS_OFF);
|
||||
|
||||
if (crtc->fb) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,84 @@
|
||||
From 7e3ac17c5a78a999c5932d6617f63a6ca7cf91b0 Mon Sep 17 00:00:00 2001
|
||||
From: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Date: Wed, 8 Feb 2012 13:34:13 +0000
|
||||
Subject: [PATCH 11/46] drm/i915: Remove use of the autoreported ringbuffer
|
||||
HEAD position
|
||||
|
||||
This is a revert of 6aa56062eaba67adfb247cded244fd877329588d.
|
||||
|
||||
This was originally introduced to workaround reads of the ringbuffer
|
||||
registers returning 0 on SandyBridge causing hangs due to ringbuffer
|
||||
overflow. The root cause here was reads through the GT powerwell require
|
||||
the forcewake dance, something we only learnt of later. Now it appears
|
||||
that reading the reported head position from the HWS is returning
|
||||
garbage, leading once again to hangs.
|
||||
|
||||
For example, on q35 the autoreported head reports:
|
||||
[ 217.975608] head now 00010000, actual 00010000
|
||||
[ 436.725613] head now 00200000, actual 00200000
|
||||
[ 462.956033] head now 00210000, actual 00210010
|
||||
[ 485.501409] head now 00400000, actual 00400020
|
||||
[ 508.064280] head now 00410000, actual 00410000
|
||||
[ 530.576078] head now 00600000, actual 00600020
|
||||
[ 553.273489] head now 00610000, actual 00610018
|
||||
which appears reasonably sane. In contrast, if we look at snb:
|
||||
[ 141.970680] head now 00e10000, actual 00008238
|
||||
[ 141.974062] head now 02734000, actual 000083c8
|
||||
[ 141.974425] head now 00e10000, actual 00008488
|
||||
[ 141.980374] head now 032b5000, actual 000088b8
|
||||
[ 141.980885] head now 03271000, actual 00008950
|
||||
[ 142.040628] head now 02101000, actual 00008b40
|
||||
[ 142.180173] head now 02734000, actual 00009050
|
||||
[ 142.181090] head now 00000000, actual 00000ae0
|
||||
[ 142.183737] head now 02734000, actual 00009050
|
||||
|
||||
In addition, the automatic reporting of the head position is scheduled
|
||||
to be defeatured in the future. It has no more utility, remove it.
|
||||
|
||||
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=45492
|
||||
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Tested-by: Eric Anholt <eric@anholt.net>
|
||||
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
|
||||
(cherry picked from commit 5d031e5b633d910f35e6e0abce94d9d842390006)
|
||||
Signed-off-by: Timo Aaltonen <timo.aaltonen@canonical.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/intel_ringbuffer.c | 14 +-------------
|
||||
1 file changed, 1 insertion(+), 13 deletions(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c
|
||||
index 933e66b..f6613dc 100644
|
||||
--- a/drivers/gpu/drm/i915/intel_ringbuffer.c
|
||||
+++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
|
||||
@@ -306,7 +306,7 @@ static int init_ring_common(struct intel_ring_buffer *ring)
|
||||
|
||||
I915_WRITE_CTL(ring,
|
||||
((ring->size - PAGE_SIZE) & RING_NR_PAGES)
|
||||
- | RING_REPORT_64K | RING_VALID);
|
||||
+ | RING_VALID);
|
||||
|
||||
/* If the head is still not zero, the ring is dead */
|
||||
if ((I915_READ_CTL(ring) & RING_VALID) == 0 ||
|
||||
@@ -1157,18 +1157,6 @@ int intel_wait_ring_buffer(struct intel_ring_buffer *ring, int n)
|
||||
struct drm_device *dev = ring->dev;
|
||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||
unsigned long end;
|
||||
- u32 head;
|
||||
-
|
||||
- /* If the reported head position has wrapped or hasn't advanced,
|
||||
- * fallback to the slow and accurate path.
|
||||
- */
|
||||
- head = intel_read_status_page(ring, 4);
|
||||
- if (head > ring->head) {
|
||||
- ring->head = head;
|
||||
- ring->space = ring_space(ring);
|
||||
- if (ring->space >= n)
|
||||
- return 0;
|
||||
- }
|
||||
|
||||
trace_i915_ring_wait_begin(ring);
|
||||
end = jiffies + 3 * HZ;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,41 @@
|
||||
From 7bc45fa1ef48339e44c48d53e0cdb9d0d4e33d43 Mon Sep 17 00:00:00 2001
|
||||
From: Chris Boot <bootc@bootc.net>
|
||||
Date: Tue, 24 Apr 2012 07:24:52 +0000
|
||||
Subject: [PATCH 12/46] e1000e: Disable ASPM L1 on 82574
|
||||
|
||||
commit id d4a4206ebbaf48b55803a7eb34e330530d83a889
|
||||
|
||||
ASPM on the 82574 causes trouble. Currently the driver disables L0s for
|
||||
this NIC but only disables L1 if the MTU is >1500. This patch simply
|
||||
causes L1 to be disabled regardless of the MTU setting.
|
||||
|
||||
Signed-off-by: Chris Boot <bootc@bootc.net>
|
||||
Cc: "Wyborny, Carolyn" <carolyn.wyborny@intel.com>
|
||||
Cc: Nix <nix@esperi.org.uk>
|
||||
Link: https://lkml.org/lkml/2012/3/19/362
|
||||
Tested-by: Jeff Pieper <jeffrey.e.pieper@intel.com>
|
||||
[Jeff Kirsher: Backport to 3.2-3.4 kernels]
|
||||
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/ethernet/intel/e1000e/82571.c | 3 ++-
|
||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/ethernet/intel/e1000e/82571.c b/drivers/net/ethernet/intel/e1000e/82571.c
|
||||
index a3e65fd..e556fc3 100644
|
||||
--- a/drivers/net/ethernet/intel/e1000e/82571.c
|
||||
+++ b/drivers/net/ethernet/intel/e1000e/82571.c
|
||||
@@ -2080,8 +2080,9 @@ const struct e1000_info e1000_82574_info = {
|
||||
| FLAG_HAS_SMART_POWER_DOWN
|
||||
| FLAG_HAS_AMT
|
||||
| FLAG_HAS_CTRLEXT_ON_LOAD,
|
||||
- .flags2 = FLAG2_CHECK_PHY_HANG
|
||||
+ .flags2 = FLAG2_CHECK_PHY_HANG
|
||||
| FLAG2_DISABLE_ASPM_L0S
|
||||
+ | FLAG2_DISABLE_ASPM_L1
|
||||
| FLAG2_NO_DISABLE_RX,
|
||||
.pba = 32,
|
||||
.max_hw_frame_size = DEFAULT_JUMBO,
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
From 51d8e7091033042d3ae09363abe5e93d0698930e Mon Sep 17 00:00:00 2001
|
||||
From: Chris Boot <bootc@bootc.net>
|
||||
Date: Tue, 24 Apr 2012 07:24:58 +0000
|
||||
Subject: [PATCH 13/46] e1000e: Remove special case for 82573/82574 ASPM L1
|
||||
disablement
|
||||
|
||||
commit 59aed95263bdd0e2b48eb9be5a94346d2d4abf90 upstream.
|
||||
|
||||
For the 82573, ASPM L1 gets disabled wholesale so this special-case code
|
||||
is not required. For the 82574 the previous patch does the same as for
|
||||
the 82573, disabling L1 on the adapter. Thus, this code is no longer
|
||||
required and can be removed.
|
||||
|
||||
Signed-off-by: Chris Boot <bootc@bootc.net>
|
||||
Tested-by: Jeff Pieper <jeffrey.e.pieper@intel.com>
|
||||
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/ethernet/intel/e1000e/netdev.c | 8 --------
|
||||
1 file changed, 8 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c
|
||||
index 4e933d1..64d3f98 100644
|
||||
--- a/drivers/net/ethernet/intel/e1000e/netdev.c
|
||||
+++ b/drivers/net/ethernet/intel/e1000e/netdev.c
|
||||
@@ -5132,14 +5132,6 @@ static int e1000_change_mtu(struct net_device *netdev, int new_mtu)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
- /* 82573 Errata 17 */
|
||||
- if (((adapter->hw.mac.type == e1000_82573) ||
|
||||
- (adapter->hw.mac.type == e1000_82574)) &&
|
||||
- (max_frame > ETH_FRAME_LEN + ETH_FCS_LEN)) {
|
||||
- adapter->flags2 |= FLAG2_DISABLE_ASPM_L1;
|
||||
- e1000e_disable_aspm(adapter->pdev, PCIE_LINK_STATE_L1);
|
||||
- }
|
||||
-
|
||||
while (test_and_set_bit(__E1000_RESETTING, &adapter->state))
|
||||
usleep_range(1000, 2000);
|
||||
/* e1000e_down -> e1000e_reset dependent on max_frame_size & mtu */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,39 @@
|
||||
From f00febe1475d06993b3f723ece375388dcf3bb9b Mon Sep 17 00:00:00 2001
|
||||
From: Eric Anholt <eric@anholt.net>
|
||||
Date: Thu, 22 Dec 2011 14:54:59 -0800
|
||||
Subject: [PATCH 14/46] drm/i915: Do the fallback non-IRQ wait in ring
|
||||
throttle, too.
|
||||
|
||||
commit 7ea29b13e5e3e1e61e612349eb0366efdb6457f3 upstream.
|
||||
|
||||
As a workaround for IRQ synchronization issues in the gen7 BLT ring,
|
||||
we want to turn the two wait functions into polling loops.
|
||||
|
||||
Signed-off-by: Eric Anholt <eric@anholt.net>
|
||||
Tested-by: Eugeni Dodonov <eugeni.dodonov@intel.com>
|
||||
Reviewed-by: Eugeni Dodonov <eugeni.dodonov@intel.com>
|
||||
Acked-by: Kenneth Graunke <kenneth@whitecape.org>
|
||||
Signed-off-by: Keith Packard <keithp@keithp.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/i915_gem.c | 4 ++++
|
||||
1 file changed, 4 insertions(+)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
|
||||
index 3e7c478..3e2edc6 100644
|
||||
--- a/drivers/gpu/drm/i915/i915_gem.c
|
||||
+++ b/drivers/gpu/drm/i915/i915_gem.c
|
||||
@@ -3312,6 +3312,10 @@ i915_gem_ring_throttle(struct drm_device *dev, struct drm_file *file)
|
||||
|
||||
if (ret == 0 && atomic_read(&dev_priv->mm.wedged))
|
||||
ret = -EIO;
|
||||
+ } else if (wait_for(i915_seqno_passed(ring->get_seqno(ring),
|
||||
+ seqno) ||
|
||||
+ atomic_read(&dev_priv->mm.wedged), 3000)) {
|
||||
+ ret = -EBUSY;
|
||||
}
|
||||
}
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,72 @@
|
||||
From 1c17511004913ab88dd06ac7df912125a97ea2c3 Mon Sep 17 00:00:00 2001
|
||||
From: wwang <wei_wang@realsil.com.cn>
|
||||
Date: Tue, 27 Mar 2012 16:43:11 +0800
|
||||
Subject: [PATCH 15/46] staging:rts_pstor:Fix possible panic by NULL pointer
|
||||
dereference
|
||||
|
||||
commit 0d05568ac79bfc595f1eadc3e0fd7a20a45f7b69 upstream.
|
||||
|
||||
rtsx_transport.c (rtsx_transfer_sglist_adma_partial):
|
||||
pointer struct scatterlist *sg, which is mapped in dma_map_sg,
|
||||
is used as an iterator in later transfer operation. It is corrupted and
|
||||
passed to dma_unmap_sg, thus causing fatal unmap of some erroneous address.
|
||||
Fix it by duplicating *sg_ptr for iterating.
|
||||
|
||||
Signed-off-by: wwang <wei_wang@realsil.com.cn>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/staging/rts_pstor/rtsx_transport.c | 11 ++++++-----
|
||||
1 file changed, 6 insertions(+), 5 deletions(-)
|
||||
|
||||
diff --git a/drivers/staging/rts_pstor/rtsx_transport.c b/drivers/staging/rts_pstor/rtsx_transport.c
|
||||
index 4e3d2c1..9b2e5c9 100644
|
||||
--- a/drivers/staging/rts_pstor/rtsx_transport.c
|
||||
+++ b/drivers/staging/rts_pstor/rtsx_transport.c
|
||||
@@ -335,6 +335,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card,
|
||||
int sg_cnt, i, resid;
|
||||
int err = 0;
|
||||
long timeleft;
|
||||
+ struct scatterlist *sg_ptr;
|
||||
u32 val = TRIG_DMA;
|
||||
|
||||
if ((sg == NULL) || (num_sg <= 0) || !offset || !index)
|
||||
@@ -371,7 +372,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card,
|
||||
sg_cnt = dma_map_sg(&(rtsx->pci->dev), sg, num_sg, dma_dir);
|
||||
|
||||
resid = size;
|
||||
-
|
||||
+ sg_ptr = sg;
|
||||
chip->sgi = 0;
|
||||
/* Usually the next entry will be @sg@ + 1, but if this sg element
|
||||
* is part of a chained scatterlist, it could jump to the start of
|
||||
@@ -379,14 +380,14 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card,
|
||||
* the proper sg
|
||||
*/
|
||||
for (i = 0; i < *index; i++)
|
||||
- sg = sg_next(sg);
|
||||
+ sg_ptr = sg_next(sg_ptr);
|
||||
for (i = *index; i < sg_cnt; i++) {
|
||||
dma_addr_t addr;
|
||||
unsigned int len;
|
||||
u8 option;
|
||||
|
||||
- addr = sg_dma_address(sg);
|
||||
- len = sg_dma_len(sg);
|
||||
+ addr = sg_dma_address(sg_ptr);
|
||||
+ len = sg_dma_len(sg_ptr);
|
||||
|
||||
RTSX_DEBUGP("DMA addr: 0x%x, Len: 0x%x\n",
|
||||
(unsigned int)addr, len);
|
||||
@@ -415,7 +416,7 @@ static int rtsx_transfer_sglist_adma_partial(struct rtsx_chip *chip, u8 card,
|
||||
if (!resid)
|
||||
break;
|
||||
|
||||
- sg = sg_next(sg);
|
||||
+ sg_ptr = sg_next(sg_ptr);
|
||||
}
|
||||
|
||||
RTSX_DEBUGP("SG table count = %d\n", chip->sgi);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,45 @@
|
||||
From f9f47b15a0eb3d8ae86f5d034fd8924ab258a4d2 Mon Sep 17 00:00:00 2001
|
||||
From: Hans de Goede <hdegoede@redhat.com>
|
||||
Date: Tue, 22 May 2012 11:24:05 -0300
|
||||
Subject: [PATCH 16/46] gspca-core: Fix buffers staying in queued state after
|
||||
a stream_off
|
||||
|
||||
commit af05ef01e9cde84620c6855a8d8ab9c8a1db9009 upstream.
|
||||
|
||||
This fixes a regression introduced by commit f7059ea and should be
|
||||
backported to all supported stable kernels which have this commit.
|
||||
|
||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||
Tested-by: Antonio Ospite <ospite@studenti.unina.it>
|
||||
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
|
||||
[bwh: Backported to 3.2: adjust context]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/media/video/gspca/gspca.c | 4 +++-
|
||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/media/video/gspca/gspca.c b/drivers/media/video/gspca/gspca.c
|
||||
index 2ca10df..981501f 100644
|
||||
--- a/drivers/media/video/gspca/gspca.c
|
||||
+++ b/drivers/media/video/gspca/gspca.c
|
||||
@@ -1697,7 +1697,7 @@ static int vidioc_streamoff(struct file *file, void *priv,
|
||||
enum v4l2_buf_type buf_type)
|
||||
{
|
||||
struct gspca_dev *gspca_dev = priv;
|
||||
- int ret;
|
||||
+ int i, ret;
|
||||
|
||||
if (buf_type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
|
||||
return -EINVAL;
|
||||
@@ -1728,6 +1728,8 @@ static int vidioc_streamoff(struct file *file, void *priv,
|
||||
wake_up_interruptible(&gspca_dev->wq);
|
||||
|
||||
/* empty the transfer queues */
|
||||
+ for (i = 0; i < gspca_dev->nframes; i++)
|
||||
+ gspca_dev->frame[i].v4l2_buf.flags &= ~BUF_ALL_FLAGS;
|
||||
atomic_set(&gspca_dev->fr_q, 0);
|
||||
atomic_set(&gspca_dev->fr_i, 0);
|
||||
gspca_dev->fr_o = 0;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,30 @@
|
||||
From ac5a4cc2f5d46f744484e577f41441acdbb0a68b Mon Sep 17 00:00:00 2001
|
||||
From: Michael Krufky <mkrufky@linuxtv.org>
|
||||
Date: Fri, 25 May 2012 09:29:12 -0300
|
||||
Subject: [PATCH 17/46] smsusb: add autodetection support for USB ID 2040:f5a0
|
||||
|
||||
commit 3e1141e2ce5667301a74ca2ef396d9bd5e995f7f upstream.
|
||||
|
||||
Signed-off-by: Michael Krufky <mkrufky@linuxtv.org>
|
||||
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/media/dvb/siano/smsusb.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/drivers/media/dvb/siano/smsusb.c b/drivers/media/dvb/siano/smsusb.c
|
||||
index b7d1e3e..fb68805 100644
|
||||
--- a/drivers/media/dvb/siano/smsusb.c
|
||||
+++ b/drivers/media/dvb/siano/smsusb.c
|
||||
@@ -544,6 +544,8 @@ static const struct usb_device_id smsusb_id_table[] __devinitconst = {
|
||||
.driver_info = SMS1XXX_BOARD_HAUPPAUGE_WINDHAM },
|
||||
{ USB_DEVICE(0x2040, 0xc0a0),
|
||||
.driver_info = SMS1XXX_BOARD_HAUPPAUGE_WINDHAM },
|
||||
+ { USB_DEVICE(0x2040, 0xf5a0),
|
||||
+ .driver_info = SMS1XXX_BOARD_HAUPPAUGE_WINDHAM },
|
||||
{ } /* Terminating entry */
|
||||
};
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,36 @@
|
||||
From 2d6a30faab149fe943e5648ef8ed9a6de7c112b1 Mon Sep 17 00:00:00 2001
|
||||
From: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Date: Tue, 19 Jun 2012 11:33:06 +0200
|
||||
Subject: [PATCH 18/46] drm/edid: don't return stack garbage from supports_rb
|
||||
|
||||
commit b196a4980ff7bb54db478e2a408dc8b12be15304 upstream.
|
||||
|
||||
We need to initialize this to false, because the is_rb callback only
|
||||
ever sets it to true.
|
||||
|
||||
Noticed while reading through the code.
|
||||
|
||||
Signed-Off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Reviewed-by: Adam Jackson <ajax@redhat.com>
|
||||
Signed-off-by: Dave Airlie <airlied@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/drm_edid.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/drm_edid.c b/drivers/gpu/drm/drm_edid.c
|
||||
index 3e927ce..a1ee634 100644
|
||||
--- a/drivers/gpu/drm/drm_edid.c
|
||||
+++ b/drivers/gpu/drm/drm_edid.c
|
||||
@@ -585,7 +585,7 @@ static bool
|
||||
drm_monitor_supports_rb(struct edid *edid)
|
||||
{
|
||||
if (edid->revision >= 4) {
|
||||
- bool ret;
|
||||
+ bool ret = false;
|
||||
drm_for_each_detailed_block((u8 *)edid, is_rb, &ret);
|
||||
return ret;
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
From 94823f5367fcb795a9e2d263b23c600ffa1b465f Mon Sep 17 00:00:00 2001
|
||||
From: Ben Skeggs <bskeggs@redhat.com>
|
||||
Date: Tue, 26 Jun 2012 12:12:30 +1000
|
||||
Subject: [PATCH 19/46] drm/nouveau/fbcon: using nv_two_heads is not a good
|
||||
idea
|
||||
|
||||
commit 9bd0c15fcfb42f6245447c53347d65ad9e72080b upstream.
|
||||
|
||||
nv_two_heads() was never meant to be used outside of pre-nv50 code. The
|
||||
code checks for >= NV_10 for 2 CRTCs, then downgrades a few specific
|
||||
chipsets to 1 CRTC based on (pci_device & 0x0ff0).
|
||||
|
||||
The breakage example seen is on GTX 560Ti, with a pciid of 0x1200, which
|
||||
gets detected as an NV20 (0x020x) with 1 CRTC by nv_two_heads(), causing
|
||||
memory corruption because there's actually 2 CRTCs..
|
||||
|
||||
This switches fbcon to use the CRTC count directly from the mode_config
|
||||
structure, which will also fix the same issue on Kepler boards which have
|
||||
4 CRTCs.
|
||||
|
||||
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
|
||||
Signed-off-by: Dave Airlie <airlied@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/nouveau/nouveau_fbcon.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/nouveau/nouveau_fbcon.c b/drivers/gpu/drm/nouveau/nouveau_fbcon.c
|
||||
index 3a4cc32..cc0801d 100644
|
||||
--- a/drivers/gpu/drm/nouveau/nouveau_fbcon.c
|
||||
+++ b/drivers/gpu/drm/nouveau/nouveau_fbcon.c
|
||||
@@ -499,7 +499,7 @@ int nouveau_fbcon_init(struct drm_device *dev)
|
||||
nfbdev->helper.funcs = &nouveau_fbcon_helper_funcs;
|
||||
|
||||
ret = drm_fb_helper_init(dev, &nfbdev->helper,
|
||||
- nv_two_heads(dev) ? 2 : 1, 4);
|
||||
+ dev->mode_config.num_crtc, 4);
|
||||
if (ret) {
|
||||
kfree(nfbdev);
|
||||
return ret;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,55 @@
|
||||
From 41466ed94cbd995e8553e3f6bd76b698cdb398ab Mon Sep 17 00:00:00 2001
|
||||
From: Mike Snitzer <snitzer@redhat.com>
|
||||
Date: Sat, 12 May 2012 01:43:12 +0100
|
||||
Subject: [PATCH 20/46] dm thin: reinstate missing mempool_free in
|
||||
cell_release_singleton
|
||||
|
||||
commit 03aaae7cdc71bc306888440b1f569d463e917b6d upstream.
|
||||
|
||||
Fix a significant memory leak inadvertently introduced during
|
||||
simplification of cell_release_singleton() in commit
|
||||
6f94a4c45a6f744383f9f695dde019998db3df55 ("dm thin: fix stacked bi_next
|
||||
usage").
|
||||
|
||||
A cell's hlist_del() must be accompanied by a mempool_free().
|
||||
Use __cell_release() to do this, like before.
|
||||
|
||||
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
|
||||
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/dm-thin.c | 9 ++++++---
|
||||
1 file changed, 6 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/drivers/md/dm-thin.c b/drivers/md/dm-thin.c
|
||||
index da2f021..532a902 100644
|
||||
--- a/drivers/md/dm-thin.c
|
||||
+++ b/drivers/md/dm-thin.c
|
||||
@@ -288,8 +288,10 @@ static void __cell_release(struct cell *cell, struct bio_list *inmates)
|
||||
|
||||
hlist_del(&cell->list);
|
||||
|
||||
- bio_list_add(inmates, cell->holder);
|
||||
- bio_list_merge(inmates, &cell->bios);
|
||||
+ if (inmates) {
|
||||
+ bio_list_add(inmates, cell->holder);
|
||||
+ bio_list_merge(inmates, &cell->bios);
|
||||
+ }
|
||||
|
||||
mempool_free(cell, prison->cell_pool);
|
||||
}
|
||||
@@ -312,9 +314,10 @@ static void cell_release(struct cell *cell, struct bio_list *bios)
|
||||
*/
|
||||
static void __cell_release_singleton(struct cell *cell, struct bio *bio)
|
||||
{
|
||||
- hlist_del(&cell->list);
|
||||
BUG_ON(cell->holder != bio);
|
||||
BUG_ON(!bio_list_empty(&cell->bios));
|
||||
+
|
||||
+ __cell_release(cell, NULL);
|
||||
}
|
||||
|
||||
static void cell_release_singleton(struct cell *cell, struct bio *bio)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,75 @@
|
||||
From 5bd15d249215ca79b080b366616c0a5f1c38904c Mon Sep 17 00:00:00 2001
|
||||
From: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Date: Wed, 6 Jun 2012 10:33:10 +0530
|
||||
Subject: [PATCH 21/46] ath9k: Fix a WARNING on suspend/resume with IBSS
|
||||
|
||||
commit 2031b4c2b4904f7448ab9e4bc6b9bf16e32709f5 upstream.
|
||||
|
||||
this patch is dependent on the patch "cfg80211: fix interface
|
||||
combinations"
|
||||
|
||||
In ath9k currently we have ADHOC interface as a single incompatible
|
||||
interface. when drv_add_interface is called during resume we got to
|
||||
consider number of vifs already present in addition to checking the
|
||||
drivers 'opmode' information about ADHOC. we incorrectly assume
|
||||
an ADHOC interface is already present. Then we may miss some driver
|
||||
specific data for the ADHOC interface after resume.
|
||||
|
||||
The above mentioned checks can be removed from the driver,
|
||||
as the patch 'cfg80211: fix interface combinations' ensures that
|
||||
if an interface type is not advertised by the driver in any of the
|
||||
interface combinations(via ieee80211_iface_combination) then it shall
|
||||
be treated as a single incompatible interface. Fixes the following
|
||||
warning on suspend/resume with ibss interface.
|
||||
|
||||
ath: phy0: Cannot create ADHOC interface when other
|
||||
interfaces already exist.
|
||||
WARNING: at net/mac80211/driver-ops.h:12
|
||||
ieee80211_reconfig+0x1882/0x1ca0 [mac80211]()
|
||||
Hardware name: 2842RK1
|
||||
wlan2: Failed check-sdata-in-driver check, flags: 0x0
|
||||
|
||||
Call Trace:
|
||||
[<c01361b2>] warn_slowpath_common+0x72/0xa0
|
||||
[<f8aaa7c2>] ? ieee80211_reconfig+0x1882/0x1ca0
|
||||
[mac80211]
|
||||
[<f8aaa7c2>] ? ieee80211_reconfig+0x1882/0x1ca0
|
||||
[mac80211]
|
||||
[<c0136283>] warn_slowpath_fmt+0x33/0x40
|
||||
[<f8aaa7c2>] ieee80211_reconfig+0x1882/0x1ca0 [mac80211]
|
||||
[<c06c1d1a>] ? mutex_lock_nested+0x23a/0x2f0
|
||||
[<f8a95097>] ieee80211_resume+0x27/0x70 [mac80211]
|
||||
[<fd177edf>] wiphy_resume+0x8f/0xa0 [cfg80211]
|
||||
|
||||
Cc: Rajkumar Manoharan <rmanohar@qca.qualcomm.com>
|
||||
Signed-off-by: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
[bwh: Backported to 3.2: adjust context]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath9k/main.c | 9 ---------
|
||||
1 file changed, 9 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
|
||||
index f76a814..5b22ecd 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/main.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/main.c
|
||||
@@ -1486,15 +1486,6 @@ static int ath9k_add_interface(struct ieee80211_hw *hw,
|
||||
}
|
||||
}
|
||||
|
||||
- if ((ah->opmode == NL80211_IFTYPE_ADHOC) ||
|
||||
- ((vif->type == NL80211_IFTYPE_ADHOC) &&
|
||||
- sc->nvifs > 0)) {
|
||||
- ath_err(common, "Cannot create ADHOC interface when other"
|
||||
- " interfaces already exist.\n");
|
||||
- ret = -EINVAL;
|
||||
- goto out;
|
||||
- }
|
||||
-
|
||||
ath_dbg(common, ATH_DBG_CONFIG,
|
||||
"Attach a VIF of type: %d\n", vif->type);
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,144 @@
|
||||
From 76f7c2172698cade04f33c7f8841b641c95ddeda Mon Sep 17 00:00:00 2001
|
||||
From: Eliad Peller <eliad@wizery.com>
|
||||
Date: Tue, 12 Jun 2012 12:53:13 +0300
|
||||
Subject: [PATCH 22/46] cfg80211: fix potential deadlock in regulatory
|
||||
|
||||
commit fe20b39ec32e975f1054c0b7866c873a954adf05 upstream.
|
||||
|
||||
reg_timeout_work() calls restore_regulatory_settings() which
|
||||
takes cfg80211_mutex.
|
||||
|
||||
reg_set_request_processed() already holds cfg80211_mutex
|
||||
before calling cancel_delayed_work_sync(reg_timeout),
|
||||
so it might deadlock.
|
||||
|
||||
Call the async cancel_delayed_work instead, in order
|
||||
to avoid the potential deadlock.
|
||||
|
||||
This is the relevant lockdep warning:
|
||||
|
||||
cfg80211: Calling CRDA for country: XX
|
||||
|
||||
======================================================
|
||||
[ INFO: possible circular locking dependency detected ]
|
||||
3.4.0-rc5-wl+ #26 Not tainted
|
||||
-------------------------------------------------------
|
||||
kworker/0:2/1391 is trying to acquire lock:
|
||||
(cfg80211_mutex){+.+.+.}, at: [<bf28ae00>] restore_regulatory_settings+0x34/0x418 [cfg80211]
|
||||
|
||||
but task is already holding lock:
|
||||
((reg_timeout).work){+.+...}, at: [<c0059e94>] process_one_work+0x1f0/0x480
|
||||
|
||||
which lock already depends on the new lock.
|
||||
|
||||
the existing dependency chain (in reverse order) is:
|
||||
|
||||
-> #2 ((reg_timeout).work){+.+...}:
|
||||
[<c008fd44>] validate_chain+0xb94/0x10f0
|
||||
[<c0090b68>] __lock_acquire+0x8c8/0x9b0
|
||||
[<c0090d40>] lock_acquire+0xf0/0x114
|
||||
[<c005b600>] wait_on_work+0x4c/0x154
|
||||
[<c005c000>] __cancel_work_timer+0xd4/0x11c
|
||||
[<c005c064>] cancel_delayed_work_sync+0x1c/0x20
|
||||
[<bf28b274>] reg_set_request_processed+0x50/0x78 [cfg80211]
|
||||
[<bf28bd84>] set_regdom+0x550/0x600 [cfg80211]
|
||||
[<bf294cd8>] nl80211_set_reg+0x218/0x258 [cfg80211]
|
||||
[<c03c7738>] genl_rcv_msg+0x1a8/0x1e8
|
||||
[<c03c6a00>] netlink_rcv_skb+0x5c/0xc0
|
||||
[<c03c7584>] genl_rcv+0x28/0x34
|
||||
[<c03c6720>] netlink_unicast+0x15c/0x228
|
||||
[<c03c6c7c>] netlink_sendmsg+0x218/0x298
|
||||
[<c03933c8>] sock_sendmsg+0xa4/0xc0
|
||||
[<c039406c>] __sys_sendmsg+0x1e4/0x268
|
||||
[<c0394228>] sys_sendmsg+0x4c/0x70
|
||||
[<c0013840>] ret_fast_syscall+0x0/0x3c
|
||||
|
||||
-> #1 (reg_mutex){+.+.+.}:
|
||||
[<c008fd44>] validate_chain+0xb94/0x10f0
|
||||
[<c0090b68>] __lock_acquire+0x8c8/0x9b0
|
||||
[<c0090d40>] lock_acquire+0xf0/0x114
|
||||
[<c04734dc>] mutex_lock_nested+0x48/0x320
|
||||
[<bf28b2cc>] reg_todo+0x30/0x538 [cfg80211]
|
||||
[<c0059f44>] process_one_work+0x2a0/0x480
|
||||
[<c005a4b4>] worker_thread+0x1bc/0x2bc
|
||||
[<c0061148>] kthread+0x98/0xa4
|
||||
[<c0014af4>] kernel_thread_exit+0x0/0x8
|
||||
|
||||
-> #0 (cfg80211_mutex){+.+.+.}:
|
||||
[<c008ed58>] print_circular_bug+0x68/0x2cc
|
||||
[<c008fb28>] validate_chain+0x978/0x10f0
|
||||
[<c0090b68>] __lock_acquire+0x8c8/0x9b0
|
||||
[<c0090d40>] lock_acquire+0xf0/0x114
|
||||
[<c04734dc>] mutex_lock_nested+0x48/0x320
|
||||
[<bf28ae00>] restore_regulatory_settings+0x34/0x418 [cfg80211]
|
||||
[<bf28b200>] reg_timeout_work+0x1c/0x20 [cfg80211]
|
||||
[<c0059f44>] process_one_work+0x2a0/0x480
|
||||
[<c005a4b4>] worker_thread+0x1bc/0x2bc
|
||||
[<c0061148>] kthread+0x98/0xa4
|
||||
[<c0014af4>] kernel_thread_exit+0x0/0x8
|
||||
|
||||
other info that might help us debug this:
|
||||
|
||||
Chain exists of:
|
||||
cfg80211_mutex --> reg_mutex --> (reg_timeout).work
|
||||
|
||||
Possible unsafe locking scenario:
|
||||
|
||||
CPU0 CPU1
|
||||
---- ----
|
||||
lock((reg_timeout).work);
|
||||
lock(reg_mutex);
|
||||
lock((reg_timeout).work);
|
||||
lock(cfg80211_mutex);
|
||||
|
||||
*** DEADLOCK ***
|
||||
|
||||
2 locks held by kworker/0:2/1391:
|
||||
#0: (events){.+.+.+}, at: [<c0059e94>] process_one_work+0x1f0/0x480
|
||||
#1: ((reg_timeout).work){+.+...}, at: [<c0059e94>] process_one_work+0x1f0/0x480
|
||||
|
||||
stack backtrace:
|
||||
[<c001b928>] (unwind_backtrace+0x0/0x12c) from [<c0471d3c>] (dump_stack+0x20/0x24)
|
||||
[<c0471d3c>] (dump_stack+0x20/0x24) from [<c008ef70>] (print_circular_bug+0x280/0x2cc)
|
||||
[<c008ef70>] (print_circular_bug+0x280/0x2cc) from [<c008fb28>] (validate_chain+0x978/0x10f0)
|
||||
[<c008fb28>] (validate_chain+0x978/0x10f0) from [<c0090b68>] (__lock_acquire+0x8c8/0x9b0)
|
||||
[<c0090b68>] (__lock_acquire+0x8c8/0x9b0) from [<c0090d40>] (lock_acquire+0xf0/0x114)
|
||||
[<c0090d40>] (lock_acquire+0xf0/0x114) from [<c04734dc>] (mutex_lock_nested+0x48/0x320)
|
||||
[<c04734dc>] (mutex_lock_nested+0x48/0x320) from [<bf28ae00>] (restore_regulatory_settings+0x34/0x418 [cfg80211])
|
||||
[<bf28ae00>] (restore_regulatory_settings+0x34/0x418 [cfg80211]) from [<bf28b200>] (reg_timeout_work+0x1c/0x20 [cfg80211])
|
||||
[<bf28b200>] (reg_timeout_work+0x1c/0x20 [cfg80211]) from [<c0059f44>] (process_one_work+0x2a0/0x480)
|
||||
[<c0059f44>] (process_one_work+0x2a0/0x480) from [<c005a4b4>] (worker_thread+0x1bc/0x2bc)
|
||||
[<c005a4b4>] (worker_thread+0x1bc/0x2bc) from [<c0061148>] (kthread+0x98/0xa4)
|
||||
[<c0061148>] (kthread+0x98/0xa4) from [<c0014af4>] (kernel_thread_exit+0x0/0x8)
|
||||
cfg80211: Calling CRDA to update world regulatory domain
|
||||
cfg80211: World regulatory domain updated:
|
||||
cfg80211: (start_freq - end_freq @ bandwidth), (max_antenna_gain, max_eirp)
|
||||
cfg80211: (2402000 KHz - 2472000 KHz @ 40000 KHz), (300 mBi, 2000 mBm)
|
||||
cfg80211: (2457000 KHz - 2482000 KHz @ 20000 KHz), (300 mBi, 2000 mBm)
|
||||
cfg80211: (2474000 KHz - 2494000 KHz @ 20000 KHz), (300 mBi, 2000 mBm)
|
||||
cfg80211: (5170000 KHz - 5250000 KHz @ 40000 KHz), (300 mBi, 2000 mBm)
|
||||
cfg80211: (5735000 KHz - 5835000 KHz @ 40000 KHz), (300 mBi, 2000 mBm)
|
||||
|
||||
Signed-off-by: Eliad Peller <eliad@wizery.com>
|
||||
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/wireless/reg.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/net/wireless/reg.c b/net/wireless/reg.c
|
||||
index c1c99dd..d57d05b 100644
|
||||
--- a/net/wireless/reg.c
|
||||
+++ b/net/wireless/reg.c
|
||||
@@ -1369,7 +1369,7 @@ static void reg_set_request_processed(void)
|
||||
spin_unlock(®_requests_lock);
|
||||
|
||||
if (last_request->initiator == NL80211_REGDOM_SET_BY_USER)
|
||||
- cancel_delayed_work_sync(®_timeout);
|
||||
+ cancel_delayed_work(®_timeout);
|
||||
|
||||
if (need_more_processing)
|
||||
schedule_work(®_work);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,68 @@
|
||||
From 7195eb3dcc15a2a0ea8c557806abf32241e276d1 Mon Sep 17 00:00:00 2001
|
||||
From: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Date: Wed, 13 Jun 2012 21:28:09 +0530
|
||||
Subject: [PATCH 23/46] ath9k: Fix softlockup in AR9485
|
||||
|
||||
commit bcb7ad7bcbef030e6ba71ede1f9866368aca7c99 upstream.
|
||||
|
||||
steps to recreate:
|
||||
load latest ath9k driver with AR9485
|
||||
stop the network-manager and wpa_supplicant
|
||||
bring the interface up
|
||||
|
||||
Call Trace:
|
||||
[<ffffffffa0517490>] ? ath_hw_check+0xe0/0xe0 [ath9k]
|
||||
[<ffffffff812cd1e8>] __const_udelay+0x28/0x30
|
||||
[<ffffffffa03bae7a>] ar9003_get_pll_sqsum_dvc+0x4a/0x80 [ath9k_hw]
|
||||
[<ffffffffa05174eb>] ath_hw_pll_work+0x5b/0xe0 [ath9k]
|
||||
[<ffffffff810744fe>] process_one_work+0x11e/0x470
|
||||
[<ffffffff8107530f>] worker_thread+0x15f/0x360
|
||||
[<ffffffff810751b0>] ? manage_workers+0x230/0x230
|
||||
[<ffffffff81079af3>] kthread+0x93/0xa0
|
||||
[<ffffffff815fd3a4>] kernel_thread_helper+0x4/0x10
|
||||
[<ffffffff81079a60>] ? kthread_freezable_should_stop+0x70/0x70
|
||||
[<ffffffff815fd3a0>] ? gs_change+0x13/0x13
|
||||
|
||||
ensure that the PLL-WAR for AR9485/AR9340 is executed only if the STA is
|
||||
associated (or) IBSS/AP mode had started beaconing. Ideally this WAR
|
||||
is needed to recover from some rare beacon stuck during stress testing.
|
||||
Before the STA is associated/IBSS had started beaconing, PLL4(0x1618c)
|
||||
always seem to have zero even though we had configured PLL3(0x16188) to
|
||||
query about PLL's locking status. When we keep on polling infinitely PLL4's
|
||||
8th bit(ie check for PLL locking measurements is done), machine hangs
|
||||
due to softlockup.
|
||||
|
||||
fixes https://bugzilla.redhat.com/show_bug.cgi?id=811142
|
||||
|
||||
Reported-by: Rolf Offermanns <rolf.offermanns@gmx.net>
|
||||
Tested-by: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Signed-off-by: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath9k/main.c | 9 +++++++++
|
||||
1 file changed, 9 insertions(+)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
|
||||
index 5b22ecd..95437fc 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/main.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/main.c
|
||||
@@ -1042,6 +1042,15 @@ void ath_hw_pll_work(struct work_struct *work)
|
||||
hw_pll_work.work);
|
||||
u32 pll_sqsum;
|
||||
|
||||
+ /*
|
||||
+ * ensure that the PLL WAR is executed only
|
||||
+ * after the STA is associated (or) if the
|
||||
+ * beaconing had started in interfaces that
|
||||
+ * uses beacons.
|
||||
+ */
|
||||
+ if (!(sc->sc_flags & SC_OP_BEACONS))
|
||||
+ return;
|
||||
+
|
||||
if (AR_SREV_9485(sc->sc_ah)) {
|
||||
|
||||
ath9k_ps_wakeup(sc);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,38 @@
|
||||
From a06c6152d3db3bab83eefcbff5a1e41c91c8295d Mon Sep 17 00:00:00 2001
|
||||
From: Dan Carpenter <dan.carpenter@oracle.com>
|
||||
Date: Fri, 15 Jun 2012 00:20:44 +0000
|
||||
Subject: [PATCH 24/46] can: c_can: precedence error in c_can_chip_config()
|
||||
|
||||
commit d9cb9bd63eb27ac19f26a8547128c053f43a5da8 upstream.
|
||||
|
||||
(CAN_CTRLMODE_LISTENONLY & CAN_CTRLMODE_LOOPBACK) is (0x02 & 0x01) which
|
||||
is zero so the condition is never true. The intent here was to test
|
||||
that both flags were set.
|
||||
|
||||
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
|
||||
Acked-by: Oliver Hartkopp <socketcan@hartkopp.net>
|
||||
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/can/c_can/c_can.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/can/c_can/c_can.c b/drivers/net/can/c_can/c_can.c
|
||||
index 8dc84d6..86cd532 100644
|
||||
--- a/drivers/net/can/c_can/c_can.c
|
||||
+++ b/drivers/net/can/c_can/c_can.c
|
||||
@@ -590,8 +590,8 @@ static void c_can_chip_config(struct net_device *dev)
|
||||
priv->write_reg(priv, &priv->regs->control,
|
||||
CONTROL_ENABLE_AR);
|
||||
|
||||
- if (priv->can.ctrlmode & (CAN_CTRLMODE_LISTENONLY &
|
||||
- CAN_CTRLMODE_LOOPBACK)) {
|
||||
+ if ((priv->can.ctrlmode & CAN_CTRLMODE_LISTENONLY) &&
|
||||
+ (priv->can.ctrlmode & CAN_CTRLMODE_LOOPBACK)) {
|
||||
/* loopback + silent mode : useful for hot self-test */
|
||||
priv->write_reg(priv, &priv->regs->control, CONTROL_EIE |
|
||||
CONTROL_SIE | CONTROL_IE | CONTROL_TEST);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,41 @@
|
||||
From aabb8d6daa5fecfc6086a480865312860e6a1080 Mon Sep 17 00:00:00 2001
|
||||
From: Felix Fietkau <nbd@openwrt.org>
|
||||
Date: Fri, 15 Jun 2012 03:04:52 +0200
|
||||
Subject: [PATCH 25/46] ath9k: fix a tx rate duration calculation bug
|
||||
|
||||
commit 76591bea9714a58d8924154068c78d702eb2cb17 upstream.
|
||||
|
||||
The rate pointer variable for a rate series is used in a loop before it is
|
||||
initialized. This went unnoticed because it was used earlier for the RTS/CTS
|
||||
rate. This bug can lead to the wrong PHY type being passed to the
|
||||
duration calculation function.
|
||||
|
||||
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath9k/xmit.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c
|
||||
index 76fd277..c59c592 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/xmit.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/xmit.c
|
||||
@@ -936,13 +936,13 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf,
|
||||
}
|
||||
|
||||
/* legacy rates */
|
||||
+ rate = &sc->sbands[tx_info->band].bitrates[rates[i].idx];
|
||||
if ((tx_info->band == IEEE80211_BAND_2GHZ) &&
|
||||
!(rate->flags & IEEE80211_RATE_ERP_G))
|
||||
phy = WLAN_RC_PHY_CCK;
|
||||
else
|
||||
phy = WLAN_RC_PHY_OFDM;
|
||||
|
||||
- rate = &sc->sbands[tx_info->band].bitrates[rates[i].idx];
|
||||
info->rates[i].Rate = rate->hw_value;
|
||||
if (rate->hw_value_short) {
|
||||
if (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,42 @@
|
||||
From 124c9eb2772ae36b2a2d9afa510976cc38a497ef Mon Sep 17 00:00:00 2001
|
||||
From: Antonio Quartulli <ordex@autistici.org>
|
||||
Date: Fri, 29 Jun 2012 22:58:03 +0200
|
||||
Subject: [PATCH 26/46] batman-adv: fix skb->data assignment
|
||||
|
||||
commit 2c995ff892313009e336ecc8ec3411022f5b1c39 upstream.
|
||||
|
||||
skb_linearize(skb) possibly rearranges the skb internal data and then changes
|
||||
the skb->data pointer value. For this reason any other pointer in the code that
|
||||
was assigned skb->data before invoking skb_linearise(skb) must be re-assigned.
|
||||
|
||||
In the current tt_query message handling code this is not done and therefore, in
|
||||
case of skb linearization, the pointer used to handle the packet header ends up
|
||||
in pointing to free'd memory.
|
||||
|
||||
This bug was introduced by a73105b8d4c765d9ebfb664d0a66802127d8e4c7
|
||||
(batman-adv: improved client announcement mechanism)
|
||||
|
||||
Signed-off-by: Antonio Quartulli <ordex@autistici.org>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
[This patch is a backport for kernel versions 3.1 and 3.2 - Antonio]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/batman-adv/routing.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/net/batman-adv/routing.c b/net/batman-adv/routing.c
|
||||
index f961cc5..da587ad 100644
|
||||
--- a/net/batman-adv/routing.c
|
||||
+++ b/net/batman-adv/routing.c
|
||||
@@ -619,6 +619,8 @@ int recv_tt_query(struct sk_buff *skb, struct hard_iface *recv_if)
|
||||
/* packet needs to be linearized to access the TT changes */
|
||||
if (skb_linearize(skb) < 0)
|
||||
goto out;
|
||||
+ /* skb_linearize() possibly changed skb->data */
|
||||
+ tt_query = (struct tt_query_packet *)skb->data;
|
||||
|
||||
if (is_my_mac(tt_query->dst))
|
||||
handle_tt_response(bat_priv, tt_query);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,33 @@
|
||||
From dcf35ea664aae563cd99db11c78285f28b7bdcde Mon Sep 17 00:00:00 2001
|
||||
From: Jonghwan Choi <jhbird.choi@samsung.com>
|
||||
Date: Wed, 20 Jun 2012 17:05:37 +0900
|
||||
Subject: [PATCH 27/46] ARM: SAMSUNG: Should check for IS_ERR(clk) instead of
|
||||
NULL
|
||||
|
||||
commit a5d8f4765f0e92ef027492a8cb979c5b8d45f2c3 upstream.
|
||||
|
||||
On the error condition clk_get() returns ERR_PTR().
|
||||
|
||||
Signed-off-by: Jonghwan Choi <jhbird.choi@samsung.com>
|
||||
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/arm/plat-samsung/include/plat/watchdog-reset.h | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/arch/arm/plat-samsung/include/plat/watchdog-reset.h b/arch/arm/plat-samsung/include/plat/watchdog-reset.h
|
||||
index 40dbb2b..11b19ea 100644
|
||||
--- a/arch/arm/plat-samsung/include/plat/watchdog-reset.h
|
||||
+++ b/arch/arm/plat-samsung/include/plat/watchdog-reset.h
|
||||
@@ -24,7 +24,7 @@ static inline void arch_wdt_reset(void)
|
||||
|
||||
__raw_writel(0, S3C2410_WTCON); /* disable watchdog, to be safe */
|
||||
|
||||
- if (s3c2410_wdtclk)
|
||||
+ if (!IS_ERR(s3c2410_wdtclk))
|
||||
clk_enable(s3c2410_wdtclk);
|
||||
|
||||
/* put initial values into count and data */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,61 @@
|
||||
From 750f92b77aa8db48a56f5d34dd6a61a3184cf119 Mon Sep 17 00:00:00 2001
|
||||
From: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Date: Mon, 18 Jun 2012 13:13:30 +0530
|
||||
Subject: [PATCH 28/46] ath9k_hw: avoid possible infinite loop in
|
||||
ar9003_get_pll_sqsum_dvc
|
||||
|
||||
commit f18e3c6b67f448ec47b3a5b242789bd3d5644879 upstream.
|
||||
|
||||
"ath9k: Fix softlockup in AR9485" with commit id
|
||||
64bc1239c790e051ff677e023435d770d2ffa174 fixed the reported
|
||||
issue, yet its better to avoid the possible infinite loop
|
||||
in ar9003_get_pll_sqsum_dvc by having a timeout as suggested
|
||||
by ath9k maintainers.
|
||||
http://www.spinics.net/lists/linux-wireless/msg92126.html.
|
||||
Based on my testing PLL's locking measurement is done in
|
||||
~200us (2 iterations).
|
||||
|
||||
Cc: Rolf Offermanns <rolf.offermanns@gmx.net>
|
||||
Cc: Sujith Manoharan <c_manoha@qca.qualcomm.com>
|
||||
Cc: Senthil Balasubramanian <senthilb@qca.qualcomm.com>
|
||||
Signed-off-by: Mohammed Shafi Shajakhan <mohammed@qca.qualcomm.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath9k/hw.c | 14 +++++++++++++-
|
||||
1 file changed, 13 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
|
||||
index 8b0c2ca..6973620 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/hw.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/hw.c
|
||||
@@ -718,13 +718,25 @@ static void ath9k_hw_init_qos(struct ath_hw *ah)
|
||||
|
||||
u32 ar9003_get_pll_sqsum_dvc(struct ath_hw *ah)
|
||||
{
|
||||
+ struct ath_common *common = ath9k_hw_common(ah);
|
||||
+ int i = 0;
|
||||
+
|
||||
REG_CLR_BIT(ah, PLL3, PLL3_DO_MEAS_MASK);
|
||||
udelay(100);
|
||||
REG_SET_BIT(ah, PLL3, PLL3_DO_MEAS_MASK);
|
||||
|
||||
- while ((REG_READ(ah, PLL4) & PLL4_MEAS_DONE) == 0)
|
||||
+ while ((REG_READ(ah, PLL4) & PLL4_MEAS_DONE) == 0) {
|
||||
+
|
||||
udelay(100);
|
||||
|
||||
+ if (WARN_ON_ONCE(i >= 100)) {
|
||||
+ ath_err(common, "PLL4 meaurement not done\n");
|
||||
+ break;
|
||||
+ }
|
||||
+
|
||||
+ i++;
|
||||
+ }
|
||||
+
|
||||
return (REG_READ(ah, PLL3) & SQSUM_DVC_MASK) >> 3;
|
||||
}
|
||||
EXPORT_SYMBOL(ar9003_get_pll_sqsum_dvc);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,67 @@
|
||||
From 470e08b2e73b3ce64336de8d55b009e4782735b8 Mon Sep 17 00:00:00 2001
|
||||
From: Johannes Berg <johannes.berg@intel.com>
|
||||
Date: Wed, 20 Jun 2012 08:46:25 +0200
|
||||
Subject: [PATCH 29/46] iwlwifi: remove log_event debugfs file debugging is
|
||||
disabled
|
||||
|
||||
commit 882b7b7d11d65e8eccce738f1ce97cdfdb998f9f upstream.
|
||||
|
||||
When debugging is disabled, the event log functions aren't
|
||||
functional in the way that the debugfs file expects. This
|
||||
leads to the debugfs access crashing. Since the event log
|
||||
functions aren't functional then, remove the debugfs file
|
||||
when CONFIG_IWLWIFI_DEBUG is not set.
|
||||
|
||||
Reported-by: Lekensteyn <lekensteyn@gmail.com>
|
||||
Reviewed-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
|
||||
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
[bwh: Backported to 3.2: adjust filename, context]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/iwlwifi/iwl-trans-pcie.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/drivers/net/wireless/iwlwifi/iwl-trans-pcie.c b/drivers/net/wireless/iwlwifi/iwl-trans-pcie.c
|
||||
index 5815cf5..4661a64 100644
|
||||
--- a/drivers/net/wireless/iwlwifi/iwl-trans-pcie.c
|
||||
+++ b/drivers/net/wireless/iwlwifi/iwl-trans-pcie.c
|
||||
@@ -1777,6 +1777,7 @@ static ssize_t iwl_dbgfs_rx_queue_read(struct file *file,
|
||||
return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
|
||||
}
|
||||
|
||||
+#ifdef CONFIG_IWLWIFI_DEBUG
|
||||
static ssize_t iwl_dbgfs_log_event_read(struct file *file,
|
||||
char __user *user_buf,
|
||||
size_t count, loff_t *ppos)
|
||||
@@ -1814,6 +1815,7 @@ static ssize_t iwl_dbgfs_log_event_write(struct file *file,
|
||||
|
||||
return count;
|
||||
}
|
||||
+#endif
|
||||
|
||||
static ssize_t iwl_dbgfs_interrupt_read(struct file *file,
|
||||
char __user *user_buf,
|
||||
@@ -1941,7 +1943,9 @@ static ssize_t iwl_dbgfs_fh_reg_read(struct file *file,
|
||||
return ret;
|
||||
}
|
||||
|
||||
+#ifdef CONFIG_IWLWIFI_DEBUG
|
||||
DEBUGFS_READ_WRITE_FILE_OPS(log_event);
|
||||
+#endif
|
||||
DEBUGFS_READ_WRITE_FILE_OPS(interrupt);
|
||||
DEBUGFS_READ_FILE_OPS(fh_reg);
|
||||
DEBUGFS_READ_FILE_OPS(rx_queue);
|
||||
@@ -1957,7 +1961,9 @@ static int iwl_trans_pcie_dbgfs_register(struct iwl_trans *trans,
|
||||
{
|
||||
DEBUGFS_ADD_FILE(rx_queue, dir, S_IRUSR);
|
||||
DEBUGFS_ADD_FILE(tx_queue, dir, S_IRUSR);
|
||||
+#ifdef CONFIG_IWLWIFI_DEBUG
|
||||
DEBUGFS_ADD_FILE(log_event, dir, S_IWUSR | S_IRUSR);
|
||||
+#endif
|
||||
DEBUGFS_ADD_FILE(interrupt, dir, S_IWUSR | S_IRUSR);
|
||||
DEBUGFS_ADD_FILE(csr, dir, S_IWUSR);
|
||||
DEBUGFS_ADD_FILE(fh_reg, dir, S_IRUSR);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,36 @@
|
||||
From 4885fac40cf4f8adf4c6832d90b3b60c4ac44f19 Mon Sep 17 00:00:00 2001
|
||||
From: Jose Miguel Goncalves <jose.goncalves@inov.pt>
|
||||
Date: Sat, 12 May 2012 06:11:49 +0900
|
||||
Subject: [PATCH 30/46] ARM: SAMSUNG: Fix for S3C2412 EBI memory mapping
|
||||
|
||||
commit 3dca938656c7b0ff6b0717a5dde0f5f45e592be5 upstream.
|
||||
|
||||
While upgrading the kernel on a S3C2412 based board I've noted
|
||||
that it was impossible to boot the board with a 2.6.32 or upper
|
||||
kernel. I've tracked down the problem to the EBI virtual memory
|
||||
mapping that is in conflict with the IO mapping definition in
|
||||
arch/arm/mach-s3c24xx/s3c2412.c.
|
||||
|
||||
Signed-off-by: Jose Miguel Goncalves <jose.goncalves@inov.pt>
|
||||
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/arm/plat-samsung/include/plat/map-s3c.h | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/arch/arm/plat-samsung/include/plat/map-s3c.h b/arch/arm/plat-samsung/include/plat/map-s3c.h
|
||||
index 7d04875..c0c70a8 100644
|
||||
--- a/arch/arm/plat-samsung/include/plat/map-s3c.h
|
||||
+++ b/arch/arm/plat-samsung/include/plat/map-s3c.h
|
||||
@@ -22,7 +22,7 @@
|
||||
#define S3C24XX_VA_WATCHDOG S3C_VA_WATCHDOG
|
||||
|
||||
#define S3C2412_VA_SSMC S3C_ADDR_CPU(0x00000000)
|
||||
-#define S3C2412_VA_EBI S3C_ADDR_CPU(0x00010000)
|
||||
+#define S3C2412_VA_EBI S3C_ADDR_CPU(0x00100000)
|
||||
|
||||
#define S3C2410_PA_UART (0x50000000)
|
||||
#define S3C24XX_PA_UART S3C2410_PA_UART
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,44 @@
|
||||
From 8ca01cdb21b1e0daed013a4536ca89543f844424 Mon Sep 17 00:00:00 2001
|
||||
From: Dmitry Shmygov <shmygov@rambler.ru>
|
||||
Date: Wed, 20 Jun 2012 15:51:40 +0400
|
||||
Subject: [PATCH 31/46] USB: option: add id for Cellient MEN-200
|
||||
|
||||
commit 1e2c4e59d2b8797973471b4a287a43eac12a0f40 upstream.
|
||||
|
||||
Add vendor and product ID to option.c driver
|
||||
for Cellient MEN-200 EVDO Rev.B 450MHz data module.
|
||||
http://cellient.com
|
||||
|
||||
Signed-off-by: Dmitry Shmygov <shmygov@rambler.ru>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/usb/serial/option.c | 5 +++++
|
||||
1 file changed, 5 insertions(+)
|
||||
|
||||
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c
|
||||
index 61d6c31..e311711c 100644
|
||||
--- a/drivers/usb/serial/option.c
|
||||
+++ b/drivers/usb/serial/option.c
|
||||
@@ -496,6 +496,10 @@ static void option_instat_callback(struct urb *urb);
|
||||
/* MediaTek products */
|
||||
#define MEDIATEK_VENDOR_ID 0x0e8d
|
||||
|
||||
+/* Cellient products */
|
||||
+#define CELLIENT_VENDOR_ID 0x2692
|
||||
+#define CELLIENT_PRODUCT_MEN200 0x9005
|
||||
+
|
||||
/* some devices interfaces need special handling due to a number of reasons */
|
||||
enum option_blacklist_reason {
|
||||
OPTION_BLACKLIST_NONE = 0,
|
||||
@@ -1227,6 +1231,7 @@ static const struct usb_device_id option_ids[] = {
|
||||
{ USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a1, 0xff, 0x02, 0x01) },
|
||||
{ USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a2, 0xff, 0x00, 0x00) },
|
||||
{ USB_DEVICE_AND_INTERFACE_INFO(MEDIATEK_VENDOR_ID, 0x00a2, 0xff, 0x02, 0x01) }, /* MediaTek MT6276M modem & app port */
|
||||
+ { USB_DEVICE(CELLIENT_VENDOR_ID, CELLIENT_PRODUCT_MEN200) },
|
||||
{ } /* Terminating entry */
|
||||
};
|
||||
MODULE_DEVICE_TABLE(usb, option_ids);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,44 @@
|
||||
From fa7b3de0ebfa0cd8a833ea2daa5ded5ea50fd085 Mon Sep 17 00:00:00 2001
|
||||
From: Will Deacon <will.deacon@arm.com>
|
||||
Date: Fri, 8 Jun 2012 16:16:04 +0100
|
||||
Subject: [PATCH 32/46] oprofile: perf: use NR_CPUS instead or nr_cpumask_bits
|
||||
for static array
|
||||
|
||||
commit e734568b675c985db2026848fefaac01c22977a5 upstream.
|
||||
|
||||
The OProfile perf backend uses a static array to keep track of the
|
||||
perf events on the system. When compiling with CONFIG_CPUMASK_OFFSTACK=y
|
||||
&& SMP, nr_cpumask_bits is not a compile-time constant and the build
|
||||
will fail with:
|
||||
|
||||
oprofile_perf.c:28: error: variably modified 'perf_events' at file scope
|
||||
|
||||
This patch uses NR_CPUs instead of nr_cpumask_bits for the array
|
||||
initialisation. If this causes space problems in the future, we can
|
||||
always move to dynamic allocation for the events array.
|
||||
|
||||
Cc: Matt Fleming <matt@console-pimps.org>
|
||||
Reported-by: Russell King - ARM Linux <linux@arm.linux.org.uk>
|
||||
Signed-off-by: Will Deacon <will.deacon@arm.com>
|
||||
Signed-off-by: Robert Richter <robert.richter@amd.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/oprofile/oprofile_perf.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/oprofile/oprofile_perf.c b/drivers/oprofile/oprofile_perf.c
|
||||
index da14432..efc4b7f 100644
|
||||
--- a/drivers/oprofile/oprofile_perf.c
|
||||
+++ b/drivers/oprofile/oprofile_perf.c
|
||||
@@ -25,7 +25,7 @@ static int oprofile_perf_enabled;
|
||||
static DEFINE_MUTEX(oprofile_perf_mutex);
|
||||
|
||||
static struct op_counter_config *counter_config;
|
||||
-static struct perf_event **perf_events[nr_cpumask_bits];
|
||||
+static struct perf_event **perf_events[NR_CPUS];
|
||||
static int num_counters;
|
||||
|
||||
/*
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,107 @@
|
||||
From 179d0e42c797861a350b6f72e534edad4dac0f65 Mon Sep 17 00:00:00 2001
|
||||
From: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Date: Sun, 15 Apr 2012 11:56:03 +0100
|
||||
Subject: [PATCH 33/46] drm/i915: Refactor the deferred PM_IIR handling into a
|
||||
single function
|
||||
|
||||
commit fc6826d1dcd65f3d1e9a5377678882e4e08f02be upstream.
|
||||
|
||||
This function, along with the registers and deferred work hander, are
|
||||
all shared with SandyBridge, IvyBridge and their variants. So remove the
|
||||
duplicate code into a single function.
|
||||
|
||||
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Reviewed-by: Ben Widawsky <ben@bwidawsk.net>
|
||||
Signed-Off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
[bwh: Backported to 3.2: adjust context; drop changes for Valley View]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/i915_irq.c | 58 +++++++++++++++++++--------------------
|
||||
1 file changed, 29 insertions(+), 29 deletions(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
|
||||
index d3820c2..17c335e 100644
|
||||
--- a/drivers/gpu/drm/i915/i915_irq.c
|
||||
+++ b/drivers/gpu/drm/i915/i915_irq.c
|
||||
@@ -424,6 +424,31 @@ static void gen6_pm_rps_work(struct work_struct *work)
|
||||
mutex_unlock(&dev_priv->dev->struct_mutex);
|
||||
}
|
||||
|
||||
+static void gen6_queue_rps_work(struct drm_i915_private *dev_priv,
|
||||
+ u32 pm_iir)
|
||||
+{
|
||||
+ unsigned long flags;
|
||||
+
|
||||
+ /*
|
||||
+ * IIR bits should never already be set because IMR should
|
||||
+ * prevent an interrupt from being shown in IIR. The warning
|
||||
+ * displays a case where we've unsafely cleared
|
||||
+ * dev_priv->pm_iir. Although missing an interrupt of the same
|
||||
+ * type is not a problem, it displays a problem in the logic.
|
||||
+ *
|
||||
+ * The mask bit in IMR is cleared by rps_work.
|
||||
+ */
|
||||
+
|
||||
+ spin_lock_irqsave(&dev_priv->rps_lock, flags);
|
||||
+ WARN(dev_priv->pm_iir & pm_iir, "Missed a PM interrupt\n");
|
||||
+ dev_priv->pm_iir |= pm_iir;
|
||||
+ I915_WRITE(GEN6_PMIMR, dev_priv->pm_iir);
|
||||
+ POSTING_READ(GEN6_PMIMR);
|
||||
+ spin_unlock_irqrestore(&dev_priv->rps_lock, flags);
|
||||
+
|
||||
+ queue_work(dev_priv->wq, &dev_priv->rps_work);
|
||||
+}
|
||||
+
|
||||
static void pch_irq_handler(struct drm_device *dev, u32 pch_iir)
|
||||
{
|
||||
drm_i915_private_t *dev_priv = (drm_i915_private_t *) dev->dev_private;
|
||||
@@ -529,16 +554,8 @@ static irqreturn_t ivybridge_irq_handler(DRM_IRQ_ARGS)
|
||||
pch_irq_handler(dev, pch_iir);
|
||||
}
|
||||
|
||||
- if (pm_iir & GEN6_PM_DEFERRED_EVENTS) {
|
||||
- unsigned long flags;
|
||||
- spin_lock_irqsave(&dev_priv->rps_lock, flags);
|
||||
- WARN(dev_priv->pm_iir & pm_iir, "Missed a PM interrupt\n");
|
||||
- dev_priv->pm_iir |= pm_iir;
|
||||
- I915_WRITE(GEN6_PMIMR, dev_priv->pm_iir);
|
||||
- POSTING_READ(GEN6_PMIMR);
|
||||
- spin_unlock_irqrestore(&dev_priv->rps_lock, flags);
|
||||
- queue_work(dev_priv->wq, &dev_priv->rps_work);
|
||||
- }
|
||||
+ if (pm_iir & GEN6_PM_DEFERRED_EVENTS)
|
||||
+ gen6_queue_rps_work(dev_priv, pm_iir);
|
||||
|
||||
/* should clear PCH hotplug event before clear CPU irq */
|
||||
I915_WRITE(SDEIIR, pch_iir);
|
||||
@@ -634,25 +651,8 @@ static irqreturn_t ironlake_irq_handler(DRM_IRQ_ARGS)
|
||||
i915_handle_rps_change(dev);
|
||||
}
|
||||
|
||||
- if (IS_GEN6(dev) && pm_iir & GEN6_PM_DEFERRED_EVENTS) {
|
||||
- /*
|
||||
- * IIR bits should never already be set because IMR should
|
||||
- * prevent an interrupt from being shown in IIR. The warning
|
||||
- * displays a case where we've unsafely cleared
|
||||
- * dev_priv->pm_iir. Although missing an interrupt of the same
|
||||
- * type is not a problem, it displays a problem in the logic.
|
||||
- *
|
||||
- * The mask bit in IMR is cleared by rps_work.
|
||||
- */
|
||||
- unsigned long flags;
|
||||
- spin_lock_irqsave(&dev_priv->rps_lock, flags);
|
||||
- WARN(dev_priv->pm_iir & pm_iir, "Missed a PM interrupt\n");
|
||||
- dev_priv->pm_iir |= pm_iir;
|
||||
- I915_WRITE(GEN6_PMIMR, dev_priv->pm_iir);
|
||||
- POSTING_READ(GEN6_PMIMR);
|
||||
- spin_unlock_irqrestore(&dev_priv->rps_lock, flags);
|
||||
- queue_work(dev_priv->wq, &dev_priv->rps_work);
|
||||
- }
|
||||
+ if (IS_GEN6(dev) && pm_iir & GEN6_PM_DEFERRED_EVENTS)
|
||||
+ gen6_queue_rps_work(dev_priv, pm_iir);
|
||||
|
||||
/* should clear PCH hotplug event before clear CPU irq */
|
||||
I915_WRITE(SDEIIR, pch_iir);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,60 @@
|
||||
From a01c3081fec2775e6ed17963f2f70ea67d5e6401 Mon Sep 17 00:00:00 2001
|
||||
From: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Date: Thu, 21 Jun 2012 14:55:22 +0200
|
||||
Subject: [PATCH 34/46] drm/i915: rip out the PM_IIR WARN
|
||||
|
||||
commit 58bf8062d0b293b8e1028e5b0342082002886bd4 upstream.
|
||||
|
||||
After banging my head against this for the past few months, I still
|
||||
don't see how this could possible race under the premise that once an
|
||||
irq bit is masked in PM_IMR and reset in PM_IIR it won't show up again
|
||||
until we unmask it in PM_IMR.
|
||||
|
||||
Still, we have reports of this being seen in the wild. Now Bspec has
|
||||
this little bit of lovely language in the PMIIR register:
|
||||
|
||||
Public SNB Docs, Vol3Part2, 2.5.14 "PMIIR":
|
||||
|
||||
"For each bit, the IIR can store a second pending interrupt if two or
|
||||
more of the same interrupt conditions occur before the first condition
|
||||
is cleared. Upon clearing the interrupt, the IIR bit will momentarily
|
||||
go low, then return high to indicate there is another interrupt
|
||||
pending."
|
||||
|
||||
Now if we presume that PMIMR only prevent new interrupts from being
|
||||
queued, we could easily end up masking an interrupt and clearing it,
|
||||
but the 2nd pending interrupt setting the bit in PMIIR right away
|
||||
again. Which leads, the next time the irq handler runs, to hitting the
|
||||
WARN.
|
||||
|
||||
Also, no bad side effects of this have ever been reported. And we've
|
||||
tracked down our issues with the gpu turbo getting stuck to bogus
|
||||
interrupt generation limits in th RPLIMIT register.
|
||||
|
||||
So let's just rip out this WARN as bogus and call it a day. The only
|
||||
shallow thing here is that this 2-deep irq queue in the hw makes you
|
||||
wonder how racy the windows irq handler is ...
|
||||
|
||||
Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=42907
|
||||
Acked-by: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Signed-Off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/i915_irq.c | 1 -
|
||||
1 file changed, 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
|
||||
index 17c335e..578ddfc 100644
|
||||
--- a/drivers/gpu/drm/i915/i915_irq.c
|
||||
+++ b/drivers/gpu/drm/i915/i915_irq.c
|
||||
@@ -440,7 +440,6 @@ static void gen6_queue_rps_work(struct drm_i915_private *dev_priv,
|
||||
*/
|
||||
|
||||
spin_lock_irqsave(&dev_priv->rps_lock, flags);
|
||||
- WARN(dev_priv->pm_iir & pm_iir, "Missed a PM interrupt\n");
|
||||
dev_priv->pm_iir |= pm_iir;
|
||||
I915_WRITE(GEN6_PMIMR, dev_priv->pm_iir);
|
||||
POSTING_READ(GEN6_PMIMR);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,46 @@
|
||||
From e083a17405e8771aaa8853534c66721aa5aa36ea Mon Sep 17 00:00:00 2001
|
||||
From: Takashi Iwai <tiwai@suse.de>
|
||||
Date: Thu, 21 Jun 2012 15:30:41 +0200
|
||||
Subject: [PATCH 35/46] drm/i915: Fix eDP blank screen after S3 resume on HP
|
||||
desktops
|
||||
|
||||
commit 6db65cbb941f9d433659bdad02b307f6d94465df upstream.
|
||||
|
||||
This patch fixes the problem on some HP desktop machines with eDP
|
||||
which give blank screens after S3 resume.
|
||||
|
||||
It turned out that BLC_PWM_CPU_CTL must be written after
|
||||
BLC_PWM_CPU_CTL2. Otherwise it doesn't take effect on these
|
||||
SNB machines.
|
||||
|
||||
Tested with 3.5-rc3 kernel.
|
||||
|
||||
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=49233
|
||||
|
||||
Signed-off-by: Takashi Iwai <tiwai@suse.de>
|
||||
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/i915_suspend.c | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/i915_suspend.c b/drivers/gpu/drm/i915/i915_suspend.c
|
||||
index a1eb83d..f38d196 100644
|
||||
--- a/drivers/gpu/drm/i915/i915_suspend.c
|
||||
+++ b/drivers/gpu/drm/i915/i915_suspend.c
|
||||
@@ -739,8 +739,11 @@ static void i915_restore_display(struct drm_device *dev)
|
||||
if (HAS_PCH_SPLIT(dev)) {
|
||||
I915_WRITE(BLC_PWM_PCH_CTL1, dev_priv->saveBLC_PWM_CTL);
|
||||
I915_WRITE(BLC_PWM_PCH_CTL2, dev_priv->saveBLC_PWM_CTL2);
|
||||
- I915_WRITE(BLC_PWM_CPU_CTL, dev_priv->saveBLC_CPU_PWM_CTL);
|
||||
+ /* NOTE: BLC_PWM_CPU_CTL must be written after BLC_PWM_CPU_CTL2;
|
||||
+ * otherwise we get blank eDP screen after S3 on some machines
|
||||
+ */
|
||||
I915_WRITE(BLC_PWM_CPU_CTL2, dev_priv->saveBLC_CPU_PWM_CTL2);
|
||||
+ I915_WRITE(BLC_PWM_CPU_CTL, dev_priv->saveBLC_CPU_PWM_CTL);
|
||||
I915_WRITE(PCH_PP_ON_DELAYS, dev_priv->savePP_ON_DELAYS);
|
||||
I915_WRITE(PCH_PP_OFF_DELAYS, dev_priv->savePP_OFF_DELAYS);
|
||||
I915_WRITE(PCH_PP_DIVISOR, dev_priv->savePP_DIVISOR);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,62 @@
|
||||
From 148576d5144418385e4a0d59c5c9547d662ae0f2 Mon Sep 17 00:00:00 2001
|
||||
From: Mandeep Singh Baines <msb@chromium.org>
|
||||
Date: Sun, 24 Jun 2012 23:31:09 +0200
|
||||
Subject: [PATCH 36/46] PM / Sleep: Prevent waiting forever on asynchronous
|
||||
suspend after abort
|
||||
|
||||
commit 1f758b23177d588a71b96ad02990e715949bb82f upstream.
|
||||
|
||||
__device_suspend() must always send a completion. Otherwise, parent
|
||||
devices will wait forever.
|
||||
|
||||
Commit 1e2ef05b, "PM: Limit race conditions between runtime PM and
|
||||
system sleep (v2)", introduced a regression by short-circuiting the
|
||||
complete_all() for certain error cases.
|
||||
|
||||
This patch fixes the bug by always signalling a completion.
|
||||
|
||||
Addresses http://crosbug.com/31972
|
||||
|
||||
Tested by injecting an abort.
|
||||
|
||||
Signed-off-by: Mandeep Singh Baines <msb@chromium.org>
|
||||
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/base/power/main.c | 6 ++++--
|
||||
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c
|
||||
index c3d2dfc..b96544a 100644
|
||||
--- a/drivers/base/power/main.c
|
||||
+++ b/drivers/base/power/main.c
|
||||
@@ -869,7 +869,7 @@ static int __device_suspend(struct device *dev, pm_message_t state, bool async)
|
||||
dpm_wait_for_children(dev, async);
|
||||
|
||||
if (async_error)
|
||||
- return 0;
|
||||
+ goto Complete;
|
||||
|
||||
pm_runtime_get_noresume(dev);
|
||||
if (pm_runtime_barrier(dev) && device_may_wakeup(dev))
|
||||
@@ -878,7 +878,7 @@ static int __device_suspend(struct device *dev, pm_message_t state, bool async)
|
||||
if (pm_wakeup_pending()) {
|
||||
pm_runtime_put_sync(dev);
|
||||
async_error = -EBUSY;
|
||||
- return 0;
|
||||
+ goto Complete;
|
||||
}
|
||||
|
||||
device_lock(dev);
|
||||
@@ -926,6 +926,8 @@ static int __device_suspend(struct device *dev, pm_message_t state, bool async)
|
||||
}
|
||||
|
||||
device_unlock(dev);
|
||||
+
|
||||
+ Complete:
|
||||
complete_all(&dev->power.completion);
|
||||
|
||||
if (error) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,73 @@
|
||||
From edb1135bf688ed567d95e964af22488274890640 Mon Sep 17 00:00:00 2001
|
||||
From: "H. Peter Anvin" <hpa@linux.intel.com>
|
||||
Date: Fri, 22 Jun 2012 10:58:06 -0700
|
||||
Subject: [PATCH 37/46] x86, cpufeature: Rename X86_FEATURE_DTS to
|
||||
X86_FEATURE_DTHERM
|
||||
|
||||
commit 4ad33411308596f2f918603509729922a1ec4411 upstream.
|
||||
|
||||
It makes sense to label "Digital Thermal Sensor" as "DTS", but
|
||||
unfortunately the string "dts" was already used for "Debug Store", and
|
||||
/proc/cpuinfo is a user space ABI.
|
||||
|
||||
Therefore, rename this to "dtherm".
|
||||
|
||||
This conflict went into mainline via the hwmon tree without any x86
|
||||
maintainer ack, and without any kind of hint in the subject.
|
||||
|
||||
a4659053 x86/hwmon: fix initialization of coretemp
|
||||
|
||||
Reported-by: Jean Delvare <khali@linux-fr.org>
|
||||
Link: http://lkml.kernel.org/r/4FE34BCB.5050305@linux.intel.com
|
||||
Cc: Jan Beulich <JBeulich@suse.com>
|
||||
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
|
||||
[bwh: Backported to 3.2: drop the coretemp device table change]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/x86/include/asm/cpufeature.h | 2 +-
|
||||
arch/x86/kernel/cpu/scattered.c | 2 +-
|
||||
drivers/hwmon/coretemp.c | 2 +-
|
||||
3 files changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/arch/x86/include/asm/cpufeature.h b/arch/x86/include/asm/cpufeature.h
|
||||
index f3444f7..0c3b775 100644
|
||||
--- a/arch/x86/include/asm/cpufeature.h
|
||||
+++ b/arch/x86/include/asm/cpufeature.h
|
||||
@@ -175,7 +175,7 @@
|
||||
#define X86_FEATURE_XSAVEOPT (7*32+ 4) /* Optimized Xsave */
|
||||
#define X86_FEATURE_PLN (7*32+ 5) /* Intel Power Limit Notification */
|
||||
#define X86_FEATURE_PTS (7*32+ 6) /* Intel Package Thermal Status */
|
||||
-#define X86_FEATURE_DTS (7*32+ 7) /* Digital Thermal Sensor */
|
||||
+#define X86_FEATURE_DTHERM (7*32+ 7) /* Digital Thermal Sensor */
|
||||
|
||||
/* Virtualization flags: Linux defined, word 8 */
|
||||
#define X86_FEATURE_TPR_SHADOW (8*32+ 0) /* Intel TPR Shadow */
|
||||
diff --git a/arch/x86/kernel/cpu/scattered.c b/arch/x86/kernel/cpu/scattered.c
|
||||
index c7f64e6..ea6106c 100644
|
||||
--- a/arch/x86/kernel/cpu/scattered.c
|
||||
+++ b/arch/x86/kernel/cpu/scattered.c
|
||||
@@ -31,7 +31,7 @@ void __cpuinit init_scattered_cpuid_features(struct cpuinfo_x86 *c)
|
||||
const struct cpuid_bit *cb;
|
||||
|
||||
static const struct cpuid_bit __cpuinitconst cpuid_bits[] = {
|
||||
- { X86_FEATURE_DTS, CR_EAX, 0, 0x00000006, 0 },
|
||||
+ { X86_FEATURE_DTHERM, CR_EAX, 0, 0x00000006, 0 },
|
||||
{ X86_FEATURE_IDA, CR_EAX, 1, 0x00000006, 0 },
|
||||
{ X86_FEATURE_ARAT, CR_EAX, 2, 0x00000006, 0 },
|
||||
{ X86_FEATURE_PLN, CR_EAX, 4, 0x00000006, 0 },
|
||||
diff --git a/drivers/hwmon/coretemp.c b/drivers/hwmon/coretemp.c
|
||||
index 427468f..0790c98 100644
|
||||
--- a/drivers/hwmon/coretemp.c
|
||||
+++ b/drivers/hwmon/coretemp.c
|
||||
@@ -660,7 +660,7 @@ static void __cpuinit get_core_online(unsigned int cpu)
|
||||
* sensors. We check this bit only, all the early CPUs
|
||||
* without thermal sensors will be filtered out.
|
||||
*/
|
||||
- if (!cpu_has(c, X86_FEATURE_DTS))
|
||||
+ if (!cpu_has(c, X86_FEATURE_DTHERM))
|
||||
return;
|
||||
|
||||
if (!pdev) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,51 @@
|
||||
From 2bbcf955f97142e2b38c1da222da381d3729beb9 Mon Sep 17 00:00:00 2001
|
||||
From: Mel Gorman <mgorman@suse.de>
|
||||
Date: Thu, 21 Jun 2012 11:36:50 +0100
|
||||
Subject: [PATCH 38/46] stable: Allow merging of backports for serious
|
||||
user-visible performance issues
|
||||
|
||||
commit eb3979f64d25120d60b9e761a4c58f70b1a02f86 upstream.
|
||||
|
||||
Distribution kernel maintainers routinely backport fixes for users that
|
||||
were deemed important but not "something critical" as defined by the
|
||||
rules. To users of these kernels they are very serious and failing to fix
|
||||
them reduces the value of -stable.
|
||||
|
||||
The problem is that the patches fixing these issues are often subtle and
|
||||
prone to regressions in other ways and need greater care and attention.
|
||||
To combat this, these "serious" backports should have a higher barrier
|
||||
to entry.
|
||||
|
||||
This patch relaxes the rules to allow a distribution maintainer to merge
|
||||
to -stable a backported patch or small series that fixes a "serious"
|
||||
user-visible performance issue. They should include additional information on
|
||||
the user-visible bug affected and a link to the bugzilla entry if available.
|
||||
The same rules about the patch being already in mainline still apply.
|
||||
|
||||
Signed-off-by: Mel Gorman <mgorman@suse.de>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
Documentation/stable_kernel_rules.txt | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/Documentation/stable_kernel_rules.txt b/Documentation/stable_kernel_rules.txt
|
||||
index 21fd05c..e1f856b 100644
|
||||
--- a/Documentation/stable_kernel_rules.txt
|
||||
+++ b/Documentation/stable_kernel_rules.txt
|
||||
@@ -12,6 +12,12 @@ Rules on what kind of patches are accepted, and which ones are not, into the
|
||||
marked CONFIG_BROKEN), an oops, a hang, data corruption, a real
|
||||
security issue, or some "oh, that's not good" issue. In short, something
|
||||
critical.
|
||||
+ - Serious issues as reported by a user of a distribution kernel may also
|
||||
+ be considered if they fix a notable performance or interactivity issue.
|
||||
+ As these fixes are not as obvious and have a higher risk of a subtle
|
||||
+ regression they should only be submitted by a distribution kernel
|
||||
+ maintainer and include an addendum linking to a bugzilla entry if it
|
||||
+ exists and additional information on the user-visible impact.
|
||||
- New device IDs and quirks are also accepted.
|
||||
- No "theoretical race condition" issues, unless an explanation of how the
|
||||
race can be exploited is also provided.
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,34 @@
|
||||
From 0aab048a80bd01c77244fa5d7e714a1174401ab1 Mon Sep 17 00:00:00 2001
|
||||
From: David Henningsson <david.henningsson@canonical.com>
|
||||
Date: Mon, 25 Jun 2012 19:49:28 +0200
|
||||
Subject: [PATCH 39/46] ALSA: hda - Add Realtek ALC280 codec support
|
||||
|
||||
commit befae82e2906cb7155020876a531b0b8c6c8d8c8 upstream.
|
||||
|
||||
This chip looks very similar to ALC269 and ALC27* variants. The bug reporter
|
||||
has verified that sound was working after this patch had been applied.
|
||||
|
||||
BugLink: https://bugs.launchpad.net/bugs/1017017
|
||||
Tested-by: Richard Crossley <richardcrossley@o2.co.uk>
|
||||
Signed-off-by: David Henningsson <david.henningsson@canonical.com>
|
||||
Signed-off-by: Takashi Iwai <tiwai@suse.de>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
sound/pci/hda/patch_realtek.c | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
|
||||
index 0005bde..5f096a5 100644
|
||||
--- a/sound/pci/hda/patch_realtek.c
|
||||
+++ b/sound/pci/hda/patch_realtek.c
|
||||
@@ -5988,6 +5988,7 @@ static const struct hda_codec_preset snd_hda_preset_realtek[] = {
|
||||
{ .id = 0x10ec0272, .name = "ALC272", .patch = patch_alc662 },
|
||||
{ .id = 0x10ec0275, .name = "ALC275", .patch = patch_alc269 },
|
||||
{ .id = 0x10ec0276, .name = "ALC276", .patch = patch_alc269 },
|
||||
+ { .id = 0x10ec0280, .name = "ALC280", .patch = patch_alc269 },
|
||||
{ .id = 0x10ec0861, .rev = 0x100340, .name = "ALC660",
|
||||
.patch = patch_alc861 },
|
||||
{ .id = 0x10ec0660, .name = "ALC660-VD", .patch = patch_alc861vd },
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,41 @@
|
||||
From 2e5d03393a6928616737edfb24457da88d21102b Mon Sep 17 00:00:00 2001
|
||||
From: Forest Bond <forest.bond@rapidrollout.com>
|
||||
Date: Fri, 22 Jun 2012 10:30:38 -0400
|
||||
Subject: [PATCH 40/46] USB: option: Add USB ID for Novatel Ovation MC551
|
||||
|
||||
commit 065b07e7a14676f4138ce4619d229c0be5a74230 upstream.
|
||||
|
||||
This device is also known as the Verizon USB551L.
|
||||
|
||||
Signed-off-by: Forest Bond <forest.bond@rapidrollout.com>
|
||||
Acked-by: Dan Williams <dcbw@redhat.com>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/usb/serial/option.c | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c
|
||||
index e311711c..21a4734 100644
|
||||
--- a/drivers/usb/serial/option.c
|
||||
+++ b/drivers/usb/serial/option.c
|
||||
@@ -235,6 +235,7 @@ static void option_instat_callback(struct urb *urb);
|
||||
#define NOVATELWIRELESS_PRODUCT_G1 0xA001
|
||||
#define NOVATELWIRELESS_PRODUCT_G1_M 0xA002
|
||||
#define NOVATELWIRELESS_PRODUCT_G2 0xA010
|
||||
+#define NOVATELWIRELESS_PRODUCT_MC551 0xB001
|
||||
|
||||
/* AMOI PRODUCTS */
|
||||
#define AMOI_VENDOR_ID 0x1614
|
||||
@@ -734,6 +735,8 @@ static const struct usb_device_id option_ids[] = {
|
||||
{ USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G1) },
|
||||
{ USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G1_M) },
|
||||
{ USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_G2) },
|
||||
+ /* Novatel Ovation MC551 a.k.a. Verizon USB551L */
|
||||
+ { USB_DEVICE_AND_INTERFACE_INFO(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC551, 0xff, 0xff, 0xff) },
|
||||
|
||||
{ USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01) },
|
||||
{ USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01A) },
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,61 @@
|
||||
From 88093f6173b2c203d31bf67ed055419f5ec21953 Mon Sep 17 00:00:00 2001
|
||||
From: Craig Shelley <craig@microtron.org.uk>
|
||||
Date: Tue, 26 Jun 2012 23:20:04 +0100
|
||||
Subject: [PATCH 41/46] USB: CP210x Add 10 Device IDs
|
||||
|
||||
commit 3fcc8f96829776cf181918461923d1e3bbb831a2 upstream.
|
||||
|
||||
This patch adds 10 device IDs for CP210x based devices from the following manufacturers:
|
||||
Timewave
|
||||
Clipsal
|
||||
Festo
|
||||
Link Instruments
|
||||
|
||||
Signed-off-by: Craig Shelley <craig@microtron.org.uk>
|
||||
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/usb/serial/cp210x.c | 11 +++++++++++
|
||||
1 file changed, 11 insertions(+)
|
||||
|
||||
diff --git a/drivers/usb/serial/cp210x.c b/drivers/usb/serial/cp210x.c
|
||||
index aa0c43f..35e6b5f 100644
|
||||
--- a/drivers/usb/serial/cp210x.c
|
||||
+++ b/drivers/usb/serial/cp210x.c
|
||||
@@ -93,6 +93,7 @@ static const struct usb_device_id id_table[] = {
|
||||
{ USB_DEVICE(0x10C4, 0x814B) }, /* West Mountain Radio RIGtalk */
|
||||
{ USB_DEVICE(0x10C4, 0x8156) }, /* B&G H3000 link cable */
|
||||
{ USB_DEVICE(0x10C4, 0x815E) }, /* Helicomm IP-Link 1220-DVM */
|
||||
+ { USB_DEVICE(0x10C4, 0x815F) }, /* Timewave HamLinkUSB */
|
||||
{ USB_DEVICE(0x10C4, 0x818B) }, /* AVIT Research USB to TTL */
|
||||
{ USB_DEVICE(0x10C4, 0x819F) }, /* MJS USB Toslink Switcher */
|
||||
{ USB_DEVICE(0x10C4, 0x81A6) }, /* ThinkOptics WavIt */
|
||||
@@ -134,7 +135,13 @@ static const struct usb_device_id id_table[] = {
|
||||
{ USB_DEVICE(0x10CE, 0xEA6A) }, /* Silicon Labs MobiData GPRS USB Modem 100EU */
|
||||
{ USB_DEVICE(0x13AD, 0x9999) }, /* Baltech card reader */
|
||||
{ USB_DEVICE(0x1555, 0x0004) }, /* Owen AC4 USB-RS485 Converter */
|
||||
+ { USB_DEVICE(0x166A, 0x0201) }, /* Clipsal 5500PACA C-Bus Pascal Automation Controller */
|
||||
+ { USB_DEVICE(0x166A, 0x0301) }, /* Clipsal 5800PC C-Bus Wireless PC Interface */
|
||||
{ USB_DEVICE(0x166A, 0x0303) }, /* Clipsal 5500PCU C-Bus USB interface */
|
||||
+ { USB_DEVICE(0x166A, 0x0304) }, /* Clipsal 5000CT2 C-Bus Black and White Touchscreen */
|
||||
+ { USB_DEVICE(0x166A, 0x0305) }, /* Clipsal C-5000CT2 C-Bus Spectrum Colour Touchscreen */
|
||||
+ { USB_DEVICE(0x166A, 0x0401) }, /* Clipsal L51xx C-Bus Architectural Dimmer */
|
||||
+ { USB_DEVICE(0x166A, 0x0101) }, /* Clipsal 5560884 C-Bus Multi-room Audio Matrix Switcher */
|
||||
{ USB_DEVICE(0x16D6, 0x0001) }, /* Jablotron serial interface */
|
||||
{ USB_DEVICE(0x16DC, 0x0010) }, /* W-IE-NE-R Plein & Baus GmbH PL512 Power Supply */
|
||||
{ USB_DEVICE(0x16DC, 0x0011) }, /* W-IE-NE-R Plein & Baus GmbH RCM Remote Control for MARATON Power Supply */
|
||||
@@ -146,7 +153,11 @@ static const struct usb_device_id id_table[] = {
|
||||
{ USB_DEVICE(0x1843, 0x0200) }, /* Vaisala USB Instrument Cable */
|
||||
{ USB_DEVICE(0x18EF, 0xE00F) }, /* ELV USB-I2C-Interface */
|
||||
{ USB_DEVICE(0x1BE3, 0x07A6) }, /* WAGO 750-923 USB Service Cable */
|
||||
+ { USB_DEVICE(0x1E29, 0x0102) }, /* Festo CPX-USB */
|
||||
+ { USB_DEVICE(0x1E29, 0x0501) }, /* Festo CMSP */
|
||||
{ USB_DEVICE(0x3195, 0xF190) }, /* Link Instruments MSO-19 */
|
||||
+ { USB_DEVICE(0x3195, 0xF280) }, /* Link Instruments MSO-28 */
|
||||
+ { USB_DEVICE(0x3195, 0xF281) }, /* Link Instruments MSO-28 */
|
||||
{ USB_DEVICE(0x413C, 0x9500) }, /* DW700 GPS USB interface */
|
||||
{ } /* Terminating Entry */
|
||||
};
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,58 @@
|
||||
From 55cebafff1e8327fe9dfa3b66d6f70bf88138902 Mon Sep 17 00:00:00 2001
|
||||
From: Ian Campbell <Ian.Campbell@citrix.com>
|
||||
Date: Mon, 25 Jun 2012 22:48:41 +0000
|
||||
Subject: [PATCH 42/46] xen/netfront: teardown the device before unregistering
|
||||
it.
|
||||
|
||||
commit 6bc96d047fe32d76ef79f3195c52a542edf7c705 upstream.
|
||||
|
||||
Fixes:
|
||||
[ 15.470311] WARNING: at /local/scratch/ianc/devel/kernels/linux/fs/sysfs/file.c:498 sysfs_attr_ns+0x95/0xa0()
|
||||
[ 15.470326] sysfs: kobject eth0 without dirent
|
||||
[ 15.470333] Modules linked in:
|
||||
[ 15.470342] Pid: 12, comm: xenwatch Not tainted 3.4.0-x86_32p-xenU #93
|
||||
and
|
||||
[ 9.150554] BUG: unable to handle kernel paging request at 2b359000
|
||||
[ 9.150577] IP: [<c1279561>] linkwatch_do_dev+0x81/0xc0
|
||||
[ 9.150592] *pdpt = 000000002c3c9027 *pde = 0000000000000000
|
||||
[ 9.150604] Oops: 0002 [#1] SMP
|
||||
[ 9.150613] Modules linked in:
|
||||
|
||||
This is http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=675190
|
||||
|
||||
Reported-by: George Shuklin <george.shuklin@gmail.com>
|
||||
Signed-off-by: Ian Campbell <ian.campbell@citrix.com>
|
||||
Tested-by: William Dauchy <wdauchy@gmail.com>
|
||||
Cc: 675190@bugs.debian.org
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/xen-netfront.c | 8 ++++----
|
||||
1 file changed, 4 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/xen-netfront.c b/drivers/net/xen-netfront.c
|
||||
index 226faab..fc35308 100644
|
||||
--- a/drivers/net/xen-netfront.c
|
||||
+++ b/drivers/net/xen-netfront.c
|
||||
@@ -1922,14 +1922,14 @@ static int __devexit xennet_remove(struct xenbus_device *dev)
|
||||
|
||||
dev_dbg(&dev->dev, "%s\n", dev->nodename);
|
||||
|
||||
- unregister_netdev(info->netdev);
|
||||
-
|
||||
xennet_disconnect_backend(info);
|
||||
|
||||
- del_timer_sync(&info->rx_refill_timer);
|
||||
-
|
||||
xennet_sysfs_delif(info->netdev);
|
||||
|
||||
+ unregister_netdev(info->netdev);
|
||||
+
|
||||
+ del_timer_sync(&info->rx_refill_timer);
|
||||
+
|
||||
free_percpu(info->stats);
|
||||
|
||||
free_netdev(info->netdev);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,44 @@
|
||||
From 06f8253f22e3ba961cc490243917206e2a8a8502 Mon Sep 17 00:00:00 2001
|
||||
From: Hui Wang <jason77.wang@gmail.com>
|
||||
Date: Wed, 27 Jun 2012 16:19:18 +0800
|
||||
Subject: [PATCH 43/46] can: flexcan: use be32_to_cpup to handle the value of
|
||||
dt entry
|
||||
|
||||
commit 85f2f834e85517307f13e30e630a5fc86f757cb5 upstream.
|
||||
|
||||
The freescale arm i.MX series platform can support this driver, and
|
||||
usually the arm cpu works in the little endian mode by default, while
|
||||
device tree entry value is stored in big endian format, we should use
|
||||
be32_to_cpup() to handle them, after modification, it can work well
|
||||
both on the le cpu and be cpu.
|
||||
|
||||
Cc: Shawn Guo <shawn.guo@linaro.org>
|
||||
Signed-off-by: Hui Wang <jason77.wang@gmail.com>
|
||||
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/can/flexcan.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/can/flexcan.c b/drivers/net/can/flexcan.c
|
||||
index e023379..e59d006 100644
|
||||
--- a/drivers/net/can/flexcan.c
|
||||
+++ b/drivers/net/can/flexcan.c
|
||||
@@ -933,12 +933,12 @@ static int __devinit flexcan_probe(struct platform_device *pdev)
|
||||
u32 clock_freq = 0;
|
||||
|
||||
if (pdev->dev.of_node) {
|
||||
- const u32 *clock_freq_p;
|
||||
+ const __be32 *clock_freq_p;
|
||||
|
||||
clock_freq_p = of_get_property(pdev->dev.of_node,
|
||||
"clock-frequency", NULL);
|
||||
if (clock_freq_p)
|
||||
- clock_freq = *clock_freq_p;
|
||||
+ clock_freq = be32_to_cpup(clock_freq_p);
|
||||
}
|
||||
|
||||
if (!clock_freq) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,66 @@
|
||||
From 64a1cb8318eb947d5217e72c7b295a1bda892ecd Mon Sep 17 00:00:00 2001
|
||||
From: Stuart Hayes <Stuart_Hayes@Dell.com>
|
||||
Date: Wed, 13 Jun 2012 16:10:45 -0500
|
||||
Subject: [PATCH 44/46] acpi_pad: fix power_saving thread deadlock
|
||||
|
||||
commit 5f1601261050251a5ca293378b492a69d590dacb upstream.
|
||||
|
||||
The acpi_pad driver can get stuck in destroy_power_saving_task()
|
||||
waiting for kthread_stop() to stop a power_saving thread. The problem
|
||||
is that the isolated_cpus_lock mutex is owned when
|
||||
destroy_power_saving_task() calls kthread_stop(), which waits for a
|
||||
power_saving thread to end, and the power_saving thread tries to
|
||||
acquire the isolated_cpus_lock when it calls round_robin_cpu(). This
|
||||
patch fixes the issue by making round_robin_cpu() use its own mutex.
|
||||
|
||||
https://bugzilla.kernel.org/show_bug.cgi?id=42981
|
||||
|
||||
Signed-off-by: Stuart Hayes <Stuart_Hayes@Dell.com>
|
||||
Signed-off-by: Len Brown <len.brown@intel.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/acpi/acpi_pad.c | 7 ++++---
|
||||
1 file changed, 4 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/drivers/acpi/acpi_pad.c b/drivers/acpi/acpi_pad.c
|
||||
index a43fa1a..1502c502 100644
|
||||
--- a/drivers/acpi/acpi_pad.c
|
||||
+++ b/drivers/acpi/acpi_pad.c
|
||||
@@ -36,6 +36,7 @@
|
||||
#define ACPI_PROCESSOR_AGGREGATOR_DEVICE_NAME "Processor Aggregator"
|
||||
#define ACPI_PROCESSOR_AGGREGATOR_NOTIFY 0x80
|
||||
static DEFINE_MUTEX(isolated_cpus_lock);
|
||||
+static DEFINE_MUTEX(round_robin_lock);
|
||||
|
||||
static unsigned long power_saving_mwait_eax;
|
||||
|
||||
@@ -107,7 +108,7 @@ static void round_robin_cpu(unsigned int tsk_index)
|
||||
if (!alloc_cpumask_var(&tmp, GFP_KERNEL))
|
||||
return;
|
||||
|
||||
- mutex_lock(&isolated_cpus_lock);
|
||||
+ mutex_lock(&round_robin_lock);
|
||||
cpumask_clear(tmp);
|
||||
for_each_cpu(cpu, pad_busy_cpus)
|
||||
cpumask_or(tmp, tmp, topology_thread_cpumask(cpu));
|
||||
@@ -116,7 +117,7 @@ static void round_robin_cpu(unsigned int tsk_index)
|
||||
if (cpumask_empty(tmp))
|
||||
cpumask_andnot(tmp, cpu_online_mask, pad_busy_cpus);
|
||||
if (cpumask_empty(tmp)) {
|
||||
- mutex_unlock(&isolated_cpus_lock);
|
||||
+ mutex_unlock(&round_robin_lock);
|
||||
return;
|
||||
}
|
||||
for_each_cpu(cpu, tmp) {
|
||||
@@ -131,7 +132,7 @@ static void round_robin_cpu(unsigned int tsk_index)
|
||||
tsk_in_cpu[tsk_index] = preferred_cpu;
|
||||
cpumask_set_cpu(preferred_cpu, pad_busy_cpus);
|
||||
cpu_weight[preferred_cpu]++;
|
||||
- mutex_unlock(&isolated_cpus_lock);
|
||||
+ mutex_unlock(&round_robin_lock);
|
||||
|
||||
set_cpus_allowed_ptr(current, cpumask_of(preferred_cpu));
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,55 @@
|
||||
From b3f045e43695ea8ac7c43715d0c98d58d488683d Mon Sep 17 00:00:00 2001
|
||||
From: Marek Lindner <lindner_marek@yahoo.de>
|
||||
Date: Wed, 20 Jun 2012 17:16:05 +0200
|
||||
Subject: [PATCH 45/46] batman-adv: only drop packets of known wifi clients
|
||||
|
||||
commit 5870adc68fc39d81089f1e80efdf64b97e5c37a1 upstream.
|
||||
|
||||
bug introduced with 59b699cdee039d75915c354da06937102d1f9a84
|
||||
|
||||
If the source or destination mac address of an ethernet packet
|
||||
could not be found in the translation table the packet was
|
||||
dropped if AP isolation was turned on. This behavior would
|
||||
make it impossible to send broadcast packets over the mesh as
|
||||
the broadcast address will never enter the translation table.
|
||||
|
||||
Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
|
||||
Acked-by: Antonio Quartulli <ordex@autistici.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/batman-adv/translation-table.c | 8 ++++----
|
||||
1 file changed, 4 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/net/batman-adv/translation-table.c b/net/batman-adv/translation-table.c
|
||||
index 5f09a57..088af45 100644
|
||||
--- a/net/batman-adv/translation-table.c
|
||||
+++ b/net/batman-adv/translation-table.c
|
||||
@@ -1816,10 +1816,10 @@ bool is_ap_isolated(struct bat_priv *bat_priv, uint8_t *src, uint8_t *dst)
|
||||
{
|
||||
struct tt_local_entry *tt_local_entry = NULL;
|
||||
struct tt_global_entry *tt_global_entry = NULL;
|
||||
- bool ret = true;
|
||||
+ bool ret = false;
|
||||
|
||||
if (!atomic_read(&bat_priv->ap_isolation))
|
||||
- return false;
|
||||
+ goto out;
|
||||
|
||||
tt_local_entry = tt_local_hash_find(bat_priv, dst);
|
||||
if (!tt_local_entry)
|
||||
@@ -1829,10 +1829,10 @@ bool is_ap_isolated(struct bat_priv *bat_priv, uint8_t *src, uint8_t *dst)
|
||||
if (!tt_global_entry)
|
||||
goto out;
|
||||
|
||||
- if (_is_ap_isolated(tt_local_entry, tt_global_entry))
|
||||
+ if (!_is_ap_isolated(tt_local_entry, tt_global_entry))
|
||||
goto out;
|
||||
|
||||
- ret = false;
|
||||
+ ret = true;
|
||||
|
||||
out:
|
||||
if (tt_global_entry)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,24 @@
|
||||
From 453efabb6ea10cbe4a726e9637b76991f39d3655 Mon Sep 17 00:00:00 2001
|
||||
From: Ben Hutchings <ben@decadent.org.uk>
|
||||
Date: Wed, 4 Jul 2012 05:44:35 +0100
|
||||
Subject: [PATCH 46/46] Linux 3.2.22
|
||||
|
||||
---
|
||||
Makefile | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/Makefile b/Makefile
|
||||
index 7eb465e..9a7d921 100644
|
||||
--- a/Makefile
|
||||
+++ b/Makefile
|
||||
@@ -1,6 +1,6 @@
|
||||
VERSION = 3
|
||||
PATCHLEVEL = 2
|
||||
-SUBLEVEL = 21
|
||||
+SUBLEVEL = 22
|
||||
EXTRAVERSION =
|
||||
NAME = Saber-toothed Squirrel
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,298 @@
|
||||
From e02d361ade75d22d28ce36460954b4bc6439fc74 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Tue, 12 Jun 2012 15:24:40 +0200
|
||||
Subject: [PATCH 01/49] splice: fix racy pipe->buffers uses
|
||||
|
||||
commit 047fe3605235888f3ebcda0c728cb31937eadfe6 upstream.
|
||||
|
||||
Dave Jones reported a kernel BUG at mm/slub.c:3474! triggered
|
||||
by splice_shrink_spd() called from vmsplice_to_pipe()
|
||||
|
||||
commit 35f3d14dbbc5 (pipe: add support for shrinking and growing pipes)
|
||||
added capability to adjust pipe->buffers.
|
||||
|
||||
Problem is some paths don't hold pipe mutex and assume pipe->buffers
|
||||
doesn't change for their duration.
|
||||
|
||||
Fix this by adding nr_pages_max field in struct splice_pipe_desc, and
|
||||
use it in place of pipe->buffers where appropriate.
|
||||
|
||||
splice_shrink_spd() loses its struct pipe_inode_info argument.
|
||||
|
||||
Reported-by: Dave Jones <davej@redhat.com>
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Cc: Jens Axboe <axboe@kernel.dk>
|
||||
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
|
||||
Cc: Tom Herbert <therbert@google.com>
|
||||
Tested-by: Dave Jones <davej@redhat.com>
|
||||
Signed-off-by: Jens Axboe <axboe@kernel.dk>
|
||||
[bwh: Backported to 3.2:
|
||||
- Adjust context in vmsplice_to_pipe()
|
||||
- Update one more call to splice_shrink_spd(), from skb_splice_bits()]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/splice.c | 35 ++++++++++++++++++++---------------
|
||||
include/linux/splice.h | 8 ++++----
|
||||
kernel/relay.c | 5 +++--
|
||||
kernel/trace/trace.c | 6 ++++--
|
||||
mm/shmem.c | 3 ++-
|
||||
net/core/skbuff.c | 3 ++-
|
||||
6 files changed, 35 insertions(+), 25 deletions(-)
|
||||
|
||||
diff --git a/fs/splice.c b/fs/splice.c
|
||||
index 6d0dfb8..014fcb4 100644
|
||||
--- a/fs/splice.c
|
||||
+++ b/fs/splice.c
|
||||
@@ -274,13 +274,16 @@ void spd_release_page(struct splice_pipe_desc *spd, unsigned int i)
|
||||
* Check if we need to grow the arrays holding pages and partial page
|
||||
* descriptions.
|
||||
*/
|
||||
-int splice_grow_spd(struct pipe_inode_info *pipe, struct splice_pipe_desc *spd)
|
||||
+int splice_grow_spd(const struct pipe_inode_info *pipe, struct splice_pipe_desc *spd)
|
||||
{
|
||||
- if (pipe->buffers <= PIPE_DEF_BUFFERS)
|
||||
+ unsigned int buffers = ACCESS_ONCE(pipe->buffers);
|
||||
+
|
||||
+ spd->nr_pages_max = buffers;
|
||||
+ if (buffers <= PIPE_DEF_BUFFERS)
|
||||
return 0;
|
||||
|
||||
- spd->pages = kmalloc(pipe->buffers * sizeof(struct page *), GFP_KERNEL);
|
||||
- spd->partial = kmalloc(pipe->buffers * sizeof(struct partial_page), GFP_KERNEL);
|
||||
+ spd->pages = kmalloc(buffers * sizeof(struct page *), GFP_KERNEL);
|
||||
+ spd->partial = kmalloc(buffers * sizeof(struct partial_page), GFP_KERNEL);
|
||||
|
||||
if (spd->pages && spd->partial)
|
||||
return 0;
|
||||
@@ -290,10 +293,9 @@ int splice_grow_spd(struct pipe_inode_info *pipe, struct splice_pipe_desc *spd)
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
-void splice_shrink_spd(struct pipe_inode_info *pipe,
|
||||
- struct splice_pipe_desc *spd)
|
||||
+void splice_shrink_spd(struct splice_pipe_desc *spd)
|
||||
{
|
||||
- if (pipe->buffers <= PIPE_DEF_BUFFERS)
|
||||
+ if (spd->nr_pages_max <= PIPE_DEF_BUFFERS)
|
||||
return;
|
||||
|
||||
kfree(spd->pages);
|
||||
@@ -316,6 +318,7 @@ __generic_file_splice_read(struct file *in, loff_t *ppos,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.partial = partial,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &page_cache_pipe_buf_ops,
|
||||
.spd_release = spd_release_page,
|
||||
@@ -327,7 +330,7 @@ __generic_file_splice_read(struct file *in, loff_t *ppos,
|
||||
index = *ppos >> PAGE_CACHE_SHIFT;
|
||||
loff = *ppos & ~PAGE_CACHE_MASK;
|
||||
req_pages = (len + loff + PAGE_CACHE_SIZE - 1) >> PAGE_CACHE_SHIFT;
|
||||
- nr_pages = min(req_pages, pipe->buffers);
|
||||
+ nr_pages = min(req_pages, spd.nr_pages_max);
|
||||
|
||||
/*
|
||||
* Lookup the (hopefully) full range of pages we need.
|
||||
@@ -498,7 +501,7 @@ fill_it:
|
||||
if (spd.nr_pages)
|
||||
error = splice_to_pipe(pipe, &spd);
|
||||
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
return error;
|
||||
}
|
||||
|
||||
@@ -599,6 +602,7 @@ ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.partial = partial,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &default_pipe_buf_ops,
|
||||
.spd_release = spd_release_page,
|
||||
@@ -609,8 +613,8 @@ ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
|
||||
|
||||
res = -ENOMEM;
|
||||
vec = __vec;
|
||||
- if (pipe->buffers > PIPE_DEF_BUFFERS) {
|
||||
- vec = kmalloc(pipe->buffers * sizeof(struct iovec), GFP_KERNEL);
|
||||
+ if (spd.nr_pages_max > PIPE_DEF_BUFFERS) {
|
||||
+ vec = kmalloc(spd.nr_pages_max * sizeof(struct iovec), GFP_KERNEL);
|
||||
if (!vec)
|
||||
goto shrink_ret;
|
||||
}
|
||||
@@ -618,7 +622,7 @@ ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
|
||||
offset = *ppos & ~PAGE_CACHE_MASK;
|
||||
nr_pages = (len + offset + PAGE_CACHE_SIZE - 1) >> PAGE_CACHE_SHIFT;
|
||||
|
||||
- for (i = 0; i < nr_pages && i < pipe->buffers && len; i++) {
|
||||
+ for (i = 0; i < nr_pages && i < spd.nr_pages_max && len; i++) {
|
||||
struct page *page;
|
||||
|
||||
page = alloc_page(GFP_USER);
|
||||
@@ -666,7 +670,7 @@ ssize_t default_file_splice_read(struct file *in, loff_t *ppos,
|
||||
shrink_ret:
|
||||
if (vec != __vec)
|
||||
kfree(vec);
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
return res;
|
||||
|
||||
err:
|
||||
@@ -1616,6 +1620,7 @@ static long vmsplice_to_pipe(struct file *file, const struct iovec __user *iov,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.partial = partial,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &user_page_pipe_buf_ops,
|
||||
.spd_release = spd_release_page,
|
||||
@@ -1631,13 +1636,13 @@ static long vmsplice_to_pipe(struct file *file, const struct iovec __user *iov,
|
||||
|
||||
spd.nr_pages = get_iovec_page_array(iov, nr_segs, spd.pages,
|
||||
spd.partial, flags & SPLICE_F_GIFT,
|
||||
- pipe->buffers);
|
||||
+ spd.nr_pages_max);
|
||||
if (spd.nr_pages <= 0)
|
||||
ret = spd.nr_pages;
|
||||
else
|
||||
ret = splice_to_pipe(pipe, &spd);
|
||||
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
return ret;
|
||||
}
|
||||
|
||||
diff --git a/include/linux/splice.h b/include/linux/splice.h
|
||||
index 26e5b61..09a545a 100644
|
||||
--- a/include/linux/splice.h
|
||||
+++ b/include/linux/splice.h
|
||||
@@ -51,7 +51,8 @@ struct partial_page {
|
||||
struct splice_pipe_desc {
|
||||
struct page **pages; /* page map */
|
||||
struct partial_page *partial; /* pages[] may not be contig */
|
||||
- int nr_pages; /* number of pages in map */
|
||||
+ int nr_pages; /* number of populated pages in map */
|
||||
+ unsigned int nr_pages_max; /* pages[] & partial[] arrays size */
|
||||
unsigned int flags; /* splice flags */
|
||||
const struct pipe_buf_operations *ops;/* ops associated with output pipe */
|
||||
void (*spd_release)(struct splice_pipe_desc *, unsigned int);
|
||||
@@ -85,9 +86,8 @@ extern ssize_t splice_direct_to_actor(struct file *, struct splice_desc *,
|
||||
/*
|
||||
* for dynamic pipe sizing
|
||||
*/
|
||||
-extern int splice_grow_spd(struct pipe_inode_info *, struct splice_pipe_desc *);
|
||||
-extern void splice_shrink_spd(struct pipe_inode_info *,
|
||||
- struct splice_pipe_desc *);
|
||||
+extern int splice_grow_spd(const struct pipe_inode_info *, struct splice_pipe_desc *);
|
||||
+extern void splice_shrink_spd(struct splice_pipe_desc *);
|
||||
extern void spd_release_page(struct splice_pipe_desc *, unsigned int);
|
||||
|
||||
extern const struct pipe_buf_operations page_cache_pipe_buf_ops;
|
||||
diff --git a/kernel/relay.c b/kernel/relay.c
|
||||
index b6f803a..a535fc9 100644
|
||||
--- a/kernel/relay.c
|
||||
+++ b/kernel/relay.c
|
||||
@@ -1235,6 +1235,7 @@ static ssize_t subbuf_splice_actor(struct file *in,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.nr_pages = 0,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.partial = partial,
|
||||
.flags = flags,
|
||||
.ops = &relay_pipe_buf_ops,
|
||||
@@ -1302,8 +1303,8 @@ static ssize_t subbuf_splice_actor(struct file *in,
|
||||
ret += padding;
|
||||
|
||||
out:
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
- return ret;
|
||||
+ splice_shrink_spd(&spd);
|
||||
+ return ret;
|
||||
}
|
||||
|
||||
static ssize_t relay_file_splice_read(struct file *in,
|
||||
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
|
||||
index 697e49d..7e4edd3 100644
|
||||
--- a/kernel/trace/trace.c
|
||||
+++ b/kernel/trace/trace.c
|
||||
@@ -3456,6 +3456,7 @@ static ssize_t tracing_splice_read_pipe(struct file *filp,
|
||||
.pages = pages_def,
|
||||
.partial = partial_def,
|
||||
.nr_pages = 0, /* This gets updated below. */
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &tracing_pipe_buf_ops,
|
||||
.spd_release = tracing_spd_release_pipe,
|
||||
@@ -3527,7 +3528,7 @@ static ssize_t tracing_splice_read_pipe(struct file *filp,
|
||||
|
||||
ret = splice_to_pipe(pipe, &spd);
|
||||
out:
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
return ret;
|
||||
|
||||
out_err:
|
||||
@@ -4017,6 +4018,7 @@ tracing_buffers_splice_read(struct file *file, loff_t *ppos,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages_def,
|
||||
.partial = partial_def,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &buffer_pipe_buf_ops,
|
||||
.spd_release = buffer_spd_release,
|
||||
@@ -4104,7 +4106,7 @@ tracing_buffers_splice_read(struct file *file, loff_t *ppos,
|
||||
}
|
||||
|
||||
ret = splice_to_pipe(pipe, &spd);
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
out:
|
||||
return ret;
|
||||
}
|
||||
diff --git a/mm/shmem.c b/mm/shmem.c
|
||||
index 6c253f7..7a82174 100644
|
||||
--- a/mm/shmem.c
|
||||
+++ b/mm/shmem.c
|
||||
@@ -1359,6 +1359,7 @@ static ssize_t shmem_file_splice_read(struct file *in, loff_t *ppos,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.partial = partial,
|
||||
+ .nr_pages_max = PIPE_DEF_BUFFERS,
|
||||
.flags = flags,
|
||||
.ops = &page_cache_pipe_buf_ops,
|
||||
.spd_release = spd_release_page,
|
||||
@@ -1447,7 +1448,7 @@ static ssize_t shmem_file_splice_read(struct file *in, loff_t *ppos,
|
||||
if (spd.nr_pages)
|
||||
error = splice_to_pipe(pipe, &spd);
|
||||
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
|
||||
if (error > 0) {
|
||||
*ppos += error;
|
||||
diff --git a/net/core/skbuff.c b/net/core/skbuff.c
|
||||
index 2ec200de..af9c3c6 100644
|
||||
--- a/net/core/skbuff.c
|
||||
+++ b/net/core/skbuff.c
|
||||
@@ -1663,6 +1663,7 @@ int skb_splice_bits(struct sk_buff *skb, unsigned int offset,
|
||||
struct splice_pipe_desc spd = {
|
||||
.pages = pages,
|
||||
.partial = partial,
|
||||
+ .nr_pages_max = MAX_SKB_FRAGS,
|
||||
.flags = flags,
|
||||
.ops = &sock_pipe_buf_ops,
|
||||
.spd_release = sock_spd_release,
|
||||
@@ -1709,7 +1710,7 @@ done:
|
||||
lock_sock(sk);
|
||||
}
|
||||
|
||||
- splice_shrink_spd(pipe, &spd);
|
||||
+ splice_shrink_spd(&spd);
|
||||
return ret;
|
||||
}
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,86 @@
|
||||
From fd0fcfd8f28824587f180ccde95c03fca533ab05 Mon Sep 17 00:00:00 2001
|
||||
From: Tao Guo <glorioustao@gmail.com>
|
||||
Date: Wed, 13 Jun 2012 21:17:21 +0200
|
||||
Subject: [PATCH 02/49] umem: fix up unplugging
|
||||
|
||||
commit 32587371ad3db2f9d335de10dbd8cffd4fff5669 upstream.
|
||||
|
||||
Fix a regression introduced by 7eaceaccab5f40 ("block: remove per-queue
|
||||
plugging"). In that patch, Jens removed the whole mm_unplug_device()
|
||||
function, which used to be the trigger to make umem start to work.
|
||||
|
||||
We need to implement unplugging to make umem start to work, or I/O will
|
||||
never be triggered.
|
||||
|
||||
Signed-off-by: Tao Guo <Tao.Guo@emc.com>
|
||||
Cc: Neil Brown <neilb@suse.de>
|
||||
Cc: Jens Axboe <axboe@kernel.dk>
|
||||
Cc: Shaohua Li <shli@kernel.org>
|
||||
Acked-by: NeilBrown <neilb@suse.de>
|
||||
Signed-off-by: Jens Axboe <axboe@kernel.dk>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/block/umem.c | 40 ++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 40 insertions(+)
|
||||
|
||||
diff --git a/drivers/block/umem.c b/drivers/block/umem.c
|
||||
index aa27120..9a72277 100644
|
||||
--- a/drivers/block/umem.c
|
||||
+++ b/drivers/block/umem.c
|
||||
@@ -513,6 +513,44 @@ static void process_page(unsigned long data)
|
||||
}
|
||||
}
|
||||
|
||||
+struct mm_plug_cb {
|
||||
+ struct blk_plug_cb cb;
|
||||
+ struct cardinfo *card;
|
||||
+};
|
||||
+
|
||||
+static void mm_unplug(struct blk_plug_cb *cb)
|
||||
+{
|
||||
+ struct mm_plug_cb *mmcb = container_of(cb, struct mm_plug_cb, cb);
|
||||
+
|
||||
+ spin_lock_irq(&mmcb->card->lock);
|
||||
+ activate(mmcb->card);
|
||||
+ spin_unlock_irq(&mmcb->card->lock);
|
||||
+ kfree(mmcb);
|
||||
+}
|
||||
+
|
||||
+static int mm_check_plugged(struct cardinfo *card)
|
||||
+{
|
||||
+ struct blk_plug *plug = current->plug;
|
||||
+ struct mm_plug_cb *mmcb;
|
||||
+
|
||||
+ if (!plug)
|
||||
+ return 0;
|
||||
+
|
||||
+ list_for_each_entry(mmcb, &plug->cb_list, cb.list) {
|
||||
+ if (mmcb->cb.callback == mm_unplug && mmcb->card == card)
|
||||
+ return 1;
|
||||
+ }
|
||||
+ /* Not currently on the callback list */
|
||||
+ mmcb = kmalloc(sizeof(*mmcb), GFP_ATOMIC);
|
||||
+ if (!mmcb)
|
||||
+ return 0;
|
||||
+
|
||||
+ mmcb->card = card;
|
||||
+ mmcb->cb.callback = mm_unplug;
|
||||
+ list_add(&mmcb->cb.list, &plug->cb_list);
|
||||
+ return 1;
|
||||
+}
|
||||
+
|
||||
static void mm_make_request(struct request_queue *q, struct bio *bio)
|
||||
{
|
||||
struct cardinfo *card = q->queuedata;
|
||||
@@ -523,6 +561,8 @@ static void mm_make_request(struct request_queue *q, struct bio *bio)
|
||||
*card->biotail = bio;
|
||||
bio->bi_next = NULL;
|
||||
card->biotail = &bio->bi_next;
|
||||
+ if (bio->bi_rw & REQ_SYNC || !mm_check_plugged(card))
|
||||
+ activate(card);
|
||||
spin_unlock_irq(&card->lock);
|
||||
|
||||
return;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,88 @@
|
||||
From 8c92af27a522bcec5dc2ced7b49b8f3f57492b21 Mon Sep 17 00:00:00 2001
|
||||
From: Stone Piao <piaoyun@marvell.com>
|
||||
Date: Wed, 20 Jun 2012 20:21:10 -0700
|
||||
Subject: [PATCH 03/49] mwifiex: fix 11n rx packet drop issue
|
||||
|
||||
commit 925839243dc9aa4ef25305f5afd10ed18258a4ac upstream.
|
||||
|
||||
Currently we check the sequence number of last packet received
|
||||
against start_win. If a sequence hole is detected, start_win is
|
||||
updated to next sequence number.
|
||||
|
||||
Since the rx sequence number is initialized to 0, a corner case
|
||||
exists when BA setup happens immediately after association. As
|
||||
0 is a valid sequence number, start_win gets increased to 1
|
||||
incorrectly. This causes the first packet with sequence number 0
|
||||
being dropped.
|
||||
|
||||
Initialize rx sequence number as 0xffff and skip adjusting
|
||||
start_win if the sequence number remains 0xffff. The sequence
|
||||
number will be updated once the first packet is received.
|
||||
|
||||
Signed-off-by: Stone Piao <piaoyun@marvell.com>
|
||||
Signed-off-by: Avinash Patil <patila@marvell.com>
|
||||
Signed-off-by: Kiran Divekar <dkiran@marvell.com>
|
||||
Signed-off-by: Bing Zhao <bzhao@marvell.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/mwifiex/11n_rxreorder.c | 5 +++--
|
||||
drivers/net/wireless/mwifiex/11n_rxreorder.h | 7 +++++++
|
||||
drivers/net/wireless/mwifiex/wmm.c | 2 ++
|
||||
3 files changed, 12 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/mwifiex/11n_rxreorder.c b/drivers/net/wireless/mwifiex/11n_rxreorder.c
|
||||
index 7aa9aa0..39fd4d5 100644
|
||||
--- a/drivers/net/wireless/mwifiex/11n_rxreorder.c
|
||||
+++ b/drivers/net/wireless/mwifiex/11n_rxreorder.c
|
||||
@@ -267,7 +267,8 @@ mwifiex_11n_create_rx_reorder_tbl(struct mwifiex_private *priv, u8 *ta,
|
||||
else
|
||||
last_seq = priv->rx_seq[tid];
|
||||
|
||||
- if (last_seq >= new_node->start_win)
|
||||
+ if (last_seq != MWIFIEX_DEF_11N_RX_SEQ_NUM &&
|
||||
+ last_seq >= new_node->start_win)
|
||||
new_node->start_win = last_seq + 1;
|
||||
|
||||
new_node->win_size = win_size;
|
||||
@@ -611,5 +612,5 @@ void mwifiex_11n_cleanup_reorder_tbl(struct mwifiex_private *priv)
|
||||
spin_unlock_irqrestore(&priv->rx_reorder_tbl_lock, flags);
|
||||
|
||||
INIT_LIST_HEAD(&priv->rx_reorder_tbl_ptr);
|
||||
- memset(priv->rx_seq, 0, sizeof(priv->rx_seq));
|
||||
+ mwifiex_reset_11n_rx_seq_num(priv);
|
||||
}
|
||||
diff --git a/drivers/net/wireless/mwifiex/11n_rxreorder.h b/drivers/net/wireless/mwifiex/11n_rxreorder.h
|
||||
index 033c8ad..7128baa 100644
|
||||
--- a/drivers/net/wireless/mwifiex/11n_rxreorder.h
|
||||
+++ b/drivers/net/wireless/mwifiex/11n_rxreorder.h
|
||||
@@ -37,6 +37,13 @@
|
||||
|
||||
#define ADDBA_RSP_STATUS_ACCEPT 0
|
||||
|
||||
+#define MWIFIEX_DEF_11N_RX_SEQ_NUM 0xffff
|
||||
+
|
||||
+static inline void mwifiex_reset_11n_rx_seq_num(struct mwifiex_private *priv)
|
||||
+{
|
||||
+ memset(priv->rx_seq, 0xff, sizeof(priv->rx_seq));
|
||||
+}
|
||||
+
|
||||
int mwifiex_11n_rx_reorder_pkt(struct mwifiex_private *,
|
||||
u16 seqNum,
|
||||
u16 tid, u8 *ta,
|
||||
diff --git a/drivers/net/wireless/mwifiex/wmm.c b/drivers/net/wireless/mwifiex/wmm.c
|
||||
index 6c239c3..b94a349 100644
|
||||
--- a/drivers/net/wireless/mwifiex/wmm.c
|
||||
+++ b/drivers/net/wireless/mwifiex/wmm.c
|
||||
@@ -406,6 +406,8 @@ mwifiex_wmm_init(struct mwifiex_adapter *adapter)
|
||||
priv->add_ba_param.tx_win_size = MWIFIEX_AMPDU_DEF_TXWINSIZE;
|
||||
priv->add_ba_param.rx_win_size = MWIFIEX_AMPDU_DEF_RXWINSIZE;
|
||||
|
||||
+ mwifiex_reset_11n_rx_seq_num(priv);
|
||||
+
|
||||
atomic_set(&priv->wmm.tx_pkts_queued, 0);
|
||||
atomic_set(&priv->wmm.highest_queued_prio, HIGH_PRIO_TID);
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,52 @@
|
||||
From ea7217bde3c1bbcb215d3b67a4308399ac1d574c Mon Sep 17 00:00:00 2001
|
||||
From: Stone Piao <piaoyun@marvell.com>
|
||||
Date: Wed, 20 Jun 2012 20:21:11 -0700
|
||||
Subject: [PATCH 04/49] mwifiex: fix WPS eapol handshake failure
|
||||
|
||||
commit f03ba7e9a24e5e9efaad56bd1713b994ea556b16 upstream.
|
||||
|
||||
After association, STA will go through eapol handshake with WPS
|
||||
enabled AP. It's observed that WPS handshake fails with some 11n
|
||||
AP. The reason for the failure is that the eapol packet is sent
|
||||
via 11n frame aggregation.
|
||||
|
||||
The eapol packet should be sent directly without 11n aggregation.
|
||||
|
||||
This patch fixes the problem by adding WPS session control while
|
||||
dequeuing Tx packets for transmission.
|
||||
|
||||
Signed-off-by: Stone Piao <piaoyun@marvell.com>
|
||||
Signed-off-by: Avinash Patil <patila@marvell.com>
|
||||
Signed-off-by: Bing Zhao <bzhao@marvell.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
[bwh: Backported to 3.2: reformat the if-statement per earlier
|
||||
upstream commit c65a30f35f938b421ac67c34a9e70b0e49e6019a]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/mwifiex/wmm.c | 10 ++++++----
|
||||
1 file changed, 6 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/mwifiex/wmm.c b/drivers/net/wireless/mwifiex/wmm.c
|
||||
index b94a349..06fcf1e 100644
|
||||
--- a/drivers/net/wireless/mwifiex/wmm.c
|
||||
+++ b/drivers/net/wireless/mwifiex/wmm.c
|
||||
@@ -1211,10 +1211,12 @@ mwifiex_dequeue_tx_packet(struct mwifiex_adapter *adapter)
|
||||
return 0;
|
||||
}
|
||||
|
||||
- if (!ptr->is_11n_enabled || mwifiex_is_ba_stream_setup(priv, ptr, tid)
|
||||
- || ((priv->sec_info.wpa_enabled
|
||||
- || priv->sec_info.wpa2_enabled) && !priv->wpa_is_gtk_set)
|
||||
- ) {
|
||||
+ if (!ptr->is_11n_enabled ||
|
||||
+ mwifiex_is_ba_stream_setup(priv, ptr, tid) ||
|
||||
+ priv->wps.session_enable ||
|
||||
+ ((priv->sec_info.wpa_enabled ||
|
||||
+ priv->sec_info.wpa2_enabled) &&
|
||||
+ !priv->wpa_is_gtk_set)) {
|
||||
mwifiex_send_single_packet(priv, ptr, ptr_index, flags);
|
||||
/* ra_list_spinlock has been freed in
|
||||
mwifiex_send_single_packet() */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,52 @@
|
||||
From e7d858dec1d8cf3c283019ff51adae14b8be9388 Mon Sep 17 00:00:00 2001
|
||||
From: Dan Rosenberg <dan.j.rosenberg@gmail.com>
|
||||
Date: Mon, 25 Jun 2012 16:05:27 +0200
|
||||
Subject: [PATCH 05/49] NFC: Prevent multiple buffer overflows in NCI
|
||||
|
||||
commit 67de956ff5dc1d4f321e16cfbd63f5be3b691b43 upstream.
|
||||
|
||||
Fix multiple remotely-exploitable stack-based buffer overflows due to
|
||||
the NCI code pulling length fields directly from incoming frames and
|
||||
copying too much data into statically-sized arrays.
|
||||
|
||||
Signed-off-by: Dan Rosenberg <dan.j.rosenberg@gmail.com>
|
||||
Cc: security@kernel.org
|
||||
Cc: Lauro Ramos Venancio <lauro.venancio@openbossa.org>
|
||||
Cc: Aloisio Almeida Jr <aloisio.almeida@openbossa.org>
|
||||
Cc: Samuel Ortiz <sameo@linux.intel.com>
|
||||
Cc: David S. Miller <davem@davemloft.net>
|
||||
Acked-by: Ilan Elias <ilane@ti.com>
|
||||
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
|
||||
[bwh: Backported to 3.2:
|
||||
- Drop changes to parsing of tech B and tech F parameters
|
||||
- Various renaming]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/nfc/nci/ntf.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/net/nfc/nci/ntf.c b/net/nfc/nci/ntf.c
|
||||
index 96633f5..12b6a80 100644
|
||||
--- a/net/nfc/nci/ntf.c
|
||||
+++ b/net/nfc/nci/ntf.c
|
||||
@@ -86,7 +86,7 @@ static int nci_rf_activate_nfca_passive_poll(struct nci_dev *ndev,
|
||||
nfca_poll->sens_res = __le16_to_cpu(*((__u16 *)data));
|
||||
data += 2;
|
||||
|
||||
- nfca_poll->nfcid1_len = *data++;
|
||||
+ nfca_poll->nfcid1_len = min_t(__u8, *data++, sizeof(nfca_poll->nfcid1));
|
||||
|
||||
nfc_dbg("sens_res 0x%x, nfcid1_len %d",
|
||||
nfca_poll->sens_res,
|
||||
@@ -111,7 +111,7 @@ static int nci_rf_activate_nfca_passive_poll(struct nci_dev *ndev,
|
||||
|
||||
switch (ntf->rf_interface_type) {
|
||||
case NCI_RF_INTERFACE_ISO_DEP:
|
||||
- nfca_poll_iso_dep->rats_res_len = *data++;
|
||||
+ nfca_poll_iso_dep->rats_res_len = min_t(__u8, *data++, 20);
|
||||
if (nfca_poll_iso_dep->rats_res_len > 0) {
|
||||
memcpy(nfca_poll_iso_dep->rats_res,
|
||||
data,
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,80 @@
|
||||
From 11f5e090b288e9e933c8b7790626db9a5beef760 Mon Sep 17 00:00:00 2001
|
||||
From: Felix Fietkau <nbd@openwrt.org>
|
||||
Date: Sat, 23 Jun 2012 19:23:31 +0200
|
||||
Subject: [PATCH 06/49] ath9k: fix dynamic WEP related regression
|
||||
|
||||
commit bed3d9c0b71f9afbfec905cb6db3b9f16be29d4d upstream.
|
||||
|
||||
commit 7a532fe7131216a02c81a6c1b1f8632da1195a58
|
||||
ath9k_hw: fix interpretation of the rx KeyMiss flag
|
||||
|
||||
This commit used the rx key miss indication to detect packets that were
|
||||
passed from the hardware without being decrypted, however it seems that
|
||||
this bit is not only undefined in the static WEP case, but also for
|
||||
dynamically allocated WEP keys. This caused a regression when using
|
||||
WEP-LEAP.
|
||||
|
||||
This patch fixes the regression by keeping track of which key indexes
|
||||
refer to CCMP keys and only using the key miss indication for those.
|
||||
|
||||
Reported-by: Stanislaw Gruszka <sgruszka@redhat.com>
|
||||
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath.h | 1 +
|
||||
drivers/net/wireless/ath/ath9k/recv.c | 3 ++-
|
||||
drivers/net/wireless/ath/key.c | 4 ++++
|
||||
3 files changed, 7 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath.h b/drivers/net/wireless/ath/ath.h
|
||||
index 0f9ee46..4cc4a8b 100644
|
||||
--- a/drivers/net/wireless/ath/ath.h
|
||||
+++ b/drivers/net/wireless/ath/ath.h
|
||||
@@ -143,6 +143,7 @@ struct ath_common {
|
||||
u32 keymax;
|
||||
DECLARE_BITMAP(keymap, ATH_KEYMAX);
|
||||
DECLARE_BITMAP(tkip_keymap, ATH_KEYMAX);
|
||||
+ DECLARE_BITMAP(ccmp_keymap, ATH_KEYMAX);
|
||||
enum ath_crypt_caps crypt_caps;
|
||||
|
||||
unsigned int clockrate;
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/recv.c b/drivers/net/wireless/ath/ath9k/recv.c
|
||||
index 2f3aeac..e6d791c 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/recv.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/recv.c
|
||||
@@ -829,7 +829,8 @@ static bool ath9k_rx_accept(struct ath_common *common,
|
||||
* descriptor does contain a valid key index. This has been observed
|
||||
* mostly with CCMP encryption.
|
||||
*/
|
||||
- if (rx_stats->rs_keyix == ATH9K_RXKEYIX_INVALID)
|
||||
+ if (rx_stats->rs_keyix == ATH9K_RXKEYIX_INVALID ||
|
||||
+ !test_bit(rx_stats->rs_keyix, common->ccmp_keymap))
|
||||
rx_stats->rs_status &= ~ATH9K_RXERR_KEYMISS;
|
||||
|
||||
if (!rx_stats->rs_datalen)
|
||||
diff --git a/drivers/net/wireless/ath/key.c b/drivers/net/wireless/ath/key.c
|
||||
index 4cf7c5e..1ec3fa5 100644
|
||||
--- a/drivers/net/wireless/ath/key.c
|
||||
+++ b/drivers/net/wireless/ath/key.c
|
||||
@@ -556,6 +556,9 @@ int ath_key_config(struct ath_common *common,
|
||||
return -EIO;
|
||||
|
||||
set_bit(idx, common->keymap);
|
||||
+ if (key->cipher == WLAN_CIPHER_SUITE_CCMP)
|
||||
+ set_bit(idx, common->ccmp_keymap);
|
||||
+
|
||||
if (key->cipher == WLAN_CIPHER_SUITE_TKIP) {
|
||||
set_bit(idx + 64, common->keymap);
|
||||
set_bit(idx, common->tkip_keymap);
|
||||
@@ -582,6 +585,7 @@ void ath_key_delete(struct ath_common *common, struct ieee80211_key_conf *key)
|
||||
return;
|
||||
|
||||
clear_bit(key->hw_key_idx, common->keymap);
|
||||
+ clear_bit(key->hw_key_idx, common->ccmp_keymap);
|
||||
if (key->cipher != WLAN_CIPHER_SUITE_TKIP)
|
||||
return;
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,107 @@
|
||||
From fd1f8dc4e31b8daeec0cb785256de7297a06e300 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Tue, 12 Jun 2012 00:47:58 +0200
|
||||
Subject: [PATCH 07/49] NFC: Return from rawsock_release when sk is NULL
|
||||
|
||||
commit 03e934f620101ca2cfc9383bd76172dd3e1f8567 upstream.
|
||||
|
||||
Sasha Levin reported following panic :
|
||||
|
||||
[ 2136.383310] BUG: unable to handle kernel NULL pointer dereference at
|
||||
00000000000003b0
|
||||
[ 2136.384022] IP: [<ffffffff8114e400>] __lock_acquire+0xc0/0x4b0
|
||||
[ 2136.384022] PGD 131c4067 PUD 11c0c067 PMD 0
|
||||
[ 2136.388106] Oops: 0000 [#1] PREEMPT SMP DEBUG_PAGEALLOC
|
||||
[ 2136.388106] CPU 1
|
||||
[ 2136.388106] Pid: 24855, comm: trinity-child1 Tainted: G W
|
||||
3.5.0-rc2-sasha-00015-g7b268f7 #374
|
||||
[ 2136.388106] RIP: 0010:[<ffffffff8114e400>] [<ffffffff8114e400>]
|
||||
__lock_acquire+0xc0/0x4b0
|
||||
[ 2136.388106] RSP: 0018:ffff8800130b3ca8 EFLAGS: 00010046
|
||||
[ 2136.388106] RAX: 0000000000000086 RBX: ffff88001186b000 RCX:
|
||||
0000000000000000
|
||||
[ 2136.388106] RDX: 0000000000000000 RSI: 0000000000000000 RDI:
|
||||
0000000000000000
|
||||
[ 2136.388106] RBP: ffff8800130b3d08 R08: 0000000000000001 R09:
|
||||
0000000000000000
|
||||
[ 2136.388106] R10: 0000000000000000 R11: 0000000000000001 R12:
|
||||
0000000000000002
|
||||
[ 2136.388106] R13: 00000000000003b0 R14: 0000000000000000 R15:
|
||||
0000000000000000
|
||||
[ 2136.388106] FS: 00007fa5b1bd4700(0000) GS:ffff88001b800000(0000)
|
||||
knlGS:0000000000000000
|
||||
[ 2136.388106] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
|
||||
[ 2136.388106] CR2: 00000000000003b0 CR3: 0000000011d1f000 CR4:
|
||||
00000000000406e0
|
||||
[ 2136.388106] DR0: 0000000000000000 DR1: 0000000000000000 DR2:
|
||||
0000000000000000
|
||||
[ 2136.388106] DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7:
|
||||
0000000000000400
|
||||
[ 2136.388106] Process trinity-child1 (pid: 24855, threadinfo
|
||||
ffff8800130b2000, task ffff88001186b000)
|
||||
[ 2136.388106] Stack:
|
||||
[ 2136.388106] ffff8800130b3cd8 ffffffff81121785 ffffffff81236774
|
||||
000080d000000001
|
||||
[ 2136.388106] ffff88001b9d6c00 00000000001d6c00 ffffffff130b3d08
|
||||
ffff88001186b000
|
||||
[ 2136.388106] 0000000000000000 0000000000000002 0000000000000000
|
||||
0000000000000000
|
||||
[ 2136.388106] Call Trace:
|
||||
[ 2136.388106] [<ffffffff81121785>] ? sched_clock_local+0x25/0x90
|
||||
[ 2136.388106] [<ffffffff81236774>] ? get_empty_filp+0x74/0x220
|
||||
[ 2136.388106] [<ffffffff8114e97a>] lock_acquire+0x18a/0x1e0
|
||||
[ 2136.388106] [<ffffffff836b37df>] ? rawsock_release+0x4f/0xa0
|
||||
[ 2136.388106] [<ffffffff837c0ef0>] _raw_write_lock_bh+0x40/0x80
|
||||
[ 2136.388106] [<ffffffff836b37df>] ? rawsock_release+0x4f/0xa0
|
||||
[ 2136.388106] [<ffffffff836b37df>] rawsock_release+0x4f/0xa0
|
||||
[ 2136.388106] [<ffffffff8321cfe8>] sock_release+0x18/0x70
|
||||
[ 2136.388106] [<ffffffff8321d069>] sock_close+0x29/0x30
|
||||
[ 2136.388106] [<ffffffff81236bca>] __fput+0x11a/0x2c0
|
||||
[ 2136.388106] [<ffffffff81236d85>] fput+0x15/0x20
|
||||
[ 2136.388106] [<ffffffff8321de34>] sys_accept4+0x1b4/0x200
|
||||
[ 2136.388106] [<ffffffff837c165c>] ? _raw_spin_unlock_irq+0x4c/0x80
|
||||
[ 2136.388106] [<ffffffff837c1669>] ? _raw_spin_unlock_irq+0x59/0x80
|
||||
[ 2136.388106] [<ffffffff837c2565>] ? sysret_check+0x22/0x5d
|
||||
[ 2136.388106] [<ffffffff8321de8b>] sys_accept+0xb/0x10
|
||||
[ 2136.388106] [<ffffffff837c2539>] system_call_fastpath+0x16/0x1b
|
||||
[ 2136.388106] Code: ec 04 00 0f 85 ea 03 00 00 be d5 0b 00 00 48 c7 c7
|
||||
8a c1 40 84 e8 b1 a5 f8 ff 31 c0 e9 d4 03 00 00 66 2e 0f 1f 84 00 00 00
|
||||
00 00 <49> 81 7d 00 60 73 5e 85 b8 01 00 00 00 44 0f 44 e0 83 fe 01 77
|
||||
[ 2136.388106] RIP [<ffffffff8114e400>] __lock_acquire+0xc0/0x4b0
|
||||
[ 2136.388106] RSP <ffff8800130b3ca8>
|
||||
[ 2136.388106] CR2: 00000000000003b0
|
||||
[ 2136.388106] ---[ end trace 6d450e935ee18982 ]---
|
||||
[ 2136.388106] Kernel panic - not syncing: Fatal exception in interrupt
|
||||
|
||||
rawsock_release() should test if sock->sk is NULL before calling
|
||||
sock_orphan()/sock_put()
|
||||
|
||||
Reported-by: Sasha Levin <levinsasha928@gmail.com>
|
||||
Tested-by: Sasha Levin <levinsasha928@gmail.com>
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
|
||||
[bwh: Backported to 3.2: keep using nfc_dbg(), not pr_debug()]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/nfc/rawsock.c | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/net/nfc/rawsock.c b/net/nfc/rawsock.c
|
||||
index ee7b2b3..7a167fc 100644
|
||||
--- a/net/nfc/rawsock.c
|
||||
+++ b/net/nfc/rawsock.c
|
||||
@@ -52,7 +52,10 @@ static int rawsock_release(struct socket *sock)
|
||||
{
|
||||
struct sock *sk = sock->sk;
|
||||
|
||||
- nfc_dbg("sock=%p", sock);
|
||||
+ nfc_dbg("sock=%p sk=%p", sock, sk);
|
||||
+
|
||||
+ if (!sk)
|
||||
+ return 0;
|
||||
|
||||
sock_orphan(sk);
|
||||
sock_put(sk);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,45 @@
|
||||
From a771eb7b20c60a73ec422943dd387fbca27cf94d Mon Sep 17 00:00:00 2001
|
||||
From: Larry Finger <Larry.Finger@lwfinger.net>
|
||||
Date: Mon, 25 Jun 2012 18:01:12 -0500
|
||||
Subject: [PATCH 08/49] rtlwifi: rtl8192cu: New USB IDs
|
||||
|
||||
commit f63d7dabd5da9ef41f28f6d69b29bc084db0ca5a upstream.
|
||||
|
||||
The latest Realtek driver for the RTL8188CU and RTL8192CU chips adds three
|
||||
new USB IDs.
|
||||
|
||||
Reported-by: Xose Vazquez Perez <xose.vazquez@gmail.com>
|
||||
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/rtlwifi/rtl8192cu/sw.c | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c b/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c
|
||||
index 94a3e17..0302148 100644
|
||||
--- a/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c
|
||||
+++ b/drivers/net/wireless/rtlwifi/rtl8192cu/sw.c
|
||||
@@ -311,9 +311,11 @@ static struct usb_device_id rtl8192c_usb_ids[] = {
|
||||
{RTL_USB_DEVICE(0x07b8, 0x8188, rtl92cu_hal_cfg)}, /*Abocom - Abocom*/
|
||||
{RTL_USB_DEVICE(0x07b8, 0x8189, rtl92cu_hal_cfg)}, /*Funai - Abocom*/
|
||||
{RTL_USB_DEVICE(0x0846, 0x9041, rtl92cu_hal_cfg)}, /*NetGear WNA1000M*/
|
||||
+ {RTL_USB_DEVICE(0x0bda, 0x5088, rtl92cu_hal_cfg)}, /*Thinkware-CC&C*/
|
||||
{RTL_USB_DEVICE(0x0df6, 0x0052, rtl92cu_hal_cfg)}, /*Sitecom - Edimax*/
|
||||
{RTL_USB_DEVICE(0x0df6, 0x005c, rtl92cu_hal_cfg)}, /*Sitecom - Edimax*/
|
||||
{RTL_USB_DEVICE(0x0eb0, 0x9071, rtl92cu_hal_cfg)}, /*NO Brand - Etop*/
|
||||
+ {RTL_USB_DEVICE(0x4856, 0x0091, rtl92cu_hal_cfg)}, /*NetweeN - Feixun*/
|
||||
/* HP - Lite-On ,8188CUS Slim Combo */
|
||||
{RTL_USB_DEVICE(0x103c, 0x1629, rtl92cu_hal_cfg)},
|
||||
{RTL_USB_DEVICE(0x13d3, 0x3357, rtl92cu_hal_cfg)}, /* AzureWave */
|
||||
@@ -355,6 +357,7 @@ static struct usb_device_id rtl8192c_usb_ids[] = {
|
||||
{RTL_USB_DEVICE(0x07b8, 0x8178, rtl92cu_hal_cfg)}, /*Funai -Abocom*/
|
||||
{RTL_USB_DEVICE(0x0846, 0x9021, rtl92cu_hal_cfg)}, /*Netgear-Sercomm*/
|
||||
{RTL_USB_DEVICE(0x0b05, 0x17ab, rtl92cu_hal_cfg)}, /*ASUS-Edimax*/
|
||||
+ {RTL_USB_DEVICE(0x0bda, 0x8186, rtl92cu_hal_cfg)}, /*Realtek 92CE-VAU*/
|
||||
{RTL_USB_DEVICE(0x0df6, 0x0061, rtl92cu_hal_cfg)}, /*Sitecom-Edimax*/
|
||||
{RTL_USB_DEVICE(0x0e66, 0x0019, rtl92cu_hal_cfg)}, /*Hawking-Edimax*/
|
||||
{RTL_USB_DEVICE(0x2001, 0x3307, rtl92cu_hal_cfg)}, /*D-Link-Cameo*/
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,34 @@
|
||||
From f65b74252f667d75391a86a6dee82aefb0e9b983 Mon Sep 17 00:00:00 2001
|
||||
From: Panayiotis Karabassis <panayk@gmail.com>
|
||||
Date: Tue, 26 Jun 2012 23:37:17 +0300
|
||||
Subject: [PATCH 09/49] ath9k: enable serialize_regmode for non-PCIE AR9287
|
||||
|
||||
commit 7508b657967cf664b5aa0f6367d05016e7e3bc2a upstream.
|
||||
|
||||
https://bugzilla.kernel.org/show_bug.cgi?id=42903
|
||||
|
||||
Based on the work of <fynivx@gmail.com>
|
||||
|
||||
Signed-off-by: Panayiotis Karabassis <panayk@gmail.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/ath/ath9k/hw.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
|
||||
index 6973620..7f97164 100644
|
||||
--- a/drivers/net/wireless/ath/ath9k/hw.c
|
||||
+++ b/drivers/net/wireless/ath/ath9k/hw.c
|
||||
@@ -557,7 +557,7 @@ static int __ath9k_hw_init(struct ath_hw *ah)
|
||||
|
||||
if (ah->config.serialize_regmode == SER_REG_MODE_AUTO) {
|
||||
if (ah->hw_version.macVersion == AR_SREV_VERSION_5416_PCI ||
|
||||
- ((AR_SREV_9160(ah) || AR_SREV_9280(ah)) &&
|
||||
+ ((AR_SREV_9160(ah) || AR_SREV_9280(ah) || AR_SREV_9287(ah)) &&
|
||||
!ah->is_pciexpress)) {
|
||||
ah->config.serialize_regmode =
|
||||
SER_REG_MODE_ON;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,48 @@
|
||||
From 21cdc703702f7ffbf440dc29b68044ac13363078 Mon Sep 17 00:00:00 2001
|
||||
From: Johannes Berg <johannes.berg@intel.com>
|
||||
Date: Wed, 27 Jun 2012 15:38:56 +0200
|
||||
Subject: [PATCH 10/49] mac80211: correct behaviour on unrecognised action
|
||||
frames
|
||||
|
||||
commit 4b5ebccc40843104d980f0714bc86bfcd5568941 upstream.
|
||||
|
||||
When receiving an "individually addressed" action frame, the
|
||||
receiver is required to return it to the sender. mac80211
|
||||
gets this wrong as it also returns group addressed (mcast)
|
||||
frames to the sender. Fix this and update the reference to
|
||||
the new 802.11 standards version since things were shuffled
|
||||
around significantly.
|
||||
|
||||
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/mac80211/rx.c | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
|
||||
index 064d20f..cda4875 100644
|
||||
--- a/net/mac80211/rx.c
|
||||
+++ b/net/mac80211/rx.c
|
||||
@@ -2389,7 +2389,7 @@ ieee80211_rx_h_action_return(struct ieee80211_rx_data *rx)
|
||||
* frames that we didn't handle, including returning unknown
|
||||
* ones. For all other modes we will return them to the sender,
|
||||
* setting the 0x80 bit in the action category, as required by
|
||||
- * 802.11-2007 7.3.1.11.
|
||||
+ * 802.11-2012 9.24.4.
|
||||
* Newer versions of hostapd shall also use the management frame
|
||||
* registration mechanisms, but older ones still use cooked
|
||||
* monitor interfaces so push all frames there.
|
||||
@@ -2399,6 +2399,9 @@ ieee80211_rx_h_action_return(struct ieee80211_rx_data *rx)
|
||||
sdata->vif.type == NL80211_IFTYPE_AP_VLAN))
|
||||
return RX_DROP_MONITOR;
|
||||
|
||||
+ if (is_multicast_ether_addr(mgmt->da))
|
||||
+ return RX_DROP_MONITOR;
|
||||
+
|
||||
/* do not return rejected action frames */
|
||||
if (mgmt->u.action.category & 0x80)
|
||||
return RX_DROP_UNUSABLE;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,62 @@
|
||||
From 8ba42ffb182648185f9f5f924d26cf97b6be721f Mon Sep 17 00:00:00 2001
|
||||
From: "Hebbar, Gururaja" <gururaja.hebbar@ti.com>
|
||||
Date: Tue, 26 Jun 2012 19:25:11 +0530
|
||||
Subject: [PATCH 11/49] ASoC: tlv320aic3x: Fix codec pll configure bug
|
||||
|
||||
commit c9fe573a6584034670c1a55ee8162d623519cbbf upstream.
|
||||
|
||||
In sound/soc/codecs/tlv320aic3x.c
|
||||
|
||||
data = snd_soc_read(codec, AIC3X_PLL_PROGA_REG);
|
||||
snd_soc_write(codec, AIC3X_PLL_PROGA_REG,
|
||||
data | (pll_p << PLLP_SHIFT));
|
||||
|
||||
In the above code, pll-p value is OR'ed with previous value without
|
||||
clearing it. Bug is not seen if pll-p value doesn't change across
|
||||
Sampling frequency.
|
||||
|
||||
However on some platforms (like AM335x EVM-SK), pll-p may have different
|
||||
values across different sampling frequencies. In such case, above code
|
||||
configures the pll with a wrong value.
|
||||
Because of this bug, when a audio stream is played with pll value
|
||||
different from previous stream, audio is heard as differently(like its
|
||||
stretched).
|
||||
|
||||
Signed-off-by: Hebbar, Gururaja <gururaja.hebbar@ti.com>
|
||||
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
sound/soc/codecs/tlv320aic3x.c | 4 +---
|
||||
sound/soc/codecs/tlv320aic3x.h | 1 +
|
||||
2 files changed, 2 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sound/soc/codecs/tlv320aic3x.c b/sound/soc/codecs/tlv320aic3x.c
|
||||
index d0dbac1..cdb473c 100644
|
||||
--- a/sound/soc/codecs/tlv320aic3x.c
|
||||
+++ b/sound/soc/codecs/tlv320aic3x.c
|
||||
@@ -963,9 +963,7 @@ static int aic3x_hw_params(struct snd_pcm_substream *substream,
|
||||
}
|
||||
|
||||
found:
|
||||
- data = snd_soc_read(codec, AIC3X_PLL_PROGA_REG);
|
||||
- snd_soc_write(codec, AIC3X_PLL_PROGA_REG,
|
||||
- data | (pll_p << PLLP_SHIFT));
|
||||
+ snd_soc_update_bits(codec, AIC3X_PLL_PROGA_REG, PLLP_MASK, pll_p);
|
||||
snd_soc_write(codec, AIC3X_OVRF_STATUS_AND_PLLR_REG,
|
||||
pll_r << PLLR_SHIFT);
|
||||
snd_soc_write(codec, AIC3X_PLL_PROGB_REG, pll_j << PLLJ_SHIFT);
|
||||
diff --git a/sound/soc/codecs/tlv320aic3x.h b/sound/soc/codecs/tlv320aic3x.h
|
||||
index 06a1978..16d9999 100644
|
||||
--- a/sound/soc/codecs/tlv320aic3x.h
|
||||
+++ b/sound/soc/codecs/tlv320aic3x.h
|
||||
@@ -166,6 +166,7 @@
|
||||
|
||||
/* PLL registers bitfields */
|
||||
#define PLLP_SHIFT 0
|
||||
+#define PLLP_MASK 7
|
||||
#define PLLQ_SHIFT 3
|
||||
#define PLLR_SHIFT 0
|
||||
#define PLLJ_SHIFT 2
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
From 6d7506b0391c86ac347dce94f2c4642ce126cf45 Mon Sep 17 00:00:00 2001
|
||||
From: Anton Blanchard <anton@samba.org>
|
||||
Date: Thu, 28 Jun 2012 19:28:57 +0000
|
||||
Subject: [PATCH 12/49] powerpc/xmon: Use cpumask iterator to avoid warning
|
||||
|
||||
commit bc1d7702910c7c7e88eb60b58429dbfe293683ce upstream.
|
||||
|
||||
We have a bug report where the kernel hits a warning in the cpumask
|
||||
code:
|
||||
|
||||
WARNING: at include/linux/cpumask.h:107
|
||||
|
||||
Which is:
|
||||
WARN_ON_ONCE(cpu >= nr_cpumask_bits);
|
||||
|
||||
The backtrace is:
|
||||
cpu_cmd
|
||||
cmds
|
||||
xmon_core
|
||||
xmon
|
||||
die
|
||||
|
||||
xmon is iterating through 0 to NR_CPUS. I'm not sure why we are still
|
||||
open coding this but iterating above nr_cpu_ids is definitely a bug.
|
||||
|
||||
This patch iterates through all possible cpus, in case we issue a
|
||||
system reset and CPUs in an offline state call in.
|
||||
|
||||
Perhaps the old code was trying to handle CPUs that were in the
|
||||
partition but were never started (eg kexec into a kernel with an
|
||||
nr_cpus= boot option). They are going to die way before we get into
|
||||
xmon since we haven't set any kernel state up for them.
|
||||
|
||||
Signed-off-by: Anton Blanchard <anton@samba.org>
|
||||
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/powerpc/xmon/xmon.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/arch/powerpc/xmon/xmon.c b/arch/powerpc/xmon/xmon.c
|
||||
index 03a217a..b7e63d8 100644
|
||||
--- a/arch/powerpc/xmon/xmon.c
|
||||
+++ b/arch/powerpc/xmon/xmon.c
|
||||
@@ -975,7 +975,7 @@ static int cpu_cmd(void)
|
||||
/* print cpus waiting or in xmon */
|
||||
printf("cpus stopped:");
|
||||
count = 0;
|
||||
- for (cpu = 0; cpu < NR_CPUS; ++cpu) {
|
||||
+ for_each_possible_cpu(cpu) {
|
||||
if (cpumask_test_cpu(cpu, &cpus_in_xmon)) {
|
||||
if (count == 0)
|
||||
printf(" %x", cpu);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,40 @@
|
||||
From af803001738a2e5609dbbe767f8f7a61bef3cf9c Mon Sep 17 00:00:00 2001
|
||||
From: Michael Neuling <mikey@neuling.org>
|
||||
Date: Mon, 25 Jun 2012 13:33:11 +0000
|
||||
Subject: [PATCH 13/49] powerpc/kvm: sldi should be sld
|
||||
|
||||
commit 2f584a146a2965b82fce89b8d2f95dc5cfe468d0 upstream.
|
||||
|
||||
Since we are taking a registers, this should never have been an sldi.
|
||||
Talking to paulus offline, this is the correct fix.
|
||||
|
||||
Was introduced by:
|
||||
commit 19ccb76a1938ab364a412253daec64613acbf3df
|
||||
Author: Paul Mackerras <paulus@samba.org>
|
||||
Date: Sat Jul 23 17:42:46 2011 +1000
|
||||
|
||||
Talking to paulus, this shouldn't be a literal.
|
||||
|
||||
Signed-off-by: Michael Neuling <mikey@neuling.org>
|
||||
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/powerpc/kvm/book3s_hv_rmhandlers.S | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/arch/powerpc/kvm/book3s_hv_rmhandlers.S b/arch/powerpc/kvm/book3s_hv_rmhandlers.S
|
||||
index 44d8829..5e8dc08 100644
|
||||
--- a/arch/powerpc/kvm/book3s_hv_rmhandlers.S
|
||||
+++ b/arch/powerpc/kvm/book3s_hv_rmhandlers.S
|
||||
@@ -763,7 +763,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_ARCH_201)
|
||||
lwz r3,VCORE_NAPPING_THREADS(r5)
|
||||
lwz r4,VCPU_PTID(r9)
|
||||
li r0,1
|
||||
- sldi r0,r0,r4
|
||||
+ sld r0,r0,r4
|
||||
andc. r3,r3,r0 /* no sense IPI'ing ourselves */
|
||||
beq 43f
|
||||
mulli r4,r4,PACA_SIZE /* get paca for thread 0 */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,50 @@
|
||||
From 8002ce8e1b7a0ef6b60567ed63ed12fe6780b98a Mon Sep 17 00:00:00 2001
|
||||
From: NeilBrown <neilb@suse.de>
|
||||
Date: Tue, 3 Jul 2012 10:37:30 +1000
|
||||
Subject: [PATCH 14/49] md/raid10: Don't try to recovery unmatched (and
|
||||
unused) chunks.
|
||||
|
||||
commit fc448a18ae6219af9a73257b1fbcd009efab4a81 upstream.
|
||||
|
||||
If a RAID10 has an odd number of chunks - as might happen when there
|
||||
are an odd number of devices - the last chunk has no pair and so is
|
||||
not mirrored. We don't store data there, but when recovering the last
|
||||
device in an array we retry to recover that last chunk from a
|
||||
non-existent location. This results in an error, and the recovery
|
||||
aborts.
|
||||
|
||||
When we get to that last chunk we should just stop - there is nothing
|
||||
more to do anyway.
|
||||
|
||||
This bug has been present since the introduction of RAID10, so the
|
||||
patch is appropriate for any -stable kernel.
|
||||
|
||||
Reported-by: Christian Balzer <chibi@gol.com>
|
||||
Tested-by: Christian Balzer <chibi@gol.com>
|
||||
Signed-off-by: NeilBrown <neilb@suse.de>
|
||||
[bwh: Backported to 3.2: adjust context]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/raid10.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c
|
||||
index b219449..3b67566 100644
|
||||
--- a/drivers/md/raid10.c
|
||||
+++ b/drivers/md/raid10.c
|
||||
@@ -2436,6 +2436,12 @@ static sector_t sync_request(struct mddev *mddev, sector_t sector_nr,
|
||||
/* want to reconstruct this device */
|
||||
rb2 = r10_bio;
|
||||
sect = raid10_find_virt(conf, sector_nr, i);
|
||||
+ if (sect >= mddev->resync_max_sectors) {
|
||||
+ /* last stripe is not complete - don't
|
||||
+ * try to recover this sector.
|
||||
+ */
|
||||
+ continue;
|
||||
+ }
|
||||
/* Unless we are doing a full sync, we only need
|
||||
* to recover the block if it is set in the bitmap
|
||||
*/
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,54 @@
|
||||
From 2afec61845b4c0bed64c257a0acc2612e1862885 Mon Sep 17 00:00:00 2001
|
||||
From: majianpeng <majianpeng@gmail.com>
|
||||
Date: Tue, 12 Jun 2012 08:31:10 +0800
|
||||
Subject: [PATCH 15/49] md/raid5: Do not add data_offset before call to
|
||||
is_badblock
|
||||
|
||||
commit 6c0544e255dd6582a9899572e120fb55d9f672a4 upstream.
|
||||
|
||||
In chunk_aligned_read() we are adding data_offset before calling
|
||||
is_badblock. But is_badblock also adds data_offset, so that is bad.
|
||||
|
||||
So move the addition of data_offset to after the call to
|
||||
is_badblock.
|
||||
|
||||
This bug was introduced by commit 31c176ecdf3563140e639
|
||||
md/raid5: avoid reading from known bad blocks.
|
||||
which first appeared in 3.0. So that patch is suitable for any
|
||||
-stable kernel from 3.0.y onwards. However it will need minor
|
||||
revision for most of those (as the comment didn't appear until
|
||||
recently).
|
||||
|
||||
Signed-off-by: majianpeng <majianpeng@gmail.com>
|
||||
Signed-off-by: NeilBrown <neilb@suse.de>
|
||||
[bwh: Backported to 3.2: ignored missing comment]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/raid5.c | 4 +++-
|
||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c
|
||||
index 858fdbb..d423c7e 100644
|
||||
--- a/drivers/md/raid5.c
|
||||
+++ b/drivers/md/raid5.c
|
||||
@@ -3621,7 +3621,6 @@ static int chunk_aligned_read(struct mddev *mddev, struct bio * raid_bio)
|
||||
raid_bio->bi_next = (void*)rdev;
|
||||
align_bi->bi_bdev = rdev->bdev;
|
||||
align_bi->bi_flags &= ~(1 << BIO_SEG_VALID);
|
||||
- align_bi->bi_sector += rdev->data_offset;
|
||||
|
||||
if (!bio_fits_rdev(align_bi) ||
|
||||
is_badblock(rdev, align_bi->bi_sector, align_bi->bi_size>>9,
|
||||
@@ -3632,6 +3631,9 @@ static int chunk_aligned_read(struct mddev *mddev, struct bio * raid_bio)
|
||||
return 0;
|
||||
}
|
||||
|
||||
+ /* No reshape active, so we can trust rdev->data_offset */
|
||||
+ align_bi->bi_sector += rdev->data_offset;
|
||||
+
|
||||
spin_lock_irq(&conf->device_lock);
|
||||
wait_event_lock_irq(conf->wait_for_stripe,
|
||||
conf->quiesce == 0,
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,45 @@
|
||||
From 1e6a8f24c1ff905a8bae6dd5222bc128eb60f886 Mon Sep 17 00:00:00 2001
|
||||
From: majianpeng <majianpeng@gmail.com>
|
||||
Date: Tue, 3 Jul 2012 12:11:54 +1000
|
||||
Subject: [PATCH 16/49] md/raid5: In ops_run_io, inc nr_pending before calling
|
||||
md_wait_for_blocked_rdev
|
||||
|
||||
commit 1850753d2e6d9ca7856581ca5d3cf09521e6a5d7 upstream.
|
||||
|
||||
In ops_run_io(), the call to md_wait_for_blocked_rdev will decrement
|
||||
nr_pending so we lose the reference we hold on the rdev.
|
||||
So atomic_inc it first to maintain the reference.
|
||||
|
||||
This bug was introduced by commit 73e92e51b7969ef5477d
|
||||
md/raid5. Don't write to known bad block on doubtful devices.
|
||||
|
||||
which appeared in 3.0, so patch is suitable for stable kernels since
|
||||
then.
|
||||
|
||||
Signed-off-by: majianpeng <majianpeng@gmail.com>
|
||||
Signed-off-by: NeilBrown <neilb@suse.de>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/raid5.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c
|
||||
index d423c7e..6ba4954 100644
|
||||
--- a/drivers/md/raid5.c
|
||||
+++ b/drivers/md/raid5.c
|
||||
@@ -542,6 +542,12 @@ static void ops_run_io(struct stripe_head *sh, struct stripe_head_state *s)
|
||||
* a chance*/
|
||||
md_check_recovery(conf->mddev);
|
||||
}
|
||||
+ /*
|
||||
+ * Because md_wait_for_blocked_rdev
|
||||
+ * will dec nr_pending, we must
|
||||
+ * increment it first.
|
||||
+ */
|
||||
+ atomic_inc(&rdev->nr_pending);
|
||||
md_wait_for_blocked_rdev(rdev, conf->mddev);
|
||||
} else {
|
||||
/* Acknowledged bad block - skip the write */
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,61 @@
|
||||
From 4c1df6ee8b798576a23b25ab391cd7f3b5835bcd Mon Sep 17 00:00:00 2001
|
||||
From: NeilBrown <neilb@suse.de>
|
||||
Date: Tue, 3 Jul 2012 15:55:33 +1000
|
||||
Subject: [PATCH 17/49] md/raid10: fix failure when trying to repair a read
|
||||
error.
|
||||
|
||||
commit 055d3747dbf00ce85c6872ecca4d466638e80c22 upstream.
|
||||
|
||||
commit 58c54fcca3bac5bf9290cfed31c76e4c4bfbabaf
|
||||
md/raid10: handle further errors during fix_read_error better.
|
||||
|
||||
in 3.1 added "r10_sync_page_io" which takes an IO size in sectors.
|
||||
But we were passing the IO size in bytes!!!
|
||||
This resulting in bio_add_page failing, and empty request being sent
|
||||
down, and a consequent BUG_ON in scsi_lib.
|
||||
|
||||
[fix missing space in error message at same time]
|
||||
|
||||
This fix is suitable for 3.1.y and later.
|
||||
|
||||
Reported-by: Christian Balzer <chibi@gol.com>
|
||||
Signed-off-by: NeilBrown <neilb@suse.de>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/raid10.c | 6 +++---
|
||||
1 file changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c
|
||||
index 3b67566..7a9eef6 100644
|
||||
--- a/drivers/md/raid10.c
|
||||
+++ b/drivers/md/raid10.c
|
||||
@@ -1919,7 +1919,7 @@ static void fix_read_error(struct r10conf *conf, struct mddev *mddev, struct r10
|
||||
if (r10_sync_page_io(rdev,
|
||||
r10_bio->devs[sl].addr +
|
||||
sect,
|
||||
- s<<9, conf->tmppage, WRITE)
|
||||
+ s, conf->tmppage, WRITE)
|
||||
== 0) {
|
||||
/* Well, this device is dead */
|
||||
printk(KERN_NOTICE
|
||||
@@ -1956,7 +1956,7 @@ static void fix_read_error(struct r10conf *conf, struct mddev *mddev, struct r10
|
||||
switch (r10_sync_page_io(rdev,
|
||||
r10_bio->devs[sl].addr +
|
||||
sect,
|
||||
- s<<9, conf->tmppage,
|
||||
+ s, conf->tmppage,
|
||||
READ)) {
|
||||
case 0:
|
||||
/* Well, this device is dead */
|
||||
@@ -2119,7 +2119,7 @@ read_more:
|
||||
rdev = conf->mirrors[mirror].rdev;
|
||||
printk_ratelimited(
|
||||
KERN_ERR
|
||||
- "md/raid10:%s: %s: redirecting"
|
||||
+ "md/raid10:%s: %s: redirecting "
|
||||
"sector %llu to another mirror\n",
|
||||
mdname(mddev),
|
||||
bdevname(rdev->bdev, b),
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,118 @@
|
||||
From 3426f0a75320d87b4fd5a63263ff4f1a7574fd90 Mon Sep 17 00:00:00 2001
|
||||
From: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Date: Sun, 1 Jul 2012 17:09:42 +0200
|
||||
Subject: [PATCH 18/49] drm/i915: kick any firmware framebuffers before
|
||||
claiming the gtt
|
||||
|
||||
commit 9f846a16d213523fbe6daea17e20df6b8ac5a1e5 upstream.
|
||||
|
||||
Especially vesafb likes to map everything as uc- (yikes), and if that
|
||||
mapping hangs around still while we try to map the gtt as wc the
|
||||
kernel will downgrade our request to uc-, resulting in abyssal
|
||||
performance.
|
||||
|
||||
Unfortunately we can't do this as early as readon does (i.e. as the
|
||||
first thing we do when initializing the hw) because our fb/mmio space
|
||||
region moves around on a per-gen basis. So I've had to move it below
|
||||
the gtt initialization, but that seems to work, too. The important
|
||||
thing is that we do this before we set up the gtt wc mapping.
|
||||
|
||||
Now an altogether different question is why people compile their
|
||||
kernels with vesafb enabled, but I guess making things just work isn't
|
||||
bad per se ...
|
||||
|
||||
v2:
|
||||
- s/radeondrmfb/inteldrmfb/
|
||||
- fix up error handling
|
||||
|
||||
v3: Kill #ifdef X86, this is Intel after all. Noticed by Ben Widawsky.
|
||||
|
||||
v4: Jani Nikula complained about the pointless bool primary
|
||||
initialization.
|
||||
|
||||
v5: Don't oops if we can't allocate, noticed by Chris Wilson.
|
||||
|
||||
v6: Resolve conflicts with agp rework and fixup whitespace.
|
||||
|
||||
This is commit e188719a2891f01b3100d in drm-next.
|
||||
|
||||
Backport to 3.5 -fixes queue requested by Dave Airlie - due to grub
|
||||
using vesa on fedora their initrd seems to load vesafb before loading
|
||||
the real kms driver. So tons more people actually experience a
|
||||
dead-slow gpu. Hence also the Cc: stable.
|
||||
|
||||
Reported-and-tested-by: "Kilarski, Bernard R" <bernard.r.kilarski@intel.com>
|
||||
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
|
||||
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
|
||||
Signed-off-by: Dave Airlie <airlied@redhat.com>
|
||||
[bwh: Backported to 3.2: adjust context]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/gpu/drm/i915/i915_dma.c | 37 ++++++++++++++++++++++++++++++-------
|
||||
1 file changed, 30 insertions(+), 7 deletions(-)
|
||||
|
||||
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
|
||||
index c4da951..ca67338 100644
|
||||
--- a/drivers/gpu/drm/i915/i915_dma.c
|
||||
+++ b/drivers/gpu/drm/i915/i915_dma.c
|
||||
@@ -1890,6 +1890,27 @@ ips_ping_for_i915_load(void)
|
||||
}
|
||||
}
|
||||
|
||||
+static void i915_kick_out_firmware_fb(struct drm_i915_private *dev_priv)
|
||||
+{
|
||||
+ struct apertures_struct *ap;
|
||||
+ struct pci_dev *pdev = dev_priv->dev->pdev;
|
||||
+ bool primary;
|
||||
+
|
||||
+ ap = alloc_apertures(1);
|
||||
+ if (!ap)
|
||||
+ return;
|
||||
+
|
||||
+ ap->ranges[0].base = dev_priv->dev->agp->base;
|
||||
+ ap->ranges[0].size =
|
||||
+ dev_priv->mm.gtt->gtt_mappable_entries << PAGE_SHIFT;
|
||||
+ primary =
|
||||
+ pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW;
|
||||
+
|
||||
+ remove_conflicting_framebuffers(ap, "inteldrmfb", primary);
|
||||
+
|
||||
+ kfree(ap);
|
||||
+}
|
||||
+
|
||||
/**
|
||||
* i915_driver_load - setup chip and create an initial config
|
||||
* @dev: DRM device
|
||||
@@ -1927,6 +1948,15 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
|
||||
goto free_priv;
|
||||
}
|
||||
|
||||
+ dev_priv->mm.gtt = intel_gtt_get();
|
||||
+ if (!dev_priv->mm.gtt) {
|
||||
+ DRM_ERROR("Failed to initialize GTT\n");
|
||||
+ ret = -ENODEV;
|
||||
+ goto put_bridge;
|
||||
+ }
|
||||
+
|
||||
+ i915_kick_out_firmware_fb(dev_priv);
|
||||
+
|
||||
/* overlay on gen2 is broken and can't address above 1G */
|
||||
if (IS_GEN2(dev))
|
||||
dma_set_coherent_mask(&dev->pdev->dev, DMA_BIT_MASK(30));
|
||||
@@ -1950,13 +1980,6 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
|
||||
goto put_bridge;
|
||||
}
|
||||
|
||||
- dev_priv->mm.gtt = intel_gtt_get();
|
||||
- if (!dev_priv->mm.gtt) {
|
||||
- DRM_ERROR("Failed to initialize GTT\n");
|
||||
- ret = -ENODEV;
|
||||
- goto out_rmmap;
|
||||
- }
|
||||
-
|
||||
agp_size = dev_priv->mm.gtt->gtt_mappable_entries << PAGE_SHIFT;
|
||||
|
||||
dev_priv->mm.gtt_mapping =
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,37 @@
|
||||
From 97bbf28874e2f7467c0d05db53041e556488087a Mon Sep 17 00:00:00 2001
|
||||
From: Mike Snitzer <snitzer@redhat.com>
|
||||
Date: Tue, 3 Jul 2012 12:55:33 +0100
|
||||
Subject: [PATCH 19/49] dm persistent data: fix shadow_info_leak on
|
||||
dm_tm_destroy
|
||||
|
||||
commit 25d7cd6faa7ae6ed2565617c3ee2500ccb8a9f7f upstream.
|
||||
|
||||
Cleanup the shadow table before destroying the transaction manager.
|
||||
|
||||
Reference: leak was identified with kmemleak when running
|
||||
test_discard_random_sectors in the thinp-test-suite.
|
||||
|
||||
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
|
||||
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/persistent-data/dm-transaction-manager.c | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/drivers/md/persistent-data/dm-transaction-manager.c b/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
index 6f8d387..e5902d1 100644
|
||||
--- a/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
+++ b/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
@@ -138,6 +138,9 @@ EXPORT_SYMBOL_GPL(dm_tm_create_non_blocking_clone);
|
||||
|
||||
void dm_tm_destroy(struct dm_transaction_manager *tm)
|
||||
{
|
||||
+ if (!tm->is_clone)
|
||||
+ wipe_shadow_table(tm);
|
||||
+
|
||||
kfree(tm);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(dm_tm_destroy);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,182 @@
|
||||
From 5ac62b535b410eb5bfbb5457703fd42f5b517088 Mon Sep 17 00:00:00 2001
|
||||
From: Mike Snitzer <snitzer@redhat.com>
|
||||
Date: Tue, 3 Jul 2012 12:55:35 +0100
|
||||
Subject: [PATCH 20/49] dm persistent data: handle space map checker creation
|
||||
failure
|
||||
|
||||
commit 62662303e7f590fdfbb0070ab820a0ad4267c119 upstream.
|
||||
|
||||
If CONFIG_DM_DEBUG_SPACE_MAPS is enabled and dm_sm_checker_create()
|
||||
fails, dm_tm_create_internal() would still return success even though it
|
||||
cleaned up all resources it was supposed to have created. This will
|
||||
lead to a kernel crash:
|
||||
|
||||
general protection fault: 0000 [#1] SMP DEBUG_PAGEALLOC
|
||||
...
|
||||
RIP: 0010:[<ffffffff81593659>] [<ffffffff81593659>] dm_bufio_get_block_size+0x9/0x20
|
||||
Call Trace:
|
||||
[<ffffffff81599bae>] dm_bm_block_size+0xe/0x10
|
||||
[<ffffffff8159b8b8>] sm_ll_init+0x78/0xd0
|
||||
[<ffffffff8159c1a6>] sm_ll_new_disk+0x16/0xa0
|
||||
[<ffffffff8159c98e>] dm_sm_disk_create+0xfe/0x160
|
||||
[<ffffffff815abf6e>] dm_pool_metadata_open+0x16e/0x6a0
|
||||
[<ffffffff815aa010>] pool_ctr+0x3f0/0x900
|
||||
[<ffffffff8158d565>] dm_table_add_target+0x195/0x450
|
||||
[<ffffffff815904c4>] table_load+0xe4/0x330
|
||||
[<ffffffff815917ea>] ctl_ioctl+0x15a/0x2c0
|
||||
[<ffffffff81591963>] dm_ctl_ioctl+0x13/0x20
|
||||
[<ffffffff8116a4f8>] do_vfs_ioctl+0x98/0x560
|
||||
[<ffffffff8116aa51>] sys_ioctl+0x91/0xa0
|
||||
[<ffffffff81869f52>] system_call_fastpath+0x16/0x1b
|
||||
|
||||
Fix the space map checker code to return an appropriate ERR_PTR and have
|
||||
dm_sm_disk_create() and dm_tm_create_internal() check for it with
|
||||
IS_ERR.
|
||||
|
||||
Reported-by: Vivek Goyal <vgoyal@redhat.com>
|
||||
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
|
||||
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/persistent-data/dm-space-map-checker.c | 24 ++++++++++----------
|
||||
drivers/md/persistent-data/dm-space-map-disk.c | 11 ++++++++-
|
||||
.../md/persistent-data/dm-transaction-manager.c | 8 +++++--
|
||||
3 files changed, 28 insertions(+), 15 deletions(-)
|
||||
|
||||
diff --git a/drivers/md/persistent-data/dm-space-map-checker.c b/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
index 50ed53b..6d7c832 100644
|
||||
--- a/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
+++ b/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
@@ -343,25 +343,25 @@ struct dm_space_map *dm_sm_checker_create(struct dm_space_map *sm)
|
||||
int r;
|
||||
struct sm_checker *smc;
|
||||
|
||||
- if (!sm)
|
||||
- return NULL;
|
||||
+ if (IS_ERR_OR_NULL(sm))
|
||||
+ return ERR_PTR(-EINVAL);
|
||||
|
||||
smc = kmalloc(sizeof(*smc), GFP_KERNEL);
|
||||
if (!smc)
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-ENOMEM);
|
||||
|
||||
memcpy(&smc->sm, &ops_, sizeof(smc->sm));
|
||||
r = ca_create(&smc->old_counts, sm);
|
||||
if (r) {
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
r = ca_create(&smc->counts, sm);
|
||||
if (r) {
|
||||
ca_destroy(&smc->old_counts);
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
smc->real_sm = sm;
|
||||
@@ -371,7 +371,7 @@ struct dm_space_map *dm_sm_checker_create(struct dm_space_map *sm)
|
||||
ca_destroy(&smc->counts);
|
||||
ca_destroy(&smc->old_counts);
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
r = ca_commit(&smc->old_counts, &smc->counts);
|
||||
@@ -379,7 +379,7 @@ struct dm_space_map *dm_sm_checker_create(struct dm_space_map *sm)
|
||||
ca_destroy(&smc->counts);
|
||||
ca_destroy(&smc->old_counts);
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
return &smc->sm;
|
||||
@@ -391,25 +391,25 @@ struct dm_space_map *dm_sm_checker_create_fresh(struct dm_space_map *sm)
|
||||
int r;
|
||||
struct sm_checker *smc;
|
||||
|
||||
- if (!sm)
|
||||
- return NULL;
|
||||
+ if (IS_ERR_OR_NULL(sm))
|
||||
+ return ERR_PTR(-EINVAL);
|
||||
|
||||
smc = kmalloc(sizeof(*smc), GFP_KERNEL);
|
||||
if (!smc)
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-ENOMEM);
|
||||
|
||||
memcpy(&smc->sm, &ops_, sizeof(smc->sm));
|
||||
r = ca_create(&smc->old_counts, sm);
|
||||
if (r) {
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
r = ca_create(&smc->counts, sm);
|
||||
if (r) {
|
||||
ca_destroy(&smc->old_counts);
|
||||
kfree(smc);
|
||||
- return NULL;
|
||||
+ return ERR_PTR(r);
|
||||
}
|
||||
|
||||
smc->real_sm = sm;
|
||||
diff --git a/drivers/md/persistent-data/dm-space-map-disk.c b/drivers/md/persistent-data/dm-space-map-disk.c
|
||||
index fc469ba..3d0ed53 100644
|
||||
--- a/drivers/md/persistent-data/dm-space-map-disk.c
|
||||
+++ b/drivers/md/persistent-data/dm-space-map-disk.c
|
||||
@@ -290,7 +290,16 @@ struct dm_space_map *dm_sm_disk_create(struct dm_transaction_manager *tm,
|
||||
dm_block_t nr_blocks)
|
||||
{
|
||||
struct dm_space_map *sm = dm_sm_disk_create_real(tm, nr_blocks);
|
||||
- return dm_sm_checker_create_fresh(sm);
|
||||
+ struct dm_space_map *smc;
|
||||
+
|
||||
+ if (IS_ERR_OR_NULL(sm))
|
||||
+ return sm;
|
||||
+
|
||||
+ smc = dm_sm_checker_create_fresh(sm);
|
||||
+ if (IS_ERR(smc))
|
||||
+ dm_sm_destroy(sm);
|
||||
+
|
||||
+ return smc;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(dm_sm_disk_create);
|
||||
|
||||
diff --git a/drivers/md/persistent-data/dm-transaction-manager.c b/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
index e5902d1..ba54aac 100644
|
||||
--- a/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
+++ b/drivers/md/persistent-data/dm-transaction-manager.c
|
||||
@@ -345,8 +345,10 @@ static int dm_tm_create_internal(struct dm_block_manager *bm,
|
||||
}
|
||||
|
||||
*sm = dm_sm_checker_create(inner);
|
||||
- if (!*sm)
|
||||
+ if (IS_ERR(*sm)) {
|
||||
+ r = PTR_ERR(*sm);
|
||||
goto bad2;
|
||||
+ }
|
||||
|
||||
} else {
|
||||
r = dm_bm_write_lock(dm_tm_get_bm(*tm), sb_location,
|
||||
@@ -365,8 +367,10 @@ static int dm_tm_create_internal(struct dm_block_manager *bm,
|
||||
}
|
||||
|
||||
*sm = dm_sm_checker_create(inner);
|
||||
- if (!*sm)
|
||||
+ if (IS_ERR(*sm)) {
|
||||
+ r = PTR_ERR(*sm);
|
||||
goto bad2;
|
||||
+ }
|
||||
}
|
||||
|
||||
return 0;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,95 @@
|
||||
From d93e7e98bbff07495ac95fd10c02c2e0d5392079 Mon Sep 17 00:00:00 2001
|
||||
From: Mike Snitzer <snitzer@redhat.com>
|
||||
Date: Tue, 3 Jul 2012 12:55:37 +0100
|
||||
Subject: [PATCH 21/49] dm persistent data: fix allocation failure in space
|
||||
map checker init
|
||||
|
||||
commit b0239faaf87c38bb419c9264bf20817438ddc3a9 upstream.
|
||||
|
||||
If CONFIG_DM_DEBUG_SPACE_MAPS is enabled and memory is fragmented and a
|
||||
sufficiently-large metadata device is used in a thin pool then the space
|
||||
map checker will fail to allocate the memory it requires.
|
||||
|
||||
Switch from kmalloc to vmalloc to allow larger virtually contiguous
|
||||
allocations for the space map checker's internal count arrays.
|
||||
|
||||
Reported-by: Vivek Goyal <vgoyal@redhat.com>
|
||||
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
|
||||
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/md/persistent-data/dm-space-map-checker.c | 30 +++++++++++++--------
|
||||
1 file changed, 19 insertions(+), 11 deletions(-)
|
||||
|
||||
diff --git a/drivers/md/persistent-data/dm-space-map-checker.c b/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
index 6d7c832..fc90c11 100644
|
||||
--- a/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
+++ b/drivers/md/persistent-data/dm-space-map-checker.c
|
||||
@@ -8,6 +8,7 @@
|
||||
|
||||
#include <linux/device-mapper.h>
|
||||
#include <linux/export.h>
|
||||
+#include <linux/vmalloc.h>
|
||||
|
||||
#ifdef CONFIG_DM_DEBUG_SPACE_MAPS
|
||||
|
||||
@@ -89,13 +90,23 @@ static int ca_create(struct count_array *ca, struct dm_space_map *sm)
|
||||
|
||||
ca->nr = nr_blocks;
|
||||
ca->nr_free = nr_blocks;
|
||||
- ca->counts = kzalloc(sizeof(*ca->counts) * nr_blocks, GFP_KERNEL);
|
||||
- if (!ca->counts)
|
||||
- return -ENOMEM;
|
||||
+
|
||||
+ if (!nr_blocks)
|
||||
+ ca->counts = NULL;
|
||||
+ else {
|
||||
+ ca->counts = vzalloc(sizeof(*ca->counts) * nr_blocks);
|
||||
+ if (!ca->counts)
|
||||
+ return -ENOMEM;
|
||||
+ }
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
+static void ca_destroy(struct count_array *ca)
|
||||
+{
|
||||
+ vfree(ca->counts);
|
||||
+}
|
||||
+
|
||||
static int ca_load(struct count_array *ca, struct dm_space_map *sm)
|
||||
{
|
||||
int r;
|
||||
@@ -126,12 +137,14 @@ static int ca_load(struct count_array *ca, struct dm_space_map *sm)
|
||||
static int ca_extend(struct count_array *ca, dm_block_t extra_blocks)
|
||||
{
|
||||
dm_block_t nr_blocks = ca->nr + extra_blocks;
|
||||
- uint32_t *counts = kzalloc(sizeof(*counts) * nr_blocks, GFP_KERNEL);
|
||||
+ uint32_t *counts = vzalloc(sizeof(*counts) * nr_blocks);
|
||||
if (!counts)
|
||||
return -ENOMEM;
|
||||
|
||||
- memcpy(counts, ca->counts, sizeof(*counts) * ca->nr);
|
||||
- kfree(ca->counts);
|
||||
+ if (ca->counts) {
|
||||
+ memcpy(counts, ca->counts, sizeof(*counts) * ca->nr);
|
||||
+ ca_destroy(ca);
|
||||
+ }
|
||||
ca->nr = nr_blocks;
|
||||
ca->nr_free += extra_blocks;
|
||||
ca->counts = counts;
|
||||
@@ -151,11 +164,6 @@ static int ca_commit(struct count_array *old, struct count_array *new)
|
||||
return 0;
|
||||
}
|
||||
|
||||
-static void ca_destroy(struct count_array *ca)
|
||||
-{
|
||||
- kfree(ca->counts);
|
||||
-}
|
||||
-
|
||||
/*----------------------------------------------------------------*/
|
||||
|
||||
struct sm_checker {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,49 @@
|
||||
From 6411ef218c12f6719597631d388f2b13945a5251 Mon Sep 17 00:00:00 2001
|
||||
From: Takashi Iwai <tiwai@suse.de>
|
||||
Date: Tue, 26 Jun 2012 17:35:10 +0200
|
||||
Subject: [PATCH 22/49] ALSA: hda - Fix power-map regression for HP dv6 & co
|
||||
|
||||
commit 6e1c39c6b00d9141a82c231ba7c5e5b1716974b2 upstream.
|
||||
|
||||
The recent fix for power-map controls (commit b0791dda813) caused
|
||||
regressions on some other HP laptops. They have fixed pins but these
|
||||
pins are exposed as jack-detectable. Thus the driver tries to control
|
||||
the power-map dynamically per jack detection where it never gets on.
|
||||
|
||||
This patch adds the check of connection and it assumes the no jack
|
||||
detection is available for fixed pins no matter what pin capability
|
||||
says.
|
||||
|
||||
BugLink: http://bugs.launchpad.net/bugs/1013183
|
||||
Reported-by: Luis Henriques <luis.henriques@canonical.com>
|
||||
Signed-off-by: Takashi Iwai <tiwai@suse.de>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
sound/pci/hda/patch_sigmatel.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
|
||||
index 7b7a516..2b973f5 100644
|
||||
--- a/sound/pci/hda/patch_sigmatel.c
|
||||
+++ b/sound/pci/hda/patch_sigmatel.c
|
||||
@@ -4457,7 +4457,7 @@ static int stac92xx_init(struct hda_codec *codec)
|
||||
AC_PINCTL_IN_EN);
|
||||
for (i = 0; i < spec->num_pwrs; i++) {
|
||||
hda_nid_t nid = spec->pwr_nids[i];
|
||||
- int pinctl, def_conf;
|
||||
+ unsigned int pinctl, def_conf;
|
||||
|
||||
/* power on when no jack detection is available */
|
||||
/* or when the VREF is used for controlling LED */
|
||||
@@ -4484,7 +4484,7 @@ static int stac92xx_init(struct hda_codec *codec)
|
||||
def_conf = get_defcfg_connect(def_conf);
|
||||
/* skip any ports that don't have jacks since presence
|
||||
* detection is useless */
|
||||
- if (def_conf != AC_JACK_PORT_NONE &&
|
||||
+ if (def_conf != AC_JACK_PORT_COMPLEX ||
|
||||
!is_jack_detectable(codec, nid)) {
|
||||
stac_toggle_power_map(codec, nid, 1);
|
||||
continue;
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
From 04098d77869c04c5bf703846783cb89b4297b2bb Mon Sep 17 00:00:00 2001
|
||||
From: Vaibhav Nagarnaik <vnagarnaik@google.com>
|
||||
Date: Thu, 3 May 2012 18:59:52 -0700
|
||||
Subject: [PATCH 23/49] tracing: change CPU ring buffer state from
|
||||
tracing_cpumask
|
||||
|
||||
commit 71babb2705e2203a64c27ede13ae3508a0d2c16c upstream.
|
||||
|
||||
According to Documentation/trace/ftrace.txt:
|
||||
|
||||
tracing_cpumask:
|
||||
|
||||
This is a mask that lets the user only trace
|
||||
on specified CPUS. The format is a hex string
|
||||
representing the CPUS.
|
||||
|
||||
The tracing_cpumask currently doesn't affect the tracing state of
|
||||
per-CPU ring buffers.
|
||||
|
||||
This patch enables/disables CPU recording as its corresponding bit in
|
||||
tracing_cpumask is set/unset.
|
||||
|
||||
Link: http://lkml.kernel.org/r/1336096792-25373-3-git-send-email-vnagarnaik@google.com
|
||||
|
||||
Cc: Frederic Weisbecker <fweisbec@gmail.com>
|
||||
Cc: Ingo Molnar <mingo@redhat.com>
|
||||
Cc: Laurent Chavey <chavey@google.com>
|
||||
Cc: Justin Teravest <teravest@google.com>
|
||||
Cc: David Sharp <dhsharp@google.com>
|
||||
Signed-off-by: Vaibhav Nagarnaik <vnagarnaik@google.com>
|
||||
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
kernel/trace/trace.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
|
||||
index 7e4edd3..5638104 100644
|
||||
--- a/kernel/trace/trace.c
|
||||
+++ b/kernel/trace/trace.c
|
||||
@@ -2541,10 +2541,12 @@ tracing_cpumask_write(struct file *filp, const char __user *ubuf,
|
||||
if (cpumask_test_cpu(cpu, tracing_cpumask) &&
|
||||
!cpumask_test_cpu(cpu, tracing_cpumask_new)) {
|
||||
atomic_inc(&global_trace.data[cpu]->disabled);
|
||||
+ ring_buffer_record_disable_cpu(global_trace.buffer, cpu);
|
||||
}
|
||||
if (!cpumask_test_cpu(cpu, tracing_cpumask) &&
|
||||
cpumask_test_cpu(cpu, tracing_cpumask_new)) {
|
||||
atomic_dec(&global_trace.data[cpu]->disabled);
|
||||
+ ring_buffer_record_enable_cpu(global_trace.buffer, cpu);
|
||||
}
|
||||
}
|
||||
arch_spin_unlock(&ftrace_max_lock);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,93 @@
|
||||
From 0b53b4fb097d5d599a3a3fcd0ac10ad140bdf9c4 Mon Sep 17 00:00:00 2001
|
||||
From: Bing Zhao <bzhao@marvell.com>
|
||||
Date: Tue, 3 Jul 2012 20:43:56 -0700
|
||||
Subject: [PATCH 24/49] mwifiex: fix wrong return values in add_virtual_intf()
|
||||
error cases
|
||||
|
||||
commit 858faa57dd9e2b91f3f870fbb1185982e42f5a2b upstream
|
||||
|
||||
backported for linux-3.2.y, linux-3.3.y, linux-3.4.y
|
||||
|
||||
add_virtual_intf() needs to return an ERR_PTR(), instead of NULL,
|
||||
on errors, otherwise cfg80211 will crash.
|
||||
|
||||
Reported-by: Johannes Berg <johannes@sipsolutions.net>
|
||||
Signed-off-by: Bing Zhao <bzhao@marvell.com>
|
||||
Signed-off-by: John W. Linville <linville@tuxdriver.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/wireless/mwifiex/cfg80211.c | 21 +++++++++------------
|
||||
1 file changed, 9 insertions(+), 12 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/wireless/mwifiex/cfg80211.c b/drivers/net/wireless/mwifiex/cfg80211.c
|
||||
index 462c710..01dcb1a 100644
|
||||
--- a/drivers/net/wireless/mwifiex/cfg80211.c
|
||||
+++ b/drivers/net/wireless/mwifiex/cfg80211.c
|
||||
@@ -1177,11 +1177,11 @@ struct net_device *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
||||
void *mdev_priv;
|
||||
|
||||
if (!priv)
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-EFAULT);
|
||||
|
||||
adapter = priv->adapter;
|
||||
if (!adapter)
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-EFAULT);
|
||||
|
||||
switch (type) {
|
||||
case NL80211_IFTYPE_UNSPECIFIED:
|
||||
@@ -1190,7 +1190,7 @@ struct net_device *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
||||
if (priv->bss_mode) {
|
||||
wiphy_err(wiphy, "cannot create multiple"
|
||||
" station/adhoc interfaces\n");
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-EINVAL);
|
||||
}
|
||||
|
||||
if (type == NL80211_IFTYPE_UNSPECIFIED)
|
||||
@@ -1208,14 +1208,15 @@ struct net_device *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
||||
break;
|
||||
default:
|
||||
wiphy_err(wiphy, "type not supported\n");
|
||||
- return NULL;
|
||||
+ return ERR_PTR(-EINVAL);
|
||||
}
|
||||
|
||||
dev = alloc_netdev_mq(sizeof(struct mwifiex_private *), name,
|
||||
ether_setup, 1);
|
||||
if (!dev) {
|
||||
wiphy_err(wiphy, "no memory available for netdevice\n");
|
||||
- goto error;
|
||||
+ priv->bss_mode = NL80211_IFTYPE_UNSPECIFIED;
|
||||
+ return ERR_PTR(-ENOMEM);
|
||||
}
|
||||
|
||||
dev_net_set(dev, wiphy_net(wiphy));
|
||||
@@ -1240,7 +1241,9 @@ struct net_device *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
||||
/* Register network device */
|
||||
if (register_netdevice(dev)) {
|
||||
wiphy_err(wiphy, "cannot register virtual network device\n");
|
||||
- goto error;
|
||||
+ free_netdev(dev);
|
||||
+ priv->bss_mode = NL80211_IFTYPE_UNSPECIFIED;
|
||||
+ return ERR_PTR(-EFAULT);
|
||||
}
|
||||
|
||||
sema_init(&priv->async_sem, 1);
|
||||
@@ -1252,12 +1255,6 @@ struct net_device *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
||||
mwifiex_dev_debugfs_init(priv);
|
||||
#endif
|
||||
return dev;
|
||||
-error:
|
||||
- if (dev && (dev->reg_state == NETREG_UNREGISTERED))
|
||||
- free_netdev(dev);
|
||||
- priv->bss_mode = NL80211_IFTYPE_UNSPECIFIED;
|
||||
-
|
||||
- return NULL;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(mwifiex_add_virtual_intf);
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,35 @@
|
||||
From 4d7257d8f5c970ce0f699d893f6050fd8bd11f3c Mon Sep 17 00:00:00 2001
|
||||
From: Jan Kara <jack@suse.cz>
|
||||
Date: Wed, 27 Jun 2012 20:08:44 +0200
|
||||
Subject: [PATCH 25/49] udf: Use 'ret' instead of abusing 'i' in
|
||||
udf_load_logicalvol()
|
||||
|
||||
commit cb14d340ef1737c24125dd663eff77734a482d47 upstream.
|
||||
|
||||
Signed-off-by: Jan Kara <jack@suse.cz>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/udf/super.c | 6 ++----
|
||||
1 file changed, 2 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/fs/udf/super.c b/fs/udf/super.c
|
||||
index 87cb24a..eea2bfe 100644
|
||||
--- a/fs/udf/super.c
|
||||
+++ b/fs/udf/super.c
|
||||
@@ -1235,11 +1235,9 @@ static int udf_load_logicalvol(struct super_block *sb, sector_t block,
|
||||
BUG_ON(ident != TAG_IDENT_LVD);
|
||||
lvd = (struct logicalVolDesc *)bh->b_data;
|
||||
|
||||
- i = udf_sb_alloc_partition_maps(sb, le32_to_cpu(lvd->numPartitionMaps));
|
||||
- if (i != 0) {
|
||||
- ret = i;
|
||||
+ ret = udf_sb_alloc_partition_maps(sb, le32_to_cpu(lvd->numPartitionMaps));
|
||||
+ if (ret)
|
||||
goto out_bh;
|
||||
- }
|
||||
|
||||
for (i = 0, offset = 0;
|
||||
i < sbi->s_partitions && offset < le32_to_cpu(lvd->mapTableLength);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,54 @@
|
||||
From 0a9d08974ed753d12541081ae062e5f69298d791 Mon Sep 17 00:00:00 2001
|
||||
From: Jan Kara <jack@suse.cz>
|
||||
Date: Wed, 27 Jun 2012 20:20:22 +0200
|
||||
Subject: [PATCH 26/49] udf: Avoid run away loop when partition table length
|
||||
is corrupted
|
||||
|
||||
commit adee11b2085bee90bd8f4f52123ffb07882d6256 upstream.
|
||||
|
||||
Check provided length of partition table so that (possibly maliciously)
|
||||
corrupted partition table cannot cause accessing data beyond current buffer.
|
||||
|
||||
Signed-off-by: Jan Kara <jack@suse.cz>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/udf/super.c | 10 +++++++++-
|
||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/fs/udf/super.c b/fs/udf/super.c
|
||||
index eea2bfe..800e839 100644
|
||||
--- a/fs/udf/super.c
|
||||
+++ b/fs/udf/super.c
|
||||
@@ -1227,6 +1227,7 @@ static int udf_load_logicalvol(struct super_block *sb, sector_t block,
|
||||
struct genericPartitionMap *gpm;
|
||||
uint16_t ident;
|
||||
struct buffer_head *bh;
|
||||
+ unsigned int table_len;
|
||||
int ret = 0;
|
||||
|
||||
bh = udf_read_tagged(sb, block, block, &ident);
|
||||
@@ -1234,13 +1235,20 @@ static int udf_load_logicalvol(struct super_block *sb, sector_t block,
|
||||
return 1;
|
||||
BUG_ON(ident != TAG_IDENT_LVD);
|
||||
lvd = (struct logicalVolDesc *)bh->b_data;
|
||||
+ table_len = le32_to_cpu(lvd->mapTableLength);
|
||||
+ if (sizeof(*lvd) + table_len > sb->s_blocksize) {
|
||||
+ udf_err(sb, "error loading logical volume descriptor: "
|
||||
+ "Partition table too long (%u > %lu)\n", table_len,
|
||||
+ sb->s_blocksize - sizeof(*lvd));
|
||||
+ goto out_bh;
|
||||
+ }
|
||||
|
||||
ret = udf_sb_alloc_partition_maps(sb, le32_to_cpu(lvd->numPartitionMaps));
|
||||
if (ret)
|
||||
goto out_bh;
|
||||
|
||||
for (i = 0, offset = 0;
|
||||
- i < sbi->s_partitions && offset < le32_to_cpu(lvd->mapTableLength);
|
||||
+ i < sbi->s_partitions && offset < table_len;
|
||||
i++, offset += gpm->partitionMapLength) {
|
||||
struct udf_part_map *map = &sbi->s_partmaps[i];
|
||||
gpm = (struct genericPartitionMap *)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,134 @@
|
||||
From 9db7244bafd8f99123cf5fe816e4961115831ca9 Mon Sep 17 00:00:00 2001
|
||||
From: Jan Kara <jack@suse.cz>
|
||||
Date: Wed, 27 Jun 2012 21:23:07 +0200
|
||||
Subject: [PATCH 27/49] udf: Fortify loading of sparing table
|
||||
|
||||
commit 1df2ae31c724e57be9d7ac00d78db8a5dabdd050 upstream.
|
||||
|
||||
Add sanity checks when loading sparing table from disk to avoid accessing
|
||||
unallocated memory or writing to it.
|
||||
|
||||
Signed-off-by: Jan Kara <jack@suse.cz>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/udf/super.c | 86 ++++++++++++++++++++++++++++++++++----------------------
|
||||
1 file changed, 53 insertions(+), 33 deletions(-)
|
||||
|
||||
diff --git a/fs/udf/super.c b/fs/udf/super.c
|
||||
index 800e839..270e135 100644
|
||||
--- a/fs/udf/super.c
|
||||
+++ b/fs/udf/super.c
|
||||
@@ -56,6 +56,7 @@
|
||||
#include <linux/seq_file.h>
|
||||
#include <linux/bitmap.h>
|
||||
#include <linux/crc-itu-t.h>
|
||||
+#include <linux/log2.h>
|
||||
#include <asm/byteorder.h>
|
||||
|
||||
#include "udf_sb.h"
|
||||
@@ -1217,11 +1218,59 @@ out_bh:
|
||||
return ret;
|
||||
}
|
||||
|
||||
+static int udf_load_sparable_map(struct super_block *sb,
|
||||
+ struct udf_part_map *map,
|
||||
+ struct sparablePartitionMap *spm)
|
||||
+{
|
||||
+ uint32_t loc;
|
||||
+ uint16_t ident;
|
||||
+ struct sparingTable *st;
|
||||
+ struct udf_sparing_data *sdata = &map->s_type_specific.s_sparing;
|
||||
+ int i;
|
||||
+ struct buffer_head *bh;
|
||||
+
|
||||
+ map->s_partition_type = UDF_SPARABLE_MAP15;
|
||||
+ sdata->s_packet_len = le16_to_cpu(spm->packetLength);
|
||||
+ if (!is_power_of_2(sdata->s_packet_len)) {
|
||||
+ udf_err(sb, "error loading logical volume descriptor: "
|
||||
+ "Invalid packet length %u\n",
|
||||
+ (unsigned)sdata->s_packet_len);
|
||||
+ return -EIO;
|
||||
+ }
|
||||
+ if (spm->numSparingTables > 4) {
|
||||
+ udf_err(sb, "error loading logical volume descriptor: "
|
||||
+ "Too many sparing tables (%d)\n",
|
||||
+ (int)spm->numSparingTables);
|
||||
+ return -EIO;
|
||||
+ }
|
||||
+
|
||||
+ for (i = 0; i < spm->numSparingTables; i++) {
|
||||
+ loc = le32_to_cpu(spm->locSparingTable[i]);
|
||||
+ bh = udf_read_tagged(sb, loc, loc, &ident);
|
||||
+ if (!bh)
|
||||
+ continue;
|
||||
+
|
||||
+ st = (struct sparingTable *)bh->b_data;
|
||||
+ if (ident != 0 ||
|
||||
+ strncmp(st->sparingIdent.ident, UDF_ID_SPARING,
|
||||
+ strlen(UDF_ID_SPARING)) ||
|
||||
+ sizeof(*st) + le16_to_cpu(st->reallocationTableLen) >
|
||||
+ sb->s_blocksize) {
|
||||
+ brelse(bh);
|
||||
+ continue;
|
||||
+ }
|
||||
+
|
||||
+ sdata->s_spar_map[i] = bh;
|
||||
+ }
|
||||
+ map->s_partition_func = udf_get_pblock_spar15;
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
static int udf_load_logicalvol(struct super_block *sb, sector_t block,
|
||||
struct kernel_lb_addr *fileset)
|
||||
{
|
||||
struct logicalVolDesc *lvd;
|
||||
- int i, j, offset;
|
||||
+ int i, offset;
|
||||
uint8_t type;
|
||||
struct udf_sb_info *sbi = UDF_SB(sb);
|
||||
struct genericPartitionMap *gpm;
|
||||
@@ -1283,38 +1332,9 @@ static int udf_load_logicalvol(struct super_block *sb, sector_t block,
|
||||
} else if (!strncmp(upm2->partIdent.ident,
|
||||
UDF_ID_SPARABLE,
|
||||
strlen(UDF_ID_SPARABLE))) {
|
||||
- uint32_t loc;
|
||||
- struct sparingTable *st;
|
||||
- struct sparablePartitionMap *spm =
|
||||
- (struct sparablePartitionMap *)gpm;
|
||||
-
|
||||
- map->s_partition_type = UDF_SPARABLE_MAP15;
|
||||
- map->s_type_specific.s_sparing.s_packet_len =
|
||||
- le16_to_cpu(spm->packetLength);
|
||||
- for (j = 0; j < spm->numSparingTables; j++) {
|
||||
- struct buffer_head *bh2;
|
||||
-
|
||||
- loc = le32_to_cpu(
|
||||
- spm->locSparingTable[j]);
|
||||
- bh2 = udf_read_tagged(sb, loc, loc,
|
||||
- &ident);
|
||||
- map->s_type_specific.s_sparing.
|
||||
- s_spar_map[j] = bh2;
|
||||
-
|
||||
- if (bh2 == NULL)
|
||||
- continue;
|
||||
-
|
||||
- st = (struct sparingTable *)bh2->b_data;
|
||||
- if (ident != 0 || strncmp(
|
||||
- st->sparingIdent.ident,
|
||||
- UDF_ID_SPARING,
|
||||
- strlen(UDF_ID_SPARING))) {
|
||||
- brelse(bh2);
|
||||
- map->s_type_specific.s_sparing.
|
||||
- s_spar_map[j] = NULL;
|
||||
- }
|
||||
- }
|
||||
- map->s_partition_func = udf_get_pblock_spar15;
|
||||
+ if (udf_load_sparable_map(sb, map,
|
||||
+ (struct sparablePartitionMap *)gpm) < 0)
|
||||
+ goto out_bh;
|
||||
} else if (!strncmp(upm2->partIdent.ident,
|
||||
UDF_ID_METADATA,
|
||||
strlen(UDF_ID_METADATA))) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,68 @@
|
||||
From cb4aa2ef6f748fa3a3e6cd3889153c191e63d48e Mon Sep 17 00:00:00 2001
|
||||
From: Russell King <rmk+kernel@arm.linux.org.uk>
|
||||
Date: Thu, 19 Jan 2012 15:20:58 +0000
|
||||
Subject: [PATCH 28/49] ARM: fix rcu stalls on SMP platforms
|
||||
|
||||
commit 7deabca0acfe02b8e18f59a4c95676012f49a304 upstream.
|
||||
|
||||
We can stall RCU processing on SMP platforms if a CPU sits in its idle
|
||||
loop for a long time. This happens because we don't call irq_enter()
|
||||
and irq_exit() around generic_smp_call_function_interrupt() and
|
||||
friends. Add the necessary calls, and remove the one from within
|
||||
ipi_timer(), so that they're all in a common place.
|
||||
|
||||
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
arch/arm/kernel/smp.c | 10 ++++++++--
|
||||
1 file changed, 8 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/arch/arm/kernel/smp.c b/arch/arm/kernel/smp.c
|
||||
index e10e59a..1d1710e 100644
|
||||
--- a/arch/arm/kernel/smp.c
|
||||
+++ b/arch/arm/kernel/smp.c
|
||||
@@ -471,9 +471,7 @@ static DEFINE_PER_CPU(struct clock_event_device, percpu_clockevent);
|
||||
static void ipi_timer(void)
|
||||
{
|
||||
struct clock_event_device *evt = &__get_cpu_var(percpu_clockevent);
|
||||
- irq_enter();
|
||||
evt->event_handler(evt);
|
||||
- irq_exit();
|
||||
}
|
||||
|
||||
#ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST
|
||||
@@ -572,7 +570,9 @@ void handle_IPI(int ipinr, struct pt_regs *regs)
|
||||
|
||||
switch (ipinr) {
|
||||
case IPI_TIMER:
|
||||
+ irq_enter();
|
||||
ipi_timer();
|
||||
+ irq_exit();
|
||||
break;
|
||||
|
||||
case IPI_RESCHEDULE:
|
||||
@@ -580,15 +580,21 @@ void handle_IPI(int ipinr, struct pt_regs *regs)
|
||||
break;
|
||||
|
||||
case IPI_CALL_FUNC:
|
||||
+ irq_enter();
|
||||
generic_smp_call_function_interrupt();
|
||||
+ irq_exit();
|
||||
break;
|
||||
|
||||
case IPI_CALL_FUNC_SINGLE:
|
||||
+ irq_enter();
|
||||
generic_smp_call_function_single_interrupt();
|
||||
+ irq_exit();
|
||||
break;
|
||||
|
||||
case IPI_CPU_STOP:
|
||||
+ irq_enter();
|
||||
ipi_cpu_stop(cpu);
|
||||
+ irq_exit();
|
||||
break;
|
||||
|
||||
default:
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,53 @@
|
||||
From 9e88f1e8bf3f7dbc0cb410a09c003180052bd7d4 Mon Sep 17 00:00:00 2001
|
||||
From: Jason Wang <jasowang@redhat.com>
|
||||
Date: Wed, 30 May 2012 21:18:10 +0000
|
||||
Subject: [PATCH 29/49] net: sock: validate data_len before allocating skb in
|
||||
sock_alloc_send_pskb()
|
||||
|
||||
[ Upstream commit cc9b17ad29ecaa20bfe426a8d4dbfb94b13ff1cc ]
|
||||
|
||||
We need to validate the number of pages consumed by data_len, otherwise frags
|
||||
array could be overflowed by userspace. So this patch validate data_len and
|
||||
return -EMSGSIZE when data_len may occupies more frags than MAX_SKB_FRAGS.
|
||||
|
||||
Signed-off-by: Jason Wang <jasowang@redhat.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/core/sock.c | 7 +++++--
|
||||
1 file changed, 5 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/net/core/sock.c b/net/core/sock.c
|
||||
index b23f174..8d095b9 100644
|
||||
--- a/net/core/sock.c
|
||||
+++ b/net/core/sock.c
|
||||
@@ -1497,6 +1497,11 @@ struct sk_buff *sock_alloc_send_pskb(struct sock *sk, unsigned long header_len,
|
||||
gfp_t gfp_mask;
|
||||
long timeo;
|
||||
int err;
|
||||
+ int npages = (data_len + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
|
||||
+
|
||||
+ err = -EMSGSIZE;
|
||||
+ if (npages > MAX_SKB_FRAGS)
|
||||
+ goto failure;
|
||||
|
||||
gfp_mask = sk->sk_allocation;
|
||||
if (gfp_mask & __GFP_WAIT)
|
||||
@@ -1515,14 +1520,12 @@ struct sk_buff *sock_alloc_send_pskb(struct sock *sk, unsigned long header_len,
|
||||
if (atomic_read(&sk->sk_wmem_alloc) < sk->sk_sndbuf) {
|
||||
skb = alloc_skb(header_len, gfp_mask);
|
||||
if (skb) {
|
||||
- int npages;
|
||||
int i;
|
||||
|
||||
/* No pages, we're done... */
|
||||
if (!data_len)
|
||||
break;
|
||||
|
||||
- npages = (data_len + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
|
||||
skb->truesize += data_len;
|
||||
skb_shinfo(skb)->nr_frags = npages;
|
||||
for (i = 0; i < npages; i++) {
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,80 @@
|
||||
From e3e2beb00731e994722f01a1c284e3bcc69264ba Mon Sep 17 00:00:00 2001
|
||||
From: Paul Moore <pmoore@redhat.com>
|
||||
Date: Fri, 1 Jun 2012 05:54:56 +0000
|
||||
Subject: [PATCH 30/49] cipso: handle CIPSO options correctly when NetLabel is
|
||||
disabled
|
||||
|
||||
[ Upstream commit 20e2a86485967c385d7c7befc1646e4d1d39362e ]
|
||||
|
||||
When NetLabel is not enabled, e.g. CONFIG_NETLABEL=n, and the system
|
||||
receives a CIPSO tagged packet it is dropped (cipso_v4_validate()
|
||||
returns non-zero). In most cases this is the correct and desired
|
||||
behavior, however, in the case where we are simply forwarding the
|
||||
traffic, e.g. acting as a network bridge, this becomes a problem.
|
||||
|
||||
This patch fixes the forwarding problem by providing the basic CIPSO
|
||||
validation code directly in ip_options_compile() without the need for
|
||||
the NetLabel or CIPSO code. The new validation code can not perform
|
||||
any of the CIPSO option label/value verification that
|
||||
cipso_v4_validate() does, but it can verify the basic CIPSO option
|
||||
format.
|
||||
|
||||
The behavior when NetLabel is enabled is unchanged.
|
||||
|
||||
Signed-off-by: Paul Moore <pmoore@redhat.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
include/net/cipso_ipv4.h | 29 ++++++++++++++++++++++++++++-
|
||||
1 file changed, 28 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/include/net/cipso_ipv4.h b/include/net/cipso_ipv4.h
|
||||
index 9808877..a7a683e 100644
|
||||
--- a/include/net/cipso_ipv4.h
|
||||
+++ b/include/net/cipso_ipv4.h
|
||||
@@ -42,6 +42,7 @@
|
||||
#include <net/netlabel.h>
|
||||
#include <net/request_sock.h>
|
||||
#include <linux/atomic.h>
|
||||
+#include <asm/unaligned.h>
|
||||
|
||||
/* known doi values */
|
||||
#define CIPSO_V4_DOI_UNKNOWN 0x00000000
|
||||
@@ -285,7 +286,33 @@ static inline int cipso_v4_skbuff_getattr(const struct sk_buff *skb,
|
||||
static inline int cipso_v4_validate(const struct sk_buff *skb,
|
||||
unsigned char **option)
|
||||
{
|
||||
- return -ENOSYS;
|
||||
+ unsigned char *opt = *option;
|
||||
+ unsigned char err_offset = 0;
|
||||
+ u8 opt_len = opt[1];
|
||||
+ u8 opt_iter;
|
||||
+
|
||||
+ if (opt_len < 8) {
|
||||
+ err_offset = 1;
|
||||
+ goto out;
|
||||
+ }
|
||||
+
|
||||
+ if (get_unaligned_be32(&opt[2]) == 0) {
|
||||
+ err_offset = 2;
|
||||
+ goto out;
|
||||
+ }
|
||||
+
|
||||
+ for (opt_iter = 6; opt_iter < opt_len;) {
|
||||
+ if (opt[opt_iter + 1] > (opt_len - opt_iter)) {
|
||||
+ err_offset = opt_iter + 1;
|
||||
+ goto out;
|
||||
+ }
|
||||
+ opt_iter += opt[opt_iter + 1];
|
||||
+ }
|
||||
+
|
||||
+out:
|
||||
+ *option = opt + err_offset;
|
||||
+ return err_offset;
|
||||
+
|
||||
}
|
||||
#endif /* CONFIG_NETLABEL */
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
From b5ad3a0c0628afa77ab9de116e252fbac91f6db2 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Thu, 7 Jun 2012 00:07:20 +0000
|
||||
Subject: [PATCH 31/49] net: l2tp_eth: fix kernel panic on rmmod l2tp_eth
|
||||
|
||||
[ Upstream commit a06998b88b1651c5f71c0e35f528bf2057188ead ]
|
||||
|
||||
We must prevent module unloading if some devices are still attached to
|
||||
l2tp_eth driver.
|
||||
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Reported-by: Denys Fedoryshchenko <denys@visp.net.lb>
|
||||
Tested-by: Denys Fedoryshchenko <denys@visp.net.lb>
|
||||
Cc: James Chapman <jchapman@katalix.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/l2tp/l2tp_eth.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/net/l2tp/l2tp_eth.c b/net/l2tp/l2tp_eth.c
|
||||
index d2726a7..3c55f63 100644
|
||||
--- a/net/l2tp/l2tp_eth.c
|
||||
+++ b/net/l2tp/l2tp_eth.c
|
||||
@@ -167,6 +167,7 @@ static void l2tp_eth_delete(struct l2tp_session *session)
|
||||
if (dev) {
|
||||
unregister_netdev(dev);
|
||||
spriv->dev = NULL;
|
||||
+ module_put(THIS_MODULE);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -254,6 +255,7 @@ static int l2tp_eth_create(struct net *net, u32 tunnel_id, u32 session_id, u32 p
|
||||
if (rc < 0)
|
||||
goto out_del_dev;
|
||||
|
||||
+ __module_get(THIS_MODULE);
|
||||
/* Must be done after register_netdev() */
|
||||
strlcpy(session->ifname, dev->name, IFNAMSIZ);
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,53 @@
|
||||
From a2ee8c14e43a7432b50a050cd07c06d43caa9314 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Fri, 8 Jun 2012 06:25:00 +0000
|
||||
Subject: [PATCH 32/49] l2tp: fix a race in l2tp_ip_sendmsg()
|
||||
|
||||
[ Upstream commit 4399a4df98a63e30fd16e9d0cecc46ea92269e8f ]
|
||||
|
||||
Commit 081b1b1bb27f (l2tp: fix l2tp_ip_sendmsg() route handling) added
|
||||
a race, in case IP route cache is disabled.
|
||||
|
||||
In this case, we should not do the dst_release(&rt->dst), since it'll
|
||||
free the dst immediately, instead of waiting a RCU grace period.
|
||||
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Cc: James Chapman <jchapman@katalix.com>
|
||||
Cc: Denys Fedoryshchenko <denys@visp.net.lb>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/l2tp/l2tp_ip.c | 9 ++++++---
|
||||
1 file changed, 6 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/net/l2tp/l2tp_ip.c b/net/l2tp/l2tp_ip.c
|
||||
index 2fbbe1f..6c7e609 100644
|
||||
--- a/net/l2tp/l2tp_ip.c
|
||||
+++ b/net/l2tp/l2tp_ip.c
|
||||
@@ -515,10 +515,12 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m
|
||||
sk->sk_bound_dev_if);
|
||||
if (IS_ERR(rt))
|
||||
goto no_route;
|
||||
- if (connected)
|
||||
+ if (connected) {
|
||||
sk_setup_caps(sk, &rt->dst);
|
||||
- else
|
||||
- dst_release(&rt->dst); /* safe since we hold rcu_read_lock */
|
||||
+ } else {
|
||||
+ skb_dst_set(skb, &rt->dst);
|
||||
+ goto xmit;
|
||||
+ }
|
||||
}
|
||||
|
||||
/* We dont need to clone dst here, it is guaranteed to not disappear.
|
||||
@@ -526,6 +528,7 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m
|
||||
*/
|
||||
skb_dst_set_noref(skb, &rt->dst);
|
||||
|
||||
+xmit:
|
||||
/* Queue the packet to IP for output */
|
||||
rc = ip_queue_xmit(skb, &inet->cork.fl);
|
||||
rcu_read_unlock();
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,47 @@
|
||||
From f13b66c5fac7aa65e68a960806d6c5e97df723eb Mon Sep 17 00:00:00 2001
|
||||
From: stephen hemminger <shemminger@vyatta.com>
|
||||
Date: Wed, 6 Jun 2012 10:01:30 +0000
|
||||
Subject: [PATCH 33/49] sky2: fix checksum bit management on some chips
|
||||
|
||||
[ Upstream commit 5ff0feac88ced864f44adb145142269196fa79d9 ]
|
||||
|
||||
The newer flavors of Yukon II use a different method for receive
|
||||
checksum offload. This is indicated in the driver by the SKY2_HW_NEW_LE
|
||||
flag. On these newer chips, the BMU_ENA_RX_CHKSUM should not be set.
|
||||
|
||||
The driver would get incorrectly toggle the bit, enabling the old
|
||||
checksum logic on these chips and cause a BUG_ON() assertion. If
|
||||
receive checksum was toggled via ethtool.
|
||||
|
||||
Reported-by: Kirill Smelkov <kirr@mns.spb.ru>
|
||||
Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/ethernet/marvell/sky2.c | 10 ++++++----
|
||||
1 file changed, 6 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/ethernet/marvell/sky2.c b/drivers/net/ethernet/marvell/sky2.c
|
||||
index 65c51ff..11ddd838 100644
|
||||
--- a/drivers/net/ethernet/marvell/sky2.c
|
||||
+++ b/drivers/net/ethernet/marvell/sky2.c
|
||||
@@ -4361,10 +4361,12 @@ static int sky2_set_features(struct net_device *dev, u32 features)
|
||||
struct sky2_port *sky2 = netdev_priv(dev);
|
||||
u32 changed = dev->features ^ features;
|
||||
|
||||
- if (changed & NETIF_F_RXCSUM) {
|
||||
- u32 on = features & NETIF_F_RXCSUM;
|
||||
- sky2_write32(sky2->hw, Q_ADDR(rxqaddr[sky2->port], Q_CSR),
|
||||
- on ? BMU_ENA_RX_CHKSUM : BMU_DIS_RX_CHKSUM);
|
||||
+ if ((changed & NETIF_F_RXCSUM) &&
|
||||
+ !(sky2->hw->flags & SKY2_HW_NEW_LE)) {
|
||||
+ sky2_write32(sky2->hw,
|
||||
+ Q_ADDR(rxqaddr[sky2->port], Q_CSR),
|
||||
+ (features & NETIF_F_RXCSUM)
|
||||
+ ? BMU_ENA_RX_CHKSUM : BMU_DIS_RX_CHKSUM);
|
||||
}
|
||||
|
||||
if (changed & NETIF_F_RXHASH)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,44 @@
|
||||
From 5588c981e9bc21ca9bd050a8e15feb4adb1215b9 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Thu, 7 Jun 2012 22:59:59 +0000
|
||||
Subject: [PATCH 34/49] be2net: fix a race in be_xmit()
|
||||
|
||||
[ Upstream commit cd8f76c0a0c6fce0b2cf23c9bd0123f91453f46d ]
|
||||
|
||||
As soon as hardware is notified of a transmit, we no longer can assume
|
||||
skb can be dereferenced, as TX completion might have freed the packet.
|
||||
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Cc: Sathya Perla <sathya.perla@emulex.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/ethernet/emulex/benet/be_main.c | 5 +++--
|
||||
1 file changed, 3 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/ethernet/emulex/benet/be_main.c b/drivers/net/ethernet/emulex/benet/be_main.c
|
||||
index bf266a0..36c7c4e 100644
|
||||
--- a/drivers/net/ethernet/emulex/benet/be_main.c
|
||||
+++ b/drivers/net/ethernet/emulex/benet/be_main.c
|
||||
@@ -696,6 +696,8 @@ static netdev_tx_t be_xmit(struct sk_buff *skb,
|
||||
|
||||
copied = make_tx_wrbs(adapter, txq, skb, wrb_cnt, dummy_wrb);
|
||||
if (copied) {
|
||||
+ int gso_segs = skb_shinfo(skb)->gso_segs;
|
||||
+
|
||||
/* record the sent skb in the sent_skb table */
|
||||
BUG_ON(txo->sent_skb_list[start]);
|
||||
txo->sent_skb_list[start] = skb;
|
||||
@@ -713,8 +715,7 @@ static netdev_tx_t be_xmit(struct sk_buff *skb,
|
||||
|
||||
be_txq_notify(adapter, txq->id, wrb_cnt);
|
||||
|
||||
- be_tx_stats_update(txo, wrb_cnt, copied,
|
||||
- skb_shinfo(skb)->gso_segs, stopped);
|
||||
+ be_tx_stats_update(txo, wrb_cnt, copied, gso_segs, stopped);
|
||||
} else {
|
||||
txq->head = start;
|
||||
dev_kfree_skb_any(skb);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,49 @@
|
||||
From 6e4b4fb46ccc49cacb3258764f2414ecd4fb27a4 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Sun, 10 Jun 2012 21:11:57 +0000
|
||||
Subject: [PATCH 35/49] dummy: fix rcu_sched self-detected stalls
|
||||
|
||||
[ Upstream commit 16b0dc29c1af9df341428f4c49ada4f626258082 ]
|
||||
|
||||
Trying to "modprobe dummy numdummies=30000" triggers :
|
||||
|
||||
INFO: rcu_sched self-detected stall on CPU { 8} (t=60000 jiffies)
|
||||
|
||||
After this splat, RTNL is locked and reboot is needed.
|
||||
|
||||
We must call cond_resched() to avoid this, even holding RTNL.
|
||||
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/dummy.c | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/net/dummy.c b/drivers/net/dummy.c
|
||||
index eeac9ca..68fe73c 100644
|
||||
--- a/drivers/net/dummy.c
|
||||
+++ b/drivers/net/dummy.c
|
||||
@@ -37,6 +37,7 @@
|
||||
#include <linux/rtnetlink.h>
|
||||
#include <net/rtnetlink.h>
|
||||
#include <linux/u64_stats_sync.h>
|
||||
+#include <linux/sched.h>
|
||||
|
||||
static int numdummies = 1;
|
||||
|
||||
@@ -186,8 +187,10 @@ static int __init dummy_init_module(void)
|
||||
rtnl_lock();
|
||||
err = __rtnl_link_register(&dummy_link_ops);
|
||||
|
||||
- for (i = 0; i < numdummies && !err; i++)
|
||||
+ for (i = 0; i < numdummies && !err; i++) {
|
||||
err = dummy_init_one();
|
||||
+ cond_resched();
|
||||
+ }
|
||||
if (err < 0)
|
||||
__rtnl_link_unregister(&dummy_link_ops);
|
||||
rtnl_unlock();
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,117 @@
|
||||
From 218ae95441a945d2a474b2277156749f416b8859 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Tue, 12 Jun 2012 06:03:51 +0000
|
||||
Subject: [PATCH 36/49] bonding: Fix corrupted queue_mapping
|
||||
|
||||
[ Upstream commit 5ee31c6898ea5537fcea160999d60dc63bc0c305 ]
|
||||
|
||||
In the transmit path of the bonding driver, skb->cb is used to
|
||||
stash the skb->queue_mapping so that the bonding device can set its
|
||||
own queue mapping. This value becomes corrupted since the skb->cb is
|
||||
also used in __dev_xmit_skb.
|
||||
|
||||
When transmitting through bonding driver, bond_select_queue is
|
||||
called from dev_queue_xmit. In bond_select_queue the original
|
||||
skb->queue_mapping is copied into skb->cb (via bond_queue_mapping)
|
||||
and skb->queue_mapping is overwritten with the bond driver queue.
|
||||
|
||||
Subsequently in dev_queue_xmit, __dev_xmit_skb is called which writes
|
||||
the packet length into skb->cb, thereby overwriting the stashed
|
||||
queue mappping. In bond_dev_queue_xmit (called from hard_start_xmit),
|
||||
the queue mapping for the skb is set to the stashed value which is now
|
||||
the skb length and hence is an invalid queue for the slave device.
|
||||
|
||||
If we want to save skb->queue_mapping into skb->cb[], best place is to
|
||||
add a field in struct qdisc_skb_cb, to make sure it wont conflict with
|
||||
other layers (eg : Qdiscc, Infiniband...)
|
||||
|
||||
This patchs also makes sure (struct qdisc_skb_cb)->data is aligned on 8
|
||||
bytes :
|
||||
|
||||
netem qdisc for example assumes it can store an u64 in it, without
|
||||
misalignment penalty.
|
||||
|
||||
Note : we only have 20 bytes left in (struct qdisc_skb_cb)->data[].
|
||||
The largest user is CHOKe and it fills it.
|
||||
|
||||
Based on a previous patch from Tom Herbert.
|
||||
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Reported-by: Tom Herbert <therbert@google.com>
|
||||
Cc: John Fastabend <john.r.fastabend@intel.com>
|
||||
Cc: Roland Dreier <roland@kernel.org>
|
||||
Acked-by: Neil Horman <nhorman@tuxdriver.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/net/bonding/bond_main.c | 9 +++++----
|
||||
include/net/sch_generic.h | 7 +++++--
|
||||
2 files changed, 10 insertions(+), 6 deletions(-)
|
||||
|
||||
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
|
||||
index f65e0b9..1a88e38 100644
|
||||
--- a/drivers/net/bonding/bond_main.c
|
||||
+++ b/drivers/net/bonding/bond_main.c
|
||||
@@ -77,6 +77,7 @@
|
||||
#include <net/route.h>
|
||||
#include <net/net_namespace.h>
|
||||
#include <net/netns/generic.h>
|
||||
+#include <net/pkt_sched.h>
|
||||
#include "bonding.h"
|
||||
#include "bond_3ad.h"
|
||||
#include "bond_alb.h"
|
||||
@@ -382,8 +383,6 @@ struct vlan_entry *bond_next_vlan(struct bonding *bond, struct vlan_entry *curr)
|
||||
return next;
|
||||
}
|
||||
|
||||
-#define bond_queue_mapping(skb) (*(u16 *)((skb)->cb))
|
||||
-
|
||||
/**
|
||||
* bond_dev_queue_xmit - Prepare skb for xmit.
|
||||
*
|
||||
@@ -396,7 +395,9 @@ int bond_dev_queue_xmit(struct bonding *bond, struct sk_buff *skb,
|
||||
{
|
||||
skb->dev = slave_dev;
|
||||
|
||||
- skb->queue_mapping = bond_queue_mapping(skb);
|
||||
+ BUILD_BUG_ON(sizeof(skb->queue_mapping) !=
|
||||
+ sizeof(qdisc_skb_cb(skb)->bond_queue_mapping));
|
||||
+ skb->queue_mapping = qdisc_skb_cb(skb)->bond_queue_mapping;
|
||||
|
||||
if (unlikely(netpoll_tx_running(slave_dev)))
|
||||
bond_netpoll_send_skb(bond_get_slave_by_dev(bond, slave_dev), skb);
|
||||
@@ -4151,7 +4152,7 @@ static u16 bond_select_queue(struct net_device *dev, struct sk_buff *skb)
|
||||
/*
|
||||
* Save the original txq to restore before passing to the driver
|
||||
*/
|
||||
- bond_queue_mapping(skb) = skb->queue_mapping;
|
||||
+ qdisc_skb_cb(skb)->bond_queue_mapping = skb->queue_mapping;
|
||||
|
||||
if (unlikely(txq >= dev->real_num_tx_queues)) {
|
||||
do {
|
||||
diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h
|
||||
index 55ce96b..9d7d54a 100644
|
||||
--- a/include/net/sch_generic.h
|
||||
+++ b/include/net/sch_generic.h
|
||||
@@ -220,13 +220,16 @@ struct tcf_proto {
|
||||
|
||||
struct qdisc_skb_cb {
|
||||
unsigned int pkt_len;
|
||||
- unsigned char data[24];
|
||||
+ u16 bond_queue_mapping;
|
||||
+ u16 _pad;
|
||||
+ unsigned char data[20];
|
||||
};
|
||||
|
||||
static inline void qdisc_cb_private_validate(const struct sk_buff *skb, int sz)
|
||||
{
|
||||
struct qdisc_skb_cb *qcb;
|
||||
- BUILD_BUG_ON(sizeof(skb->cb) < sizeof(unsigned int) + sz);
|
||||
+
|
||||
+ BUILD_BUG_ON(sizeof(skb->cb) < offsetof(struct qdisc_skb_cb, data) + sz);
|
||||
BUILD_BUG_ON(sizeof(qcb->data) < sz);
|
||||
}
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,36 @@
|
||||
From 7d1a3b73b1d85f034aeb9e5c1e4eb44ce56658be Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?Micha=C5=82=20Miros=C5=82aw?= <mirq-linux@rere.qmqm.pl>
|
||||
Date: Sun, 22 Jan 2012 00:20:40 +0000
|
||||
Subject: [PATCH 37/49] ethtool: allow ETHTOOL_GSSET_INFO for users
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
[ Upstream commit f80400a26a2e8bff541de12834a1134358bb6642 ]
|
||||
|
||||
Allow ETHTOOL_GSSET_INFO ethtool ioctl() for unprivileged users.
|
||||
ETHTOOL_GSTRINGS is already allowed, but is unusable without this one.
|
||||
|
||||
Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl>
|
||||
Acked-by: Ben Hutchings <bhutchings@solarflare.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/core/ethtool.c | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/net/core/ethtool.c b/net/core/ethtool.c
|
||||
index 2b587ec..2367246 100644
|
||||
--- a/net/core/ethtool.c
|
||||
+++ b/net/core/ethtool.c
|
||||
@@ -1672,6 +1672,7 @@ int dev_ethtool(struct net *net, struct ifreq *ifr)
|
||||
case ETHTOOL_GRXCSUM:
|
||||
case ETHTOOL_GTXCSUM:
|
||||
case ETHTOOL_GSG:
|
||||
+ case ETHTOOL_GSSET_INFO:
|
||||
case ETHTOOL_GSTRINGS:
|
||||
case ETHTOOL_GTSO:
|
||||
case ETHTOOL_GPERMADDR:
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,77 @@
|
||||
From 1757946f8c246a1b46bf27d40716d4f78145f4a1 Mon Sep 17 00:00:00 2001
|
||||
From: Eric Dumazet <edumazet@google.com>
|
||||
Date: Tue, 12 Jun 2012 19:30:21 +0000
|
||||
Subject: [PATCH 38/49] netpoll: fix netpoll_send_udp() bugs
|
||||
|
||||
[ Upstream commit 954fba0274058d27c7c07b5ea07c41b3b7477894 ]
|
||||
|
||||
Bogdan Hamciuc diagnosed and fixed following bug in netpoll_send_udp() :
|
||||
|
||||
"skb->len += len;" instead of "skb_put(skb, len);"
|
||||
|
||||
Meaning that _if_ a network driver needs to call skb_realloc_headroom(),
|
||||
only packet headers would be copied, leaving garbage in the payload.
|
||||
|
||||
However the skb_realloc_headroom() must be avoided as much as possible
|
||||
since it requires memory and netpoll tries hard to work even if memory
|
||||
is exhausted (using a pool of preallocated skbs)
|
||||
|
||||
It appears netpoll_send_udp() reserved 16 bytes for the ethernet header,
|
||||
which happens to work for typicall drivers but not all.
|
||||
|
||||
Right thing is to use LL_RESERVED_SPACE(dev)
|
||||
(And also add dev->needed_tailroom of tailroom)
|
||||
|
||||
This patch combines both fixes.
|
||||
|
||||
Many thanks to Bogdan for raising this issue.
|
||||
|
||||
Reported-by: Bogdan Hamciuc <bogdan.hamciuc@freescale.com>
|
||||
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
||||
Tested-by: Bogdan Hamciuc <bogdan.hamciuc@freescale.com>
|
||||
Cc: Herbert Xu <herbert@gondor.apana.org.au>
|
||||
Cc: Neil Horman <nhorman@tuxdriver.com>
|
||||
Reviewed-by: Neil Horman <nhorman@tuxdriver.com>
|
||||
Reviewed-by: Cong Wang <xiyou.wangcong@gmail.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/core/netpoll.c | 11 ++++++-----
|
||||
1 file changed, 6 insertions(+), 5 deletions(-)
|
||||
|
||||
diff --git a/net/core/netpoll.c b/net/core/netpoll.c
|
||||
index ab0633f..db4bb7a 100644
|
||||
--- a/net/core/netpoll.c
|
||||
+++ b/net/core/netpoll.c
|
||||
@@ -351,22 +351,23 @@ EXPORT_SYMBOL(netpoll_send_skb_on_dev);
|
||||
|
||||
void netpoll_send_udp(struct netpoll *np, const char *msg, int len)
|
||||
{
|
||||
- int total_len, eth_len, ip_len, udp_len;
|
||||
+ int total_len, ip_len, udp_len;
|
||||
struct sk_buff *skb;
|
||||
struct udphdr *udph;
|
||||
struct iphdr *iph;
|
||||
struct ethhdr *eth;
|
||||
|
||||
udp_len = len + sizeof(*udph);
|
||||
- ip_len = eth_len = udp_len + sizeof(*iph);
|
||||
- total_len = eth_len + ETH_HLEN + NET_IP_ALIGN;
|
||||
+ ip_len = udp_len + sizeof(*iph);
|
||||
+ total_len = ip_len + LL_RESERVED_SPACE(np->dev);
|
||||
|
||||
- skb = find_skb(np, total_len, total_len - len);
|
||||
+ skb = find_skb(np, total_len + np->dev->needed_tailroom,
|
||||
+ total_len - len);
|
||||
if (!skb)
|
||||
return;
|
||||
|
||||
skb_copy_to_linear_data(skb, msg, len);
|
||||
- skb->len += len;
|
||||
+ skb_put(skb, len);
|
||||
|
||||
skb_push(skb, sizeof(*udph));
|
||||
skb_reset_transport_header(skb);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,126 @@
|
||||
From 0991f9681e1142099a36959648a920e9ee9dda33 Mon Sep 17 00:00:00 2001
|
||||
From: Thomas Graf <tgraf@suug.ch>
|
||||
Date: Mon, 18 Jun 2012 12:08:33 +0000
|
||||
Subject: [PATCH 39/49] ipv6: Move ipv6 proc file registration to end of init
|
||||
order
|
||||
|
||||
[ Upstream commit d189634ecab947c10f6f832258b103d0bbfe73cc ]
|
||||
|
||||
/proc/net/ipv6_route reflects the contents of fib_table_hash. The proc
|
||||
handler is installed in ip6_route_net_init() whereas fib_table_hash is
|
||||
allocated in fib6_net_init() _after_ the proc handler has been installed.
|
||||
|
||||
This opens up a short time frame to access fib_table_hash with its pants
|
||||
down.
|
||||
|
||||
Move the registration of the proc files to a later point in the init
|
||||
order to avoid the race.
|
||||
|
||||
Tested :-)
|
||||
|
||||
Signed-off-by: Thomas Graf <tgraf@suug.ch>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/ipv6/route.c | 41 +++++++++++++++++++++++++++++++----------
|
||||
1 file changed, 31 insertions(+), 10 deletions(-)
|
||||
|
||||
diff --git a/net/ipv6/route.c b/net/ipv6/route.c
|
||||
index 059b9d9..2e21751 100644
|
||||
--- a/net/ipv6/route.c
|
||||
+++ b/net/ipv6/route.c
|
||||
@@ -2881,10 +2881,6 @@ static int __net_init ip6_route_net_init(struct net *net)
|
||||
net->ipv6.sysctl.ip6_rt_mtu_expires = 10*60*HZ;
|
||||
net->ipv6.sysctl.ip6_rt_min_advmss = IPV6_MIN_MTU - 20 - 40;
|
||||
|
||||
-#ifdef CONFIG_PROC_FS
|
||||
- proc_net_fops_create(net, "ipv6_route", 0, &ipv6_route_proc_fops);
|
||||
- proc_net_fops_create(net, "rt6_stats", S_IRUGO, &rt6_stats_seq_fops);
|
||||
-#endif
|
||||
net->ipv6.ip6_rt_gc_expire = 30*HZ;
|
||||
|
||||
ret = 0;
|
||||
@@ -2905,10 +2901,6 @@ out_ip6_dst_ops:
|
||||
|
||||
static void __net_exit ip6_route_net_exit(struct net *net)
|
||||
{
|
||||
-#ifdef CONFIG_PROC_FS
|
||||
- proc_net_remove(net, "ipv6_route");
|
||||
- proc_net_remove(net, "rt6_stats");
|
||||
-#endif
|
||||
kfree(net->ipv6.ip6_null_entry);
|
||||
#ifdef CONFIG_IPV6_MULTIPLE_TABLES
|
||||
kfree(net->ipv6.ip6_prohibit_entry);
|
||||
@@ -2917,11 +2909,33 @@ static void __net_exit ip6_route_net_exit(struct net *net)
|
||||
dst_entries_destroy(&net->ipv6.ip6_dst_ops);
|
||||
}
|
||||
|
||||
+static int __net_init ip6_route_net_init_late(struct net *net)
|
||||
+{
|
||||
+#ifdef CONFIG_PROC_FS
|
||||
+ proc_net_fops_create(net, "ipv6_route", 0, &ipv6_route_proc_fops);
|
||||
+ proc_net_fops_create(net, "rt6_stats", S_IRUGO, &rt6_stats_seq_fops);
|
||||
+#endif
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+static void __net_exit ip6_route_net_exit_late(struct net *net)
|
||||
+{
|
||||
+#ifdef CONFIG_PROC_FS
|
||||
+ proc_net_remove(net, "ipv6_route");
|
||||
+ proc_net_remove(net, "rt6_stats");
|
||||
+#endif
|
||||
+}
|
||||
+
|
||||
static struct pernet_operations ip6_route_net_ops = {
|
||||
.init = ip6_route_net_init,
|
||||
.exit = ip6_route_net_exit,
|
||||
};
|
||||
|
||||
+static struct pernet_operations ip6_route_net_late_ops = {
|
||||
+ .init = ip6_route_net_init_late,
|
||||
+ .exit = ip6_route_net_exit_late,
|
||||
+};
|
||||
+
|
||||
static struct notifier_block ip6_route_dev_notifier = {
|
||||
.notifier_call = ip6_route_dev_notify,
|
||||
.priority = 0,
|
||||
@@ -2971,19 +2985,25 @@ int __init ip6_route_init(void)
|
||||
if (ret)
|
||||
goto xfrm6_init;
|
||||
|
||||
+ ret = register_pernet_subsys(&ip6_route_net_late_ops);
|
||||
+ if (ret)
|
||||
+ goto fib6_rules_init;
|
||||
+
|
||||
ret = -ENOBUFS;
|
||||
if (__rtnl_register(PF_INET6, RTM_NEWROUTE, inet6_rtm_newroute, NULL, NULL) ||
|
||||
__rtnl_register(PF_INET6, RTM_DELROUTE, inet6_rtm_delroute, NULL, NULL) ||
|
||||
__rtnl_register(PF_INET6, RTM_GETROUTE, inet6_rtm_getroute, NULL, NULL))
|
||||
- goto fib6_rules_init;
|
||||
+ goto out_register_late_subsys;
|
||||
|
||||
ret = register_netdevice_notifier(&ip6_route_dev_notifier);
|
||||
if (ret)
|
||||
- goto fib6_rules_init;
|
||||
+ goto out_register_late_subsys;
|
||||
|
||||
out:
|
||||
return ret;
|
||||
|
||||
+out_register_late_subsys:
|
||||
+ unregister_pernet_subsys(&ip6_route_net_late_ops);
|
||||
fib6_rules_init:
|
||||
fib6_rules_cleanup();
|
||||
xfrm6_init:
|
||||
@@ -3002,6 +3022,7 @@ out_kmem_cache:
|
||||
void ip6_route_cleanup(void)
|
||||
{
|
||||
unregister_netdevice_notifier(&ip6_route_dev_notifier);
|
||||
+ unregister_pernet_subsys(&ip6_route_net_late_ops);
|
||||
fib6_rules_cleanup();
|
||||
xfrm6_fini();
|
||||
fib6_gc_cleanup();
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,62 @@
|
||||
From e310ae5ff49ec77b2c991cffe288ac766e5f5203 Mon Sep 17 00:00:00 2001
|
||||
From: stephen hemminger <shemminger@vyatta.com>
|
||||
Date: Tue, 26 Jun 2012 05:48:45 +0000
|
||||
Subject: [PATCH 40/49] bridge: Assign rtnl_link_ops to bridge devices created
|
||||
via ioctl (v2)
|
||||
|
||||
[ Upstream commit 149ddd83a92b02c658d6c61f3276eb6500d585e8 ]
|
||||
|
||||
This ensures that bridges created with brctl(8) or ioctl(2) directly
|
||||
also carry IFLA_LINKINFO when dumped over netlink. This also allows
|
||||
to create a bridge with ioctl(2) and delete it with RTM_DELLINK.
|
||||
|
||||
Signed-off-by: Thomas Graf <tgraf@suug.ch>
|
||||
Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
|
||||
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
net/bridge/br_if.c | 1 +
|
||||
net/bridge/br_netlink.c | 2 +-
|
||||
net/bridge/br_private.h | 1 +
|
||||
3 files changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/net/bridge/br_if.c b/net/bridge/br_if.c
|
||||
index f603e5b..f3f75ad 100644
|
||||
--- a/net/bridge/br_if.c
|
||||
+++ b/net/bridge/br_if.c
|
||||
@@ -240,6 +240,7 @@ int br_add_bridge(struct net *net, const char *name)
|
||||
return -ENOMEM;
|
||||
|
||||
dev_net_set(dev, net);
|
||||
+ dev->rtnl_link_ops = &br_link_ops;
|
||||
|
||||
res = register_netdev(dev);
|
||||
if (res)
|
||||
diff --git a/net/bridge/br_netlink.c b/net/bridge/br_netlink.c
|
||||
index a1daf82..cbf9ccd 100644
|
||||
--- a/net/bridge/br_netlink.c
|
||||
+++ b/net/bridge/br_netlink.c
|
||||
@@ -211,7 +211,7 @@ static int br_validate(struct nlattr *tb[], struct nlattr *data[])
|
||||
return 0;
|
||||
}
|
||||
|
||||
-static struct rtnl_link_ops br_link_ops __read_mostly = {
|
||||
+struct rtnl_link_ops br_link_ops __read_mostly = {
|
||||
.kind = "bridge",
|
||||
.priv_size = sizeof(struct net_bridge),
|
||||
.setup = br_dev_setup,
|
||||
diff --git a/net/bridge/br_private.h b/net/bridge/br_private.h
|
||||
index 93264df..b9bba8f 100644
|
||||
--- a/net/bridge/br_private.h
|
||||
+++ b/net/bridge/br_private.h
|
||||
@@ -536,6 +536,7 @@ extern int (*br_fdb_test_addr_hook)(struct net_device *dev, unsigned char *addr)
|
||||
#endif
|
||||
|
||||
/* br_netlink.c */
|
||||
+extern struct rtnl_link_ops br_link_ops;
|
||||
extern int br_netlink_init(void);
|
||||
extern void br_netlink_fini(void);
|
||||
extern void br_ifinfo_notify(int event, struct net_bridge_port *port);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
From 478ed8ce8490d599e1bb8e79007b85d6a9e7f1a0 Mon Sep 17 00:00:00 2001
|
||||
From: Chris Mason <chris.mason@fusionio.com>
|
||||
Date: Mon, 2 Jul 2012 15:29:53 -0400
|
||||
Subject: [PATCH 41/49] Btrfs: run delayed directory updates during log replay
|
||||
|
||||
commit b6305567e7d31b0bec1b8cb9ec0cadd7f7086f5f upstream.
|
||||
|
||||
While we are resolving directory modifications in the
|
||||
tree log, we are triggering delayed metadata updates to
|
||||
the filesystem btrees.
|
||||
|
||||
This commit forces the delayed updates to run so the
|
||||
replay code can find any modifications done. It stops
|
||||
us from crashing because the directory deleltion replay
|
||||
expects items to be removed immediately from the tree.
|
||||
|
||||
Signed-off-by: Chris Mason <chris.mason@fusionio.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/btrfs/tree-log.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c
|
||||
index 3568374..19b127c 100644
|
||||
--- a/fs/btrfs/tree-log.c
|
||||
+++ b/fs/btrfs/tree-log.c
|
||||
@@ -692,6 +692,8 @@ static noinline int drop_one_dir_item(struct btrfs_trans_handle *trans,
|
||||
kfree(name);
|
||||
|
||||
iput(inode);
|
||||
+
|
||||
+ btrfs_run_delayed_items(trans, root);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@@ -897,6 +899,7 @@ again:
|
||||
ret = btrfs_unlink_inode(trans, root, dir,
|
||||
inode, victim_name,
|
||||
victim_name_len);
|
||||
+ btrfs_run_delayed_items(trans, root);
|
||||
}
|
||||
kfree(victim_name);
|
||||
ptr = (unsigned long)(victim_ref + 1) + victim_name_len;
|
||||
@@ -1477,6 +1480,9 @@ again:
|
||||
ret = btrfs_unlink_inode(trans, root, dir, inode,
|
||||
name, name_len);
|
||||
BUG_ON(ret);
|
||||
+
|
||||
+ btrfs_run_delayed_items(trans, root);
|
||||
+
|
||||
kfree(name);
|
||||
iput(inode);
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,60 @@
|
||||
From 3ef708aec9359ad6b05d8ae43663cf5e73c58e9d Mon Sep 17 00:00:00 2001
|
||||
From: Jeff Layton <jlayton@redhat.com>
|
||||
Date: Mon, 2 Jul 2012 07:24:25 -0400
|
||||
Subject: [PATCH 42/49] cifs: when server doesn't set CAP_LARGE_READ_X, cap
|
||||
default rsize at MaxBufferSize
|
||||
|
||||
commit ec01d738a1691dfc85b96b9f796020267a7be577 upstream.
|
||||
|
||||
When the server doesn't advertise CAP_LARGE_READ_X, then MS-CIFS states
|
||||
that you must cap the size of the read at the client's MaxBufferSize.
|
||||
Unfortunately, testing with many older servers shows that they often
|
||||
can't service a read larger than their own MaxBufferSize.
|
||||
|
||||
Since we can't assume what the server will do in this situation, we must
|
||||
be conservative here for the default. When the server can't do large
|
||||
reads, then assume that it can't satisfy any read larger than its
|
||||
MaxBufferSize either.
|
||||
|
||||
Luckily almost all modern servers can do large reads, so this won't
|
||||
affect them. This is really just for older win9x and OS/2 era servers.
|
||||
Also, note that this patch just governs the default rsize. The admin can
|
||||
always override this if he so chooses.
|
||||
|
||||
Reported-by: David H. Durgee <dhdurgee@acm.org>
|
||||
Signed-off-by: Jeff Layton <jlayton@redhat.com>
|
||||
Signed-off-by: Steven French <sfrench@w500smf.(none)>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/cifs/connect.c | 9 +++------
|
||||
1 file changed, 3 insertions(+), 6 deletions(-)
|
||||
|
||||
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c
|
||||
index 9e0675a..b21670c 100644
|
||||
--- a/fs/cifs/connect.c
|
||||
+++ b/fs/cifs/connect.c
|
||||
@@ -2975,18 +2975,15 @@ cifs_negotiate_rsize(struct cifs_tcon *tcon, struct smb_vol *pvolume_info)
|
||||
* MS-CIFS indicates that servers are only limited by the client's
|
||||
* bufsize for reads, testing against win98se shows that it throws
|
||||
* INVALID_PARAMETER errors if you try to request too large a read.
|
||||
+ * OS/2 just sends back short reads.
|
||||
*
|
||||
- * If the server advertises a MaxBufferSize of less than one page,
|
||||
- * assume that it also can't satisfy reads larger than that either.
|
||||
- *
|
||||
- * FIXME: Is there a better heuristic for this?
|
||||
+ * If the server doesn't advertise CAP_LARGE_READ_X, then assume that
|
||||
+ * it can't handle a read request larger than its MaxBufferSize either.
|
||||
*/
|
||||
if (tcon->unix_ext && (unix_cap & CIFS_UNIX_LARGE_READ_CAP))
|
||||
defsize = CIFS_DEFAULT_IOSIZE;
|
||||
else if (server->capabilities & CAP_LARGE_READ_X)
|
||||
defsize = CIFS_DEFAULT_NON_POSIX_RSIZE;
|
||||
- else if (server->maxBuf >= PAGE_CACHE_SIZE)
|
||||
- defsize = CIFSMaxBufSize;
|
||||
else
|
||||
defsize = server->maxBuf - sizeof(READ_RSP);
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,38 @@
|
||||
From 605e639247e5f40be06b013748769bd2cc252e04 Mon Sep 17 00:00:00 2001
|
||||
From: Junxiao Bi <junxiao.bi@oracle.com>
|
||||
Date: Wed, 27 Jun 2012 17:09:55 +0800
|
||||
Subject: [PATCH 43/49] ocfs2: clear unaligned io flag when dio fails
|
||||
|
||||
commit 3e5d3c35a68c9a933bdbdd8685bd1a205b57e806 upstream.
|
||||
|
||||
The unaligned io flag is set in the kiocb when an unaligned
|
||||
dio is issued, it should be cleared even when the dio fails,
|
||||
or it may affect the following io which are using the same
|
||||
kiocb.
|
||||
|
||||
Signed-off-by: Junxiao Bi <junxiao.bi@oracle.com>
|
||||
Signed-off-by: Joel Becker <jlbec@evilplan.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/ocfs2/file.c | 4 +++-
|
||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c
|
||||
index 6e39668..07ee5b4 100644
|
||||
--- a/fs/ocfs2/file.c
|
||||
+++ b/fs/ocfs2/file.c
|
||||
@@ -2422,8 +2422,10 @@ out_dio:
|
||||
unaligned_dio = 0;
|
||||
}
|
||||
|
||||
- if (unaligned_dio)
|
||||
+ if (unaligned_dio) {
|
||||
+ ocfs2_iocb_clear_unaligned_aio(iocb);
|
||||
atomic_dec(&OCFS2_I(inode)->ip_unaligned_aio);
|
||||
+ }
|
||||
|
||||
out:
|
||||
if (rw_level != -1)
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,39 @@
|
||||
From 21dbeb828448f788ffb3590cf6706c074bb1048f Mon Sep 17 00:00:00 2001
|
||||
From: Junxiao Bi <junxiao.bi@oracle.com>
|
||||
Date: Wed, 27 Jun 2012 17:09:54 +0800
|
||||
Subject: [PATCH 44/49] aio: make kiocb->private NUll in init_sync_kiocb()
|
||||
|
||||
commit 2dfd06036ba7ae8e7be2daf5a2fff1dac42390bf upstream.
|
||||
|
||||
Ocfs2 uses kiocb.*private as a flag of unsigned long size. In
|
||||
commit a11f7e6 ocfs2: serialize unaligned aio, the unaligned
|
||||
io flag is involved in it to serialize the unaligned aio. As
|
||||
*private is not initialized in init_sync_kiocb() of do_sync_write(),
|
||||
this unaligned io flag may be unexpectly set in an aligned dio.
|
||||
And this will cause OCFS2_I(inode)->ip_unaligned_aio decreased
|
||||
to -1 in ocfs2_dio_end_io(), thus the following unaligned dio
|
||||
will hang forever at ocfs2_aiodio_wait() in ocfs2_file_aio_write().
|
||||
|
||||
Signed-off-by: Junxiao Bi <junxiao.bi@oracle.com>
|
||||
Acked-by: Jeff Moyer <jmoyer@redhat.com>
|
||||
Signed-off-by: Joel Becker <jlbec@evilplan.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
include/linux/aio.h | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/include/linux/aio.h b/include/linux/aio.h
|
||||
index 2314ad8..b1a520e 100644
|
||||
--- a/include/linux/aio.h
|
||||
+++ b/include/linux/aio.h
|
||||
@@ -140,6 +140,7 @@ struct kiocb {
|
||||
(x)->ki_dtor = NULL; \
|
||||
(x)->ki_obj.tsk = tsk; \
|
||||
(x)->ki_user_data = 0; \
|
||||
+ (x)->private = NULL; \
|
||||
} while (0)
|
||||
|
||||
#define AIO_RING_MAGIC 0xa10a10a1
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,39 @@
|
||||
From e48907a3c090265dcbe0965537bbe9b510a1f7ef Mon Sep 17 00:00:00 2001
|
||||
From: Dan Carpenter <dan.carpenter@oracle.com>
|
||||
Date: Sat, 9 Jun 2012 19:08:25 +0300
|
||||
Subject: [PATCH 45/49] mtd: cafe_nand: fix an & vs | mistake
|
||||
|
||||
commit 48f8b641297df49021093763a3271119a84990a2 upstream.
|
||||
|
||||
The intent here was clearly to set result to true if the 0x40000000 flag
|
||||
was set. But instead there was a | vs & typo and we always set result
|
||||
to true.
|
||||
|
||||
Artem: check the spec at
|
||||
wiki.laptop.org/images/5/5c/88ALP01_Datasheet_July_2007.pdf
|
||||
and this fix looks correct.
|
||||
|
||||
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
|
||||
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
|
||||
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/mtd/nand/cafe_nand.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/mtd/nand/cafe_nand.c b/drivers/mtd/nand/cafe_nand.c
|
||||
index 72d3f23..68ecf48 100644
|
||||
--- a/drivers/mtd/nand/cafe_nand.c
|
||||
+++ b/drivers/mtd/nand/cafe_nand.c
|
||||
@@ -102,7 +102,7 @@ static const char *part_probes[] = { "cmdlinepart", "RedBoot", NULL };
|
||||
static int cafe_device_ready(struct mtd_info *mtd)
|
||||
{
|
||||
struct cafe_priv *cafe = mtd->priv;
|
||||
- int result = !!(cafe_readl(cafe, NAND_STATUS) | 0x40000000);
|
||||
+ int result = !!(cafe_readl(cafe, NAND_STATUS) & 0x40000000);
|
||||
uint32_t irqs = cafe_readl(cafe, NAND_IRQ);
|
||||
|
||||
cafe_writel(cafe, irqs, NAND_IRQ);
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,80 @@
|
||||
From 565460286859b1512972fc637f2c653cf648d622 Mon Sep 17 00:00:00 2001
|
||||
From: Andy Lutomirski <luto@amacapital.net>
|
||||
Date: Thu, 5 Jul 2012 16:00:11 -0700
|
||||
Subject: [PATCH 46/49] mm: Hold a file reference in madvise_remove
|
||||
|
||||
commit 9ab4233dd08036fe34a89c7dc6f47a8bf2eb29eb upstream.
|
||||
|
||||
Otherwise the code races with munmap (causing a use-after-free
|
||||
of the vma) or with close (causing a use-after-free of the struct
|
||||
file).
|
||||
|
||||
The bug was introduced by commit 90ed52ebe481 ("[PATCH] holepunch: fix
|
||||
mmap_sem i_mutex deadlock")
|
||||
|
||||
Cc: Hugh Dickins <hugh@veritas.com>
|
||||
Cc: Miklos Szeredi <mszeredi@suse.cz>
|
||||
Cc: Badari Pulavarty <pbadari@us.ibm.com>
|
||||
Cc: Nick Piggin <npiggin@suse.de>
|
||||
Signed-off-by: Andy Lutomirski <luto@amacapital.net>
|
||||
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
[bwh: Backported to 3.2:
|
||||
- Adjust context
|
||||
- madvise_remove() calls vmtruncate_range(), not do_fallocate()]
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
mm/madvise.c | 16 +++++++++++++---
|
||||
1 file changed, 13 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/mm/madvise.c b/mm/madvise.c
|
||||
index 74bf193..23d3a6b 100644
|
||||
--- a/mm/madvise.c
|
||||
+++ b/mm/madvise.c
|
||||
@@ -13,6 +13,7 @@
|
||||
#include <linux/hugetlb.h>
|
||||
#include <linux/sched.h>
|
||||
#include <linux/ksm.h>
|
||||
+#include <linux/file.h>
|
||||
|
||||
/*
|
||||
* Any behaviour which results in changes to the vma->vm_flags needs to
|
||||
@@ -197,14 +198,16 @@ static long madvise_remove(struct vm_area_struct *vma,
|
||||
struct address_space *mapping;
|
||||
loff_t offset, endoff;
|
||||
int error;
|
||||
+ struct file *f;
|
||||
|
||||
*prev = NULL; /* tell sys_madvise we drop mmap_sem */
|
||||
|
||||
if (vma->vm_flags & (VM_LOCKED|VM_NONLINEAR|VM_HUGETLB))
|
||||
return -EINVAL;
|
||||
|
||||
- if (!vma->vm_file || !vma->vm_file->f_mapping
|
||||
- || !vma->vm_file->f_mapping->host) {
|
||||
+ f = vma->vm_file;
|
||||
+
|
||||
+ if (!f || !f->f_mapping || !f->f_mapping->host) {
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
@@ -218,9 +221,16 @@ static long madvise_remove(struct vm_area_struct *vma,
|
||||
endoff = (loff_t)(end - vma->vm_start - 1)
|
||||
+ ((loff_t)vma->vm_pgoff << PAGE_SHIFT);
|
||||
|
||||
- /* vmtruncate_range needs to take i_mutex */
|
||||
+ /*
|
||||
+ * vmtruncate_range may need to take i_mutex. We need to
|
||||
+ * explicitly grab a reference because the vma (and hence the
|
||||
+ * vma's reference to the file) can go away as soon as we drop
|
||||
+ * mmap_sem.
|
||||
+ */
|
||||
+ get_file(f);
|
||||
up_read(¤t->mm->mmap_sem);
|
||||
error = vmtruncate_range(mapping->host, offset, endoff);
|
||||
+ fput(f);
|
||||
down_read(¤t->mm->mmap_sem);
|
||||
return error;
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,36 @@
|
||||
From 7b764186beda304507cde2161d84f4e9b16c8ce6 Mon Sep 17 00:00:00 2001
|
||||
From: Mark Rustad <mark.d.rustad@intel.com>
|
||||
Date: Tue, 26 Jun 2012 15:57:30 -0700
|
||||
Subject: [PATCH 47/49] tcm_fc: Resolve suspicious RCU usage warnings
|
||||
|
||||
commit 863555be0c81558b1af277addcf68acb8f778860 upstream.
|
||||
|
||||
Use rcu_dereference_protected to tell rcu that the ft_lport_lock
|
||||
is held during ft_lport_create. This resolved "suspicious RCU usage"
|
||||
warnings when debugging options are turned on.
|
||||
|
||||
Signed-off-by: Mark Rustad <mark.d.rustad@intel.com>
|
||||
Tested-by: Ross Brattain <ross.b.brattain@intel.com>
|
||||
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
drivers/target/tcm_fc/tfc_sess.c | 3 ++-
|
||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/drivers/target/tcm_fc/tfc_sess.c b/drivers/target/tcm_fc/tfc_sess.c
|
||||
index 3269213..64ddb63 100644
|
||||
--- a/drivers/target/tcm_fc/tfc_sess.c
|
||||
+++ b/drivers/target/tcm_fc/tfc_sess.c
|
||||
@@ -61,7 +61,8 @@ static struct ft_tport *ft_tport_create(struct fc_lport *lport)
|
||||
struct ft_tport *tport;
|
||||
int i;
|
||||
|
||||
- tport = rcu_dereference(lport->prov[FC_TYPE_FCP]);
|
||||
+ tport = rcu_dereference_protected(lport->prov[FC_TYPE_FCP],
|
||||
+ lockdep_is_held(&ft_lport_lock));
|
||||
if (tport && tport->tpg)
|
||||
return tport;
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
From 7c0f859e15ad91f6d6921970fc9d48f1f7804bf9 Mon Sep 17 00:00:00 2001
|
||||
From: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
Date: Sat, 7 Jul 2012 10:17:00 -0700
|
||||
Subject: [PATCH 48/49] vfs: make O_PATH file descriptors usable for
|
||||
'fchdir()'
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
commit 332a2e1244bd08b9e3ecd378028513396a004a24 upstream.
|
||||
|
||||
We already use them for openat() and friends, but fchdir() also wants to
|
||||
be able to use O_PATH file descriptors. This should make it comparable
|
||||
to the O_SEARCH of Solaris. In particular, O_PATH allows you to access
|
||||
(not-quite-open) a directory you don't have read persmission to, only
|
||||
execute permission.
|
||||
|
||||
Noticed during development of multithread support for ksh93.
|
||||
|
||||
Reported-by: ольга крыжановская <olga.kryzhanovska@gmail.com>
|
||||
Cc: Al Viro <viro@zeniv.linux.org.uk>
|
||||
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||
---
|
||||
fs/open.c | 6 +++---
|
||||
1 file changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/fs/open.c b/fs/open.c
|
||||
index 22c41b5..e2b5d51 100644
|
||||
--- a/fs/open.c
|
||||
+++ b/fs/open.c
|
||||
@@ -396,10 +396,10 @@ SYSCALL_DEFINE1(fchdir, unsigned int, fd)
|
||||
{
|
||||
struct file *file;
|
||||
struct inode *inode;
|
||||
- int error;
|
||||
+ int error, fput_needed;
|
||||
|
||||
error = -EBADF;
|
||||
- file = fget(fd);
|
||||
+ file = fget_raw_light(fd, &fput_needed);
|
||||
if (!file)
|
||||
goto out;
|
||||
|
||||
@@ -413,7 +413,7 @@ SYSCALL_DEFINE1(fchdir, unsigned int, fd)
|
||||
if (!error)
|
||||
set_fs_pwd(current->fs, &file->f_path);
|
||||
out_putf:
|
||||
- fput(file);
|
||||
+ fput_light(file, fput_needed);
|
||||
out:
|
||||
return error;
|
||||
}
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -0,0 +1,24 @@
|
||||
From 70aac971ed12a5a23e0b10035df743f2ada81151 Mon Sep 17 00:00:00 2001
|
||||
From: Ben Hutchings <ben@decadent.org.uk>
|
||||
Date: Thu, 12 Jul 2012 04:32:21 +0100
|
||||
Subject: [PATCH 49/49] Linux 3.2.23
|
||||
|
||||
---
|
||||
Makefile | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/Makefile b/Makefile
|
||||
index 9a7d921..40d1e3b 100644
|
||||
--- a/Makefile
|
||||
+++ b/Makefile
|
||||
@@ -1,6 +1,6 @@
|
||||
VERSION = 3
|
||||
PATCHLEVEL = 2
|
||||
-SUBLEVEL = 22
|
||||
+SUBLEVEL = 23
|
||||
EXTRAVERSION =
|
||||
NAME = Saber-toothed Squirrel
|
||||
|
||||
--
|
||||
1.7.10
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
From 0a8e60a2f92c5507739e84cdbe5fb3de3f4ee1b6 Mon Sep 17 00:00:00 2001
|
||||
From 87fae6477f8987244e2331dc60001c79e5421e80 Mon Sep 17 00:00:00 2001
|
||||
From: Koen Kooi <koen@dominion.thruhere.net>
|
||||
Date: Fri, 7 Oct 2011 15:29:28 +0200
|
||||
Subject: [PATCH 01/56] f_rndis: HACK around undefined variables
|
||||
Subject: [PATCH 01/79] f_rndis: HACK around undefined variables
|
||||
|
||||
Signed-off-by: Koen Kooi <koen@dominion.thruhere.net>
|
||||
---
|
||||
drivers/usb/gadget/f_rndis.c | 4 ++--
|
||||
1 files changed, 2 insertions(+), 2 deletions(-)
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/drivers/usb/gadget/f_rndis.c b/drivers/usb/gadget/f_rndis.c
|
||||
index 6614490..d2f1b6f 100644
|
||||
@@ -27,5 +27,5 @@ index 6614490..d2f1b6f 100644
|
||||
* the network link ... which is unavailable to this code
|
||||
* until we're activated via set_alt().
|
||||
--
|
||||
1.7.7.6
|
||||
1.7.10
|
||||
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
From 7db7d9b0c2ca8aea0ae522b7fc30c7ac034edfe2 Mon Sep 17 00:00:00 2001
|
||||
From 30dcf1f8efb223e5b6fc3c049bc8ce3236ec17a0 Mon Sep 17 00:00:00 2001
|
||||
From: Koen Kooi <koen@dominion.thruhere.net>
|
||||
Date: Thu, 3 Nov 2011 17:35:50 +0100
|
||||
Subject: [PATCH 02/56] da8xx-fb: add DVI support for beaglebone
|
||||
Subject: [PATCH 02/79] da8xx-fb: add DVI support for beaglebone
|
||||
|
||||
Signed-off-by: Koen Kooi <koen@dominion.thruhere.net>
|
||||
---
|
||||
drivers/video/da8xx-fb.c | 14 ++++++++++++++
|
||||
1 files changed, 14 insertions(+), 0 deletions(-)
|
||||
1 file changed, 14 insertions(+)
|
||||
|
||||
diff --git a/drivers/video/da8xx-fb.c b/drivers/video/da8xx-fb.c
|
||||
index 2e69278..b01f15b 100644
|
||||
@@ -34,5 +34,5 @@ index 2e69278..b01f15b 100644
|
||||
|
||||
/* Enable the Raster Engine of the LCD Controller */
|
||||
--
|
||||
1.7.7.6
|
||||
1.7.10
|
||||
|
||||
|
||||
@@ -1,13 +1,13 @@
|
||||
From 8ba62500dc8a2a033099ddcf85fd765b09c47f6d Mon Sep 17 00:00:00 2001
|
||||
From 482ed8f98b87299bf77298b86871b4af74334751 Mon Sep 17 00:00:00 2001
|
||||
From: Koen Kooi <koen@dominion.thruhere.net>
|
||||
Date: Mon, 30 Jan 2012 21:30:09 +0100
|
||||
Subject: [PATCH 03/56] beaglebone: rebase everything onto 3.2 - WARNING
|
||||
Subject: [PATCH 03/79] beaglebone: rebase everything onto 3.2 - WARNING
|
||||
MEGAPATCH
|
||||
|
||||
Signed-off-by: Koen Kooi <koen@dominion.thruhere.net>
|
||||
---
|
||||
arch/arm/mach-omap2/board-am335xevm.c | 426 ++++++++++++++++++++++++++++++++-
|
||||
1 files changed, 415 insertions(+), 11 deletions(-)
|
||||
1 file changed, 415 insertions(+), 11 deletions(-)
|
||||
|
||||
diff --git a/arch/arm/mach-omap2/board-am335xevm.c b/arch/arm/mach-omap2/board-am335xevm.c
|
||||
index 563bdf1..2741431 100644
|
||||
@@ -559,5 +559,5 @@ index 563bdf1..2741431 100644
|
||||
/* Beagle Bone has Micro-SD slot which doesn't have Write Protect pin */
|
||||
am335x_mmc[0].gpio_wp = -EINVAL;
|
||||
--
|
||||
1.7.7.6
|
||||
1.7.10
|
||||
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
From b5158f58ced19e39423d3f12b01f67435a1029b0 Mon Sep 17 00:00:00 2001
|
||||
From e495bd4f47ad3b8f48916582b12ec0bf0a7e7134 Mon Sep 17 00:00:00 2001
|
||||
From: Koen Kooi <koen@dominion.thruhere.net>
|
||||
Date: Tue, 31 Jan 2012 10:04:03 +0100
|
||||
Subject: [PATCH 04/56] more beaglebone merges
|
||||
Subject: [PATCH 04/79] more beaglebone merges
|
||||
|
||||
Signed-off-by: Koen Kooi <koen@dominion.thruhere.net>
|
||||
---
|
||||
arch/arm/mach-omap2/board-am335xevm.c | 52 +++++++++++++++++++++++++++++++-
|
||||
1 files changed, 50 insertions(+), 2 deletions(-)
|
||||
arch/arm/mach-omap2/board-am335xevm.c | 52 +++++++++++++++++++++++++++++++--
|
||||
1 file changed, 50 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/arch/arm/mach-omap2/board-am335xevm.c b/arch/arm/mach-omap2/board-am335xevm.c
|
||||
index 2741431..ffbecae 100644
|
||||
@@ -103,5 +103,5 @@ index 2741431..ffbecae 100644
|
||||
} else if (!strncmp("1.0", config.version, 3)) {
|
||||
gp_evm_revision = GP_EVM_REV_IS_1_0;
|
||||
--
|
||||
1.7.7.6
|
||||
1.7.10
|
||||
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user