summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnthony G. Basile <blueness@gentoo.org>2015-04-20 17:42:44 -0400
committerAnthony G. Basile <blueness@gentoo.org>2015-04-20 17:42:44 -0400
commit3ad75e2ff7027972c65d54be8f6a2becadce34f2 (patch)
tree5ceb26afb6a4d661816294256bd1f1d04e04701c
parentGrsec/PaX: 3.1-{3.2.68,3.14.38,3.19.4}-201504142300 (diff)
downloadhardened-patchset-3ad75e2ff7027972c65d54be8f6a2becadce34f2.tar.gz
hardened-patchset-3ad75e2ff7027972c65d54be8f6a2becadce34f2.tar.bz2
hardened-patchset-3ad75e2ff7027972c65d54be8f6a2becadce34f2.zip
Grsec/PaX: 3.1-{3.14.39,3.19.5}-20150419081420150419
-rw-r--r--3.14.38/1037_linux-3.14.38.patch1029
-rw-r--r--3.14.39/0000_README (renamed from 3.14.38/0000_README)6
-rw-r--r--3.14.39/4420_grsecurity-3.1-3.14.39-201504190814.patch (renamed from 3.14.38/4420_grsecurity-3.1-3.14.38-201504142259.patch)173
-rw-r--r--3.14.39/4425_grsec_remove_EI_PAX.patch (renamed from 3.14.38/4425_grsec_remove_EI_PAX.patch)0
-rw-r--r--3.14.39/4427_force_XATTR_PAX_tmpfs.patch (renamed from 3.14.38/4427_force_XATTR_PAX_tmpfs.patch)0
-rw-r--r--3.14.39/4430_grsec-remove-localversion-grsec.patch (renamed from 3.14.38/4430_grsec-remove-localversion-grsec.patch)0
-rw-r--r--3.14.39/4435_grsec-mute-warnings.patch (renamed from 3.14.38/4435_grsec-mute-warnings.patch)0
-rw-r--r--3.14.39/4440_grsec-remove-protected-paths.patch (renamed from 3.14.38/4440_grsec-remove-protected-paths.patch)0
-rw-r--r--3.14.39/4450_grsec-kconfig-default-gids.patch (renamed from 3.14.38/4450_grsec-kconfig-default-gids.patch)0
-rw-r--r--3.14.39/4465_selinux-avc_audit-log-curr_ip.patch (renamed from 3.14.38/4465_selinux-avc_audit-log-curr_ip.patch)0
-rw-r--r--3.14.39/4470_disable-compat_vdso.patch (renamed from 3.14.38/4470_disable-compat_vdso.patch)0
-rw-r--r--3.14.39/4475_emutramp_default_on.patch (renamed from 3.14.38/4475_emutramp_default_on.patch)0
-rw-r--r--3.19.4/1003_linux-3.19.4.patch3185
-rw-r--r--3.19.5/0000_README (renamed from 3.19.4/0000_README)6
-rw-r--r--3.19.5/4420_grsecurity-3.1-3.19.5-201504190814.patch (renamed from 3.19.4/4420_grsecurity-3.1-3.19.4-201504142300.patch)343
-rw-r--r--3.19.5/4425_grsec_remove_EI_PAX.patch (renamed from 3.19.4/4425_grsec_remove_EI_PAX.patch)0
-rw-r--r--3.19.5/4427_force_XATTR_PAX_tmpfs.patch (renamed from 3.19.4/4427_force_XATTR_PAX_tmpfs.patch)0
-rw-r--r--3.19.5/4430_grsec-remove-localversion-grsec.patch (renamed from 3.19.4/4430_grsec-remove-localversion-grsec.patch)0
-rw-r--r--3.19.5/4435_grsec-mute-warnings.patch (renamed from 3.19.4/4435_grsec-mute-warnings.patch)0
-rw-r--r--3.19.5/4440_grsec-remove-protected-paths.patch (renamed from 3.19.4/4440_grsec-remove-protected-paths.patch)0
-rw-r--r--3.19.5/4450_grsec-kconfig-default-gids.patch (renamed from 3.19.4/4450_grsec-kconfig-default-gids.patch)0
-rw-r--r--3.19.5/4465_selinux-avc_audit-log-curr_ip.patch (renamed from 3.19.4/4465_selinux-avc_audit-log-curr_ip.patch)0
-rw-r--r--3.19.5/4470_disable-compat_vdso.patch (renamed from 3.19.4/4470_disable-compat_vdso.patch)0
-rw-r--r--3.19.5/4475_emutramp_default_on.patch (renamed from 3.19.4/4475_emutramp_default_on.patch)0
24 files changed, 174 insertions, 4568 deletions
diff --git a/3.14.38/1037_linux-3.14.38.patch b/3.14.38/1037_linux-3.14.38.patch
deleted file mode 100644
index 261e9f9..0000000
--- a/3.14.38/1037_linux-3.14.38.patch
+++ /dev/null
@@ -1,1029 +0,0 @@
-diff --git a/Makefile b/Makefile
-index c24acc0..f09e19d 100644
---- a/Makefile
-+++ b/Makefile
-@@ -1,6 +1,6 @@
- VERSION = 3
- PATCHLEVEL = 14
--SUBLEVEL = 37
-+SUBLEVEL = 38
- EXTRAVERSION =
- NAME = Remembering Coco
-
-diff --git a/arch/arm64/include/asm/mmu_context.h b/arch/arm64/include/asm/mmu_context.h
-index a9eee33..101a42b 100644
---- a/arch/arm64/include/asm/mmu_context.h
-+++ b/arch/arm64/include/asm/mmu_context.h
-@@ -151,6 +151,15 @@ switch_mm(struct mm_struct *prev, struct mm_struct *next,
- {
- unsigned int cpu = smp_processor_id();
-
-+ /*
-+ * init_mm.pgd does not contain any user mappings and it is always
-+ * active for kernel addresses in TTBR1. Just set the reserved TTBR0.
-+ */
-+ if (next == &init_mm) {
-+ cpu_set_reserved_ttbr0();
-+ return;
-+ }
-+
- if (!cpumask_test_and_set_cpu(cpu, mm_cpumask(next)) || prev != next)
- check_and_switch_context(next, tsk);
- }
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-index 1382fec..7fcb1ac 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-@@ -50,6 +50,7 @@ ethernet@b0000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b0000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-index 221cd2e..9f25427 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-@@ -50,6 +50,7 @@ ethernet@b1000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b1000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-index 61456c3..cd7c318 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-@@ -49,6 +49,7 @@ ethernet@b2000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b2000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/kernel/exceptions-64s.S b/arch/powerpc/kernel/exceptions-64s.S
-index 38d5073..5193116 100644
---- a/arch/powerpc/kernel/exceptions-64s.S
-+++ b/arch/powerpc/kernel/exceptions-64s.S
-@@ -1422,7 +1422,7 @@ machine_check_handle_early:
- bne 9f /* continue in V mode if we are. */
-
- 5:
--#ifdef CONFIG_KVM_BOOK3S_64_HV
-+#ifdef CONFIG_KVM_BOOK3S_64_HANDLER
- /*
- * We are coming from kernel context. Check if we are coming from
- * guest. if yes, then we can continue. We will fall through
-diff --git a/arch/powerpc/platforms/pseries/mobility.c b/arch/powerpc/platforms/pseries/mobility.c
-index cde4e0a..bf38292 100644
---- a/arch/powerpc/platforms/pseries/mobility.c
-+++ b/arch/powerpc/platforms/pseries/mobility.c
-@@ -24,10 +24,10 @@
- static struct kobject *mobility_kobj;
-
- struct update_props_workarea {
-- u32 phandle;
-- u32 state;
-- u64 reserved;
-- u32 nprops;
-+ __be32 phandle;
-+ __be32 state;
-+ __be64 reserved;
-+ __be32 nprops;
- } __packed;
-
- #define NODE_ACTION_MASK 0xff000000
-@@ -53,11 +53,11 @@ static int mobility_rtas_call(int token, char *buf, s32 scope)
- return rc;
- }
-
--static int delete_dt_node(u32 phandle)
-+static int delete_dt_node(__be32 phandle)
- {
- struct device_node *dn;
-
-- dn = of_find_node_by_phandle(phandle);
-+ dn = of_find_node_by_phandle(be32_to_cpu(phandle));
- if (!dn)
- return -ENOENT;
-
-@@ -126,7 +126,7 @@ static int update_dt_property(struct device_node *dn, struct property **prop,
- return 0;
- }
-
--static int update_dt_node(u32 phandle, s32 scope)
-+static int update_dt_node(__be32 phandle, s32 scope)
- {
- struct update_props_workarea *upwa;
- struct device_node *dn;
-@@ -135,6 +135,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- char *prop_data;
- char *rtas_buf;
- int update_properties_token;
-+ u32 nprops;
- u32 vd;
-
- update_properties_token = rtas_token("ibm,update-properties");
-@@ -145,7 +146,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- if (!rtas_buf)
- return -ENOMEM;
-
-- dn = of_find_node_by_phandle(phandle);
-+ dn = of_find_node_by_phandle(be32_to_cpu(phandle));
- if (!dn) {
- kfree(rtas_buf);
- return -ENOENT;
-@@ -161,6 +162,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- break;
-
- prop_data = rtas_buf + sizeof(*upwa);
-+ nprops = be32_to_cpu(upwa->nprops);
-
- /* On the first call to ibm,update-properties for a node the
- * the first property value descriptor contains an empty
-@@ -169,17 +171,17 @@ static int update_dt_node(u32 phandle, s32 scope)
- */
- if (*prop_data == 0) {
- prop_data++;
-- vd = *(u32 *)prop_data;
-+ vd = be32_to_cpu(*(__be32 *)prop_data);
- prop_data += vd + sizeof(vd);
-- upwa->nprops--;
-+ nprops--;
- }
-
-- for (i = 0; i < upwa->nprops; i++) {
-+ for (i = 0; i < nprops; i++) {
- char *prop_name;
-
- prop_name = prop_data;
- prop_data += strlen(prop_name) + 1;
-- vd = *(u32 *)prop_data;
-+ vd = be32_to_cpu(*(__be32 *)prop_data);
- prop_data += sizeof(vd);
-
- switch (vd) {
-@@ -211,13 +213,13 @@ static int update_dt_node(u32 phandle, s32 scope)
- return 0;
- }
-
--static int add_dt_node(u32 parent_phandle, u32 drc_index)
-+static int add_dt_node(__be32 parent_phandle, __be32 drc_index)
- {
- struct device_node *dn;
- struct device_node *parent_dn;
- int rc;
-
-- parent_dn = of_find_node_by_phandle(parent_phandle);
-+ parent_dn = of_find_node_by_phandle(be32_to_cpu(parent_phandle));
- if (!parent_dn)
- return -ENOENT;
-
-@@ -236,7 +238,7 @@ static int add_dt_node(u32 parent_phandle, u32 drc_index)
- int pseries_devicetree_update(s32 scope)
- {
- char *rtas_buf;
-- u32 *data;
-+ __be32 *data;
- int update_nodes_token;
- int rc;
-
-@@ -253,17 +255,17 @@ int pseries_devicetree_update(s32 scope)
- if (rc && rc != 1)
- break;
-
-- data = (u32 *)rtas_buf + 4;
-- while (*data & NODE_ACTION_MASK) {
-+ data = (__be32 *)rtas_buf + 4;
-+ while (be32_to_cpu(*data) & NODE_ACTION_MASK) {
- int i;
-- u32 action = *data & NODE_ACTION_MASK;
-- int node_count = *data & NODE_COUNT_MASK;
-+ u32 action = be32_to_cpu(*data) & NODE_ACTION_MASK;
-+ u32 node_count = be32_to_cpu(*data) & NODE_COUNT_MASK;
-
- data++;
-
- for (i = 0; i < node_count; i++) {
-- u32 phandle = *data++;
-- u32 drc_index;
-+ __be32 phandle = *data++;
-+ __be32 drc_index;
-
- switch (action) {
- case DELETE_DT_NODE:
-diff --git a/drivers/base/regmap/regcache-rbtree.c b/drivers/base/regmap/regcache-rbtree.c
-index 930cad4..2b946bc 100644
---- a/drivers/base/regmap/regcache-rbtree.c
-+++ b/drivers/base/regmap/regcache-rbtree.c
-@@ -313,7 +313,7 @@ static int regcache_rbtree_insert_to_block(struct regmap *map,
- if (pos == 0) {
- memmove(blk + offset * map->cache_word_size,
- blk, rbnode->blklen * map->cache_word_size);
-- bitmap_shift_right(present, present, offset, blklen);
-+ bitmap_shift_left(present, present, offset, blklen);
- }
-
- /* update the rbnode block, its size and the base register */
-diff --git a/drivers/clocksource/time-efm32.c b/drivers/clocksource/time-efm32.c
-index 1a6205b..35b0161 100644
---- a/drivers/clocksource/time-efm32.c
-+++ b/drivers/clocksource/time-efm32.c
-@@ -225,12 +225,12 @@ static int __init efm32_clockevent_init(struct device_node *np)
- clock_event_ddata.base = base;
- clock_event_ddata.periodic_top = DIV_ROUND_CLOSEST(rate, 1024 * HZ);
-
-- setup_irq(irq, &efm32_clock_event_irq);
--
- clockevents_config_and_register(&clock_event_ddata.evtdev,
- DIV_ROUND_CLOSEST(rate, 1024),
- 0xf, 0xffff);
-
-+ setup_irq(irq, &efm32_clock_event_irq);
-+
- return 0;
-
- err_get_irq:
-diff --git a/drivers/clocksource/timer-sun5i.c b/drivers/clocksource/timer-sun5i.c
-index deebcd6..4f0f361 100644
---- a/drivers/clocksource/timer-sun5i.c
-+++ b/drivers/clocksource/timer-sun5i.c
-@@ -172,10 +172,6 @@ static void __init sun5i_timer_init(struct device_node *node)
-
- ticks_per_jiffy = DIV_ROUND_UP(rate, HZ);
-
-- ret = setup_irq(irq, &sun5i_timer_irq);
-- if (ret)
-- pr_warn("failed to setup irq %d\n", irq);
--
- /* Enable timer0 interrupt */
- val = readl(timer_base + TIMER_IRQ_EN_REG);
- writel(val | TIMER_IRQ_EN(0), timer_base + TIMER_IRQ_EN_REG);
-@@ -185,6 +181,10 @@ static void __init sun5i_timer_init(struct device_node *node)
-
- clockevents_config_and_register(&sun5i_clockevent, rate,
- TIMER_SYNC_TICKS, 0xffffffff);
-+
-+ ret = setup_irq(irq, &sun5i_timer_irq);
-+ if (ret)
-+ pr_warn("failed to setup irq %d\n", irq);
- }
- CLOCKSOURCE_OF_DECLARE(sun5i_a13, "allwinner,sun5i-a13-hstimer",
- sun5i_timer_init);
-diff --git a/drivers/dma/dw/platform.c b/drivers/dma/dw/platform.c
-index 453822c..fe8b0c9 100644
---- a/drivers/dma/dw/platform.c
-+++ b/drivers/dma/dw/platform.c
-@@ -48,6 +48,8 @@ static bool dw_dma_of_filter(struct dma_chan *chan, void *param)
- return true;
- }
-
-+#define DRV_NAME "dw_dmac"
-+
- static struct dma_chan *dw_dma_of_xlate(struct of_phandle_args *dma_spec,
- struct of_dma *ofdma)
- {
-@@ -293,7 +295,7 @@ static struct platform_driver dw_driver = {
- .remove = dw_remove,
- .shutdown = dw_shutdown,
- .driver = {
-- .name = "dw_dmac",
-+ .name = DRV_NAME,
- .pm = &dw_dev_pm_ops,
- .of_match_table = of_match_ptr(dw_dma_of_id_table),
- .acpi_match_table = ACPI_PTR(dw_dma_acpi_id_table),
-@@ -314,3 +316,4 @@ module_exit(dw_exit);
-
- MODULE_LICENSE("GPL v2");
- MODULE_DESCRIPTION("Synopsys DesignWare DMA Controller platform driver");
-+MODULE_ALIAS("platform:" DRV_NAME);
-diff --git a/drivers/md/dm-io.c b/drivers/md/dm-io.c
-index d2a8d64..080e767 100644
---- a/drivers/md/dm-io.c
-+++ b/drivers/md/dm-io.c
-@@ -291,9 +291,16 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- struct request_queue *q = bdev_get_queue(where->bdev);
- unsigned short logical_block_size = queue_logical_block_size(q);
- sector_t num_sectors;
-+ unsigned int uninitialized_var(special_cmd_max_sectors);
-
-- /* Reject unsupported discard requests */
-- if ((rw & REQ_DISCARD) && !blk_queue_discard(q)) {
-+ /*
-+ * Reject unsupported discard and write same requests.
-+ */
-+ if (rw & REQ_DISCARD)
-+ special_cmd_max_sectors = q->limits.max_discard_sectors;
-+ else if (rw & REQ_WRITE_SAME)
-+ special_cmd_max_sectors = q->limits.max_write_same_sectors;
-+ if ((rw & (REQ_DISCARD | REQ_WRITE_SAME)) && special_cmd_max_sectors == 0) {
- dec_count(io, region, -EOPNOTSUPP);
- return;
- }
-@@ -319,7 +326,7 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- store_io_and_region_in_bio(bio, io, region);
-
- if (rw & REQ_DISCARD) {
-- num_sectors = min_t(sector_t, q->limits.max_discard_sectors, remaining);
-+ num_sectors = min_t(sector_t, special_cmd_max_sectors, remaining);
- bio->bi_iter.bi_size = num_sectors << SECTOR_SHIFT;
- remaining -= num_sectors;
- } else if (rw & REQ_WRITE_SAME) {
-@@ -328,7 +335,7 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- */
- dp->get_page(dp, &page, &len, &offset);
- bio_add_page(bio, page, logical_block_size, offset);
-- num_sectors = min_t(sector_t, q->limits.max_write_same_sectors, remaining);
-+ num_sectors = min_t(sector_t, special_cmd_max_sectors, remaining);
- bio->bi_iter.bi_size = num_sectors << SECTOR_SHIFT;
-
- offset = 0;
-diff --git a/drivers/md/dm.c b/drivers/md/dm.c
-index 1582c3da..e400591 100644
---- a/drivers/md/dm.c
-+++ b/drivers/md/dm.c
-@@ -2352,10 +2352,16 @@ static void __dm_destroy(struct mapped_device *md, bool wait)
- set_bit(DMF_FREEING, &md->flags);
- spin_unlock(&_minor_lock);
-
-+ /*
-+ * Take suspend_lock so that presuspend and postsuspend methods
-+ * do not race with internal suspend.
-+ */
-+ mutex_lock(&md->suspend_lock);
- if (!dm_suspended_md(md)) {
- dm_table_presuspend_targets(map);
- dm_table_postsuspend_targets(map);
- }
-+ mutex_unlock(&md->suspend_lock);
-
- /* dm_put_live_table must be before msleep, otherwise deadlock is possible */
- dm_put_live_table(md, srcu_idx);
-diff --git a/drivers/mfd/kempld-core.c b/drivers/mfd/kempld-core.c
-index 38917a8..2df3cbc 100644
---- a/drivers/mfd/kempld-core.c
-+++ b/drivers/mfd/kempld-core.c
-@@ -629,7 +629,7 @@ static int __init kempld_init(void)
- if (force_device_id[0]) {
- for (id = kempld_dmi_table; id->matches[0].slot != DMI_NONE; id++)
- if (strstr(id->ident, force_device_id))
-- if (id->callback && id->callback(id))
-+ if (id->callback && !id->callback(id))
- break;
- if (id->matches[0].slot == DMI_NONE)
- return -ENODEV;
-diff --git a/drivers/net/ethernet/amd/pcnet32.c b/drivers/net/ethernet/amd/pcnet32.c
-index 9339ccc..ad0e71c 100644
---- a/drivers/net/ethernet/amd/pcnet32.c
-+++ b/drivers/net/ethernet/amd/pcnet32.c
-@@ -1516,7 +1516,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- {
- struct pcnet32_private *lp;
- int i, media;
-- int fdx, mii, fset, dxsuflo;
-+ int fdx, mii, fset, dxsuflo, sram;
- int chip_version;
- char *chipname;
- struct net_device *dev;
-@@ -1553,7 +1553,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- }
-
- /* initialize variables */
-- fdx = mii = fset = dxsuflo = 0;
-+ fdx = mii = fset = dxsuflo = sram = 0;
- chip_version = (chip_version >> 12) & 0xffff;
-
- switch (chip_version) {
-@@ -1586,6 +1586,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- chipname = "PCnet/FAST III 79C973"; /* PCI */
- fdx = 1;
- mii = 1;
-+ sram = 1;
- break;
- case 0x2626:
- chipname = "PCnet/Home 79C978"; /* PCI */
-@@ -1609,6 +1610,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- chipname = "PCnet/FAST III 79C975"; /* PCI */
- fdx = 1;
- mii = 1;
-+ sram = 1;
- break;
- case 0x2628:
- chipname = "PCnet/PRO 79C976";
-@@ -1637,6 +1639,31 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- dxsuflo = 1;
- }
-
-+ /*
-+ * The Am79C973/Am79C975 controllers come with 12K of SRAM
-+ * which we can use for the Tx/Rx buffers but most importantly,
-+ * the use of SRAM allow us to use the BCR18:NOUFLO bit to avoid
-+ * Tx fifo underflows.
-+ */
-+ if (sram) {
-+ /*
-+ * The SRAM is being configured in two steps. First we
-+ * set the SRAM size in the BCR25:SRAM_SIZE bits. According
-+ * to the datasheet, each bit corresponds to a 512-byte
-+ * page so we can have at most 24 pages. The SRAM_SIZE
-+ * holds the value of the upper 8 bits of the 16-bit SRAM size.
-+ * The low 8-bits start at 0x00 and end at 0xff. So the
-+ * address range is from 0x0000 up to 0x17ff. Therefore,
-+ * the SRAM_SIZE is set to 0x17. The next step is to set
-+ * the BCR26:SRAM_BND midway through so the Tx and Rx
-+ * buffers can share the SRAM equally.
-+ */
-+ a->write_bcr(ioaddr, 25, 0x17);
-+ a->write_bcr(ioaddr, 26, 0xc);
-+ /* And finally enable the NOUFLO bit */
-+ a->write_bcr(ioaddr, 18, a->read_bcr(ioaddr, 18) | (1 << 11));
-+ }
-+
- dev = alloc_etherdev(sizeof(*lp));
- if (!dev) {
- ret = -ENOMEM;
-diff --git a/drivers/net/wireless/iwlwifi/mvm/mac80211.c b/drivers/net/wireless/iwlwifi/mvm/mac80211.c
-index a041746..4a3b8b7 100644
---- a/drivers/net/wireless/iwlwifi/mvm/mac80211.c
-+++ b/drivers/net/wireless/iwlwifi/mvm/mac80211.c
-@@ -594,7 +594,7 @@ static int iwl_mvm_mac_add_interface(struct ieee80211_hw *hw,
-
- ret = iwl_mvm_mac_ctxt_add(mvm, vif);
- if (ret)
-- goto out_remove_mac;
-+ goto out_release;
-
- iwl_mvm_power_disable(mvm, vif);
-
-diff --git a/drivers/of/irq.c b/drivers/of/irq.c
-index 48f20ff..bbff99d 100644
---- a/drivers/of/irq.c
-+++ b/drivers/of/irq.c
-@@ -290,7 +290,7 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar
- struct device_node *p;
- const __be32 *intspec, *tmp, *addr;
- u32 intsize, intlen;
-- int i, res = -EINVAL;
-+ int i, res;
-
- pr_debug("of_irq_parse_one: dev=%s, index=%d\n", of_node_full_name(device), index);
-
-@@ -323,15 +323,19 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar
-
- /* Get size of interrupt specifier */
- tmp = of_get_property(p, "#interrupt-cells", NULL);
-- if (tmp == NULL)
-+ if (tmp == NULL) {
-+ res = -EINVAL;
- goto out;
-+ }
- intsize = be32_to_cpu(*tmp);
-
- pr_debug(" intsize=%d intlen=%d\n", intsize, intlen);
-
- /* Check index */
-- if ((index + 1) * intsize > intlen)
-+ if ((index + 1) * intsize > intlen) {
-+ res = -EINVAL;
- goto out;
-+ }
-
- /* Copy intspec into irq structure */
- intspec += index * intsize;
-diff --git a/drivers/phy/phy-core.c b/drivers/phy/phy-core.c
-index 34d56f7..86592dd 100644
---- a/drivers/phy/phy-core.c
-+++ b/drivers/phy/phy-core.c
-@@ -50,7 +50,9 @@ static void devm_phy_consume(struct device *dev, void *res)
-
- static int devm_phy_match(struct device *dev, void *res, void *match_data)
- {
-- return res == match_data;
-+ struct phy **phy = res;
-+
-+ return *phy == match_data;
- }
-
- static struct phy *phy_lookup(struct device *device, const char *port)
-diff --git a/drivers/scsi/qla2xxx/tcm_qla2xxx.c b/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-index 9d81f76..1817f3f 100644
---- a/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-+++ b/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-@@ -1515,7 +1515,7 @@ static int tcm_qla2xxx_check_initiator_node_acl(
- /*
- * Finally register the new FC Nexus with TCM
- */
-- __transport_register_session(se_nacl->se_tpg, se_nacl, se_sess, sess);
-+ transport_register_session(se_nacl->se_tpg, se_nacl, se_sess, sess);
-
- return 0;
- }
-diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c
-index fbf3b22..d6563ec 100644
---- a/drivers/spi/spi.c
-+++ b/drivers/spi/spi.c
-@@ -846,13 +846,14 @@ void spi_finalize_current_message(struct spi_master *master)
- "failed to unprepare message: %d\n", ret);
- }
- }
-+
-+ trace_spi_message_done(mesg);
-+
- master->cur_msg_prepared = false;
-
- mesg->state = NULL;
- if (mesg->complete)
- mesg->complete(mesg->context);
--
-- trace_spi_message_done(mesg);
- }
- EXPORT_SYMBOL_GPL(spi_finalize_current_message);
-
-diff --git a/drivers/staging/vt6655/rf.c b/drivers/staging/vt6655/rf.c
-index edb1b27..dbd9d44 100644
---- a/drivers/staging/vt6655/rf.c
-+++ b/drivers/staging/vt6655/rf.c
-@@ -936,6 +936,7 @@ bool RFbSetPower(
- break;
- case RATE_6M:
- case RATE_9M:
-+ case RATE_12M:
- case RATE_18M:
- byPwr = pDevice->abyOFDMPwrTbl[uCH];
- if (pDevice->byRFType == RF_UW2452) {
-diff --git a/drivers/staging/vt6656/rf.c b/drivers/staging/vt6656/rf.c
-index 1e8f64b..2dc48d4 100644
---- a/drivers/staging/vt6656/rf.c
-+++ b/drivers/staging/vt6656/rf.c
-@@ -752,6 +752,7 @@ int RFbSetPower(struct vnt_private *priv, u32 rate, u32 channel)
- break;
- case RATE_6M:
- case RATE_9M:
-+ case RATE_12M:
- case RATE_18M:
- case RATE_24M:
- case RATE_36M:
-diff --git a/drivers/target/tcm_fc/tfc_io.c b/drivers/target/tcm_fc/tfc_io.c
-index e415af3..c67d379 100644
---- a/drivers/target/tcm_fc/tfc_io.c
-+++ b/drivers/target/tcm_fc/tfc_io.c
-@@ -346,7 +346,7 @@ void ft_invl_hw_context(struct ft_cmd *cmd)
- ep = fc_seq_exch(seq);
- if (ep) {
- lport = ep->lp;
-- if (lport && (ep->xid <= lport->lro_xid))
-+ if (lport && (ep->xid <= lport->lro_xid)) {
- /*
- * "ddp_done" trigger invalidation of HW
- * specific DDP context
-@@ -361,6 +361,7 @@ void ft_invl_hw_context(struct ft_cmd *cmd)
- * identified using ep->xid)
- */
- cmd->was_ddp_setup = 0;
-+ }
- }
- }
- }
-diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c
-index 6e560d5..754fdf8 100644
---- a/fs/hfsplus/brec.c
-+++ b/fs/hfsplus/brec.c
-@@ -131,13 +131,16 @@ skip:
- hfs_bnode_write(node, entry, data_off + key_len, entry_len);
- hfs_bnode_dump(node);
-
-- if (new_node) {
-- /* update parent key if we inserted a key
-- * at the start of the first node
-- */
-- if (!rec && new_node != node)
-- hfs_brec_update_parent(fd);
-+ /*
-+ * update parent key if we inserted a key
-+ * at the start of the node and it is not the new node
-+ */
-+ if (!rec && new_node != node) {
-+ hfs_bnode_read_key(node, fd->search_key, data_off + size);
-+ hfs_brec_update_parent(fd);
-+ }
-
-+ if (new_node) {
- hfs_bnode_put(fd->bnode);
- if (!new_node->parent) {
- hfs_btree_inc_height(tree);
-@@ -168,9 +171,6 @@ skip:
- goto again;
- }
-
-- if (!rec)
-- hfs_brec_update_parent(fd);
--
- return 0;
- }
-
-@@ -370,6 +370,8 @@ again:
- if (IS_ERR(parent))
- return PTR_ERR(parent);
- __hfs_brec_find(parent, fd, hfs_find_rec_by_key);
-+ if (fd->record < 0)
-+ return -ENOENT;
- hfs_bnode_dump(parent);
- rec = fd->record;
-
-diff --git a/kernel/events/core.c b/kernel/events/core.c
-index 69cffb4..60146fe 100644
---- a/kernel/events/core.c
-+++ b/kernel/events/core.c
-@@ -4232,6 +4232,13 @@ static void perf_pending_event(struct irq_work *entry)
- {
- struct perf_event *event = container_of(entry,
- struct perf_event, pending);
-+ int rctx;
-+
-+ rctx = perf_swevent_get_recursion_context();
-+ /*
-+ * If we 'fail' here, that's OK, it means recursion is already disabled
-+ * and we won't recurse 'further'.
-+ */
-
- if (event->pending_disable) {
- event->pending_disable = 0;
-@@ -4242,6 +4249,9 @@ static void perf_pending_event(struct irq_work *entry)
- event->pending_wakeup = 0;
- perf_event_wakeup(event);
- }
-+
-+ if (rctx >= 0)
-+ perf_swevent_put_recursion_context(rctx);
- }
-
- /*
-diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
-index bf7a1bb..e278c64 100644
---- a/net/mac80211/ieee80211_i.h
-+++ b/net/mac80211/ieee80211_i.h
-@@ -57,13 +57,24 @@ struct ieee80211_local;
- #define IEEE80211_UNSET_POWER_LEVEL INT_MIN
-
- /*
-- * Some APs experience problems when working with U-APSD. Decrease the
-- * probability of that happening by using legacy mode for all ACs but VO.
-- * The AP that caused us trouble was a Cisco 4410N. It ignores our
-- * setting, and always treats non-VO ACs as legacy.
-+ * Some APs experience problems when working with U-APSD. Decreasing the
-+ * probability of that happening by using legacy mode for all ACs but VO isn't
-+ * enough.
-+ *
-+ * Cisco 4410N originally forced us to enable VO by default only because it
-+ * treated non-VO ACs as legacy.
-+ *
-+ * However some APs (notably Netgear R7000) silently reclassify packets to
-+ * different ACs. Since u-APSD ACs require trigger frames for frame retrieval
-+ * clients would never see some frames (e.g. ARP responses) or would fetch them
-+ * accidentally after a long time.
-+ *
-+ * It makes little sense to enable u-APSD queues by default because it needs
-+ * userspace applications to be aware of it to actually take advantage of the
-+ * possible additional powersavings. Implicitly depending on driver autotrigger
-+ * frame support doesn't make much sense.
- */
--#define IEEE80211_DEFAULT_UAPSD_QUEUES \
-- IEEE80211_WMM_IE_STA_QOSINFO_AC_VO
-+#define IEEE80211_DEFAULT_UAPSD_QUEUES 0
-
- #define IEEE80211_DEFAULT_MAX_SP_LEN \
- IEEE80211_WMM_IE_STA_QOSINFO_SP_ALL
-diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
-index 815ca56..9abb445 100644
---- a/net/mac80211/rx.c
-+++ b/net/mac80211/rx.c
-@@ -2107,6 +2107,9 @@ ieee80211_rx_h_mesh_fwding(struct ieee80211_rx_data *rx)
- hdr = (struct ieee80211_hdr *) skb->data;
- mesh_hdr = (struct ieee80211s_hdr *) (skb->data + hdrlen);
-
-+ if (ieee80211_drop_unencrypted(rx, hdr->frame_control))
-+ return RX_DROP_MONITOR;
-+
- /* frame is in RMC, don't forward */
- if (ieee80211_is_data(hdr->frame_control) &&
- is_multicast_ether_addr(hdr->addr1) &&
-diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
-index 18d73df..c260243 100644
---- a/net/wireless/nl80211.c
-+++ b/net/wireless/nl80211.c
-@@ -4190,6 +4190,16 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info)
- if (parse_station_flags(info, dev->ieee80211_ptr->iftype, &params))
- return -EINVAL;
-
-+ /* HT/VHT requires QoS, but if we don't have that just ignore HT/VHT
-+ * as userspace might just pass through the capabilities from the IEs
-+ * directly, rather than enforcing this restriction and returning an
-+ * error in this case.
-+ */
-+ if (!(params.sta_flags_set & BIT(NL80211_STA_FLAG_WME))) {
-+ params.ht_capa = NULL;
-+ params.vht_capa = NULL;
-+ }
-+
- /* When you run into this, adjust the code below for the new flag */
- BUILD_BUG_ON(NL80211_STA_FLAG_MAX != 7);
-
-diff --git a/sound/soc/codecs/adav80x.c b/sound/soc/codecs/adav80x.c
-index f78b27a..23454e9 100644
---- a/sound/soc/codecs/adav80x.c
-+++ b/sound/soc/codecs/adav80x.c
-@@ -319,7 +319,7 @@ static int adav80x_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct adav80x *adav80x = snd_soc_codec_get_drvdata(codec);
-- unsigned int deemph = ucontrol->value.enumerated.item[0];
-+ unsigned int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-@@ -335,7 +335,7 @@ static int adav80x_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct adav80x *adav80x = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = adav80x->deemph;
-+ ucontrol->value.integer.value[0] = adav80x->deemph;
- return 0;
- };
-
-diff --git a/sound/soc/codecs/ak4641.c b/sound/soc/codecs/ak4641.c
-index 94cbe50..d718472 100644
---- a/sound/soc/codecs/ak4641.c
-+++ b/sound/soc/codecs/ak4641.c
-@@ -76,7 +76,7 @@ static int ak4641_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct ak4641_priv *ak4641 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-@@ -92,7 +92,7 @@ static int ak4641_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct ak4641_priv *ak4641 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = ak4641->deemph;
-+ ucontrol->value.integer.value[0] = ak4641->deemph;
- return 0;
- };
-
-diff --git a/sound/soc/codecs/cs4271.c b/sound/soc/codecs/cs4271.c
-index ce05fd9..a0ad41a 100644
---- a/sound/soc/codecs/cs4271.c
-+++ b/sound/soc/codecs/cs4271.c
-@@ -288,7 +288,7 @@ static int cs4271_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct cs4271_private *cs4271 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = cs4271->deemph;
-+ ucontrol->value.integer.value[0] = cs4271->deemph;
- return 0;
- }
-
-@@ -298,7 +298,7 @@ static int cs4271_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct cs4271_private *cs4271 = snd_soc_codec_get_drvdata(codec);
-
-- cs4271->deemph = ucontrol->value.enumerated.item[0];
-+ cs4271->deemph = ucontrol->value.integer.value[0];
- return cs4271_set_deemph(codec);
- }
-
-diff --git a/sound/soc/codecs/pcm1681.c b/sound/soc/codecs/pcm1681.c
-index 73f9c36..651e2fe 100644
---- a/sound/soc/codecs/pcm1681.c
-+++ b/sound/soc/codecs/pcm1681.c
-@@ -118,7 +118,7 @@ static int pcm1681_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct pcm1681_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = priv->deemph;
-+ ucontrol->value.integer.value[0] = priv->deemph;
-
- return 0;
- }
-@@ -129,7 +129,7 @@ static int pcm1681_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct pcm1681_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- priv->deemph = ucontrol->value.enumerated.item[0];
-+ priv->deemph = ucontrol->value.integer.value[0];
-
- return pcm1681_set_deemph(codec);
- }
-diff --git a/sound/soc/codecs/sgtl5000.c b/sound/soc/codecs/sgtl5000.c
-index 715589f..e93c36f 100644
---- a/sound/soc/codecs/sgtl5000.c
-+++ b/sound/soc/codecs/sgtl5000.c
-@@ -1198,13 +1198,7 @@ static int sgtl5000_set_power_regs(struct snd_soc_codec *codec)
- /* Enable VDDC charge pump */
- ana_pwr |= SGTL5000_VDDC_CHRGPMP_POWERUP;
- } else if (vddio >= 3100 && vdda >= 3100) {
-- /*
-- * if vddio and vddd > 3.1v,
-- * charge pump should be clean before set ana_pwr
-- */
-- snd_soc_update_bits(codec, SGTL5000_CHIP_ANA_POWER,
-- SGTL5000_VDDC_CHRGPMP_POWERUP, 0);
--
-+ ana_pwr &= ~SGTL5000_VDDC_CHRGPMP_POWERUP;
- /* VDDC use VDDIO rail */
- lreg_ctrl |= SGTL5000_VDDC_ASSN_OVRD;
- lreg_ctrl |= SGTL5000_VDDC_MAN_ASSN_VDDIO <<
-diff --git a/sound/soc/codecs/tas5086.c b/sound/soc/codecs/tas5086.c
-index a895a5e..c6c6500 100644
---- a/sound/soc/codecs/tas5086.c
-+++ b/sound/soc/codecs/tas5086.c
-@@ -275,7 +275,7 @@ static int tas5086_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct tas5086_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = priv->deemph;
-+ ucontrol->value.integer.value[0] = priv->deemph;
-
- return 0;
- }
-@@ -286,7 +286,7 @@ static int tas5086_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct tas5086_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- priv->deemph = ucontrol->value.enumerated.item[0];
-+ priv->deemph = ucontrol->value.integer.value[0];
-
- return tas5086_set_deemph(codec);
- }
-diff --git a/sound/soc/codecs/wm2000.c b/sound/soc/codecs/wm2000.c
-index 8ae5027..1a9f457 100644
---- a/sound/soc/codecs/wm2000.c
-+++ b/sound/soc/codecs/wm2000.c
-@@ -610,7 +610,7 @@ static int wm2000_anc_mode_get(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-
-- ucontrol->value.enumerated.item[0] = wm2000->anc_active;
-+ ucontrol->value.integer.value[0] = wm2000->anc_active;
-
- return 0;
- }
-@@ -620,7 +620,7 @@ static int wm2000_anc_mode_put(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-- int anc_active = ucontrol->value.enumerated.item[0];
-+ int anc_active = ucontrol->value.integer.value[0];
- int ret;
-
- if (anc_active > 1)
-@@ -643,7 +643,7 @@ static int wm2000_speaker_get(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-
-- ucontrol->value.enumerated.item[0] = wm2000->spk_ena;
-+ ucontrol->value.integer.value[0] = wm2000->spk_ena;
-
- return 0;
- }
-@@ -653,7 +653,7 @@ static int wm2000_speaker_put(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-- int val = ucontrol->value.enumerated.item[0];
-+ int val = ucontrol->value.integer.value[0];
- int ret;
-
- if (val > 1)
-diff --git a/sound/soc/codecs/wm8731.c b/sound/soc/codecs/wm8731.c
-index 0297203..e593722 100644
---- a/sound/soc/codecs/wm8731.c
-+++ b/sound/soc/codecs/wm8731.c
-@@ -122,7 +122,7 @@ static int wm8731_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8731_priv *wm8731 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8731->deemph;
-+ ucontrol->value.integer.value[0] = wm8731->deemph;
-
- return 0;
- }
-@@ -132,7 +132,7 @@ static int wm8731_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8731_priv *wm8731 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
- int ret = 0;
-
- if (deemph > 1)
-diff --git a/sound/soc/codecs/wm8903.c b/sound/soc/codecs/wm8903.c
-index eebcb1d..ae7d76e 100644
---- a/sound/soc/codecs/wm8903.c
-+++ b/sound/soc/codecs/wm8903.c
-@@ -442,7 +442,7 @@ static int wm8903_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8903_priv *wm8903 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8903->deemph;
-+ ucontrol->value.integer.value[0] = wm8903->deemph;
-
- return 0;
- }
-@@ -452,7 +452,7 @@ static int wm8903_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8903_priv *wm8903 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
- int ret = 0;
-
- if (deemph > 1)
-diff --git a/sound/soc/codecs/wm8904.c b/sound/soc/codecs/wm8904.c
-index 53bbfac..66cb9e9 100644
---- a/sound/soc/codecs/wm8904.c
-+++ b/sound/soc/codecs/wm8904.c
-@@ -523,7 +523,7 @@ static int wm8904_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8904_priv *wm8904 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8904->deemph;
-+ ucontrol->value.integer.value[0] = wm8904->deemph;
- return 0;
- }
-
-@@ -532,7 +532,7 @@ static int wm8904_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8904_priv *wm8904 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/codecs/wm8955.c b/sound/soc/codecs/wm8955.c
-index 82c8ba9..1c1fc61 100644
---- a/sound/soc/codecs/wm8955.c
-+++ b/sound/soc/codecs/wm8955.c
-@@ -393,7 +393,7 @@ static int wm8955_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8955_priv *wm8955 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8955->deemph;
-+ ucontrol->value.integer.value[0] = wm8955->deemph;
- return 0;
- }
-
-@@ -402,7 +402,7 @@ static int wm8955_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8955_priv *wm8955 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/codecs/wm8960.c b/sound/soc/codecs/wm8960.c
-index 942ef84..2a0bfb8 100644
---- a/sound/soc/codecs/wm8960.c
-+++ b/sound/soc/codecs/wm8960.c
-@@ -181,7 +181,7 @@ static int wm8960_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8960_priv *wm8960 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8960->deemph;
-+ ucontrol->value.integer.value[0] = wm8960->deemph;
- return 0;
- }
-
-@@ -190,7 +190,7 @@ static int wm8960_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
- struct wm8960_priv *wm8960 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/jz4740/Makefile b/sound/soc/jz4740/Makefile
-index be873c1..d32c540 100644
---- a/sound/soc/jz4740/Makefile
-+++ b/sound/soc/jz4740/Makefile
-@@ -1,10 +1,8 @@
- #
- # Jz4740 Platform Support
- #
--snd-soc-jz4740-objs := jz4740-pcm.o
- snd-soc-jz4740-i2s-objs := jz4740-i2s.o
-
--obj-$(CONFIG_SND_JZ4740_SOC) += snd-soc-jz4740.o
- obj-$(CONFIG_SND_JZ4740_SOC_I2S) += snd-soc-jz4740-i2s.o
-
- # Jz4740 Machine Support
diff --git a/3.14.38/0000_README b/3.14.39/0000_README
index de197d5..df5ef6d 100644
--- a/3.14.38/0000_README
+++ b/3.14.39/0000_README
@@ -2,11 +2,7 @@ README
-----------------------------------------------------------------------------
Individual Patch Descriptions:
-----------------------------------------------------------------------------
-Patch: 1037_linux-3.14.38.patch
-From: http://www.kernel.org
-Desc: Linux 3.14.38
-
-Patch: 4420_grsecurity-3.1-3.14.38-201504142259.patch
+Patch: 4420_grsecurity-3.1-3.14.39-201504190814.patch
From: http://www.grsecurity.net
Desc: hardened-sources base patch from upstream grsecurity
diff --git a/3.14.38/4420_grsecurity-3.1-3.14.38-201504142259.patch b/3.14.39/4420_grsecurity-3.1-3.14.39-201504190814.patch
index daa158d..71f78fb 100644
--- a/3.14.38/4420_grsecurity-3.1-3.14.38-201504142259.patch
+++ b/3.14.39/4420_grsecurity-3.1-3.14.39-201504190814.patch
@@ -295,7 +295,7 @@ index 5d91ba1..ef1d374 100644
pcd. [PARIDE]
diff --git a/Makefile b/Makefile
-index f09e19d..bfca3b8 100644
+index b40845e..c9b79e2 100644
--- a/Makefile
+++ b/Makefile
@@ -244,8 +244,9 @@ CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
@@ -27011,7 +27011,7 @@ index 2f355d2..e75ed0a 100644
return ret;
diff --git a/arch/x86/kernel/reboot.c b/arch/x86/kernel/reboot.c
-index c752cb4..866c432 100644
+index a6aa91f..74ba85d 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -68,6 +68,11 @@ static int __init set_bios_reboot(const struct dmi_system_id *d)
@@ -27057,7 +27057,7 @@ index c752cb4..866c432 100644
"rm" (real_mode_header->machine_real_restart_asm),
"a" (type));
#else
-@@ -470,7 +497,7 @@ void __attribute__((weak)) mach_reboot_fixups(void)
+@@ -480,7 +507,7 @@ void __attribute__((weak)) mach_reboot_fixups(void)
* try to force a triple fault and then cycle between hitting the keyboard
* controller and doing that
*/
@@ -27066,7 +27066,7 @@ index c752cb4..866c432 100644
{
int i;
int attempt = 0;
-@@ -593,13 +620,13 @@ void native_machine_shutdown(void)
+@@ -603,13 +630,13 @@ void native_machine_shutdown(void)
#endif
}
@@ -27082,7 +27082,7 @@ index c752cb4..866c432 100644
{
pr_notice("machine restart\n");
-@@ -608,7 +635,7 @@ static void native_machine_restart(char *__unused)
+@@ -618,7 +645,7 @@ static void native_machine_restart(char *__unused)
__machine_emergency_restart(0);
}
@@ -27091,7 +27091,7 @@ index c752cb4..866c432 100644
{
/* Stop other cpus and apics */
machine_shutdown();
-@@ -618,7 +645,7 @@ static void native_machine_halt(void)
+@@ -628,7 +655,7 @@ static void native_machine_halt(void)
stop_this_cpu(NULL);
}
@@ -27100,7 +27100,7 @@ index c752cb4..866c432 100644
{
if (pm_power_off) {
if (!reboot_force)
-@@ -627,9 +654,10 @@ static void native_machine_power_off(void)
+@@ -637,9 +664,10 @@ static void native_machine_power_off(void)
}
/* A fallback in case there is no PM info available */
tboot_shutdown(TB_SHUTDOWN_HALT);
@@ -37105,7 +37105,7 @@ index c68e724..e863008 100644
/* parse the table header to get the table length */
if (count <= sizeof(struct acpi_table_header))
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c
-index 17f9ec5..d9a455e 100644
+index fd8496a..bd2c3e3 100644
--- a/drivers/acpi/processor_idle.c
+++ b/drivers/acpi/processor_idle.c
@@ -952,7 +952,7 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
@@ -40401,7 +40401,7 @@ index ca89412..a7b9c49 100644
cpuidle_curr_governor->rating < gov->rating)
cpuidle_switch_governor(gov);
diff --git a/drivers/cpuidle/sysfs.c b/drivers/cpuidle/sysfs.c
-index e918b6d..f87ea80 100644
+index dcaae4c..80cd4dd 100644
--- a/drivers/cpuidle/sysfs.c
+++ b/drivers/cpuidle/sysfs.c
@@ -135,7 +135,7 @@ static struct attribute *cpuidle_switch_attrs[] = {
@@ -43394,25 +43394,6 @@ index 9f5ad7c..588cd84 100644
wake_up_process(pool->thread);
}
}
-diff --git a/drivers/infiniband/core/umem.c b/drivers/infiniband/core/umem.c
-index a841123..055ebeb 100644
---- a/drivers/infiniband/core/umem.c
-+++ b/drivers/infiniband/core/umem.c
-@@ -94,6 +94,14 @@ struct ib_umem *ib_umem_get(struct ib_ucontext *context, unsigned long addr,
- if (dmasync)
- dma_set_attr(DMA_ATTR_WRITE_BARRIER, &attrs);
-
-+ /*
-+ * If the combination of the addr and size requested for this memory
-+ * region causes an integer overflow, return error.
-+ */
-+ if ((PAGE_ALIGN(addr + size) <= size) ||
-+ (PAGE_ALIGN(addr + size) <= addr))
-+ return ERR_PTR(-EINVAL);
-+
- if (!can_do_mlock())
- return ERR_PTR(-EPERM);
-
diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c
index 2adc143..619e970 100644
--- a/drivers/infiniband/core/uverbs_cmd.c
@@ -43539,10 +43520,10 @@ index 1f95bba..9530f87 100644
sdata, wqe->wr.wr.atomic.swap);
goto send_comp;
diff --git a/drivers/infiniband/hw/mlx4/mad.c b/drivers/infiniband/hw/mlx4/mad.c
-index f2a3f48..673ec79 100644
+index 2592ab5..0d35c7e 100644
--- a/drivers/infiniband/hw/mlx4/mad.c
+++ b/drivers/infiniband/hw/mlx4/mad.c
-@@ -98,7 +98,7 @@ __be64 mlx4_ib_gen_node_guid(void)
+@@ -106,7 +106,7 @@ __be64 mlx4_ib_gen_node_guid(void)
__be64 mlx4_ib_get_new_demux_tid(struct mlx4_ib_demux_ctx *ctx)
{
@@ -51822,10 +51803,10 @@ index d8afec8..3ec7152 100644
/* check if the device is still usable */
if (unlikely(cmd->device->sdev_state == SDEV_DEL)) {
diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c
-index 64e487a..384f684 100644
+index 719bd82..c996ebc 100644
--- a/drivers/scsi/scsi_lib.c
+++ b/drivers/scsi/scsi_lib.c
-@@ -1482,7 +1482,7 @@ static void scsi_kill_request(struct request *req, struct request_queue *q)
+@@ -1484,7 +1484,7 @@ static void scsi_kill_request(struct request *req, struct request_queue *q)
shost = sdev->host;
scsi_init_cmd_errh(cmd);
cmd->result = DID_NO_CONNECT << 16;
@@ -51834,7 +51815,7 @@ index 64e487a..384f684 100644
/*
* SCSI request completion path will do scsi_device_unbusy(),
-@@ -1508,9 +1508,9 @@ static void scsi_softirq_done(struct request *rq)
+@@ -1510,9 +1510,9 @@ static void scsi_softirq_done(struct request *rq)
INIT_LIST_HEAD(&cmd->eh_entry);
@@ -52817,19 +52798,6 @@ index 67ba48b..24e602f 100644
pDevice->apdev->netdev_ops = &apdev_netdev_ops;
pDevice->apdev->type = ARPHRD_IEEE80211;
-diff --git a/drivers/target/iscsi/iscsi_target.c b/drivers/target/iscsi/iscsi_target.c
-index e168a63..b61c555 100644
---- a/drivers/target/iscsi/iscsi_target.c
-+++ b/drivers/target/iscsi/iscsi_target.c
-@@ -1165,7 +1165,7 @@ iscsit_handle_scsi_cmd(struct iscsi_conn *conn, struct iscsi_cmd *cmd,
- * traditional iSCSI block I/O.
- */
- if (iscsit_allocate_iovecs(cmd) < 0) {
-- return iscsit_add_reject_cmd(cmd,
-+ return iscsit_reject_cmd(cmd,
- ISCSI_REASON_BOOKMARK_NO_RESOURCES, buf);
- }
- immed_data = cmd->immediate_data;
diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
index 24884ca..26c8220 100644
--- a/drivers/target/sbp/sbp_target.c
@@ -53369,7 +53337,7 @@ index 2ebe47b..3205833 100644
dlci->modem_rx = 0;
diff --git a/drivers/tty/n_tty.c b/drivers/tty/n_tty.c
-index 850e232..59a0ccd 100644
+index 8ab46ad..b8db1e2 100644
--- a/drivers/tty/n_tty.c
+++ b/drivers/tty/n_tty.c
@@ -115,7 +115,7 @@ struct n_tty_data {
@@ -53381,7 +53349,7 @@ index 850e232..59a0ccd 100644
size_t line_start;
/* protected by output lock */
-@@ -2526,6 +2526,7 @@ void n_tty_inherit_ops(struct tty_ldisc_ops *ops)
+@@ -2578,6 +2578,7 @@ void n_tty_inherit_ops(struct tty_ldisc_ops *ops)
{
*ops = tty_ldisc_N_TTY;
ops->owner = NULL;
@@ -58532,7 +58500,7 @@ index ce25d75..dc09eeb 100644
&data);
if (!inode) {
diff --git a/fs/aio.c b/fs/aio.c
-index 2f7e8c2..6c0f6ec 100644
+index 3241659..62856eb 100644
--- a/fs/aio.c
+++ b/fs/aio.c
@@ -389,7 +389,7 @@ static int aio_setup_ring(struct kioctx *ctx)
@@ -60247,10 +60215,10 @@ index 5d12d69..161d0ce 100644
GLOBAL_EXTERN atomic_t smBufAllocCount;
GLOBAL_EXTERN atomic_t midCount;
diff --git a/fs/cifs/file.c b/fs/cifs/file.c
-index 0218a9b..2f1ac75 100644
+index 40ddb6e..8f3e755 100644
--- a/fs/cifs/file.c
+++ b/fs/cifs/file.c
-@@ -1904,10 +1904,14 @@ static int cifs_writepages(struct address_space *mapping,
+@@ -1905,10 +1905,14 @@ static int cifs_writepages(struct address_space *mapping,
index = mapping->writeback_index; /* Start from prev offset */
end = -1;
} else {
@@ -60400,7 +60368,7 @@ index e9ad8d3..6395e45 100644
}
diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c
-index 34a17d4..9ca186f 100644
+index 30f3eb5..a01371c 100644
--- a/fs/cifs/smb2ops.c
+++ b/fs/cifs/smb2ops.c
@@ -364,8 +364,8 @@ smb2_clear_stats(struct cifs_tcon *tcon)
@@ -81997,7 +81965,7 @@ index 4d89e0e..5281847 100644
/* flags */
#define CPUFREQ_STICKY (1 << 0) /* driver isn't removed even if
diff --git a/include/linux/cpuidle.h b/include/linux/cpuidle.h
-index 50fcbb0..9d2dbd9 100644
+index d133817..3429a09 100644
--- a/include/linux/cpuidle.h
+++ b/include/linux/cpuidle.h
@@ -50,7 +50,8 @@ struct cpuidle_state {
@@ -82010,7 +81978,7 @@ index 50fcbb0..9d2dbd9 100644
/* Idle State Flags */
#define CPUIDLE_FLAG_TIME_VALID (0x01) /* is residency time measurable? */
-@@ -192,7 +193,7 @@ struct cpuidle_governor {
+@@ -191,7 +192,7 @@ struct cpuidle_governor {
void (*reflect) (struct cpuidle_device *dev, int index);
struct module *owner;
@@ -94129,7 +94097,7 @@ index a63f4dc..349bbb0 100644
unsigned long timeout)
{
diff --git a/kernel/sched/core.c b/kernel/sched/core.c
-index 9a3f3c4..943fa11 100644
+index 5e973ef..9a0e514 100644
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -1775,7 +1775,7 @@ void set_numabalancing_state(bool enabled)
@@ -94153,7 +94121,7 @@ index 9a3f3c4..943fa11 100644
if (!prev->mm) {
prev->active_mm = NULL;
-@@ -3053,6 +3055,8 @@ int can_nice(const struct task_struct *p, const int nice)
+@@ -3055,6 +3057,8 @@ int can_nice(const struct task_struct *p, const int nice)
/* convert nice value [19,-20] to rlimit style value [1,40] */
int nice_rlim = 20 - nice;
@@ -94162,7 +94130,7 @@ index 9a3f3c4..943fa11 100644
return (nice_rlim <= task_rlimit(p, RLIMIT_NICE) ||
capable(CAP_SYS_NICE));
}
-@@ -3086,7 +3090,8 @@ SYSCALL_DEFINE1(nice, int, increment)
+@@ -3088,7 +3092,8 @@ SYSCALL_DEFINE1(nice, int, increment)
if (nice > 19)
nice = 19;
@@ -94172,7 +94140,7 @@ index 9a3f3c4..943fa11 100644
return -EPERM;
retval = security_task_setnice(current, nice);
-@@ -3359,6 +3364,7 @@ recheck:
+@@ -3361,6 +3366,7 @@ recheck:
if (policy != p->policy && !rlim_rtprio)
return -EPERM;
@@ -94180,7 +94148,7 @@ index 9a3f3c4..943fa11 100644
/* can't increase priority */
if (attr->sched_priority > p->rt_priority &&
attr->sched_priority > rlim_rtprio)
-@@ -4732,8 +4738,10 @@ void idle_task_exit(void)
+@@ -4734,8 +4740,10 @@ void idle_task_exit(void)
BUG_ON(cpu_online(smp_processor_id()));
@@ -94192,7 +94160,7 @@ index 9a3f3c4..943fa11 100644
mmdrop(mm);
}
-@@ -4811,7 +4819,7 @@ static void migrate_tasks(unsigned int dead_cpu)
+@@ -4813,7 +4821,7 @@ static void migrate_tasks(unsigned int dead_cpu)
#if defined(CONFIG_SCHED_DEBUG) && defined(CONFIG_SYSCTL)
@@ -94201,7 +94169,7 @@ index 9a3f3c4..943fa11 100644
{
.procname = "sched_domain",
.mode = 0555,
-@@ -4828,17 +4836,17 @@ static struct ctl_table sd_ctl_root[] = {
+@@ -4830,17 +4838,17 @@ static struct ctl_table sd_ctl_root[] = {
{}
};
@@ -94223,7 +94191,7 @@ index 9a3f3c4..943fa11 100644
/*
* In the intermediate directories, both the child directory and
-@@ -4846,22 +4854,25 @@ static void sd_free_ctl_entry(struct ctl_table **tablep)
+@@ -4848,22 +4856,25 @@ static void sd_free_ctl_entry(struct ctl_table **tablep)
* will always be set. In the lowest directory the names are
* static strings and all have proc handlers.
*/
@@ -94255,7 +94223,7 @@ index 9a3f3c4..943fa11 100644
const char *procname, void *data, int maxlen,
umode_t mode, proc_handler *proc_handler,
bool load_idx)
-@@ -4881,7 +4892,7 @@ set_table_entry(struct ctl_table *entry,
+@@ -4883,7 +4894,7 @@ set_table_entry(struct ctl_table *entry,
static struct ctl_table *
sd_alloc_ctl_domain_table(struct sched_domain *sd)
{
@@ -94264,7 +94232,7 @@ index 9a3f3c4..943fa11 100644
if (table == NULL)
return NULL;
-@@ -4916,9 +4927,9 @@ sd_alloc_ctl_domain_table(struct sched_domain *sd)
+@@ -4918,9 +4929,9 @@ sd_alloc_ctl_domain_table(struct sched_domain *sd)
return table;
}
@@ -94276,7 +94244,7 @@ index 9a3f3c4..943fa11 100644
struct sched_domain *sd;
int domain_num = 0, i;
char buf[32];
-@@ -4945,11 +4956,13 @@ static struct ctl_table_header *sd_sysctl_header;
+@@ -4947,11 +4958,13 @@ static struct ctl_table_header *sd_sysctl_header;
static void register_sched_domain_sysctl(void)
{
int i, cpu_num = num_possible_cpus();
@@ -94291,7 +94259,7 @@ index 9a3f3c4..943fa11 100644
if (entry == NULL)
return;
-@@ -4972,8 +4985,12 @@ static void unregister_sched_domain_sysctl(void)
+@@ -4974,8 +4987,12 @@ static void unregister_sched_domain_sysctl(void)
if (sd_sysctl_header)
unregister_sysctl_table(sd_sysctl_header);
sd_sysctl_header = NULL;
@@ -99983,7 +99951,7 @@ index 76b3f90..d79b8e2 100644
struct mm_struct *mm;
diff --git a/mm/page-writeback.c b/mm/page-writeback.c
-index 9f45f87..749bfd8 100644
+index 51d8d15..24c90d7 100644
--- a/mm/page-writeback.c
+++ b/mm/page-writeback.c
@@ -685,7 +685,7 @@ static long long pos_ratio_polynom(unsigned long setpoint,
@@ -106251,43 +106219,6 @@ index 1a3c7e0..80f8b0c 100644
if (!llc_proc_dir)
goto out;
-diff --git a/net/llc/sysctl_net_llc.c b/net/llc/sysctl_net_llc.c
-index 612a5dd..799bafc 100644
---- a/net/llc/sysctl_net_llc.c
-+++ b/net/llc/sysctl_net_llc.c
-@@ -18,28 +18,28 @@ static struct ctl_table llc2_timeout_table[] = {
- {
- .procname = "ack",
- .data = &sysctl_llc2_ack_timeout,
-- .maxlen = sizeof(long),
-+ .maxlen = sizeof(sysctl_llc2_ack_timeout),
- .mode = 0644,
- .proc_handler = proc_dointvec_jiffies,
- },
- {
- .procname = "busy",
- .data = &sysctl_llc2_busy_timeout,
-- .maxlen = sizeof(long),
-+ .maxlen = sizeof(sysctl_llc2_busy_timeout),
- .mode = 0644,
- .proc_handler = proc_dointvec_jiffies,
- },
- {
- .procname = "p",
- .data = &sysctl_llc2_p_timeout,
-- .maxlen = sizeof(long),
-+ .maxlen = sizeof(sysctl_llc2_p_timeout),
- .mode = 0644,
- .proc_handler = proc_dointvec_jiffies,
- },
- {
- .procname = "rej",
- .data = &sysctl_llc2_rej_timeout,
-- .maxlen = sizeof(long),
-+ .maxlen = sizeof(sysctl_llc2_rej_timeout),
- .mode = 0644,
- .proc_handler = proc_dointvec_jiffies,
- },
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index 453e974..b3a43a5 100644
--- a/net/mac80211/cfg.c
@@ -107636,27 +107567,6 @@ index a82fb66..54c5c19 100644
continue;
}
list_del_init(&rm->m_conn_item);
-diff --git a/net/rds/sysctl.c b/net/rds/sysctl.c
-index b5cb2aa..35773ad 100644
---- a/net/rds/sysctl.c
-+++ b/net/rds/sysctl.c
-@@ -71,14 +71,14 @@ static struct ctl_table rds_sysctl_rds_table[] = {
- {
- .procname = "max_unacked_packets",
- .data = &rds_sysctl_max_unacked_packets,
-- .maxlen = sizeof(unsigned long),
-+ .maxlen = sizeof(int),
- .mode = 0644,
- .proc_handler = proc_dointvec,
- },
- {
- .procname = "max_unacked_bytes",
- .data = &rds_sysctl_max_unacked_bytes,
-- .maxlen = sizeof(unsigned long),
-+ .maxlen = sizeof(int),
- .mode = 0644,
- .proc_handler = proc_dointvec,
- },
diff --git a/net/rds/tcp.c b/net/rds/tcp.c
index edac9ef..16bcb98 100644
--- a/net/rds/tcp.c
@@ -111416,19 +111326,6 @@ index 9f05847..7933395 100644
rtnl_lock();
for_each_net(net)
rt_genid_bump_all(net);
-diff --git a/security/selinux/selinuxfs.c b/security/selinux/selinuxfs.c
-index d60c0ee..6c4cbd9 100644
---- a/security/selinux/selinuxfs.c
-+++ b/security/selinux/selinuxfs.c
-@@ -152,7 +152,7 @@ static ssize_t sel_write_enforce(struct file *file, const char __user *buf,
- goto out;
-
- /* No partial writes. */
-- length = EINVAL;
-+ length = -EINVAL;
- if (*ppos != 0)
- goto out;
-
diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c
index 14f52be..7352368 100644
--- a/security/smack/smack_lsm.c
diff --git a/3.14.38/4425_grsec_remove_EI_PAX.patch b/3.14.39/4425_grsec_remove_EI_PAX.patch
index 86e242a..86e242a 100644
--- a/3.14.38/4425_grsec_remove_EI_PAX.patch
+++ b/3.14.39/4425_grsec_remove_EI_PAX.patch
diff --git a/3.14.38/4427_force_XATTR_PAX_tmpfs.patch b/3.14.39/4427_force_XATTR_PAX_tmpfs.patch
index 4c236cc..4c236cc 100644
--- a/3.14.38/4427_force_XATTR_PAX_tmpfs.patch
+++ b/3.14.39/4427_force_XATTR_PAX_tmpfs.patch
diff --git a/3.14.38/4430_grsec-remove-localversion-grsec.patch b/3.14.39/4430_grsec-remove-localversion-grsec.patch
index 31cf878..31cf878 100644
--- a/3.14.38/4430_grsec-remove-localversion-grsec.patch
+++ b/3.14.39/4430_grsec-remove-localversion-grsec.patch
diff --git a/3.14.38/4435_grsec-mute-warnings.patch b/3.14.39/4435_grsec-mute-warnings.patch
index 392cefb..392cefb 100644
--- a/3.14.38/4435_grsec-mute-warnings.patch
+++ b/3.14.39/4435_grsec-mute-warnings.patch
diff --git a/3.14.38/4440_grsec-remove-protected-paths.patch b/3.14.39/4440_grsec-remove-protected-paths.patch
index 741546d..741546d 100644
--- a/3.14.38/4440_grsec-remove-protected-paths.patch
+++ b/3.14.39/4440_grsec-remove-protected-paths.patch
diff --git a/3.14.38/4450_grsec-kconfig-default-gids.patch b/3.14.39/4450_grsec-kconfig-default-gids.patch
index 8c878fc..8c878fc 100644
--- a/3.14.38/4450_grsec-kconfig-default-gids.patch
+++ b/3.14.39/4450_grsec-kconfig-default-gids.patch
diff --git a/3.14.38/4465_selinux-avc_audit-log-curr_ip.patch b/3.14.39/4465_selinux-avc_audit-log-curr_ip.patch
index bba906e..bba906e 100644
--- a/3.14.38/4465_selinux-avc_audit-log-curr_ip.patch
+++ b/3.14.39/4465_selinux-avc_audit-log-curr_ip.patch
diff --git a/3.14.38/4470_disable-compat_vdso.patch b/3.14.39/4470_disable-compat_vdso.patch
index 3b3953b..3b3953b 100644
--- a/3.14.38/4470_disable-compat_vdso.patch
+++ b/3.14.39/4470_disable-compat_vdso.patch
diff --git a/3.14.38/4475_emutramp_default_on.patch b/3.14.39/4475_emutramp_default_on.patch
index ad4967a..ad4967a 100644
--- a/3.14.38/4475_emutramp_default_on.patch
+++ b/3.14.39/4475_emutramp_default_on.patch
diff --git a/3.19.4/1003_linux-3.19.4.patch b/3.19.4/1003_linux-3.19.4.patch
deleted file mode 100644
index 4c73b31..0000000
--- a/3.19.4/1003_linux-3.19.4.patch
+++ /dev/null
@@ -1,3185 +0,0 @@
-diff --git a/Makefile b/Makefile
-index 713bf26..2ef2078 100644
---- a/Makefile
-+++ b/Makefile
-@@ -1,6 +1,6 @@
- VERSION = 3
- PATCHLEVEL = 19
--SUBLEVEL = 3
-+SUBLEVEL = 4
- EXTRAVERSION =
- NAME = Diseased Newt
-
-diff --git a/arch/arm64/include/asm/cmpxchg.h b/arch/arm64/include/asm/cmpxchg.h
-index cb95930..d8c25b7 100644
---- a/arch/arm64/include/asm/cmpxchg.h
-+++ b/arch/arm64/include/asm/cmpxchg.h
-@@ -246,14 +246,30 @@ static inline unsigned long __cmpxchg_mb(volatile void *ptr, unsigned long old,
- __ret; \
- })
-
--#define this_cpu_cmpxchg_1(ptr, o, n) cmpxchg_local(raw_cpu_ptr(&(ptr)), o, n)
--#define this_cpu_cmpxchg_2(ptr, o, n) cmpxchg_local(raw_cpu_ptr(&(ptr)), o, n)
--#define this_cpu_cmpxchg_4(ptr, o, n) cmpxchg_local(raw_cpu_ptr(&(ptr)), o, n)
--#define this_cpu_cmpxchg_8(ptr, o, n) cmpxchg_local(raw_cpu_ptr(&(ptr)), o, n)
--
--#define this_cpu_cmpxchg_double_8(ptr1, ptr2, o1, o2, n1, n2) \
-- cmpxchg_double_local(raw_cpu_ptr(&(ptr1)), raw_cpu_ptr(&(ptr2)), \
-- o1, o2, n1, n2)
-+#define _protect_cmpxchg_local(pcp, o, n) \
-+({ \
-+ typeof(*raw_cpu_ptr(&(pcp))) __ret; \
-+ preempt_disable(); \
-+ __ret = cmpxchg_local(raw_cpu_ptr(&(pcp)), o, n); \
-+ preempt_enable(); \
-+ __ret; \
-+})
-+
-+#define this_cpu_cmpxchg_1(ptr, o, n) _protect_cmpxchg_local(ptr, o, n)
-+#define this_cpu_cmpxchg_2(ptr, o, n) _protect_cmpxchg_local(ptr, o, n)
-+#define this_cpu_cmpxchg_4(ptr, o, n) _protect_cmpxchg_local(ptr, o, n)
-+#define this_cpu_cmpxchg_8(ptr, o, n) _protect_cmpxchg_local(ptr, o, n)
-+
-+#define this_cpu_cmpxchg_double_8(ptr1, ptr2, o1, o2, n1, n2) \
-+({ \
-+ int __ret; \
-+ preempt_disable(); \
-+ __ret = cmpxchg_double_local( raw_cpu_ptr(&(ptr1)), \
-+ raw_cpu_ptr(&(ptr2)), \
-+ o1, o2, n1, n2); \
-+ preempt_enable(); \
-+ __ret; \
-+})
-
- #define cmpxchg64(ptr,o,n) cmpxchg((ptr),(o),(n))
- #define cmpxchg64_local(ptr,o,n) cmpxchg_local((ptr),(o),(n))
-diff --git a/arch/arm64/include/asm/mmu_context.h b/arch/arm64/include/asm/mmu_context.h
-index a9eee33..101a42b 100644
---- a/arch/arm64/include/asm/mmu_context.h
-+++ b/arch/arm64/include/asm/mmu_context.h
-@@ -151,6 +151,15 @@ switch_mm(struct mm_struct *prev, struct mm_struct *next,
- {
- unsigned int cpu = smp_processor_id();
-
-+ /*
-+ * init_mm.pgd does not contain any user mappings and it is always
-+ * active for kernel addresses in TTBR1. Just set the reserved TTBR0.
-+ */
-+ if (next == &init_mm) {
-+ cpu_set_reserved_ttbr0();
-+ return;
-+ }
-+
- if (!cpumask_test_and_set_cpu(cpu, mm_cpumask(next)) || prev != next)
- check_and_switch_context(next, tsk);
- }
-diff --git a/arch/arm64/include/asm/percpu.h b/arch/arm64/include/asm/percpu.h
-index 09da25b..4fde8c1 100644
---- a/arch/arm64/include/asm/percpu.h
-+++ b/arch/arm64/include/asm/percpu.h
-@@ -204,25 +204,47 @@ static inline unsigned long __percpu_xchg(void *ptr, unsigned long val,
- return ret;
- }
-
-+#define _percpu_read(pcp) \
-+({ \
-+ typeof(pcp) __retval; \
-+ preempt_disable(); \
-+ __retval = (typeof(pcp))__percpu_read(raw_cpu_ptr(&(pcp)), \
-+ sizeof(pcp)); \
-+ preempt_enable(); \
-+ __retval; \
-+})
-+
-+#define _percpu_write(pcp, val) \
-+do { \
-+ preempt_disable(); \
-+ __percpu_write(raw_cpu_ptr(&(pcp)), (unsigned long)(val), \
-+ sizeof(pcp)); \
-+ preempt_enable(); \
-+} while(0) \
-+
-+#define _pcp_protect(operation, pcp, val) \
-+({ \
-+ typeof(pcp) __retval; \
-+ preempt_disable(); \
-+ __retval = (typeof(pcp))operation(raw_cpu_ptr(&(pcp)), \
-+ (val), sizeof(pcp)); \
-+ preempt_enable(); \
-+ __retval; \
-+})
-+
- #define _percpu_add(pcp, val) \
-- __percpu_add(raw_cpu_ptr(&(pcp)), val, sizeof(pcp))
-+ _pcp_protect(__percpu_add, pcp, val)
-
--#define _percpu_add_return(pcp, val) (typeof(pcp)) (_percpu_add(pcp, val))
-+#define _percpu_add_return(pcp, val) _percpu_add(pcp, val)
-
- #define _percpu_and(pcp, val) \
-- __percpu_and(raw_cpu_ptr(&(pcp)), val, sizeof(pcp))
-+ _pcp_protect(__percpu_and, pcp, val)
-
- #define _percpu_or(pcp, val) \
-- __percpu_or(raw_cpu_ptr(&(pcp)), val, sizeof(pcp))
--
--#define _percpu_read(pcp) (typeof(pcp)) \
-- (__percpu_read(raw_cpu_ptr(&(pcp)), sizeof(pcp)))
--
--#define _percpu_write(pcp, val) \
-- __percpu_write(raw_cpu_ptr(&(pcp)), (unsigned long)(val), sizeof(pcp))
-+ _pcp_protect(__percpu_or, pcp, val)
-
- #define _percpu_xchg(pcp, val) (typeof(pcp)) \
-- (__percpu_xchg(raw_cpu_ptr(&(pcp)), (unsigned long)(val), sizeof(pcp)))
-+ _pcp_protect(__percpu_xchg, pcp, (unsigned long)(val))
-
- #define this_cpu_add_1(pcp, val) _percpu_add(pcp, val)
- #define this_cpu_add_2(pcp, val) _percpu_add(pcp, val)
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-index 1382fec..7fcb1ac 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-0.dtsi
-@@ -50,6 +50,7 @@ ethernet@b0000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b0000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-index 221cd2e..9f25427 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-1.dtsi
-@@ -50,6 +50,7 @@ ethernet@b1000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b1000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi b/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-index 61456c3..cd7c318 100644
---- a/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-+++ b/arch/powerpc/boot/dts/fsl/pq3-etsec2-2.dtsi
-@@ -49,6 +49,7 @@ ethernet@b2000 {
- fsl,num_tx_queues = <0x8>;
- fsl,magic-packet;
- local-mac-address = [ 00 00 00 00 00 00 ];
-+ ranges;
-
- queue-group@b2000 {
- #address-cells = <1>;
-diff --git a/arch/powerpc/kernel/exceptions-64s.S b/arch/powerpc/kernel/exceptions-64s.S
-index c2df815..9519e6b 100644
---- a/arch/powerpc/kernel/exceptions-64s.S
-+++ b/arch/powerpc/kernel/exceptions-64s.S
-@@ -1408,7 +1408,7 @@ machine_check_handle_early:
- bne 9f /* continue in V mode if we are. */
-
- 5:
--#ifdef CONFIG_KVM_BOOK3S_64_HV
-+#ifdef CONFIG_KVM_BOOK3S_64_HANDLER
- /*
- * We are coming from kernel context. Check if we are coming from
- * guest. if yes, then we can continue. We will fall through
-diff --git a/arch/powerpc/platforms/pseries/mobility.c b/arch/powerpc/platforms/pseries/mobility.c
-index e7cb6d4..f8c9ff7 100644
---- a/arch/powerpc/platforms/pseries/mobility.c
-+++ b/arch/powerpc/platforms/pseries/mobility.c
-@@ -25,10 +25,10 @@
- static struct kobject *mobility_kobj;
-
- struct update_props_workarea {
-- u32 phandle;
-- u32 state;
-- u64 reserved;
-- u32 nprops;
-+ __be32 phandle;
-+ __be32 state;
-+ __be64 reserved;
-+ __be32 nprops;
- } __packed;
-
- #define NODE_ACTION_MASK 0xff000000
-@@ -54,11 +54,11 @@ static int mobility_rtas_call(int token, char *buf, s32 scope)
- return rc;
- }
-
--static int delete_dt_node(u32 phandle)
-+static int delete_dt_node(__be32 phandle)
- {
- struct device_node *dn;
-
-- dn = of_find_node_by_phandle(phandle);
-+ dn = of_find_node_by_phandle(be32_to_cpu(phandle));
- if (!dn)
- return -ENOENT;
-
-@@ -127,7 +127,7 @@ static int update_dt_property(struct device_node *dn, struct property **prop,
- return 0;
- }
-
--static int update_dt_node(u32 phandle, s32 scope)
-+static int update_dt_node(__be32 phandle, s32 scope)
- {
- struct update_props_workarea *upwa;
- struct device_node *dn;
-@@ -136,6 +136,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- char *prop_data;
- char *rtas_buf;
- int update_properties_token;
-+ u32 nprops;
- u32 vd;
-
- update_properties_token = rtas_token("ibm,update-properties");
-@@ -146,7 +147,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- if (!rtas_buf)
- return -ENOMEM;
-
-- dn = of_find_node_by_phandle(phandle);
-+ dn = of_find_node_by_phandle(be32_to_cpu(phandle));
- if (!dn) {
- kfree(rtas_buf);
- return -ENOENT;
-@@ -162,6 +163,7 @@ static int update_dt_node(u32 phandle, s32 scope)
- break;
-
- prop_data = rtas_buf + sizeof(*upwa);
-+ nprops = be32_to_cpu(upwa->nprops);
-
- /* On the first call to ibm,update-properties for a node the
- * the first property value descriptor contains an empty
-@@ -170,17 +172,17 @@ static int update_dt_node(u32 phandle, s32 scope)
- */
- if (*prop_data == 0) {
- prop_data++;
-- vd = *(u32 *)prop_data;
-+ vd = be32_to_cpu(*(__be32 *)prop_data);
- prop_data += vd + sizeof(vd);
-- upwa->nprops--;
-+ nprops--;
- }
-
-- for (i = 0; i < upwa->nprops; i++) {
-+ for (i = 0; i < nprops; i++) {
- char *prop_name;
-
- prop_name = prop_data;
- prop_data += strlen(prop_name) + 1;
-- vd = *(u32 *)prop_data;
-+ vd = be32_to_cpu(*(__be32 *)prop_data);
- prop_data += sizeof(vd);
-
- switch (vd) {
-@@ -212,13 +214,13 @@ static int update_dt_node(u32 phandle, s32 scope)
- return 0;
- }
-
--static int add_dt_node(u32 parent_phandle, u32 drc_index)
-+static int add_dt_node(__be32 parent_phandle, __be32 drc_index)
- {
- struct device_node *dn;
- struct device_node *parent_dn;
- int rc;
-
-- parent_dn = of_find_node_by_phandle(parent_phandle);
-+ parent_dn = of_find_node_by_phandle(be32_to_cpu(parent_phandle));
- if (!parent_dn)
- return -ENOENT;
-
-@@ -237,7 +239,7 @@ static int add_dt_node(u32 parent_phandle, u32 drc_index)
- int pseries_devicetree_update(s32 scope)
- {
- char *rtas_buf;
-- u32 *data;
-+ __be32 *data;
- int update_nodes_token;
- int rc;
-
-@@ -254,17 +256,17 @@ int pseries_devicetree_update(s32 scope)
- if (rc && rc != 1)
- break;
-
-- data = (u32 *)rtas_buf + 4;
-- while (*data & NODE_ACTION_MASK) {
-+ data = (__be32 *)rtas_buf + 4;
-+ while (be32_to_cpu(*data) & NODE_ACTION_MASK) {
- int i;
-- u32 action = *data & NODE_ACTION_MASK;
-- int node_count = *data & NODE_COUNT_MASK;
-+ u32 action = be32_to_cpu(*data) & NODE_ACTION_MASK;
-+ u32 node_count = be32_to_cpu(*data) & NODE_COUNT_MASK;
-
- data++;
-
- for (i = 0; i < node_count; i++) {
-- u32 phandle = *data++;
-- u32 drc_index;
-+ __be32 phandle = *data++;
-+ __be32 drc_index;
-
- switch (action) {
- case DELETE_DT_NODE:
-diff --git a/drivers/base/regmap/internal.h b/drivers/base/regmap/internal.h
-index 0da5865..8e1f5f6 100644
---- a/drivers/base/regmap/internal.h
-+++ b/drivers/base/regmap/internal.h
-@@ -237,4 +237,12 @@ extern struct regcache_ops regcache_rbtree_ops;
- extern struct regcache_ops regcache_lzo_ops;
- extern struct regcache_ops regcache_flat_ops;
-
-+static inline const char *regmap_name(const struct regmap *map)
-+{
-+ if (map->dev)
-+ return dev_name(map->dev);
-+
-+ return map->name;
-+}
-+
- #endif
-diff --git a/drivers/base/regmap/regcache-rbtree.c b/drivers/base/regmap/regcache-rbtree.c
-index d453a2c..81751a4 100644
---- a/drivers/base/regmap/regcache-rbtree.c
-+++ b/drivers/base/regmap/regcache-rbtree.c
-@@ -307,7 +307,7 @@ static int regcache_rbtree_insert_to_block(struct regmap *map,
- if (pos == 0) {
- memmove(blk + offset * map->cache_word_size,
- blk, rbnode->blklen * map->cache_word_size);
-- bitmap_shift_right(present, present, offset, blklen);
-+ bitmap_shift_left(present, present, offset, blklen);
- }
-
- /* update the rbnode block, its size and the base register */
-diff --git a/drivers/base/regmap/regcache.c b/drivers/base/regmap/regcache.c
-index f373c35..f5db662 100644
---- a/drivers/base/regmap/regcache.c
-+++ b/drivers/base/regmap/regcache.c
-@@ -218,7 +218,7 @@ int regcache_read(struct regmap *map,
- ret = map->cache_ops->read(map, reg, value);
-
- if (ret == 0)
-- trace_regmap_reg_read_cache(map->dev, reg, *value);
-+ trace_regmap_reg_read_cache(map, reg, *value);
-
- return ret;
- }
-@@ -311,7 +311,7 @@ int regcache_sync(struct regmap *map)
- dev_dbg(map->dev, "Syncing %s cache\n",
- map->cache_ops->name);
- name = map->cache_ops->name;
-- trace_regcache_sync(map->dev, name, "start");
-+ trace_regcache_sync(map, name, "start");
-
- if (!map->cache_dirty)
- goto out;
-@@ -346,7 +346,7 @@ out:
-
- regmap_async_complete(map);
-
-- trace_regcache_sync(map->dev, name, "stop");
-+ trace_regcache_sync(map, name, "stop");
-
- return ret;
- }
-@@ -381,7 +381,7 @@ int regcache_sync_region(struct regmap *map, unsigned int min,
- name = map->cache_ops->name;
- dev_dbg(map->dev, "Syncing %s cache from %d-%d\n", name, min, max);
-
-- trace_regcache_sync(map->dev, name, "start region");
-+ trace_regcache_sync(map, name, "start region");
-
- if (!map->cache_dirty)
- goto out;
-@@ -401,7 +401,7 @@ out:
-
- regmap_async_complete(map);
-
-- trace_regcache_sync(map->dev, name, "stop region");
-+ trace_regcache_sync(map, name, "stop region");
-
- return ret;
- }
-@@ -428,7 +428,7 @@ int regcache_drop_region(struct regmap *map, unsigned int min,
-
- map->lock(map->lock_arg);
-
-- trace_regcache_drop_region(map->dev, min, max);
-+ trace_regcache_drop_region(map, min, max);
-
- ret = map->cache_ops->drop(map, min, max);
-
-@@ -455,7 +455,7 @@ void regcache_cache_only(struct regmap *map, bool enable)
- map->lock(map->lock_arg);
- WARN_ON(map->cache_bypass && enable);
- map->cache_only = enable;
-- trace_regmap_cache_only(map->dev, enable);
-+ trace_regmap_cache_only(map, enable);
- map->unlock(map->lock_arg);
- }
- EXPORT_SYMBOL_GPL(regcache_cache_only);
-@@ -493,7 +493,7 @@ void regcache_cache_bypass(struct regmap *map, bool enable)
- map->lock(map->lock_arg);
- WARN_ON(map->cache_only && enable);
- map->cache_bypass = enable;
-- trace_regmap_cache_bypass(map->dev, enable);
-+ trace_regmap_cache_bypass(map, enable);
- map->unlock(map->lock_arg);
- }
- EXPORT_SYMBOL_GPL(regcache_cache_bypass);
-diff --git a/drivers/base/regmap/regmap.c b/drivers/base/regmap/regmap.c
-index d2f8a81..ee731bb 100644
---- a/drivers/base/regmap/regmap.c
-+++ b/drivers/base/regmap/regmap.c
-@@ -1280,7 +1280,7 @@ int _regmap_raw_write(struct regmap *map, unsigned int reg,
- if (map->async && map->bus->async_write) {
- struct regmap_async *async;
-
-- trace_regmap_async_write_start(map->dev, reg, val_len);
-+ trace_regmap_async_write_start(map, reg, val_len);
-
- spin_lock_irqsave(&map->async_lock, flags);
- async = list_first_entry_or_null(&map->async_free,
-@@ -1338,8 +1338,7 @@ int _regmap_raw_write(struct regmap *map, unsigned int reg,
- return ret;
- }
-
-- trace_regmap_hw_write_start(map->dev, reg,
-- val_len / map->format.val_bytes);
-+ trace_regmap_hw_write_start(map, reg, val_len / map->format.val_bytes);
-
- /* If we're doing a single register write we can probably just
- * send the work_buf directly, otherwise try to do a gather
-@@ -1371,8 +1370,7 @@ int _regmap_raw_write(struct regmap *map, unsigned int reg,
- kfree(buf);
- }
-
-- trace_regmap_hw_write_done(map->dev, reg,
-- val_len / map->format.val_bytes);
-+ trace_regmap_hw_write_done(map, reg, val_len / map->format.val_bytes);
-
- return ret;
- }
-@@ -1406,12 +1404,12 @@ static int _regmap_bus_formatted_write(void *context, unsigned int reg,
-
- map->format.format_write(map, reg, val);
-
-- trace_regmap_hw_write_start(map->dev, reg, 1);
-+ trace_regmap_hw_write_start(map, reg, 1);
-
- ret = map->bus->write(map->bus_context, map->work_buf,
- map->format.buf_size);
-
-- trace_regmap_hw_write_done(map->dev, reg, 1);
-+ trace_regmap_hw_write_done(map, reg, 1);
-
- return ret;
- }
-@@ -1469,7 +1467,7 @@ int _regmap_write(struct regmap *map, unsigned int reg,
- dev_info(map->dev, "%x <= %x\n", reg, val);
- #endif
-
-- trace_regmap_reg_write(map->dev, reg, val);
-+ trace_regmap_reg_write(map, reg, val);
-
- return map->reg_write(context, reg, val);
- }
-@@ -1772,7 +1770,7 @@ static int _regmap_raw_multi_reg_write(struct regmap *map,
- for (i = 0; i < num_regs; i++) {
- int reg = regs[i].reg;
- int val = regs[i].def;
-- trace_regmap_hw_write_start(map->dev, reg, 1);
-+ trace_regmap_hw_write_start(map, reg, 1);
- map->format.format_reg(u8, reg, map->reg_shift);
- u8 += reg_bytes + pad_bytes;
- map->format.format_val(u8, val, 0);
-@@ -1787,7 +1785,7 @@ static int _regmap_raw_multi_reg_write(struct regmap *map,
-
- for (i = 0; i < num_regs; i++) {
- int reg = regs[i].reg;
-- trace_regmap_hw_write_done(map->dev, reg, 1);
-+ trace_regmap_hw_write_done(map, reg, 1);
- }
- return ret;
- }
-@@ -2058,15 +2056,13 @@ static int _regmap_raw_read(struct regmap *map, unsigned int reg, void *val,
- */
- u8[0] |= map->read_flag_mask;
-
-- trace_regmap_hw_read_start(map->dev, reg,
-- val_len / map->format.val_bytes);
-+ trace_regmap_hw_read_start(map, reg, val_len / map->format.val_bytes);
-
- ret = map->bus->read(map->bus_context, map->work_buf,
- map->format.reg_bytes + map->format.pad_bytes,
- val, val_len);
-
-- trace_regmap_hw_read_done(map->dev, reg,
-- val_len / map->format.val_bytes);
-+ trace_regmap_hw_read_done(map, reg, val_len / map->format.val_bytes);
-
- return ret;
- }
-@@ -2122,7 +2118,7 @@ static int _regmap_read(struct regmap *map, unsigned int reg,
- dev_info(map->dev, "%x => %x\n", reg, *val);
- #endif
-
-- trace_regmap_reg_read(map->dev, reg, *val);
-+ trace_regmap_reg_read(map, reg, *val);
-
- if (!map->cache_bypass)
- regcache_write(map, reg, *val);
-@@ -2479,7 +2475,7 @@ void regmap_async_complete_cb(struct regmap_async *async, int ret)
- struct regmap *map = async->map;
- bool wake;
-
-- trace_regmap_async_io_complete(map->dev);
-+ trace_regmap_async_io_complete(map);
-
- spin_lock(&map->async_lock);
- list_move(&async->list, &map->async_free);
-@@ -2524,7 +2520,7 @@ int regmap_async_complete(struct regmap *map)
- if (!map->bus || !map->bus->async_write)
- return 0;
-
-- trace_regmap_async_complete_start(map->dev);
-+ trace_regmap_async_complete_start(map);
-
- wait_event(map->async_waitq, regmap_async_is_done(map));
-
-@@ -2533,7 +2529,7 @@ int regmap_async_complete(struct regmap *map)
- map->async_ret = 0;
- spin_unlock_irqrestore(&map->async_lock, flags);
-
-- trace_regmap_async_complete_done(map->dev);
-+ trace_regmap_async_complete_done(map);
-
- return ret;
- }
-diff --git a/drivers/clocksource/time-efm32.c b/drivers/clocksource/time-efm32.c
-index bba62f9..ec57ba2 100644
---- a/drivers/clocksource/time-efm32.c
-+++ b/drivers/clocksource/time-efm32.c
-@@ -225,12 +225,12 @@ static int __init efm32_clockevent_init(struct device_node *np)
- clock_event_ddata.base = base;
- clock_event_ddata.periodic_top = DIV_ROUND_CLOSEST(rate, 1024 * HZ);
-
-- setup_irq(irq, &efm32_clock_event_irq);
--
- clockevents_config_and_register(&clock_event_ddata.evtdev,
- DIV_ROUND_CLOSEST(rate, 1024),
- 0xf, 0xffff);
-
-+ setup_irq(irq, &efm32_clock_event_irq);
-+
- return 0;
-
- err_get_irq:
-diff --git a/drivers/clocksource/timer-sun5i.c b/drivers/clocksource/timer-sun5i.c
-index 0226844..5dcbf90 100644
---- a/drivers/clocksource/timer-sun5i.c
-+++ b/drivers/clocksource/timer-sun5i.c
-@@ -178,10 +178,6 @@ static void __init sun5i_timer_init(struct device_node *node)
-
- ticks_per_jiffy = DIV_ROUND_UP(rate, HZ);
-
-- ret = setup_irq(irq, &sun5i_timer_irq);
-- if (ret)
-- pr_warn("failed to setup irq %d\n", irq);
--
- /* Enable timer0 interrupt */
- val = readl(timer_base + TIMER_IRQ_EN_REG);
- writel(val | TIMER_IRQ_EN(0), timer_base + TIMER_IRQ_EN_REG);
-@@ -191,6 +187,10 @@ static void __init sun5i_timer_init(struct device_node *node)
-
- clockevents_config_and_register(&sun5i_clockevent, rate,
- TIMER_SYNC_TICKS, 0xffffffff);
-+
-+ ret = setup_irq(irq, &sun5i_timer_irq);
-+ if (ret)
-+ pr_warn("failed to setup irq %d\n", irq);
- }
- CLOCKSOURCE_OF_DECLARE(sun5i_a13, "allwinner,sun5i-a13-hstimer",
- sun5i_timer_init);
-diff --git a/drivers/cpuidle/cpuidle-mvebu-v7.c b/drivers/cpuidle/cpuidle-mvebu-v7.c
-index 38e6861..cefa074 100644
---- a/drivers/cpuidle/cpuidle-mvebu-v7.c
-+++ b/drivers/cpuidle/cpuidle-mvebu-v7.c
-@@ -37,11 +37,11 @@ static int mvebu_v7_enter_idle(struct cpuidle_device *dev,
- deepidle = true;
-
- ret = mvebu_v7_cpu_suspend(deepidle);
-+ cpu_pm_exit();
-+
- if (ret)
- return ret;
-
-- cpu_pm_exit();
--
- return index;
- }
-
-diff --git a/drivers/dma/dw/platform.c b/drivers/dma/dw/platform.c
-index 32ea1ac..272f01f 100644
---- a/drivers/dma/dw/platform.c
-+++ b/drivers/dma/dw/platform.c
-@@ -26,6 +26,8 @@
-
- #include "internal.h"
-
-+#define DRV_NAME "dw_dmac"
-+
- static struct dma_chan *dw_dma_of_xlate(struct of_phandle_args *dma_spec,
- struct of_dma *ofdma)
- {
-@@ -284,7 +286,7 @@ static struct platform_driver dw_driver = {
- .remove = dw_remove,
- .shutdown = dw_shutdown,
- .driver = {
-- .name = "dw_dmac",
-+ .name = DRV_NAME,
- .pm = &dw_dev_pm_ops,
- .of_match_table = of_match_ptr(dw_dma_of_id_table),
- .acpi_match_table = ACPI_PTR(dw_dma_acpi_id_table),
-@@ -305,3 +307,4 @@ module_exit(dw_exit);
-
- MODULE_LICENSE("GPL v2");
- MODULE_DESCRIPTION("Synopsys DesignWare DMA Controller platform driver");
-+MODULE_ALIAS("platform:" DRV_NAME);
-diff --git a/drivers/input/mouse/synaptics.c b/drivers/input/mouse/synaptics.c
-index 23e26e0..2176874 100644
---- a/drivers/input/mouse/synaptics.c
-+++ b/drivers/input/mouse/synaptics.c
-@@ -120,32 +120,41 @@ void synaptics_reset(struct psmouse *psmouse)
-
- static bool cr48_profile_sensor;
-
-+#define ANY_BOARD_ID 0
- struct min_max_quirk {
- const char * const *pnp_ids;
-+ struct {
-+ unsigned long int min, max;
-+ } board_id;
- int x_min, x_max, y_min, y_max;
- };
-
- static const struct min_max_quirk min_max_pnpid_table[] = {
- {
- (const char * const []){"LEN0033", NULL},
-+ {ANY_BOARD_ID, ANY_BOARD_ID},
- 1024, 5052, 2258, 4832
- },
- {
-- (const char * const []){"LEN0035", "LEN0042", NULL},
-+ (const char * const []){"LEN0042", NULL},
-+ {ANY_BOARD_ID, ANY_BOARD_ID},
- 1232, 5710, 1156, 4696
- },
- {
- (const char * const []){"LEN0034", "LEN0036", "LEN0037",
- "LEN0039", "LEN2002", "LEN2004",
- NULL},
-+ {ANY_BOARD_ID, 2961},
- 1024, 5112, 2024, 4832
- },
- {
- (const char * const []){"LEN2001", NULL},
-+ {ANY_BOARD_ID, ANY_BOARD_ID},
- 1024, 5022, 2508, 4832
- },
- {
- (const char * const []){"LEN2006", NULL},
-+ {ANY_BOARD_ID, ANY_BOARD_ID},
- 1264, 5675, 1171, 4688
- },
- { }
-@@ -241,6 +250,10 @@ static int synaptics_board_id(struct psmouse *psmouse)
- struct synaptics_data *priv = psmouse->private;
- unsigned char bid[3];
-
-+ /* firmwares prior 7.5 have no board_id encoded */
-+ if (SYN_ID_FULL(priv->identity) < 0x705)
-+ return 0;
-+
- if (synaptics_send_cmd(psmouse, SYN_QUE_MODES, bid))
- return -1;
- priv->board_id = ((bid[0] & 0xfc) << 6) | bid[1];
-@@ -343,7 +356,6 @@ static int synaptics_resolution(struct psmouse *psmouse)
- {
- struct synaptics_data *priv = psmouse->private;
- unsigned char resp[3];
-- int i;
-
- if (SYN_ID_MAJOR(priv->identity) < 4)
- return 0;
-@@ -355,17 +367,6 @@ static int synaptics_resolution(struct psmouse *psmouse)
- }
- }
-
-- for (i = 0; min_max_pnpid_table[i].pnp_ids; i++) {
-- if (psmouse_matches_pnp_id(psmouse,
-- min_max_pnpid_table[i].pnp_ids)) {
-- priv->x_min = min_max_pnpid_table[i].x_min;
-- priv->x_max = min_max_pnpid_table[i].x_max;
-- priv->y_min = min_max_pnpid_table[i].y_min;
-- priv->y_max = min_max_pnpid_table[i].y_max;
-- return 0;
-- }
-- }
--
- if (SYN_EXT_CAP_REQUESTS(priv->capabilities) >= 5 &&
- SYN_CAP_MAX_DIMENSIONS(priv->ext_cap_0c)) {
- if (synaptics_send_cmd(psmouse, SYN_QUE_EXT_MAX_COORDS, resp)) {
-@@ -374,23 +375,69 @@ static int synaptics_resolution(struct psmouse *psmouse)
- } else {
- priv->x_max = (resp[0] << 5) | ((resp[1] & 0x0f) << 1);
- priv->y_max = (resp[2] << 5) | ((resp[1] & 0xf0) >> 3);
-+ psmouse_info(psmouse,
-+ "queried max coordinates: x [..%d], y [..%d]\n",
-+ priv->x_max, priv->y_max);
- }
- }
-
-- if (SYN_EXT_CAP_REQUESTS(priv->capabilities) >= 7 &&
-- SYN_CAP_MIN_DIMENSIONS(priv->ext_cap_0c)) {
-+ if (SYN_CAP_MIN_DIMENSIONS(priv->ext_cap_0c) &&
-+ (SYN_EXT_CAP_REQUESTS(priv->capabilities) >= 7 ||
-+ /*
-+ * Firmware v8.1 does not report proper number of extended
-+ * capabilities, but has been proven to report correct min
-+ * coordinates.
-+ */
-+ SYN_ID_FULL(priv->identity) == 0x801)) {
- if (synaptics_send_cmd(psmouse, SYN_QUE_EXT_MIN_COORDS, resp)) {
- psmouse_warn(psmouse,
- "device claims to have min coordinates query, but I'm not able to read it.\n");
- } else {
- priv->x_min = (resp[0] << 5) | ((resp[1] & 0x0f) << 1);
- priv->y_min = (resp[2] << 5) | ((resp[1] & 0xf0) >> 3);
-+ psmouse_info(psmouse,
-+ "queried min coordinates: x [%d..], y [%d..]\n",
-+ priv->x_min, priv->y_min);
- }
- }
-
- return 0;
- }
-
-+/*
-+ * Apply quirk(s) if the hardware matches
-+ */
-+
-+static void synaptics_apply_quirks(struct psmouse *psmouse)
-+{
-+ struct synaptics_data *priv = psmouse->private;
-+ int i;
-+
-+ for (i = 0; min_max_pnpid_table[i].pnp_ids; i++) {
-+ if (!psmouse_matches_pnp_id(psmouse,
-+ min_max_pnpid_table[i].pnp_ids))
-+ continue;
-+
-+ if (min_max_pnpid_table[i].board_id.min != ANY_BOARD_ID &&
-+ priv->board_id < min_max_pnpid_table[i].board_id.min)
-+ continue;
-+
-+ if (min_max_pnpid_table[i].board_id.max != ANY_BOARD_ID &&
-+ priv->board_id > min_max_pnpid_table[i].board_id.max)
-+ continue;
-+
-+ priv->x_min = min_max_pnpid_table[i].x_min;
-+ priv->x_max = min_max_pnpid_table[i].x_max;
-+ priv->y_min = min_max_pnpid_table[i].y_min;
-+ priv->y_max = min_max_pnpid_table[i].y_max;
-+ psmouse_info(psmouse,
-+ "quirked min/max coordinates: x [%d..%d], y [%d..%d]\n",
-+ priv->x_min, priv->x_max,
-+ priv->y_min, priv->y_max);
-+ break;
-+ }
-+}
-+
- static int synaptics_query_hardware(struct psmouse *psmouse)
- {
- if (synaptics_identify(psmouse))
-@@ -406,6 +453,8 @@ static int synaptics_query_hardware(struct psmouse *psmouse)
- if (synaptics_resolution(psmouse))
- return -1;
-
-+ synaptics_apply_quirks(psmouse);
-+
- return 0;
- }
-
-@@ -613,6 +662,18 @@ static void synaptics_parse_agm(const unsigned char buf[],
- priv->agm_pending = true;
- }
-
-+static void synaptics_parse_ext_buttons(const unsigned char buf[],
-+ struct synaptics_data *priv,
-+ struct synaptics_hw_state *hw)
-+{
-+ unsigned int ext_bits =
-+ (SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap) + 1) >> 1;
-+ unsigned int ext_mask = GENMASK(ext_bits - 1, 0);
-+
-+ hw->ext_buttons = buf[4] & ext_mask;
-+ hw->ext_buttons |= (buf[5] & ext_mask) << ext_bits;
-+}
-+
- static bool is_forcepad;
-
- static int synaptics_parse_hw_state(const unsigned char buf[],
-@@ -699,28 +760,9 @@ static int synaptics_parse_hw_state(const unsigned char buf[],
- hw->down = ((buf[0] ^ buf[3]) & 0x02) ? 1 : 0;
- }
-
-- if (SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap) &&
-+ if (SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap) > 0 &&
- ((buf[0] ^ buf[3]) & 0x02)) {
-- switch (SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap) & ~0x01) {
-- default:
-- /*
-- * if nExtBtn is greater than 8 it should be
-- * considered invalid and treated as 0
-- */
-- break;
-- case 8:
-- hw->ext_buttons |= ((buf[5] & 0x08)) ? 0x80 : 0;
-- hw->ext_buttons |= ((buf[4] & 0x08)) ? 0x40 : 0;
-- case 6:
-- hw->ext_buttons |= ((buf[5] & 0x04)) ? 0x20 : 0;
-- hw->ext_buttons |= ((buf[4] & 0x04)) ? 0x10 : 0;
-- case 4:
-- hw->ext_buttons |= ((buf[5] & 0x02)) ? 0x08 : 0;
-- hw->ext_buttons |= ((buf[4] & 0x02)) ? 0x04 : 0;
-- case 2:
-- hw->ext_buttons |= ((buf[5] & 0x01)) ? 0x02 : 0;
-- hw->ext_buttons |= ((buf[4] & 0x01)) ? 0x01 : 0;
-- }
-+ synaptics_parse_ext_buttons(buf, priv, hw);
- }
- } else {
- hw->x = (((buf[1] & 0x1f) << 8) | buf[2]);
-@@ -782,12 +824,35 @@ static void synaptics_report_semi_mt_data(struct input_dev *dev,
- }
- }
-
-+static void synaptics_report_ext_buttons(struct psmouse *psmouse,
-+ const struct synaptics_hw_state *hw)
-+{
-+ struct input_dev *dev = psmouse->dev;
-+ struct synaptics_data *priv = psmouse->private;
-+ int ext_bits = (SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap) + 1) >> 1;
-+ int i;
-+
-+ if (!SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap))
-+ return;
-+
-+ /* Bug in FW 8.1, buttons are reported only when ExtBit is 1 */
-+ if (SYN_ID_FULL(priv->identity) == 0x801 &&
-+ !((psmouse->packet[0] ^ psmouse->packet[3]) & 0x02))
-+ return;
-+
-+ for (i = 0; i < ext_bits; i++) {
-+ input_report_key(dev, BTN_0 + 2 * i,
-+ hw->ext_buttons & (1 << i));
-+ input_report_key(dev, BTN_1 + 2 * i,
-+ hw->ext_buttons & (1 << (i + ext_bits)));
-+ }
-+}
-+
- static void synaptics_report_buttons(struct psmouse *psmouse,
- const struct synaptics_hw_state *hw)
- {
- struct input_dev *dev = psmouse->dev;
- struct synaptics_data *priv = psmouse->private;
-- int i;
-
- input_report_key(dev, BTN_LEFT, hw->left);
- input_report_key(dev, BTN_RIGHT, hw->right);
-@@ -800,8 +865,7 @@ static void synaptics_report_buttons(struct psmouse *psmouse,
- input_report_key(dev, BTN_BACK, hw->down);
- }
-
-- for (i = 0; i < SYN_CAP_MULTI_BUTTON_NO(priv->ext_cap); i++)
-- input_report_key(dev, BTN_0 + i, hw->ext_buttons & (1 << i));
-+ synaptics_report_ext_buttons(psmouse, hw);
- }
-
- static void synaptics_report_slot(struct input_dev *dev, int slot,
-diff --git a/drivers/md/dm-io.c b/drivers/md/dm-io.c
-index 37de017..74adcd2 100644
---- a/drivers/md/dm-io.c
-+++ b/drivers/md/dm-io.c
-@@ -289,9 +289,16 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- struct request_queue *q = bdev_get_queue(where->bdev);
- unsigned short logical_block_size = queue_logical_block_size(q);
- sector_t num_sectors;
-+ unsigned int uninitialized_var(special_cmd_max_sectors);
-
-- /* Reject unsupported discard requests */
-- if ((rw & REQ_DISCARD) && !blk_queue_discard(q)) {
-+ /*
-+ * Reject unsupported discard and write same requests.
-+ */
-+ if (rw & REQ_DISCARD)
-+ special_cmd_max_sectors = q->limits.max_discard_sectors;
-+ else if (rw & REQ_WRITE_SAME)
-+ special_cmd_max_sectors = q->limits.max_write_same_sectors;
-+ if ((rw & (REQ_DISCARD | REQ_WRITE_SAME)) && special_cmd_max_sectors == 0) {
- dec_count(io, region, -EOPNOTSUPP);
- return;
- }
-@@ -317,7 +324,7 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- store_io_and_region_in_bio(bio, io, region);
-
- if (rw & REQ_DISCARD) {
-- num_sectors = min_t(sector_t, q->limits.max_discard_sectors, remaining);
-+ num_sectors = min_t(sector_t, special_cmd_max_sectors, remaining);
- bio->bi_iter.bi_size = num_sectors << SECTOR_SHIFT;
- remaining -= num_sectors;
- } else if (rw & REQ_WRITE_SAME) {
-@@ -326,7 +333,7 @@ static void do_region(int rw, unsigned region, struct dm_io_region *where,
- */
- dp->get_page(dp, &page, &len, &offset);
- bio_add_page(bio, page, logical_block_size, offset);
-- num_sectors = min_t(sector_t, q->limits.max_write_same_sectors, remaining);
-+ num_sectors = min_t(sector_t, special_cmd_max_sectors, remaining);
- bio->bi_iter.bi_size = num_sectors << SECTOR_SHIFT;
-
- offset = 0;
-diff --git a/drivers/md/dm-snap.c b/drivers/md/dm-snap.c
-index 8b204ae2..f83a0f3 100644
---- a/drivers/md/dm-snap.c
-+++ b/drivers/md/dm-snap.c
-@@ -20,6 +20,8 @@
- #include <linux/log2.h>
- #include <linux/dm-kcopyd.h>
-
-+#include "dm.h"
-+
- #include "dm-exception-store.h"
-
- #define DM_MSG_PREFIX "snapshots"
-@@ -291,12 +293,23 @@ struct origin {
- };
-
- /*
-+ * This structure is allocated for each origin target
-+ */
-+struct dm_origin {
-+ struct dm_dev *dev;
-+ struct dm_target *ti;
-+ unsigned split_boundary;
-+ struct list_head hash_list;
-+};
-+
-+/*
- * Size of the hash table for origin volumes. If we make this
- * the size of the minors list then it should be nearly perfect
- */
- #define ORIGIN_HASH_SIZE 256
- #define ORIGIN_MASK 0xFF
- static struct list_head *_origins;
-+static struct list_head *_dm_origins;
- static struct rw_semaphore _origins_lock;
-
- static DECLARE_WAIT_QUEUE_HEAD(_pending_exceptions_done);
-@@ -310,12 +323,22 @@ static int init_origin_hash(void)
- _origins = kmalloc(ORIGIN_HASH_SIZE * sizeof(struct list_head),
- GFP_KERNEL);
- if (!_origins) {
-- DMERR("unable to allocate memory");
-+ DMERR("unable to allocate memory for _origins");
- return -ENOMEM;
- }
--
- for (i = 0; i < ORIGIN_HASH_SIZE; i++)
- INIT_LIST_HEAD(_origins + i);
-+
-+ _dm_origins = kmalloc(ORIGIN_HASH_SIZE * sizeof(struct list_head),
-+ GFP_KERNEL);
-+ if (!_dm_origins) {
-+ DMERR("unable to allocate memory for _dm_origins");
-+ kfree(_origins);
-+ return -ENOMEM;
-+ }
-+ for (i = 0; i < ORIGIN_HASH_SIZE; i++)
-+ INIT_LIST_HEAD(_dm_origins + i);
-+
- init_rwsem(&_origins_lock);
-
- return 0;
-@@ -324,6 +347,7 @@ static int init_origin_hash(void)
- static void exit_origin_hash(void)
- {
- kfree(_origins);
-+ kfree(_dm_origins);
- }
-
- static unsigned origin_hash(struct block_device *bdev)
-@@ -350,6 +374,30 @@ static void __insert_origin(struct origin *o)
- list_add_tail(&o->hash_list, sl);
- }
-
-+static struct dm_origin *__lookup_dm_origin(struct block_device *origin)
-+{
-+ struct list_head *ol;
-+ struct dm_origin *o;
-+
-+ ol = &_dm_origins[origin_hash(origin)];
-+ list_for_each_entry (o, ol, hash_list)
-+ if (bdev_equal(o->dev->bdev, origin))
-+ return o;
-+
-+ return NULL;
-+}
-+
-+static void __insert_dm_origin(struct dm_origin *o)
-+{
-+ struct list_head *sl = &_dm_origins[origin_hash(o->dev->bdev)];
-+ list_add_tail(&o->hash_list, sl);
-+}
-+
-+static void __remove_dm_origin(struct dm_origin *o)
-+{
-+ list_del(&o->hash_list);
-+}
-+
- /*
- * _origins_lock must be held when calling this function.
- * Returns number of snapshots registered using the supplied cow device, plus:
-@@ -1840,9 +1888,40 @@ static int snapshot_preresume(struct dm_target *ti)
- static void snapshot_resume(struct dm_target *ti)
- {
- struct dm_snapshot *s = ti->private;
-- struct dm_snapshot *snap_src = NULL, *snap_dest = NULL;
-+ struct dm_snapshot *snap_src = NULL, *snap_dest = NULL, *snap_merging = NULL;
-+ struct dm_origin *o;
-+ struct mapped_device *origin_md = NULL;
-+ bool must_restart_merging = false;
-
- down_read(&_origins_lock);
-+
-+ o = __lookup_dm_origin(s->origin->bdev);
-+ if (o)
-+ origin_md = dm_table_get_md(o->ti->table);
-+ if (!origin_md) {
-+ (void) __find_snapshots_sharing_cow(s, NULL, NULL, &snap_merging);
-+ if (snap_merging)
-+ origin_md = dm_table_get_md(snap_merging->ti->table);
-+ }
-+ if (origin_md == dm_table_get_md(ti->table))
-+ origin_md = NULL;
-+ if (origin_md) {
-+ if (dm_hold(origin_md))
-+ origin_md = NULL;
-+ }
-+
-+ up_read(&_origins_lock);
-+
-+ if (origin_md) {
-+ dm_internal_suspend_fast(origin_md);
-+ if (snap_merging && test_bit(RUNNING_MERGE, &snap_merging->state_bits)) {
-+ must_restart_merging = true;
-+ stop_merge(snap_merging);
-+ }
-+ }
-+
-+ down_read(&_origins_lock);
-+
- (void) __find_snapshots_sharing_cow(s, &snap_src, &snap_dest, NULL);
- if (snap_src && snap_dest) {
- down_write(&snap_src->lock);
-@@ -1851,8 +1930,16 @@ static void snapshot_resume(struct dm_target *ti)
- up_write(&snap_dest->lock);
- up_write(&snap_src->lock);
- }
-+
- up_read(&_origins_lock);
-
-+ if (origin_md) {
-+ if (must_restart_merging)
-+ start_merge(snap_merging);
-+ dm_internal_resume_fast(origin_md);
-+ dm_put(origin_md);
-+ }
-+
- /* Now we have correct chunk size, reregister */
- reregister_snapshot(s);
-
-@@ -2133,11 +2220,6 @@ static int origin_write_extent(struct dm_snapshot *merging_snap,
- * Origin: maps a linear range of a device, with hooks for snapshotting.
- */
-
--struct dm_origin {
-- struct dm_dev *dev;
-- unsigned split_boundary;
--};
--
- /*
- * Construct an origin mapping: <dev_path>
- * The context for an origin is merely a 'struct dm_dev *'
-@@ -2166,6 +2248,7 @@ static int origin_ctr(struct dm_target *ti, unsigned int argc, char **argv)
- goto bad_open;
- }
-
-+ o->ti = ti;
- ti->private = o;
- ti->num_flush_bios = 1;
-
-@@ -2180,6 +2263,7 @@ bad_alloc:
- static void origin_dtr(struct dm_target *ti)
- {
- struct dm_origin *o = ti->private;
-+
- dm_put_device(ti, o->dev);
- kfree(o);
- }
-@@ -2216,6 +2300,19 @@ static void origin_resume(struct dm_target *ti)
- struct dm_origin *o = ti->private;
-
- o->split_boundary = get_origin_minimum_chunksize(o->dev->bdev);
-+
-+ down_write(&_origins_lock);
-+ __insert_dm_origin(o);
-+ up_write(&_origins_lock);
-+}
-+
-+static void origin_postsuspend(struct dm_target *ti)
-+{
-+ struct dm_origin *o = ti->private;
-+
-+ down_write(&_origins_lock);
-+ __remove_dm_origin(o);
-+ up_write(&_origins_lock);
- }
-
- static void origin_status(struct dm_target *ti, status_type_t type,
-@@ -2258,12 +2355,13 @@ static int origin_iterate_devices(struct dm_target *ti,
-
- static struct target_type origin_target = {
- .name = "snapshot-origin",
-- .version = {1, 8, 1},
-+ .version = {1, 9, 0},
- .module = THIS_MODULE,
- .ctr = origin_ctr,
- .dtr = origin_dtr,
- .map = origin_map,
- .resume = origin_resume,
-+ .postsuspend = origin_postsuspend,
- .status = origin_status,
- .merge = origin_merge,
- .iterate_devices = origin_iterate_devices,
-@@ -2271,7 +2369,7 @@ static struct target_type origin_target = {
-
- static struct target_type snapshot_target = {
- .name = "snapshot",
-- .version = {1, 12, 0},
-+ .version = {1, 13, 0},
- .module = THIS_MODULE,
- .ctr = snapshot_ctr,
- .dtr = snapshot_dtr,
-@@ -2285,7 +2383,7 @@ static struct target_type snapshot_target = {
-
- static struct target_type merge_target = {
- .name = dm_snapshot_merge_target_name,
-- .version = {1, 2, 0},
-+ .version = {1, 3, 0},
- .module = THIS_MODULE,
- .ctr = snapshot_ctr,
- .dtr = snapshot_dtr,
-diff --git a/drivers/md/dm-thin.c b/drivers/md/dm-thin.c
-index 07705ee..159a113 100644
---- a/drivers/md/dm-thin.c
-+++ b/drivers/md/dm-thin.c
-@@ -2357,17 +2357,6 @@ static int thin_bio_map(struct dm_target *ti, struct bio *bio)
- return DM_MAPIO_REMAPPED;
-
- case -ENODATA:
-- if (get_pool_mode(tc->pool) == PM_READ_ONLY) {
-- /*
-- * This block isn't provisioned, and we have no way
-- * of doing so.
-- */
-- handle_unserviceable_bio(tc->pool, bio);
-- cell_defer_no_holder(tc, virt_cell);
-- return DM_MAPIO_SUBMITTED;
-- }
-- /* fall through */
--
- case -EWOULDBLOCK:
- thin_defer_cell(tc, virt_cell);
- return DM_MAPIO_SUBMITTED;
-diff --git a/drivers/md/dm.c b/drivers/md/dm.c
-index 64b10e0..b71c600 100644
---- a/drivers/md/dm.c
-+++ b/drivers/md/dm.c
-@@ -2507,6 +2507,19 @@ void dm_get(struct mapped_device *md)
- BUG_ON(test_bit(DMF_FREEING, &md->flags));
- }
-
-+int dm_hold(struct mapped_device *md)
-+{
-+ spin_lock(&_minor_lock);
-+ if (test_bit(DMF_FREEING, &md->flags)) {
-+ spin_unlock(&_minor_lock);
-+ return -EBUSY;
-+ }
-+ dm_get(md);
-+ spin_unlock(&_minor_lock);
-+ return 0;
-+}
-+EXPORT_SYMBOL_GPL(dm_hold);
-+
- const char *dm_device_name(struct mapped_device *md)
- {
- return md->name;
-@@ -2526,10 +2539,16 @@ static void __dm_destroy(struct mapped_device *md, bool wait)
- set_bit(DMF_FREEING, &md->flags);
- spin_unlock(&_minor_lock);
-
-+ /*
-+ * Take suspend_lock so that presuspend and postsuspend methods
-+ * do not race with internal suspend.
-+ */
-+ mutex_lock(&md->suspend_lock);
- if (!dm_suspended_md(md)) {
- dm_table_presuspend_targets(map);
- dm_table_postsuspend_targets(map);
- }
-+ mutex_unlock(&md->suspend_lock);
-
- /* dm_put_live_table must be before msleep, otherwise deadlock is possible */
- dm_put_live_table(md, srcu_idx);
-@@ -3001,6 +3020,7 @@ void dm_internal_suspend_fast(struct mapped_device *md)
- flush_workqueue(md->wq);
- dm_wait_for_completion(md, TASK_UNINTERRUPTIBLE);
- }
-+EXPORT_SYMBOL_GPL(dm_internal_suspend_fast);
-
- void dm_internal_resume_fast(struct mapped_device *md)
- {
-@@ -3012,6 +3032,7 @@ void dm_internal_resume_fast(struct mapped_device *md)
- done:
- mutex_unlock(&md->suspend_lock);
- }
-+EXPORT_SYMBOL_GPL(dm_internal_resume_fast);
-
- /*-----------------------------------------------------------------
- * Event notification.
-diff --git a/drivers/mfd/kempld-core.c b/drivers/mfd/kempld-core.c
-index f38ec42..5615522 100644
---- a/drivers/mfd/kempld-core.c
-+++ b/drivers/mfd/kempld-core.c
-@@ -739,7 +739,7 @@ static int __init kempld_init(void)
- for (id = kempld_dmi_table;
- id->matches[0].slot != DMI_NONE; id++)
- if (strstr(id->ident, force_device_id))
-- if (id->callback && id->callback(id))
-+ if (id->callback && !id->callback(id))
- break;
- if (id->matches[0].slot == DMI_NONE)
- return -ENODEV;
-diff --git a/drivers/net/ethernet/amd/pcnet32.c b/drivers/net/ethernet/amd/pcnet32.c
-index e2e3aaf..30f088b 100644
---- a/drivers/net/ethernet/amd/pcnet32.c
-+++ b/drivers/net/ethernet/amd/pcnet32.c
-@@ -1543,7 +1543,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- {
- struct pcnet32_private *lp;
- int i, media;
-- int fdx, mii, fset, dxsuflo;
-+ int fdx, mii, fset, dxsuflo, sram;
- int chip_version;
- char *chipname;
- struct net_device *dev;
-@@ -1580,7 +1580,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- }
-
- /* initialize variables */
-- fdx = mii = fset = dxsuflo = 0;
-+ fdx = mii = fset = dxsuflo = sram = 0;
- chip_version = (chip_version >> 12) & 0xffff;
-
- switch (chip_version) {
-@@ -1613,6 +1613,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- chipname = "PCnet/FAST III 79C973"; /* PCI */
- fdx = 1;
- mii = 1;
-+ sram = 1;
- break;
- case 0x2626:
- chipname = "PCnet/Home 79C978"; /* PCI */
-@@ -1636,6 +1637,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- chipname = "PCnet/FAST III 79C975"; /* PCI */
- fdx = 1;
- mii = 1;
-+ sram = 1;
- break;
- case 0x2628:
- chipname = "PCnet/PRO 79C976";
-@@ -1664,6 +1666,31 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev)
- dxsuflo = 1;
- }
-
-+ /*
-+ * The Am79C973/Am79C975 controllers come with 12K of SRAM
-+ * which we can use for the Tx/Rx buffers but most importantly,
-+ * the use of SRAM allow us to use the BCR18:NOUFLO bit to avoid
-+ * Tx fifo underflows.
-+ */
-+ if (sram) {
-+ /*
-+ * The SRAM is being configured in two steps. First we
-+ * set the SRAM size in the BCR25:SRAM_SIZE bits. According
-+ * to the datasheet, each bit corresponds to a 512-byte
-+ * page so we can have at most 24 pages. The SRAM_SIZE
-+ * holds the value of the upper 8 bits of the 16-bit SRAM size.
-+ * The low 8-bits start at 0x00 and end at 0xff. So the
-+ * address range is from 0x0000 up to 0x17ff. Therefore,
-+ * the SRAM_SIZE is set to 0x17. The next step is to set
-+ * the BCR26:SRAM_BND midway through so the Tx and Rx
-+ * buffers can share the SRAM equally.
-+ */
-+ a->write_bcr(ioaddr, 25, 0x17);
-+ a->write_bcr(ioaddr, 26, 0xc);
-+ /* And finally enable the NOUFLO bit */
-+ a->write_bcr(ioaddr, 18, a->read_bcr(ioaddr, 18) | (1 << 11));
-+ }
-+
- dev = alloc_etherdev(sizeof(*lp));
- if (!dev) {
- ret = -ENOMEM;
-diff --git a/drivers/net/wireless/brcm80211/brcmfmac/vendor.c b/drivers/net/wireless/brcm80211/brcmfmac/vendor.c
-index 50cdf70..8eff275 100644
---- a/drivers/net/wireless/brcm80211/brcmfmac/vendor.c
-+++ b/drivers/net/wireless/brcm80211/brcmfmac/vendor.c
-@@ -39,13 +39,22 @@ static int brcmf_cfg80211_vndr_cmds_dcmd_handler(struct wiphy *wiphy,
- void *dcmd_buf = NULL, *wr_pointer;
- u16 msglen, maxmsglen = PAGE_SIZE - 0x100;
-
-- brcmf_dbg(TRACE, "cmd %x set %d len %d\n", cmdhdr->cmd, cmdhdr->set,
-- cmdhdr->len);
-+ if (len < sizeof(*cmdhdr)) {
-+ brcmf_err("vendor command too short: %d\n", len);
-+ return -EINVAL;
-+ }
-
- vif = container_of(wdev, struct brcmf_cfg80211_vif, wdev);
- ifp = vif->ifp;
-
-- len -= sizeof(struct brcmf_vndr_dcmd_hdr);
-+ brcmf_dbg(TRACE, "ifidx=%d, cmd=%d\n", ifp->ifidx, cmdhdr->cmd);
-+
-+ if (cmdhdr->offset > len) {
-+ brcmf_err("bad buffer offset %d > %d\n", cmdhdr->offset, len);
-+ return -EINVAL;
-+ }
-+
-+ len -= cmdhdr->offset;
- ret_len = cmdhdr->len;
- if (ret_len > 0 || len > 0) {
- if (len > BRCMF_DCMD_MAXLEN) {
-diff --git a/drivers/net/wireless/iwlwifi/iwl-1000.c b/drivers/net/wireless/iwlwifi/iwl-1000.c
-index c3817fa..06f6cc0 100644
---- a/drivers/net/wireless/iwlwifi/iwl-1000.c
-+++ b/drivers/net/wireless/iwlwifi/iwl-1000.c
-@@ -95,7 +95,8 @@ static const struct iwl_eeprom_params iwl1000_eeprom_params = {
- .nvm_calib_ver = EEPROM_1000_TX_POWER_VERSION, \
- .base_params = &iwl1000_base_params, \
- .eeprom_params = &iwl1000_eeprom_params, \
-- .led_mode = IWL_LED_BLINK
-+ .led_mode = IWL_LED_BLINK, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl1000_bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 1000 BGN",
-@@ -121,7 +122,8 @@ const struct iwl_cfg iwl1000_bg_cfg = {
- .base_params = &iwl1000_base_params, \
- .eeprom_params = &iwl1000_eeprom_params, \
- .led_mode = IWL_LED_RF_STATE, \
-- .rx_with_siso_diversity = true
-+ .rx_with_siso_diversity = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl100_bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 100 BGN",
-diff --git a/drivers/net/wireless/iwlwifi/iwl-2000.c b/drivers/net/wireless/iwlwifi/iwl-2000.c
-index 21e5d08..890b95f 100644
---- a/drivers/net/wireless/iwlwifi/iwl-2000.c
-+++ b/drivers/net/wireless/iwlwifi/iwl-2000.c
-@@ -123,7 +123,9 @@ static const struct iwl_eeprom_params iwl20x0_eeprom_params = {
- .nvm_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
- .base_params = &iwl2000_base_params, \
- .eeprom_params = &iwl20x0_eeprom_params, \
-- .led_mode = IWL_LED_RF_STATE
-+ .led_mode = IWL_LED_RF_STATE, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-+
-
- const struct iwl_cfg iwl2000_2bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 2200 BGN",
-@@ -149,7 +151,8 @@ const struct iwl_cfg iwl2000_2bgn_d_cfg = {
- .nvm_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
- .base_params = &iwl2030_base_params, \
- .eeprom_params = &iwl20x0_eeprom_params, \
-- .led_mode = IWL_LED_RF_STATE
-+ .led_mode = IWL_LED_RF_STATE, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl2030_2bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 2230 BGN",
-@@ -170,7 +173,8 @@ const struct iwl_cfg iwl2030_2bgn_cfg = {
- .base_params = &iwl2000_base_params, \
- .eeprom_params = &iwl20x0_eeprom_params, \
- .led_mode = IWL_LED_RF_STATE, \
-- .rx_with_siso_diversity = true
-+ .rx_with_siso_diversity = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl105_bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 105 BGN",
-@@ -197,7 +201,8 @@ const struct iwl_cfg iwl105_bgn_d_cfg = {
- .base_params = &iwl2030_base_params, \
- .eeprom_params = &iwl20x0_eeprom_params, \
- .led_mode = IWL_LED_RF_STATE, \
-- .rx_with_siso_diversity = true
-+ .rx_with_siso_diversity = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl135_bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N 135 BGN",
-diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c
-index 332bbede..724194e 100644
---- a/drivers/net/wireless/iwlwifi/iwl-5000.c
-+++ b/drivers/net/wireless/iwlwifi/iwl-5000.c
-@@ -93,7 +93,8 @@ static const struct iwl_eeprom_params iwl5000_eeprom_params = {
- .nvm_calib_ver = EEPROM_5000_TX_POWER_VERSION, \
- .base_params = &iwl5000_base_params, \
- .eeprom_params = &iwl5000_eeprom_params, \
-- .led_mode = IWL_LED_BLINK
-+ .led_mode = IWL_LED_BLINK, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl5300_agn_cfg = {
- .name = "Intel(R) Ultimate N WiFi Link 5300 AGN",
-@@ -158,7 +159,8 @@ const struct iwl_cfg iwl5350_agn_cfg = {
- .base_params = &iwl5000_base_params, \
- .eeprom_params = &iwl5000_eeprom_params, \
- .led_mode = IWL_LED_BLINK, \
-- .internal_wimax_coex = true
-+ .internal_wimax_coex = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl5150_agn_cfg = {
- .name = "Intel(R) WiMAX/WiFi Link 5150 AGN",
-diff --git a/drivers/net/wireless/iwlwifi/iwl-6000.c b/drivers/net/wireless/iwlwifi/iwl-6000.c
-index 8f2c3c8..21b2630 100644
---- a/drivers/net/wireless/iwlwifi/iwl-6000.c
-+++ b/drivers/net/wireless/iwlwifi/iwl-6000.c
-@@ -145,7 +145,8 @@ static const struct iwl_eeprom_params iwl6000_eeprom_params = {
- .nvm_calib_ver = EEPROM_6005_TX_POWER_VERSION, \
- .base_params = &iwl6000_g2_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
-- .led_mode = IWL_LED_RF_STATE
-+ .led_mode = IWL_LED_RF_STATE, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6005_2agn_cfg = {
- .name = "Intel(R) Centrino(R) Advanced-N 6205 AGN",
-@@ -199,7 +200,8 @@ const struct iwl_cfg iwl6005_2agn_mow2_cfg = {
- .nvm_calib_ver = EEPROM_6030_TX_POWER_VERSION, \
- .base_params = &iwl6000_g2_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
-- .led_mode = IWL_LED_RF_STATE
-+ .led_mode = IWL_LED_RF_STATE, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6030_2agn_cfg = {
- .name = "Intel(R) Centrino(R) Advanced-N 6230 AGN",
-@@ -235,7 +237,8 @@ const struct iwl_cfg iwl6030_2bg_cfg = {
- .nvm_calib_ver = EEPROM_6030_TX_POWER_VERSION, \
- .base_params = &iwl6000_g2_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
-- .led_mode = IWL_LED_RF_STATE
-+ .led_mode = IWL_LED_RF_STATE, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6035_2agn_cfg = {
- .name = "Intel(R) Centrino(R) Advanced-N 6235 AGN",
-@@ -290,7 +293,8 @@ const struct iwl_cfg iwl130_bg_cfg = {
- .nvm_calib_ver = EEPROM_6000_TX_POWER_VERSION, \
- .base_params = &iwl6000_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
-- .led_mode = IWL_LED_BLINK
-+ .led_mode = IWL_LED_BLINK, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6000i_2agn_cfg = {
- .name = "Intel(R) Centrino(R) Advanced-N 6200 AGN",
-@@ -322,7 +326,8 @@ const struct iwl_cfg iwl6000i_2bg_cfg = {
- .base_params = &iwl6050_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
- .led_mode = IWL_LED_BLINK, \
-- .internal_wimax_coex = true
-+ .internal_wimax_coex = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6050_2agn_cfg = {
- .name = "Intel(R) Centrino(R) Advanced-N + WiMAX 6250 AGN",
-@@ -347,7 +352,8 @@ const struct iwl_cfg iwl6050_2abg_cfg = {
- .base_params = &iwl6050_base_params, \
- .eeprom_params = &iwl6000_eeprom_params, \
- .led_mode = IWL_LED_BLINK, \
-- .internal_wimax_coex = true
-+ .internal_wimax_coex = true, \
-+ .max_ht_ampdu_exponent = IEEE80211_HT_MAX_AMPDU_64K
-
- const struct iwl_cfg iwl6150_bgn_cfg = {
- .name = "Intel(R) Centrino(R) Wireless-N + WiMAX 6150 BGN",
-diff --git a/drivers/net/wireless/iwlwifi/mvm/coex.c b/drivers/net/wireless/iwlwifi/mvm/coex.c
-index a3bfda4..ae5a4ec 100644
---- a/drivers/net/wireless/iwlwifi/mvm/coex.c
-+++ b/drivers/net/wireless/iwlwifi/mvm/coex.c
-@@ -793,7 +793,8 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac,
- if (!vif->bss_conf.assoc)
- smps_mode = IEEE80211_SMPS_AUTOMATIC;
-
-- if (IWL_COEX_IS_RRC_ON(mvm->last_bt_notif.ttc_rrc_status,
-+ if (mvmvif->phy_ctxt &&
-+ IWL_COEX_IS_RRC_ON(mvm->last_bt_notif.ttc_rrc_status,
- mvmvif->phy_ctxt->id))
- smps_mode = IEEE80211_SMPS_AUTOMATIC;
-
-diff --git a/drivers/net/wireless/iwlwifi/mvm/coex_legacy.c b/drivers/net/wireless/iwlwifi/mvm/coex_legacy.c
-index b3210cf..d804585 100644
---- a/drivers/net/wireless/iwlwifi/mvm/coex_legacy.c
-+++ b/drivers/net/wireless/iwlwifi/mvm/coex_legacy.c
-@@ -832,7 +832,8 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac,
- if (!vif->bss_conf.assoc)
- smps_mode = IEEE80211_SMPS_AUTOMATIC;
-
-- if (data->notif->rrc_enabled & BIT(mvmvif->phy_ctxt->id))
-+ if (mvmvif->phy_ctxt &&
-+ data->notif->rrc_enabled & BIT(mvmvif->phy_ctxt->id))
- smps_mode = IEEE80211_SMPS_AUTOMATIC;
-
- IWL_DEBUG_COEX(data->mvm,
-diff --git a/drivers/net/wireless/iwlwifi/mvm/rs.c b/drivers/net/wireless/iwlwifi/mvm/rs.c
-index 30ceb67..1a03270 100644
---- a/drivers/net/wireless/iwlwifi/mvm/rs.c
-+++ b/drivers/net/wireless/iwlwifi/mvm/rs.c
-@@ -146,9 +146,12 @@ enum rs_column_mode {
- #define MAX_NEXT_COLUMNS 7
- #define MAX_COLUMN_CHECKS 3
-
-+struct rs_tx_column;
-+
- typedef bool (*allow_column_func_t) (struct iwl_mvm *mvm,
- struct ieee80211_sta *sta,
-- struct iwl_scale_tbl_info *tbl);
-+ struct iwl_scale_tbl_info *tbl,
-+ const struct rs_tx_column *next_col);
-
- struct rs_tx_column {
- enum rs_column_mode mode;
-@@ -159,13 +162,15 @@ struct rs_tx_column {
- };
-
- static bool rs_ant_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
-- struct iwl_scale_tbl_info *tbl)
-+ struct iwl_scale_tbl_info *tbl,
-+ const struct rs_tx_column *next_col)
- {
-- return iwl_mvm_bt_coex_is_ant_avail(mvm, tbl->rate.ant);
-+ return iwl_mvm_bt_coex_is_ant_avail(mvm, next_col->ant);
- }
-
- static bool rs_mimo_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
-- struct iwl_scale_tbl_info *tbl)
-+ struct iwl_scale_tbl_info *tbl,
-+ const struct rs_tx_column *next_col)
- {
- if (!sta->ht_cap.ht_supported)
- return false;
-@@ -183,7 +188,8 @@ static bool rs_mimo_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
- }
-
- static bool rs_siso_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
-- struct iwl_scale_tbl_info *tbl)
-+ struct iwl_scale_tbl_info *tbl,
-+ const struct rs_tx_column *next_col)
- {
- if (!sta->ht_cap.ht_supported)
- return false;
-@@ -192,7 +198,8 @@ static bool rs_siso_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
- }
-
- static bool rs_sgi_allow(struct iwl_mvm *mvm, struct ieee80211_sta *sta,
-- struct iwl_scale_tbl_info *tbl)
-+ struct iwl_scale_tbl_info *tbl,
-+ const struct rs_tx_column *next_col)
- {
- struct rs_rate *rate = &tbl->rate;
- struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
-@@ -1594,7 +1601,7 @@ static enum rs_column rs_get_next_column(struct iwl_mvm *mvm,
-
- for (j = 0; j < MAX_COLUMN_CHECKS; j++) {
- allow_func = next_col->checks[j];
-- if (allow_func && !allow_func(mvm, sta, tbl))
-+ if (allow_func && !allow_func(mvm, sta, tbl, next_col))
- break;
- }
-
-diff --git a/drivers/net/wireless/iwlwifi/mvm/time-event.c b/drivers/net/wireless/iwlwifi/mvm/time-event.c
-index 54fafbf..f8d6f30 100644
---- a/drivers/net/wireless/iwlwifi/mvm/time-event.c
-+++ b/drivers/net/wireless/iwlwifi/mvm/time-event.c
-@@ -750,8 +750,7 @@ void iwl_mvm_stop_roc(struct iwl_mvm *mvm)
- * request
- */
- list_for_each_entry(te_data, &mvm->time_event_list, list) {
-- if (te_data->vif->type == NL80211_IFTYPE_P2P_DEVICE &&
-- te_data->running) {
-+ if (te_data->vif->type == NL80211_IFTYPE_P2P_DEVICE) {
- mvmvif = iwl_mvm_vif_from_mac80211(te_data->vif);
- is_p2p = true;
- goto remove_te;
-@@ -766,10 +765,8 @@ void iwl_mvm_stop_roc(struct iwl_mvm *mvm)
- * request
- */
- list_for_each_entry(te_data, &mvm->aux_roc_te_list, list) {
-- if (te_data->running) {
-- mvmvif = iwl_mvm_vif_from_mac80211(te_data->vif);
-- goto remove_te;
-- }
-+ mvmvif = iwl_mvm_vif_from_mac80211(te_data->vif);
-+ goto remove_te;
- }
-
- remove_te:
-diff --git a/drivers/net/wireless/rtlwifi/base.c b/drivers/net/wireless/rtlwifi/base.c
-index 40b6d1d..af24869 100644
---- a/drivers/net/wireless/rtlwifi/base.c
-+++ b/drivers/net/wireless/rtlwifi/base.c
-@@ -1314,8 +1314,11 @@ u8 rtl_is_special_data(struct ieee80211_hw *hw, struct sk_buff *skb, u8 is_tx)
- }
-
- return true;
-- } else if (0x86DD == ether_type) {
-- return true;
-+ } else if (ETH_P_IPV6 == ether_type) {
-+ /* TODO: Handle any IPv6 cases that need special handling.
-+ * For now, always return false
-+ */
-+ goto end;
- }
-
- end:
-diff --git a/drivers/of/irq.c b/drivers/of/irq.c
-index 0d77658..1a79806 100644
---- a/drivers/of/irq.c
-+++ b/drivers/of/irq.c
-@@ -290,7 +290,7 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar
- struct device_node *p;
- const __be32 *intspec, *tmp, *addr;
- u32 intsize, intlen;
-- int i, res = -EINVAL;
-+ int i, res;
-
- pr_debug("of_irq_parse_one: dev=%s, index=%d\n", of_node_full_name(device), index);
-
-@@ -323,15 +323,19 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar
-
- /* Get size of interrupt specifier */
- tmp = of_get_property(p, "#interrupt-cells", NULL);
-- if (tmp == NULL)
-+ if (tmp == NULL) {
-+ res = -EINVAL;
- goto out;
-+ }
- intsize = be32_to_cpu(*tmp);
-
- pr_debug(" intsize=%d intlen=%d\n", intsize, intlen);
-
- /* Check index */
-- if ((index + 1) * intsize > intlen)
-+ if ((index + 1) * intsize > intlen) {
-+ res = -EINVAL;
- goto out;
-+ }
-
- /* Copy intspec into irq structure */
- intspec += index * intsize;
-diff --git a/drivers/phy/phy-core.c b/drivers/phy/phy-core.c
-index a12d353..04fc84f 100644
---- a/drivers/phy/phy-core.c
-+++ b/drivers/phy/phy-core.c
-@@ -52,7 +52,9 @@ static void devm_phy_consume(struct device *dev, void *res)
-
- static int devm_phy_match(struct device *dev, void *res, void *match_data)
- {
-- return res == match_data;
-+ struct phy **phy = res;
-+
-+ return *phy == match_data;
- }
-
- /**
-diff --git a/drivers/powercap/intel_rapl.c b/drivers/powercap/intel_rapl.c
-index 97b5e4e..63d4033 100644
---- a/drivers/powercap/intel_rapl.c
-+++ b/drivers/powercap/intel_rapl.c
-@@ -73,7 +73,7 @@
-
- #define TIME_WINDOW_MAX_MSEC 40000
- #define TIME_WINDOW_MIN_MSEC 250
--
-+#define ENERGY_UNIT_SCALE 1000 /* scale from driver unit to powercap unit */
- enum unit_type {
- ARBITRARY_UNIT, /* no translation */
- POWER_UNIT,
-@@ -158,6 +158,7 @@ struct rapl_domain {
- struct rapl_power_limit rpl[NR_POWER_LIMITS];
- u64 attr_map; /* track capabilities */
- unsigned int state;
-+ unsigned int domain_energy_unit;
- int package_id;
- };
- #define power_zone_to_rapl_domain(_zone) \
-@@ -190,6 +191,7 @@ struct rapl_defaults {
- void (*set_floor_freq)(struct rapl_domain *rd, bool mode);
- u64 (*compute_time_window)(struct rapl_package *rp, u64 val,
- bool to_raw);
-+ unsigned int dram_domain_energy_unit;
- };
- static struct rapl_defaults *rapl_defaults;
-
-@@ -227,7 +229,8 @@ static int rapl_read_data_raw(struct rapl_domain *rd,
- static int rapl_write_data_raw(struct rapl_domain *rd,
- enum rapl_primitives prim,
- unsigned long long value);
--static u64 rapl_unit_xlate(int package, enum unit_type type, u64 value,
-+static u64 rapl_unit_xlate(struct rapl_domain *rd, int package,
-+ enum unit_type type, u64 value,
- int to_raw);
- static void package_power_limit_irq_save(int package_id);
-
-@@ -305,7 +308,9 @@ static int get_energy_counter(struct powercap_zone *power_zone, u64 *energy_raw)
-
- static int get_max_energy_counter(struct powercap_zone *pcd_dev, u64 *energy)
- {
-- *energy = rapl_unit_xlate(0, ENERGY_UNIT, ENERGY_STATUS_MASK, 0);
-+ struct rapl_domain *rd = power_zone_to_rapl_domain(pcd_dev);
-+
-+ *energy = rapl_unit_xlate(rd, 0, ENERGY_UNIT, ENERGY_STATUS_MASK, 0);
- return 0;
- }
-
-@@ -639,6 +644,11 @@ static void rapl_init_domains(struct rapl_package *rp)
- rd->msrs[4] = MSR_DRAM_POWER_INFO;
- rd->rpl[0].prim_id = PL1_ENABLE;
- rd->rpl[0].name = pl1_name;
-+ rd->domain_energy_unit =
-+ rapl_defaults->dram_domain_energy_unit;
-+ if (rd->domain_energy_unit)
-+ pr_info("DRAM domain energy unit %dpj\n",
-+ rd->domain_energy_unit);
- break;
- }
- if (mask) {
-@@ -648,11 +658,13 @@ static void rapl_init_domains(struct rapl_package *rp)
- }
- }
-
--static u64 rapl_unit_xlate(int package, enum unit_type type, u64 value,
-+static u64 rapl_unit_xlate(struct rapl_domain *rd, int package,
-+ enum unit_type type, u64 value,
- int to_raw)
- {
- u64 units = 1;
- struct rapl_package *rp;
-+ u64 scale = 1;
-
- rp = find_package_by_id(package);
- if (!rp)
-@@ -663,7 +675,12 @@ static u64 rapl_unit_xlate(int package, enum unit_type type, u64 value,
- units = rp->power_unit;
- break;
- case ENERGY_UNIT:
-- units = rp->energy_unit;
-+ scale = ENERGY_UNIT_SCALE;
-+ /* per domain unit takes precedence */
-+ if (rd && rd->domain_energy_unit)
-+ units = rd->domain_energy_unit;
-+ else
-+ units = rp->energy_unit;
- break;
- case TIME_UNIT:
- return rapl_defaults->compute_time_window(rp, value, to_raw);
-@@ -673,11 +690,11 @@ static u64 rapl_unit_xlate(int package, enum unit_type type, u64 value,
- };
-
- if (to_raw)
-- return div64_u64(value, units);
-+ return div64_u64(value, units) * scale;
-
- value *= units;
-
-- return value;
-+ return div64_u64(value, scale);
- }
-
- /* in the order of enum rapl_primitives */
-@@ -773,7 +790,7 @@ static int rapl_read_data_raw(struct rapl_domain *rd,
- final = value & rp->mask;
- final = final >> rp->shift;
- if (xlate)
-- *data = rapl_unit_xlate(rd->package_id, rp->unit, final, 0);
-+ *data = rapl_unit_xlate(rd, rd->package_id, rp->unit, final, 0);
- else
- *data = final;
-
-@@ -799,7 +816,7 @@ static int rapl_write_data_raw(struct rapl_domain *rd,
- "failed to read msr 0x%x on cpu %d\n", msr, cpu);
- return -EIO;
- }
-- value = rapl_unit_xlate(rd->package_id, rp->unit, value, 1);
-+ value = rapl_unit_xlate(rd, rd->package_id, rp->unit, value, 1);
- msr_val &= ~rp->mask;
- msr_val |= value << rp->shift;
- if (wrmsrl_safe_on_cpu(cpu, msr, msr_val)) {
-@@ -818,7 +835,7 @@ static int rapl_write_data_raw(struct rapl_domain *rd,
- * calculate units differ on different CPUs.
- * We convert the units to below format based on CPUs.
- * i.e.
-- * energy unit: microJoules : Represented in microJoules by default
-+ * energy unit: picoJoules : Represented in picoJoules by default
- * power unit : microWatts : Represented in milliWatts by default
- * time unit : microseconds: Represented in seconds by default
- */
-@@ -834,7 +851,7 @@ static int rapl_check_unit_core(struct rapl_package *rp, int cpu)
- }
-
- value = (msr_val & ENERGY_UNIT_MASK) >> ENERGY_UNIT_OFFSET;
-- rp->energy_unit = 1000000 / (1 << value);
-+ rp->energy_unit = ENERGY_UNIT_SCALE * 1000000 / (1 << value);
-
- value = (msr_val & POWER_UNIT_MASK) >> POWER_UNIT_OFFSET;
- rp->power_unit = 1000000 / (1 << value);
-@@ -842,7 +859,7 @@ static int rapl_check_unit_core(struct rapl_package *rp, int cpu)
- value = (msr_val & TIME_UNIT_MASK) >> TIME_UNIT_OFFSET;
- rp->time_unit = 1000000 / (1 << value);
-
-- pr_debug("Core CPU package %d energy=%duJ, time=%dus, power=%duW\n",
-+ pr_debug("Core CPU package %d energy=%dpJ, time=%dus, power=%duW\n",
- rp->id, rp->energy_unit, rp->time_unit, rp->power_unit);
-
- return 0;
-@@ -859,7 +876,7 @@ static int rapl_check_unit_atom(struct rapl_package *rp, int cpu)
- return -ENODEV;
- }
- value = (msr_val & ENERGY_UNIT_MASK) >> ENERGY_UNIT_OFFSET;
-- rp->energy_unit = 1 << value;
-+ rp->energy_unit = ENERGY_UNIT_SCALE * 1 << value;
-
- value = (msr_val & POWER_UNIT_MASK) >> POWER_UNIT_OFFSET;
- rp->power_unit = (1 << value) * 1000;
-@@ -867,7 +884,7 @@ static int rapl_check_unit_atom(struct rapl_package *rp, int cpu)
- value = (msr_val & TIME_UNIT_MASK) >> TIME_UNIT_OFFSET;
- rp->time_unit = 1000000 / (1 << value);
-
-- pr_debug("Atom package %d energy=%duJ, time=%dus, power=%duW\n",
-+ pr_debug("Atom package %d energy=%dpJ, time=%dus, power=%duW\n",
- rp->id, rp->energy_unit, rp->time_unit, rp->power_unit);
-
- return 0;
-@@ -1017,6 +1034,13 @@ static const struct rapl_defaults rapl_defaults_core = {
- .compute_time_window = rapl_compute_time_window_core,
- };
-
-+static const struct rapl_defaults rapl_defaults_hsw_server = {
-+ .check_unit = rapl_check_unit_core,
-+ .set_floor_freq = set_floor_freq_default,
-+ .compute_time_window = rapl_compute_time_window_core,
-+ .dram_domain_energy_unit = 15300,
-+};
-+
- static const struct rapl_defaults rapl_defaults_atom = {
- .check_unit = rapl_check_unit_atom,
- .set_floor_freq = set_floor_freq_atom,
-@@ -1037,7 +1061,7 @@ static const struct x86_cpu_id rapl_ids[] = {
- RAPL_CPU(0x3a, rapl_defaults_core),/* Ivy Bridge */
- RAPL_CPU(0x3c, rapl_defaults_core),/* Haswell */
- RAPL_CPU(0x3d, rapl_defaults_core),/* Broadwell */
-- RAPL_CPU(0x3f, rapl_defaults_core),/* Haswell */
-+ RAPL_CPU(0x3f, rapl_defaults_hsw_server),/* Haswell servers */
- RAPL_CPU(0x45, rapl_defaults_core),/* Haswell ULT */
- RAPL_CPU(0x4C, rapl_defaults_atom),/* Braswell */
- RAPL_CPU(0x4A, rapl_defaults_atom),/* Tangier */
-diff --git a/drivers/regulator/palmas-regulator.c b/drivers/regulator/palmas-regulator.c
-index 9205f43..1819831 100644
---- a/drivers/regulator/palmas-regulator.c
-+++ b/drivers/regulator/palmas-regulator.c
-@@ -1572,6 +1572,10 @@ static int palmas_regulators_probe(struct platform_device *pdev)
- if (!pmic)
- return -ENOMEM;
-
-+ if (of_device_is_compatible(node, "ti,tps659038-pmic"))
-+ palmas_generic_regs_info[PALMAS_REG_REGEN2].ctrl_addr =
-+ TPS659038_REGEN2_CTRL;
-+
- pmic->dev = &pdev->dev;
- pmic->palmas = palmas;
- palmas->pmic = pmic;
-diff --git a/drivers/scsi/qla2xxx/tcm_qla2xxx.c b/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-index 73f9fee..272a264 100644
---- a/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-+++ b/drivers/scsi/qla2xxx/tcm_qla2xxx.c
-@@ -1598,7 +1598,7 @@ static int tcm_qla2xxx_check_initiator_node_acl(
- /*
- * Finally register the new FC Nexus with TCM
- */
-- __transport_register_session(se_nacl->se_tpg, se_nacl, se_sess, sess);
-+ transport_register_session(se_nacl->se_tpg, se_nacl, se_sess, sess);
-
- return 0;
- }
-diff --git a/drivers/spi/spi-dw-mid.c b/drivers/spi/spi-dw-mid.c
-index 22ca08a..8076e89 100644
---- a/drivers/spi/spi-dw-mid.c
-+++ b/drivers/spi/spi-dw-mid.c
-@@ -108,7 +108,8 @@ static void dw_spi_dma_tx_done(void *arg)
- {
- struct dw_spi *dws = arg;
-
-- if (test_and_clear_bit(TX_BUSY, &dws->dma_chan_busy) & BIT(RX_BUSY))
-+ clear_bit(TX_BUSY, &dws->dma_chan_busy);
-+ if (test_bit(RX_BUSY, &dws->dma_chan_busy))
- return;
- dw_spi_xfer_done(dws);
- }
-@@ -156,7 +157,8 @@ static void dw_spi_dma_rx_done(void *arg)
- {
- struct dw_spi *dws = arg;
-
-- if (test_and_clear_bit(RX_BUSY, &dws->dma_chan_busy) & BIT(TX_BUSY))
-+ clear_bit(RX_BUSY, &dws->dma_chan_busy);
-+ if (test_bit(TX_BUSY, &dws->dma_chan_busy))
- return;
- dw_spi_xfer_done(dws);
- }
-diff --git a/drivers/spi/spi-qup.c b/drivers/spi/spi-qup.c
-index e7fb5a0..e27c12a 100644
---- a/drivers/spi/spi-qup.c
-+++ b/drivers/spi/spi-qup.c
-@@ -489,7 +489,7 @@ static int spi_qup_probe(struct platform_device *pdev)
- struct resource *res;
- struct device *dev;
- void __iomem *base;
-- u32 max_freq, iomode;
-+ u32 max_freq, iomode, num_cs;
- int ret, irq, size;
-
- dev = &pdev->dev;
-@@ -541,10 +541,11 @@ static int spi_qup_probe(struct platform_device *pdev)
- }
-
- /* use num-cs unless not present or out of range */
-- if (of_property_read_u16(dev->of_node, "num-cs",
-- &master->num_chipselect) ||
-- (master->num_chipselect > SPI_NUM_CHIPSELECTS))
-+ if (of_property_read_u32(dev->of_node, "num-cs", &num_cs) ||
-+ num_cs > SPI_NUM_CHIPSELECTS)
- master->num_chipselect = SPI_NUM_CHIPSELECTS;
-+ else
-+ master->num_chipselect = num_cs;
-
- master->bus_num = pdev->id;
- master->mode_bits = SPI_CPOL | SPI_CPHA | SPI_CS_HIGH | SPI_LOOP;
-diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c
-index 66a70e9..a17f533 100644
---- a/drivers/spi/spi.c
-+++ b/drivers/spi/spi.c
-@@ -1073,13 +1073,14 @@ void spi_finalize_current_message(struct spi_master *master)
- "failed to unprepare message: %d\n", ret);
- }
- }
-+
-+ trace_spi_message_done(mesg);
-+
- master->cur_msg_prepared = false;
-
- mesg->state = NULL;
- if (mesg->complete)
- mesg->complete(mesg->context);
--
-- trace_spi_message_done(mesg);
- }
- EXPORT_SYMBOL_GPL(spi_finalize_current_message);
-
-diff --git a/drivers/staging/vt6655/device_main.c b/drivers/staging/vt6655/device_main.c
-index cd1a277..ace0521 100644
---- a/drivers/staging/vt6655/device_main.c
-+++ b/drivers/staging/vt6655/device_main.c
-@@ -357,16 +357,6 @@ static void device_init_registers(struct vnt_private *pDevice)
- /* zonetype initial */
- pDevice->byOriginalZonetype = pDevice->abyEEPROM[EEP_OFS_ZONETYPE];
-
-- /* Get RFType */
-- pDevice->byRFType = SROMbyReadEmbedded(pDevice->PortOffset, EEP_OFS_RFTYPE);
--
-- /* force change RevID for VT3253 emu */
-- if ((pDevice->byRFType & RF_EMU) != 0)
-- pDevice->byRevId = 0x80;
--
-- pDevice->byRFType &= RF_MASK;
-- pr_debug("pDevice->byRFType = %x\n", pDevice->byRFType);
--
- if (!pDevice->bZoneRegExist)
- pDevice->byZoneType = pDevice->abyEEPROM[EEP_OFS_ZONETYPE];
-
-@@ -1806,6 +1796,12 @@ vt6655_probe(struct pci_dev *pcid, const struct pci_device_id *ent)
- MACvInitialize(priv->PortOffset);
- MACvReadEtherAddress(priv->PortOffset, priv->abyCurrentNetAddr);
-
-+ /* Get RFType */
-+ priv->byRFType = SROMbyReadEmbedded(priv->PortOffset, EEP_OFS_RFTYPE);
-+ priv->byRFType &= RF_MASK;
-+
-+ dev_dbg(&pcid->dev, "RF Type = %x\n", priv->byRFType);
-+
- device_get_options(priv);
- device_set_options(priv);
- /* Mask out the options cannot be set to the chip */
-diff --git a/drivers/staging/vt6655/rf.c b/drivers/staging/vt6655/rf.c
-index 32ef993..5d65ad0 100644
---- a/drivers/staging/vt6655/rf.c
-+++ b/drivers/staging/vt6655/rf.c
-@@ -791,6 +791,7 @@ bool RFbSetPower(
- break;
- case RATE_6M:
- case RATE_9M:
-+ case RATE_12M:
- case RATE_18M:
- byPwr = priv->abyOFDMPwrTbl[uCH];
- if (priv->byRFType == RF_UW2452)
-diff --git a/drivers/staging/vt6656/rf.c b/drivers/staging/vt6656/rf.c
-index c42cde5..c4286cc 100644
---- a/drivers/staging/vt6656/rf.c
-+++ b/drivers/staging/vt6656/rf.c
-@@ -640,6 +640,7 @@ int vnt_rf_setpower(struct vnt_private *priv, u32 rate, u32 channel)
- break;
- case RATE_6M:
- case RATE_9M:
-+ case RATE_12M:
- case RATE_18M:
- case RATE_24M:
- case RATE_36M:
-diff --git a/drivers/target/tcm_fc/tfc_io.c b/drivers/target/tcm_fc/tfc_io.c
-index 97b486c..583e755 100644
---- a/drivers/target/tcm_fc/tfc_io.c
-+++ b/drivers/target/tcm_fc/tfc_io.c
-@@ -359,7 +359,7 @@ void ft_invl_hw_context(struct ft_cmd *cmd)
- ep = fc_seq_exch(seq);
- if (ep) {
- lport = ep->lp;
-- if (lport && (ep->xid <= lport->lro_xid))
-+ if (lport && (ep->xid <= lport->lro_xid)) {
- /*
- * "ddp_done" trigger invalidation of HW
- * specific DDP context
-@@ -374,6 +374,7 @@ void ft_invl_hw_context(struct ft_cmd *cmd)
- * identified using ep->xid)
- */
- cmd->was_ddp_setup = 0;
-+ }
- }
- }
- }
-diff --git a/drivers/usb/chipidea/udc.c b/drivers/usb/chipidea/udc.c
-index 4fe18ce..7c14565 100644
---- a/drivers/usb/chipidea/udc.c
-+++ b/drivers/usb/chipidea/udc.c
-@@ -929,6 +929,13 @@ __acquires(hwep->lock)
- return retval;
- }
-
-+static int otg_a_alt_hnp_support(struct ci_hdrc *ci)
-+{
-+ dev_warn(&ci->gadget.dev,
-+ "connect the device to an alternate port if you want HNP\n");
-+ return isr_setup_status_phase(ci);
-+}
-+
- /**
- * isr_setup_packet_handler: setup packet handler
- * @ci: UDC descriptor
-@@ -1061,6 +1068,10 @@ __acquires(ci->lock)
- ci);
- }
- break;
-+ case USB_DEVICE_A_ALT_HNP_SUPPORT:
-+ if (ci_otg_is_fsm_mode(ci))
-+ err = otg_a_alt_hnp_support(ci);
-+ break;
- default:
- goto delegate;
- }
-diff --git a/drivers/usb/common/usb-otg-fsm.c b/drivers/usb/common/usb-otg-fsm.c
-index c6b35b7..61d538a 100644
---- a/drivers/usb/common/usb-otg-fsm.c
-+++ b/drivers/usb/common/usb-otg-fsm.c
-@@ -150,9 +150,9 @@ static int otg_set_state(struct otg_fsm *fsm, enum usb_otg_state new_state)
- break;
- case OTG_STATE_B_PERIPHERAL:
- otg_chrg_vbus(fsm, 0);
-- otg_loc_conn(fsm, 1);
- otg_loc_sof(fsm, 0);
- otg_set_protocol(fsm, PROTO_GADGET);
-+ otg_loc_conn(fsm, 1);
- break;
- case OTG_STATE_B_WAIT_ACON:
- otg_chrg_vbus(fsm, 0);
-@@ -213,10 +213,10 @@ static int otg_set_state(struct otg_fsm *fsm, enum usb_otg_state new_state)
-
- break;
- case OTG_STATE_A_PERIPHERAL:
-- otg_loc_conn(fsm, 1);
- otg_loc_sof(fsm, 0);
- otg_set_protocol(fsm, PROTO_GADGET);
- otg_drv_vbus(fsm, 1);
-+ otg_loc_conn(fsm, 1);
- otg_add_timer(fsm, A_BIDL_ADIS);
- break;
- case OTG_STATE_A_WAIT_VFALL:
-diff --git a/drivers/usb/phy/phy-am335x-control.c b/drivers/usb/phy/phy-am335x-control.c
-index 403fab7..7b3035f 100644
---- a/drivers/usb/phy/phy-am335x-control.c
-+++ b/drivers/usb/phy/phy-am335x-control.c
-@@ -126,6 +126,9 @@ struct phy_control *am335x_get_phy_control(struct device *dev)
- return NULL;
-
- dev = bus_find_device(&platform_bus_type, NULL, node, match);
-+ if (!dev)
-+ return NULL;
-+
- ctrl_usb = dev_get_drvdata(dev);
- if (!ctrl_usb)
- return NULL;
-diff --git a/drivers/usb/storage/unusual_uas.h b/drivers/usb/storage/unusual_uas.h
-index 8257042..c85ea53 100644
---- a/drivers/usb/storage/unusual_uas.h
-+++ b/drivers/usb/storage/unusual_uas.h
-@@ -113,6 +113,13 @@ UNUSUAL_DEV(0x0bc2, 0xab2a, 0x0000, 0x9999,
- USB_SC_DEVICE, USB_PR_DEVICE, NULL,
- US_FL_NO_ATA_1X),
-
-+/* Reported-by: Benjamin Tissoires <benjamin.tissoires@redhat.com> */
-+UNUSUAL_DEV(0x13fd, 0x3940, 0x0000, 0x9999,
-+ "Initio Corporation",
-+ "",
-+ USB_SC_DEVICE, USB_PR_DEVICE, NULL,
-+ US_FL_NO_ATA_1X),
-+
- /* Reported-by: Tom Arild Naess <tanaess@gmail.com> */
- UNUSUAL_DEV(0x152d, 0x0539, 0x0000, 0x9999,
- "JMicron",
-diff --git a/drivers/virtio/virtio_balloon.c b/drivers/virtio/virtio_balloon.c
-index 50c5f42..b8b7a6c 100644
---- a/drivers/virtio/virtio_balloon.c
-+++ b/drivers/virtio/virtio_balloon.c
-@@ -29,6 +29,7 @@
- #include <linux/module.h>
- #include <linux/balloon_compaction.h>
- #include <linux/oom.h>
-+#include <linux/wait.h>
-
- /*
- * Balloon device works in 4K page units. So each page is pointed to by
-@@ -335,17 +336,25 @@ static int virtballoon_oom_notify(struct notifier_block *self,
- static int balloon(void *_vballoon)
- {
- struct virtio_balloon *vb = _vballoon;
-+ DEFINE_WAIT_FUNC(wait, woken_wake_function);
-
- set_freezable();
- while (!kthread_should_stop()) {
- s64 diff;
-
- try_to_freeze();
-- wait_event_interruptible(vb->config_change,
-- (diff = towards_target(vb)) != 0
-- || vb->need_stats_update
-- || kthread_should_stop()
-- || freezing(current));
-+
-+ add_wait_queue(&vb->config_change, &wait);
-+ for (;;) {
-+ if ((diff = towards_target(vb)) != 0 ||
-+ vb->need_stats_update ||
-+ kthread_should_stop() ||
-+ freezing(current))
-+ break;
-+ wait_woken(&wait, TASK_INTERRUPTIBLE, MAX_SCHEDULE_TIMEOUT);
-+ }
-+ remove_wait_queue(&vb->config_change, &wait);
-+
- if (vb->need_stats_update)
- stats_handle_request(vb);
- if (diff > 0)
-@@ -494,6 +503,8 @@ static int virtballoon_probe(struct virtio_device *vdev)
- if (err < 0)
- goto out_oom_notify;
-
-+ virtio_device_ready(vdev);
-+
- vb->thread = kthread_run(balloon, vb, "vballoon");
- if (IS_ERR(vb->thread)) {
- err = PTR_ERR(vb->thread);
-diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c
-index 6e560d5..754fdf8 100644
---- a/fs/hfsplus/brec.c
-+++ b/fs/hfsplus/brec.c
-@@ -131,13 +131,16 @@ skip:
- hfs_bnode_write(node, entry, data_off + key_len, entry_len);
- hfs_bnode_dump(node);
-
-- if (new_node) {
-- /* update parent key if we inserted a key
-- * at the start of the first node
-- */
-- if (!rec && new_node != node)
-- hfs_brec_update_parent(fd);
-+ /*
-+ * update parent key if we inserted a key
-+ * at the start of the node and it is not the new node
-+ */
-+ if (!rec && new_node != node) {
-+ hfs_bnode_read_key(node, fd->search_key, data_off + size);
-+ hfs_brec_update_parent(fd);
-+ }
-
-+ if (new_node) {
- hfs_bnode_put(fd->bnode);
- if (!new_node->parent) {
- hfs_btree_inc_height(tree);
-@@ -168,9 +171,6 @@ skip:
- goto again;
- }
-
-- if (!rec)
-- hfs_brec_update_parent(fd);
--
- return 0;
- }
-
-@@ -370,6 +370,8 @@ again:
- if (IS_ERR(parent))
- return PTR_ERR(parent);
- __hfs_brec_find(parent, fd, hfs_find_rec_by_key);
-+ if (fd->record < 0)
-+ return -ENOENT;
- hfs_bnode_dump(parent);
- rec = fd->record;
-
-diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h
-index ca6d2acc..f39722b 100644
---- a/include/linux/device-mapper.h
-+++ b/include/linux/device-mapper.h
-@@ -368,6 +368,7 @@ int dm_create(int minor, struct mapped_device **md);
- */
- struct mapped_device *dm_get_md(dev_t dev);
- void dm_get(struct mapped_device *md);
-+int dm_hold(struct mapped_device *md);
- void dm_put(struct mapped_device *md);
-
- /*
-diff --git a/include/linux/mfd/palmas.h b/include/linux/mfd/palmas.h
-index fb0390a..ee7b1ce 100644
---- a/include/linux/mfd/palmas.h
-+++ b/include/linux/mfd/palmas.h
-@@ -2999,6 +2999,9 @@ enum usb_irq_events {
- #define PALMAS_GPADC_TRIM15 0x0E
- #define PALMAS_GPADC_TRIM16 0x0F
-
-+/* TPS659038 regen2_ctrl offset iss different from palmas */
-+#define TPS659038_REGEN2_CTRL 0x12
-+
- /* TPS65917 Interrupt registers */
-
- /* Registers for function INTERRUPT */
-diff --git a/include/trace/events/regmap.h b/include/trace/events/regmap.h
-index 23d5615..22317d2 100644
---- a/include/trace/events/regmap.h
-+++ b/include/trace/events/regmap.h
-@@ -7,27 +7,26 @@
- #include <linux/ktime.h>
- #include <linux/tracepoint.h>
-
--struct device;
--struct regmap;
-+#include "../../../drivers/base/regmap/internal.h"
-
- /*
- * Log register events
- */
- DECLARE_EVENT_CLASS(regmap_reg,
-
-- TP_PROTO(struct device *dev, unsigned int reg,
-+ TP_PROTO(struct regmap *map, unsigned int reg,
- unsigned int val),
-
-- TP_ARGS(dev, reg, val),
-+ TP_ARGS(map, reg, val),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-- __field( unsigned int, reg )
-- __field( unsigned int, val )
-+ __string( name, regmap_name(map) )
-+ __field( unsigned int, reg )
-+ __field( unsigned int, val )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- __entry->reg = reg;
- __entry->val = val;
- ),
-@@ -39,45 +38,45 @@ DECLARE_EVENT_CLASS(regmap_reg,
-
- DEFINE_EVENT(regmap_reg, regmap_reg_write,
-
-- TP_PROTO(struct device *dev, unsigned int reg,
-+ TP_PROTO(struct regmap *map, unsigned int reg,
- unsigned int val),
-
-- TP_ARGS(dev, reg, val)
-+ TP_ARGS(map, reg, val)
-
- );
-
- DEFINE_EVENT(regmap_reg, regmap_reg_read,
-
-- TP_PROTO(struct device *dev, unsigned int reg,
-+ TP_PROTO(struct regmap *map, unsigned int reg,
- unsigned int val),
-
-- TP_ARGS(dev, reg, val)
-+ TP_ARGS(map, reg, val)
-
- );
-
- DEFINE_EVENT(regmap_reg, regmap_reg_read_cache,
-
-- TP_PROTO(struct device *dev, unsigned int reg,
-+ TP_PROTO(struct regmap *map, unsigned int reg,
- unsigned int val),
-
-- TP_ARGS(dev, reg, val)
-+ TP_ARGS(map, reg, val)
-
- );
-
- DECLARE_EVENT_CLASS(regmap_block,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count),
-+ TP_ARGS(map, reg, count),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-- __field( unsigned int, reg )
-- __field( int, count )
-+ __string( name, regmap_name(map) )
-+ __field( unsigned int, reg )
-+ __field( int, count )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- __entry->reg = reg;
- __entry->count = count;
- ),
-@@ -89,48 +88,48 @@ DECLARE_EVENT_CLASS(regmap_block,
-
- DEFINE_EVENT(regmap_block, regmap_hw_read_start,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count)
-+ TP_ARGS(map, reg, count)
- );
-
- DEFINE_EVENT(regmap_block, regmap_hw_read_done,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count)
-+ TP_ARGS(map, reg, count)
- );
-
- DEFINE_EVENT(regmap_block, regmap_hw_write_start,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count)
-+ TP_ARGS(map, reg, count)
- );
-
- DEFINE_EVENT(regmap_block, regmap_hw_write_done,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count)
-+ TP_ARGS(map, reg, count)
- );
-
- TRACE_EVENT(regcache_sync,
-
-- TP_PROTO(struct device *dev, const char *type,
-+ TP_PROTO(struct regmap *map, const char *type,
- const char *status),
-
-- TP_ARGS(dev, type, status),
-+ TP_ARGS(map, type, status),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-- __string( status, status )
-- __string( type, type )
-- __field( int, type )
-+ __string( name, regmap_name(map) )
-+ __string( status, status )
-+ __string( type, type )
-+ __field( int, type )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- __assign_str(status, status);
- __assign_str(type, type);
- ),
-@@ -141,17 +140,17 @@ TRACE_EVENT(regcache_sync,
-
- DECLARE_EVENT_CLASS(regmap_bool,
-
-- TP_PROTO(struct device *dev, bool flag),
-+ TP_PROTO(struct regmap *map, bool flag),
-
-- TP_ARGS(dev, flag),
-+ TP_ARGS(map, flag),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-- __field( int, flag )
-+ __string( name, regmap_name(map) )
-+ __field( int, flag )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- __entry->flag = flag;
- ),
-
-@@ -161,32 +160,32 @@ DECLARE_EVENT_CLASS(regmap_bool,
-
- DEFINE_EVENT(regmap_bool, regmap_cache_only,
-
-- TP_PROTO(struct device *dev, bool flag),
-+ TP_PROTO(struct regmap *map, bool flag),
-
-- TP_ARGS(dev, flag)
-+ TP_ARGS(map, flag)
-
- );
-
- DEFINE_EVENT(regmap_bool, regmap_cache_bypass,
-
-- TP_PROTO(struct device *dev, bool flag),
-+ TP_PROTO(struct regmap *map, bool flag),
-
-- TP_ARGS(dev, flag)
-+ TP_ARGS(map, flag)
-
- );
-
- DECLARE_EVENT_CLASS(regmap_async,
-
-- TP_PROTO(struct device *dev),
-+ TP_PROTO(struct regmap *map),
-
-- TP_ARGS(dev),
-+ TP_ARGS(map),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-+ __string( name, regmap_name(map) )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- ),
-
- TP_printk("%s", __get_str(name))
-@@ -194,50 +193,50 @@ DECLARE_EVENT_CLASS(regmap_async,
-
- DEFINE_EVENT(regmap_block, regmap_async_write_start,
-
-- TP_PROTO(struct device *dev, unsigned int reg, int count),
-+ TP_PROTO(struct regmap *map, unsigned int reg, int count),
-
-- TP_ARGS(dev, reg, count)
-+ TP_ARGS(map, reg, count)
- );
-
- DEFINE_EVENT(regmap_async, regmap_async_io_complete,
-
-- TP_PROTO(struct device *dev),
-+ TP_PROTO(struct regmap *map),
-
-- TP_ARGS(dev)
-+ TP_ARGS(map)
-
- );
-
- DEFINE_EVENT(regmap_async, regmap_async_complete_start,
-
-- TP_PROTO(struct device *dev),
-+ TP_PROTO(struct regmap *map),
-
-- TP_ARGS(dev)
-+ TP_ARGS(map)
-
- );
-
- DEFINE_EVENT(regmap_async, regmap_async_complete_done,
-
-- TP_PROTO(struct device *dev),
-+ TP_PROTO(struct regmap *map),
-
-- TP_ARGS(dev)
-+ TP_ARGS(map)
-
- );
-
- TRACE_EVENT(regcache_drop_region,
-
-- TP_PROTO(struct device *dev, unsigned int from,
-+ TP_PROTO(struct regmap *map, unsigned int from,
- unsigned int to),
-
-- TP_ARGS(dev, from, to),
-+ TP_ARGS(map, from, to),
-
- TP_STRUCT__entry(
-- __string( name, dev_name(dev) )
-- __field( unsigned int, from )
-- __field( unsigned int, to )
-+ __string( name, regmap_name(map) )
-+ __field( unsigned int, from )
-+ __field( unsigned int, to )
- ),
-
- TP_fast_assign(
-- __assign_str(name, dev_name(dev));
-+ __assign_str(name, regmap_name(map));
- __entry->from = from;
- __entry->to = to;
- ),
-diff --git a/kernel/events/core.c b/kernel/events/core.c
-index 19efcf1..7959624 100644
---- a/kernel/events/core.c
-+++ b/kernel/events/core.c
-@@ -4412,6 +4412,13 @@ static void perf_pending_event(struct irq_work *entry)
- {
- struct perf_event *event = container_of(entry,
- struct perf_event, pending);
-+ int rctx;
-+
-+ rctx = perf_swevent_get_recursion_context();
-+ /*
-+ * If we 'fail' here, that's OK, it means recursion is already disabled
-+ * and we won't recurse 'further'.
-+ */
-
- if (event->pending_disable) {
- event->pending_disable = 0;
-@@ -4422,6 +4429,9 @@ static void perf_pending_event(struct irq_work *entry)
- event->pending_wakeup = 0;
- perf_event_wakeup(event);
- }
-+
-+ if (rctx >= 0)
-+ perf_swevent_put_recursion_context(rctx);
- }
-
- /*
-diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
-index cc6e964..fa7568c 100644
---- a/net/mac80211/ieee80211_i.h
-+++ b/net/mac80211/ieee80211_i.h
-@@ -58,13 +58,24 @@ struct ieee80211_local;
- #define IEEE80211_UNSET_POWER_LEVEL INT_MIN
-
- /*
-- * Some APs experience problems when working with U-APSD. Decrease the
-- * probability of that happening by using legacy mode for all ACs but VO.
-- * The AP that caused us trouble was a Cisco 4410N. It ignores our
-- * setting, and always treats non-VO ACs as legacy.
-+ * Some APs experience problems when working with U-APSD. Decreasing the
-+ * probability of that happening by using legacy mode for all ACs but VO isn't
-+ * enough.
-+ *
-+ * Cisco 4410N originally forced us to enable VO by default only because it
-+ * treated non-VO ACs as legacy.
-+ *
-+ * However some APs (notably Netgear R7000) silently reclassify packets to
-+ * different ACs. Since u-APSD ACs require trigger frames for frame retrieval
-+ * clients would never see some frames (e.g. ARP responses) or would fetch them
-+ * accidentally after a long time.
-+ *
-+ * It makes little sense to enable u-APSD queues by default because it needs
-+ * userspace applications to be aware of it to actually take advantage of the
-+ * possible additional powersavings. Implicitly depending on driver autotrigger
-+ * frame support doesn't make much sense.
- */
--#define IEEE80211_DEFAULT_UAPSD_QUEUES \
-- IEEE80211_WMM_IE_STA_QOSINFO_AC_VO
-+#define IEEE80211_DEFAULT_UAPSD_QUEUES 0
-
- #define IEEE80211_DEFAULT_MAX_SP_LEN \
- IEEE80211_WMM_IE_STA_QOSINFO_SP_ALL
-diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
-index d69ca51..b448e8f 100644
---- a/net/mac80211/rx.c
-+++ b/net/mac80211/rx.c
-@@ -2191,6 +2191,9 @@ ieee80211_rx_h_mesh_fwding(struct ieee80211_rx_data *rx)
- hdr = (struct ieee80211_hdr *) skb->data;
- mesh_hdr = (struct ieee80211s_hdr *) (skb->data + hdrlen);
-
-+ if (ieee80211_drop_unencrypted(rx, hdr->frame_control))
-+ return RX_DROP_MONITOR;
-+
- /* frame is in RMC, don't forward */
- if (ieee80211_is_data(hdr->frame_control) &&
- is_multicast_ether_addr(hdr->addr1) &&
-diff --git a/net/mac80211/util.c b/net/mac80211/util.c
-index 974ebe7..1ce38e7 100644
---- a/net/mac80211/util.c
-+++ b/net/mac80211/util.c
-@@ -3153,7 +3153,7 @@ int ieee80211_check_combinations(struct ieee80211_sub_if_data *sdata,
- wdev_iter = &sdata_iter->wdev;
-
- if (sdata_iter == sdata ||
-- rcu_access_pointer(sdata_iter->vif.chanctx_conf) == NULL ||
-+ !ieee80211_sdata_running(sdata_iter) ||
- local->hw.wiphy->software_iftypes & BIT(wdev_iter->iftype))
- continue;
-
-diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
-index 8887c6e..e13325f 100644
---- a/net/wireless/nl80211.c
-+++ b/net/wireless/nl80211.c
-@@ -4360,6 +4360,16 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info)
- if (parse_station_flags(info, dev->ieee80211_ptr->iftype, &params))
- return -EINVAL;
-
-+ /* HT/VHT requires QoS, but if we don't have that just ignore HT/VHT
-+ * as userspace might just pass through the capabilities from the IEs
-+ * directly, rather than enforcing this restriction and returning an
-+ * error in this case.
-+ */
-+ if (!(params.sta_flags_set & BIT(NL80211_STA_FLAG_WME))) {
-+ params.ht_capa = NULL;
-+ params.vht_capa = NULL;
-+ }
-+
- /* When you run into this, adjust the code below for the new flag */
- BUILD_BUG_ON(NL80211_STA_FLAG_MAX != 7);
-
-diff --git a/sound/soc/codecs/adav80x.c b/sound/soc/codecs/adav80x.c
-index b67480f..4373ada 100644
---- a/sound/soc/codecs/adav80x.c
-+++ b/sound/soc/codecs/adav80x.c
-@@ -317,7 +317,7 @@ static int adav80x_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct adav80x *adav80x = snd_soc_codec_get_drvdata(codec);
-- unsigned int deemph = ucontrol->value.enumerated.item[0];
-+ unsigned int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-@@ -333,7 +333,7 @@ static int adav80x_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct adav80x *adav80x = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = adav80x->deemph;
-+ ucontrol->value.integer.value[0] = adav80x->deemph;
- return 0;
- };
-
-diff --git a/sound/soc/codecs/ak4641.c b/sound/soc/codecs/ak4641.c
-index 70861c7..81b54a2 100644
---- a/sound/soc/codecs/ak4641.c
-+++ b/sound/soc/codecs/ak4641.c
-@@ -76,7 +76,7 @@ static int ak4641_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct ak4641_priv *ak4641 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-@@ -92,7 +92,7 @@ static int ak4641_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct ak4641_priv *ak4641 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = ak4641->deemph;
-+ ucontrol->value.integer.value[0] = ak4641->deemph;
- return 0;
- };
-
-diff --git a/sound/soc/codecs/ak4671.c b/sound/soc/codecs/ak4671.c
-index 686cacb..a981c1e 100644
---- a/sound/soc/codecs/ak4671.c
-+++ b/sound/soc/codecs/ak4671.c
-@@ -343,25 +343,25 @@ static const struct snd_soc_dapm_widget ak4671_dapm_widgets[] = {
- };
-
- static const struct snd_soc_dapm_route ak4671_intercon[] = {
-- {"DAC Left", "NULL", "PMPLL"},
-- {"DAC Right", "NULL", "PMPLL"},
-- {"ADC Left", "NULL", "PMPLL"},
-- {"ADC Right", "NULL", "PMPLL"},
-+ {"DAC Left", NULL, "PMPLL"},
-+ {"DAC Right", NULL, "PMPLL"},
-+ {"ADC Left", NULL, "PMPLL"},
-+ {"ADC Right", NULL, "PMPLL"},
-
- /* Outputs */
-- {"LOUT1", "NULL", "LOUT1 Mixer"},
-- {"ROUT1", "NULL", "ROUT1 Mixer"},
-- {"LOUT2", "NULL", "LOUT2 Mix Amp"},
-- {"ROUT2", "NULL", "ROUT2 Mix Amp"},
-- {"LOUT3", "NULL", "LOUT3 Mixer"},
-- {"ROUT3", "NULL", "ROUT3 Mixer"},
-+ {"LOUT1", NULL, "LOUT1 Mixer"},
-+ {"ROUT1", NULL, "ROUT1 Mixer"},
-+ {"LOUT2", NULL, "LOUT2 Mix Amp"},
-+ {"ROUT2", NULL, "ROUT2 Mix Amp"},
-+ {"LOUT3", NULL, "LOUT3 Mixer"},
-+ {"ROUT3", NULL, "ROUT3 Mixer"},
-
- {"LOUT1 Mixer", "DACL", "DAC Left"},
- {"ROUT1 Mixer", "DACR", "DAC Right"},
- {"LOUT2 Mixer", "DACHL", "DAC Left"},
- {"ROUT2 Mixer", "DACHR", "DAC Right"},
-- {"LOUT2 Mix Amp", "NULL", "LOUT2 Mixer"},
-- {"ROUT2 Mix Amp", "NULL", "ROUT2 Mixer"},
-+ {"LOUT2 Mix Amp", NULL, "LOUT2 Mixer"},
-+ {"ROUT2 Mix Amp", NULL, "ROUT2 Mixer"},
- {"LOUT3 Mixer", "DACSL", "DAC Left"},
- {"ROUT3 Mixer", "DACSR", "DAC Right"},
-
-@@ -381,18 +381,18 @@ static const struct snd_soc_dapm_route ak4671_intercon[] = {
- {"LIN2", NULL, "Mic Bias"},
- {"RIN2", NULL, "Mic Bias"},
-
-- {"ADC Left", "NULL", "LIN MUX"},
-- {"ADC Right", "NULL", "RIN MUX"},
-+ {"ADC Left", NULL, "LIN MUX"},
-+ {"ADC Right", NULL, "RIN MUX"},
-
- /* Analog Loops */
-- {"LIN1 Mixing Circuit", "NULL", "LIN1"},
-- {"RIN1 Mixing Circuit", "NULL", "RIN1"},
-- {"LIN2 Mixing Circuit", "NULL", "LIN2"},
-- {"RIN2 Mixing Circuit", "NULL", "RIN2"},
-- {"LIN3 Mixing Circuit", "NULL", "LIN3"},
-- {"RIN3 Mixing Circuit", "NULL", "RIN3"},
-- {"LIN4 Mixing Circuit", "NULL", "LIN4"},
-- {"RIN4 Mixing Circuit", "NULL", "RIN4"},
-+ {"LIN1 Mixing Circuit", NULL, "LIN1"},
-+ {"RIN1 Mixing Circuit", NULL, "RIN1"},
-+ {"LIN2 Mixing Circuit", NULL, "LIN2"},
-+ {"RIN2 Mixing Circuit", NULL, "RIN2"},
-+ {"LIN3 Mixing Circuit", NULL, "LIN3"},
-+ {"RIN3 Mixing Circuit", NULL, "RIN3"},
-+ {"LIN4 Mixing Circuit", NULL, "LIN4"},
-+ {"RIN4 Mixing Circuit", NULL, "RIN4"},
-
- {"LOUT1 Mixer", "LINL1", "LIN1 Mixing Circuit"},
- {"ROUT1 Mixer", "RINR1", "RIN1 Mixing Circuit"},
-diff --git a/sound/soc/codecs/cs4271.c b/sound/soc/codecs/cs4271.c
-index 79a4efc..7d3a6ac 100644
---- a/sound/soc/codecs/cs4271.c
-+++ b/sound/soc/codecs/cs4271.c
-@@ -286,7 +286,7 @@ static int cs4271_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct cs4271_private *cs4271 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = cs4271->deemph;
-+ ucontrol->value.integer.value[0] = cs4271->deemph;
- return 0;
- }
-
-@@ -296,7 +296,7 @@ static int cs4271_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct cs4271_private *cs4271 = snd_soc_codec_get_drvdata(codec);
-
-- cs4271->deemph = ucontrol->value.enumerated.item[0];
-+ cs4271->deemph = ucontrol->value.integer.value[0];
- return cs4271_set_deemph(codec);
- }
-
-diff --git a/sound/soc/codecs/da732x.c b/sound/soc/codecs/da732x.c
-index 61b2f9a..e3110c6 100644
---- a/sound/soc/codecs/da732x.c
-+++ b/sound/soc/codecs/da732x.c
-@@ -876,11 +876,11 @@ static const struct snd_soc_dapm_widget da732x_dapm_widgets[] = {
-
- static const struct snd_soc_dapm_route da732x_dapm_routes[] = {
- /* Inputs */
-- {"AUX1L PGA", "NULL", "AUX1L"},
-- {"AUX1R PGA", "NULL", "AUX1R"},
-+ {"AUX1L PGA", NULL, "AUX1L"},
-+ {"AUX1R PGA", NULL, "AUX1R"},
- {"MIC1 PGA", NULL, "MIC1"},
-- {"MIC2 PGA", "NULL", "MIC2"},
-- {"MIC3 PGA", "NULL", "MIC3"},
-+ {"MIC2 PGA", NULL, "MIC2"},
-+ {"MIC3 PGA", NULL, "MIC3"},
-
- /* Capture Path */
- {"ADC1 Left MUX", "MIC1", "MIC1 PGA"},
-diff --git a/sound/soc/codecs/es8328.c b/sound/soc/codecs/es8328.c
-index f273251..c5f35a0 100644
---- a/sound/soc/codecs/es8328.c
-+++ b/sound/soc/codecs/es8328.c
-@@ -120,7 +120,7 @@ static int es8328_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct es8328_priv *es8328 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = es8328->deemph;
-+ ucontrol->value.integer.value[0] = es8328->deemph;
- return 0;
- }
-
-@@ -129,7 +129,7 @@ static int es8328_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct es8328_priv *es8328 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
- int ret;
-
- if (deemph > 1)
-diff --git a/sound/soc/codecs/pcm1681.c b/sound/soc/codecs/pcm1681.c
-index a722a02..477e13d 100644
---- a/sound/soc/codecs/pcm1681.c
-+++ b/sound/soc/codecs/pcm1681.c
-@@ -118,7 +118,7 @@ static int pcm1681_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct pcm1681_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = priv->deemph;
-+ ucontrol->value.integer.value[0] = priv->deemph;
-
- return 0;
- }
-@@ -129,7 +129,7 @@ static int pcm1681_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct pcm1681_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- priv->deemph = ucontrol->value.enumerated.item[0];
-+ priv->deemph = ucontrol->value.integer.value[0];
-
- return pcm1681_set_deemph(codec);
- }
-diff --git a/sound/soc/codecs/sgtl5000.c b/sound/soc/codecs/sgtl5000.c
-index aa98be3..10d2415 100644
---- a/sound/soc/codecs/sgtl5000.c
-+++ b/sound/soc/codecs/sgtl5000.c
-@@ -1149,13 +1149,7 @@ static int sgtl5000_set_power_regs(struct snd_soc_codec *codec)
- /* Enable VDDC charge pump */
- ana_pwr |= SGTL5000_VDDC_CHRGPMP_POWERUP;
- } else if (vddio >= 3100 && vdda >= 3100) {
-- /*
-- * if vddio and vddd > 3.1v,
-- * charge pump should be clean before set ana_pwr
-- */
-- snd_soc_update_bits(codec, SGTL5000_CHIP_ANA_POWER,
-- SGTL5000_VDDC_CHRGPMP_POWERUP, 0);
--
-+ ana_pwr &= ~SGTL5000_VDDC_CHRGPMP_POWERUP;
- /* VDDC use VDDIO rail */
- lreg_ctrl |= SGTL5000_VDDC_ASSN_OVRD;
- lreg_ctrl |= SGTL5000_VDDC_MAN_ASSN_VDDIO <<
-diff --git a/sound/soc/codecs/sn95031.c b/sound/soc/codecs/sn95031.c
-index 1f451a1..4ff4aa7 100644
---- a/sound/soc/codecs/sn95031.c
-+++ b/sound/soc/codecs/sn95031.c
-@@ -531,8 +531,8 @@ static const struct snd_soc_dapm_route sn95031_audio_map[] = {
- /* speaker map */
- { "IHFOUTL", NULL, "Speaker Rail"},
- { "IHFOUTR", NULL, "Speaker Rail"},
-- { "IHFOUTL", "NULL", "Speaker Left Playback"},
-- { "IHFOUTR", "NULL", "Speaker Right Playback"},
-+ { "IHFOUTL", NULL, "Speaker Left Playback"},
-+ { "IHFOUTR", NULL, "Speaker Right Playback"},
- { "Speaker Left Playback", NULL, "Speaker Left Filter"},
- { "Speaker Right Playback", NULL, "Speaker Right Filter"},
- { "Speaker Left Filter", NULL, "IHFDAC Left"},
-diff --git a/sound/soc/codecs/tas5086.c b/sound/soc/codecs/tas5086.c
-index 249ef5c..32942be 100644
---- a/sound/soc/codecs/tas5086.c
-+++ b/sound/soc/codecs/tas5086.c
-@@ -281,7 +281,7 @@ static int tas5086_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct tas5086_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = priv->deemph;
-+ ucontrol->value.integer.value[0] = priv->deemph;
-
- return 0;
- }
-@@ -292,7 +292,7 @@ static int tas5086_put_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct tas5086_private *priv = snd_soc_codec_get_drvdata(codec);
-
-- priv->deemph = ucontrol->value.enumerated.item[0];
-+ priv->deemph = ucontrol->value.integer.value[0];
-
- return tas5086_set_deemph(codec);
- }
-diff --git a/sound/soc/codecs/wm2000.c b/sound/soc/codecs/wm2000.c
-index 34ef65c..8eeab47 100644
---- a/sound/soc/codecs/wm2000.c
-+++ b/sound/soc/codecs/wm2000.c
-@@ -610,7 +610,7 @@ static int wm2000_anc_mode_get(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-
-- ucontrol->value.enumerated.item[0] = wm2000->anc_active;
-+ ucontrol->value.integer.value[0] = wm2000->anc_active;
-
- return 0;
- }
-@@ -620,7 +620,7 @@ static int wm2000_anc_mode_put(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-- int anc_active = ucontrol->value.enumerated.item[0];
-+ int anc_active = ucontrol->value.integer.value[0];
- int ret;
-
- if (anc_active > 1)
-@@ -643,7 +643,7 @@ static int wm2000_speaker_get(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-
-- ucontrol->value.enumerated.item[0] = wm2000->spk_ena;
-+ ucontrol->value.integer.value[0] = wm2000->spk_ena;
-
- return 0;
- }
-@@ -653,7 +653,7 @@ static int wm2000_speaker_put(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm2000_priv *wm2000 = dev_get_drvdata(codec->dev);
-- int val = ucontrol->value.enumerated.item[0];
-+ int val = ucontrol->value.integer.value[0];
- int ret;
-
- if (val > 1)
-diff --git a/sound/soc/codecs/wm8731.c b/sound/soc/codecs/wm8731.c
-index b115ed8..391534f 100644
---- a/sound/soc/codecs/wm8731.c
-+++ b/sound/soc/codecs/wm8731.c
-@@ -125,7 +125,7 @@ static int wm8731_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8731_priv *wm8731 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8731->deemph;
-+ ucontrol->value.integer.value[0] = wm8731->deemph;
-
- return 0;
- }
-@@ -135,7 +135,7 @@ static int wm8731_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8731_priv *wm8731 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
- int ret = 0;
-
- if (deemph > 1)
-diff --git a/sound/soc/codecs/wm8903.c b/sound/soc/codecs/wm8903.c
-index cc6b0ef..15435c9 100644
---- a/sound/soc/codecs/wm8903.c
-+++ b/sound/soc/codecs/wm8903.c
-@@ -442,7 +442,7 @@ static int wm8903_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8903_priv *wm8903 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8903->deemph;
-+ ucontrol->value.integer.value[0] = wm8903->deemph;
-
- return 0;
- }
-@@ -452,7 +452,7 @@ static int wm8903_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8903_priv *wm8903 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
- int ret = 0;
-
- if (deemph > 1)
-diff --git a/sound/soc/codecs/wm8904.c b/sound/soc/codecs/wm8904.c
-index 75b87c5..b945a3b 100644
---- a/sound/soc/codecs/wm8904.c
-+++ b/sound/soc/codecs/wm8904.c
-@@ -525,7 +525,7 @@ static int wm8904_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8904_priv *wm8904 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8904->deemph;
-+ ucontrol->value.integer.value[0] = wm8904->deemph;
- return 0;
- }
-
-@@ -534,7 +534,7 @@ static int wm8904_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8904_priv *wm8904 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/codecs/wm8955.c b/sound/soc/codecs/wm8955.c
-index 1173f7f..035bdc4 100644
---- a/sound/soc/codecs/wm8955.c
-+++ b/sound/soc/codecs/wm8955.c
-@@ -393,7 +393,7 @@ static int wm8955_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8955_priv *wm8955 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8955->deemph;
-+ ucontrol->value.integer.value[0] = wm8955->deemph;
- return 0;
- }
-
-@@ -402,7 +402,7 @@ static int wm8955_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8955_priv *wm8955 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/codecs/wm8960.c b/sound/soc/codecs/wm8960.c
-index a96eb49..0435aeb 100644
---- a/sound/soc/codecs/wm8960.c
-+++ b/sound/soc/codecs/wm8960.c
-@@ -182,7 +182,7 @@ static int wm8960_get_deemph(struct snd_kcontrol *kcontrol,
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8960_priv *wm8960 = snd_soc_codec_get_drvdata(codec);
-
-- ucontrol->value.enumerated.item[0] = wm8960->deemph;
-+ ucontrol->value.integer.value[0] = wm8960->deemph;
- return 0;
- }
-
-@@ -191,7 +191,7 @@ static int wm8960_put_deemph(struct snd_kcontrol *kcontrol,
- {
- struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
- struct wm8960_priv *wm8960 = snd_soc_codec_get_drvdata(codec);
-- int deemph = ucontrol->value.enumerated.item[0];
-+ int deemph = ucontrol->value.integer.value[0];
-
- if (deemph > 1)
- return -EINVAL;
-diff --git a/sound/soc/codecs/wm9712.c b/sound/soc/codecs/wm9712.c
-index 9517571..98c9525 100644
---- a/sound/soc/codecs/wm9712.c
-+++ b/sound/soc/codecs/wm9712.c
-@@ -180,7 +180,7 @@ static int wm9712_hp_mixer_put(struct snd_kcontrol *kcontrol,
- struct snd_soc_dapm_context *dapm = snd_soc_dapm_kcontrol_dapm(kcontrol);
- struct snd_soc_codec *codec = snd_soc_dapm_to_codec(dapm);
- struct wm9712_priv *wm9712 = snd_soc_codec_get_drvdata(codec);
-- unsigned int val = ucontrol->value.enumerated.item[0];
-+ unsigned int val = ucontrol->value.integer.value[0];
- struct soc_mixer_control *mc =
- (struct soc_mixer_control *)kcontrol->private_value;
- unsigned int mixer, mask, shift, old;
-@@ -193,7 +193,7 @@ static int wm9712_hp_mixer_put(struct snd_kcontrol *kcontrol,
-
- mutex_lock(&wm9712->lock);
- old = wm9712->hp_mixer[mixer];
-- if (ucontrol->value.enumerated.item[0])
-+ if (ucontrol->value.integer.value[0])
- wm9712->hp_mixer[mixer] |= mask;
- else
- wm9712->hp_mixer[mixer] &= ~mask;
-@@ -231,7 +231,7 @@ static int wm9712_hp_mixer_get(struct snd_kcontrol *kcontrol,
- mixer = mc->shift >> 8;
- shift = mc->shift & 0xff;
-
-- ucontrol->value.enumerated.item[0] =
-+ ucontrol->value.integer.value[0] =
- (wm9712->hp_mixer[mixer] >> shift) & 1;
-
- return 0;
-diff --git a/sound/soc/codecs/wm9713.c b/sound/soc/codecs/wm9713.c
-index 6ab1122..db644c6 100644
---- a/sound/soc/codecs/wm9713.c
-+++ b/sound/soc/codecs/wm9713.c
-@@ -255,7 +255,7 @@ static int wm9713_hp_mixer_put(struct snd_kcontrol *kcontrol,
- struct snd_soc_dapm_context *dapm = snd_soc_dapm_kcontrol_dapm(kcontrol);
- struct snd_soc_codec *codec = snd_soc_dapm_to_codec(dapm);
- struct wm9713_priv *wm9713 = snd_soc_codec_get_drvdata(codec);
-- unsigned int val = ucontrol->value.enumerated.item[0];
-+ unsigned int val = ucontrol->value.integer.value[0];
- struct soc_mixer_control *mc =
- (struct soc_mixer_control *)kcontrol->private_value;
- unsigned int mixer, mask, shift, old;
-@@ -268,7 +268,7 @@ static int wm9713_hp_mixer_put(struct snd_kcontrol *kcontrol,
-
- mutex_lock(&wm9713->lock);
- old = wm9713->hp_mixer[mixer];
-- if (ucontrol->value.enumerated.item[0])
-+ if (ucontrol->value.integer.value[0])
- wm9713->hp_mixer[mixer] |= mask;
- else
- wm9713->hp_mixer[mixer] &= ~mask;
-@@ -306,7 +306,7 @@ static int wm9713_hp_mixer_get(struct snd_kcontrol *kcontrol,
- mixer = mc->shift >> 8;
- shift = mc->shift & 0xff;
-
-- ucontrol->value.enumerated.item[0] =
-+ ucontrol->value.integer.value[0] =
- (wm9713->hp_mixer[mixer] >> shift) & 1;
-
- return 0;
diff --git a/3.19.4/0000_README b/3.19.5/0000_README
index d6b2506..fe57086 100644
--- a/3.19.4/0000_README
+++ b/3.19.5/0000_README
@@ -2,11 +2,7 @@ README
-----------------------------------------------------------------------------
Individual Patch Descriptions:
-----------------------------------------------------------------------------
-Patch: 1003_linux-3.19.4.patch
-From: http://www.kernel.org
-Desc: Linux 3.19.4
-
-Patch: 4420_grsecurity-3.1-3.19.4-201504142300.patch
+Patch: 4420_grsecurity-3.1-3.19.5-201504190814.patch
From: http://www.grsecurity.net
Desc: hardened-sources base patch from upstream grsecurity
diff --git a/3.19.4/4420_grsecurity-3.1-3.19.4-201504142300.patch b/3.19.5/4420_grsecurity-3.1-3.19.5-201504190814.patch
index 93459d8..6ae0a6e 100644
--- a/3.19.4/4420_grsecurity-3.1-3.19.4-201504142300.patch
+++ b/3.19.5/4420_grsecurity-3.1-3.19.5-201504190814.patch
@@ -373,7 +373,7 @@ index 176d4fe..6eabd3c 100644
pcd. [PARIDE]
diff --git a/Makefile b/Makefile
-index 2ef2078..dbf475b 100644
+index 633b5f0..10aa54f 100644
--- a/Makefile
+++ b/Makefile
@@ -298,7 +298,9 @@ CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
@@ -27041,7 +27041,7 @@ index 2f355d2..e75ed0a 100644
return ret;
diff --git a/arch/x86/kernel/reboot.c b/arch/x86/kernel/reboot.c
-index bae6c60..b438619 100644
+index 86db4bc..531675b 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -70,6 +70,11 @@ static int __init set_bios_reboot(const struct dmi_system_id *d)
@@ -27087,7 +27087,7 @@ index bae6c60..b438619 100644
"rm" (real_mode_header->machine_real_restart_asm),
"a" (type));
#else
-@@ -501,7 +528,7 @@ void __attribute__((weak)) mach_reboot_fixups(void)
+@@ -511,7 +538,7 @@ void __attribute__((weak)) mach_reboot_fixups(void)
* This means that this function can never return, it can misbehave
* by not rebooting properly and hanging.
*/
@@ -27096,7 +27096,7 @@ index bae6c60..b438619 100644
{
int i;
int attempt = 0;
-@@ -621,13 +648,13 @@ void native_machine_shutdown(void)
+@@ -631,13 +658,13 @@ void native_machine_shutdown(void)
#endif
}
@@ -27112,7 +27112,7 @@ index bae6c60..b438619 100644
{
pr_notice("machine restart\n");
-@@ -636,7 +663,7 @@ static void native_machine_restart(char *__unused)
+@@ -646,7 +673,7 @@ static void native_machine_restart(char *__unused)
__machine_emergency_restart(0);
}
@@ -27121,7 +27121,7 @@ index bae6c60..b438619 100644
{
/* Stop other cpus and apics */
machine_shutdown();
-@@ -646,7 +673,7 @@ static void native_machine_halt(void)
+@@ -656,7 +683,7 @@ static void native_machine_halt(void)
stop_this_cpu(NULL);
}
@@ -27130,7 +27130,7 @@ index bae6c60..b438619 100644
{
if (pm_power_off) {
if (!reboot_force)
-@@ -655,9 +682,10 @@ static void native_machine_power_off(void)
+@@ -665,9 +692,10 @@ static void native_machine_power_off(void)
}
/* A fallback in case there is no PM info available */
tboot_shutdown(TB_SHUTDOWN_HALT);
@@ -36155,7 +36155,7 @@ index f890d43..97b0482 100644
bio = bio_copy_kern(q, kbuf, len, gfp_mask, reading);
else
diff --git a/block/blk-mq.c b/block/blk-mq.c
-index 2390c55..e3fefe4 100644
+index 447f533..da01de2 100644
--- a/block/blk-mq.c
+++ b/block/blk-mq.c
@@ -1456,7 +1456,7 @@ static struct blk_mq_tags *blk_mq_init_rq_map(struct blk_mq_tag_set *set,
@@ -36556,7 +36556,7 @@ index c0d44d3..5ad8f9a 100644
}
EXPORT_SYMBOL_GPL(acpi_dev_pm_attach);
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c
-index 87b704e..2d1d0c1 100644
+index b27ab7a..275b1b6 100644
--- a/drivers/acpi/processor_idle.c
+++ b/drivers/acpi/processor_idle.c
@@ -952,7 +952,7 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
@@ -36600,7 +36600,7 @@ index 61a9c07..ea98fa1 100644
unsigned long timeout_msec)
{
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
-index d1a05f9..eb70e10 100644
+index 00f2f74..efd8b7d 100644
--- a/drivers/ata/libata-core.c
+++ b/drivers/ata/libata-core.c
@@ -99,7 +99,7 @@ static unsigned int ata_dev_set_xfermode(struct ata_device *dev);
@@ -36612,7 +36612,7 @@ index d1a05f9..eb70e10 100644
struct ata_force_param {
const char *name;
-@@ -4831,7 +4831,7 @@ void ata_qc_free(struct ata_queued_cmd *qc)
+@@ -4842,7 +4842,7 @@ void ata_qc_free(struct ata_queued_cmd *qc)
struct ata_port *ap;
unsigned int tag;
@@ -36621,7 +36621,7 @@ index d1a05f9..eb70e10 100644
ap = qc->ap;
qc->flags = 0;
-@@ -4847,7 +4847,7 @@ void __ata_qc_complete(struct ata_queued_cmd *qc)
+@@ -4858,7 +4858,7 @@ void __ata_qc_complete(struct ata_queued_cmd *qc)
struct ata_port *ap;
struct ata_link *link;
@@ -36630,7 +36630,7 @@ index d1a05f9..eb70e10 100644
WARN_ON_ONCE(!(qc->flags & ATA_QCFLAG_ACTIVE));
ap = qc->ap;
link = qc->dev->link;
-@@ -5951,6 +5951,7 @@ static void ata_finalize_port_ops(struct ata_port_operations *ops)
+@@ -5962,6 +5962,7 @@ static void ata_finalize_port_ops(struct ata_port_operations *ops)
return;
spin_lock(&lock);
@@ -36638,7 +36638,7 @@ index d1a05f9..eb70e10 100644
for (cur = ops->inherits; cur; cur = cur->inherits) {
void **inherit = (void **)cur;
-@@ -5964,8 +5965,9 @@ static void ata_finalize_port_ops(struct ata_port_operations *ops)
+@@ -5975,8 +5976,9 @@ static void ata_finalize_port_ops(struct ata_port_operations *ops)
if (IS_ERR(*pp))
*pp = NULL;
@@ -36649,7 +36649,7 @@ index d1a05f9..eb70e10 100644
spin_unlock(&lock);
}
-@@ -6161,7 +6163,7 @@ int ata_host_register(struct ata_host *host, struct scsi_host_template *sht)
+@@ -6172,7 +6174,7 @@ int ata_host_register(struct ata_host *host, struct scsi_host_template *sht)
/* give ports names and add SCSI hosts */
for (i = 0; i < host->n_ports; i++) {
@@ -39384,10 +39384,10 @@ index fde97d6..3631eca 100644
ret = cpufreq_register_driver(&dt_cpufreq_driver);
if (ret)
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c
-index 7030c40..3a97de6 100644
+index 24736bb..aae33f4 100644
--- a/drivers/cpufreq/cpufreq.c
+++ b/drivers/cpufreq/cpufreq.c
-@@ -2135,7 +2135,7 @@ void cpufreq_unregister_governor(struct cpufreq_governor *governor)
+@@ -2138,7 +2138,7 @@ void cpufreq_unregister_governor(struct cpufreq_governor *governor)
}
mutex_lock(&cpufreq_governor_mutex);
@@ -39396,7 +39396,7 @@ index 7030c40..3a97de6 100644
mutex_unlock(&cpufreq_governor_mutex);
return;
}
-@@ -2351,7 +2351,7 @@ static int cpufreq_cpu_callback(struct notifier_block *nfb,
+@@ -2354,7 +2354,7 @@ static int cpufreq_cpu_callback(struct notifier_block *nfb,
return NOTIFY_OK;
}
@@ -39405,7 +39405,7 @@ index 7030c40..3a97de6 100644
.notifier_call = cpufreq_cpu_callback,
};
-@@ -2391,13 +2391,17 @@ int cpufreq_boost_trigger_state(int state)
+@@ -2394,13 +2394,17 @@ int cpufreq_boost_trigger_state(int state)
return 0;
write_lock_irqsave(&cpufreq_driver_lock, flags);
@@ -39425,7 +39425,7 @@ index 7030c40..3a97de6 100644
write_unlock_irqrestore(&cpufreq_driver_lock, flags);
pr_err("%s: Cannot %s BOOST\n",
-@@ -2454,8 +2458,11 @@ int cpufreq_register_driver(struct cpufreq_driver *driver_data)
+@@ -2457,8 +2461,11 @@ int cpufreq_register_driver(struct cpufreq_driver *driver_data)
pr_debug("trying to register driver %s\n", driver_data->name);
@@ -39439,7 +39439,7 @@ index 7030c40..3a97de6 100644
write_lock_irqsave(&cpufreq_driver_lock, flags);
if (cpufreq_driver) {
-@@ -2470,8 +2477,11 @@ int cpufreq_register_driver(struct cpufreq_driver *driver_data)
+@@ -2473,8 +2480,11 @@ int cpufreq_register_driver(struct cpufreq_driver *driver_data)
* Check if driver provides function to enable boost -
* if not, use cpufreq_boost_set_sw as default
*/
@@ -39806,7 +39806,7 @@ index fb9f511..213e6cc 100644
cpuidle_curr_governor->rating < gov->rating)
cpuidle_switch_governor(gov);
diff --git a/drivers/cpuidle/sysfs.c b/drivers/cpuidle/sysfs.c
-index 97c5903..023ad23 100644
+index 832a2c3..1794080 100644
--- a/drivers/cpuidle/sysfs.c
+++ b/drivers/cpuidle/sysfs.c
@@ -135,7 +135,7 @@ static struct attribute *cpuidle_switch_attrs[] = {
@@ -40175,10 +40175,10 @@ index 94a58a0..f5eba42 100644
container_of(_dev_attr, struct dmi_device_attribute, dev_attr)
diff --git a/drivers/firmware/dmi_scan.c b/drivers/firmware/dmi_scan.c
-index 69fac06..820f0c9a 100644
+index 2eebd28b..4261350 100644
--- a/drivers/firmware/dmi_scan.c
+++ b/drivers/firmware/dmi_scan.c
-@@ -901,7 +901,7 @@ int dmi_walk(void (*decode)(const struct dmi_header *, void *),
+@@ -893,7 +893,7 @@ int dmi_walk(void (*decode)(const struct dmi_header *, void *),
if (buf == NULL)
return -1;
@@ -40360,10 +40360,10 @@ index 568aa2b..d1204d8 100644
/*
* Prepare the mapping since the irqchip shall be orthogonal to
diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c
-index 29168fa..c9baec6 100644
+index 27a37e5..b6c6c71 100644
--- a/drivers/gpu/drm/drm_crtc.c
+++ b/drivers/gpu/drm/drm_crtc.c
-@@ -3964,7 +3964,7 @@ int drm_mode_getproperty_ioctl(struct drm_device *dev,
+@@ -3953,7 +3953,7 @@ int drm_mode_getproperty_ioctl(struct drm_device *dev,
goto done;
}
@@ -40678,10 +40678,10 @@ index 176de63..1ef9ac7 100644
return ret;
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
-index c10b52e..e5e27ff 100644
+index 791b00e..4d10235 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
-@@ -12935,13 +12935,13 @@ struct intel_quirk {
+@@ -12939,13 +12939,13 @@ struct intel_quirk {
int subsystem_vendor;
int subsystem_device;
void (*hook)(struct drm_device *dev);
@@ -40697,7 +40697,7 @@ index c10b52e..e5e27ff 100644
static int intel_dmi_reverse_brightness(const struct dmi_system_id *id)
{
-@@ -12949,18 +12949,20 @@ static int intel_dmi_reverse_brightness(const struct dmi_system_id *id)
+@@ -12953,18 +12953,20 @@ static int intel_dmi_reverse_brightness(const struct dmi_system_id *id)
return 1;
}
@@ -41404,10 +41404,10 @@ index 15aee72..cda326e 100644
DRM_DEBUG("pid=%d\n", DRM_CURRENTPID);
diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
-index d02aa1d..ca19e2c 100644
+index b292aca..4e338b5 100644
--- a/drivers/gpu/drm/radeon/radeon_ttm.c
+++ b/drivers/gpu/drm/radeon/radeon_ttm.c
-@@ -959,7 +959,7 @@ void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size)
+@@ -963,7 +963,7 @@ void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size)
man->size = size >> PAGE_SHIFT;
}
@@ -41416,7 +41416,7 @@ index d02aa1d..ca19e2c 100644
static const struct vm_operations_struct *ttm_vm_ops = NULL;
static int radeon_ttm_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
-@@ -1000,8 +1000,10 @@ int radeon_mmap(struct file *filp, struct vm_area_struct *vma)
+@@ -1004,8 +1004,10 @@ int radeon_mmap(struct file *filp, struct vm_area_struct *vma)
}
if (unlikely(ttm_vm_ops == NULL)) {
ttm_vm_ops = vma->vm_ops;
@@ -42445,7 +42445,7 @@ index 0b510ba..4fbb5085 100644
}
}
diff --git a/drivers/iio/industrialio-core.c b/drivers/iio/industrialio-core.c
-index af3e76d..96dfe5e 100644
+index f009d05..d95b613 100644
--- a/drivers/iio/industrialio-core.c
+++ b/drivers/iio/industrialio-core.c
@@ -555,7 +555,7 @@ static ssize_t iio_write_channel_info(struct device *dev,
@@ -42671,25 +42671,6 @@ index 9f5ad7c..588cd84 100644
wake_up_process(pool->thread);
}
}
-diff --git a/drivers/infiniband/core/umem.c b/drivers/infiniband/core/umem.c
-index aec7a6a..8c014b5 100644
---- a/drivers/infiniband/core/umem.c
-+++ b/drivers/infiniband/core/umem.c
-@@ -99,6 +99,14 @@ struct ib_umem *ib_umem_get(struct ib_ucontext *context, unsigned long addr,
- if (dmasync)
- dma_set_attr(DMA_ATTR_WRITE_BARRIER, &attrs);
-
-+ /*
-+ * If the combination of the addr and size requested for this memory
-+ * region causes an integer overflow, return error.
-+ */
-+ if ((PAGE_ALIGN(addr + size) <= size) ||
-+ (PAGE_ALIGN(addr + size) <= addr))
-+ return ERR_PTR(-EINVAL);
-+
- if (!can_do_mlock())
- return ERR_PTR(-EPERM);
-
diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c
index 6c52e72..6303e3f 100644
--- a/drivers/infiniband/core/uverbs_cmd.c
@@ -42781,10 +42762,10 @@ index 1f95bba..9530f87 100644
sdata, wqe->wr.wr.atomic.swap);
goto send_comp;
diff --git a/drivers/infiniband/hw/mlx4/mad.c b/drivers/infiniband/hw/mlx4/mad.c
-index 82a7dd8..8fb6ba6 100644
+index 729382c..2f82b8d 100644
--- a/drivers/infiniband/hw/mlx4/mad.c
+++ b/drivers/infiniband/hw/mlx4/mad.c
-@@ -98,7 +98,7 @@ __be64 mlx4_ib_gen_node_guid(void)
+@@ -106,7 +106,7 @@ __be64 mlx4_ib_gen_node_guid(void)
__be64 mlx4_ib_get_new_demux_tid(struct mlx4_ib_demux_ctx *ctx)
{
@@ -51741,10 +51722,10 @@ index 6d25879..3031a9f 100644
ddb_entry->default_relogin_timeout =
(def_timeout > LOGIN_TOV) && (def_timeout < LOGIN_TOV * 10) ?
diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c
-index 17bb541..85f4508 100644
+index 7129701..b49c4e5 100644
--- a/drivers/scsi/scsi_lib.c
+++ b/drivers/scsi/scsi_lib.c
-@@ -1595,7 +1595,7 @@ static void scsi_kill_request(struct request *req, struct request_queue *q)
+@@ -1597,7 +1597,7 @@ static void scsi_kill_request(struct request *req, struct request_queue *q)
shost = sdev->host;
scsi_init_cmd_errh(cmd);
cmd->result = DID_NO_CONNECT << 16;
@@ -51753,7 +51734,7 @@ index 17bb541..85f4508 100644
/*
* SCSI request completion path will do scsi_device_unbusy(),
-@@ -1618,9 +1618,9 @@ static void scsi_softirq_done(struct request *rq)
+@@ -1620,9 +1620,9 @@ static void scsi_softirq_done(struct request *rq)
INIT_LIST_HEAD(&cmd->eh_entry);
@@ -51765,7 +51746,7 @@ index 17bb541..85f4508 100644
disposition = scsi_decide_disposition(cmd);
if (disposition != SUCCESS &&
-@@ -1661,7 +1661,7 @@ static int scsi_dispatch_cmd(struct scsi_cmnd *cmd)
+@@ -1663,7 +1663,7 @@ static int scsi_dispatch_cmd(struct scsi_cmnd *cmd)
struct Scsi_Host *host = cmd->device->host;
int rtn = 0;
@@ -52426,19 +52407,6 @@ index 46dad63..fe4acdc 100644
/** Register functions (in the bus driver) to get called by visorchipset
* whenever a bus or device appears for which this service partition is
-diff --git a/drivers/target/iscsi/iscsi_target.c b/drivers/target/iscsi/iscsi_target.c
-index 8d27db47..22d67c0 100644
---- a/drivers/target/iscsi/iscsi_target.c
-+++ b/drivers/target/iscsi/iscsi_target.c
-@@ -1185,7 +1185,7 @@ iscsit_handle_scsi_cmd(struct iscsi_conn *conn, struct iscsi_cmd *cmd,
- * traditional iSCSI block I/O.
- */
- if (iscsit_allocate_iovecs(cmd) < 0) {
-- return iscsit_add_reject_cmd(cmd,
-+ return iscsit_reject_cmd(cmd,
- ISCSI_REASON_BOOKMARK_NO_RESOURCES, buf);
- }
- immed_data = cmd->immediate_data;
diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
index 9512af6..045bf5a 100644
--- a/drivers/target/sbp/sbp_target.c
@@ -52999,7 +52967,7 @@ index c434376..114ce13 100644
dlci->modem_rx = 0;
diff --git a/drivers/tty/n_tty.c b/drivers/tty/n_tty.c
-index 4ddfa60..1b7e112 100644
+index 6f8cf3a..c690dfb 100644
--- a/drivers/tty/n_tty.c
+++ b/drivers/tty/n_tty.c
@@ -115,7 +115,7 @@ struct n_tty_data {
@@ -53011,7 +52979,7 @@ index 4ddfa60..1b7e112 100644
size_t line_start;
/* protected by output lock */
-@@ -2503,6 +2503,7 @@ void n_tty_inherit_ops(struct tty_ldisc_ops *ops)
+@@ -2555,6 +2555,7 @@ void n_tty_inherit_ops(struct tty_ldisc_ops *ops)
{
*ops = tty_ldisc_N_TTY;
ops->owner = NULL;
@@ -58212,7 +58180,7 @@ index 8a1d38e..300a14e 100644
&data);
if (!inode) {
diff --git a/fs/aio.c b/fs/aio.c
-index c428871..3f3041b 100644
+index ebd0e9b..c577c91 100644
--- a/fs/aio.c
+++ b/fs/aio.c
@@ -413,7 +413,7 @@ static int aio_setup_ring(struct kioctx *ctx)
@@ -59830,10 +59798,10 @@ index 22b289a..bbbba08 100644
GLOBAL_EXTERN atomic_t smBufAllocCount;
GLOBAL_EXTERN atomic_t midCount;
diff --git a/fs/cifs/file.c b/fs/cifs/file.c
-index 74f1287..7ef0237 100644
+index 3e30d92..2c9f066 100644
--- a/fs/cifs/file.c
+++ b/fs/cifs/file.c
-@@ -2060,10 +2060,14 @@ static int cifs_writepages(struct address_space *mapping,
+@@ -2061,10 +2061,14 @@ static int cifs_writepages(struct address_space *mapping,
index = mapping->writeback_index; /* Start from prev offset */
end = -1;
} else {
@@ -59983,7 +59951,7 @@ index d297903..1cb7516 100644
}
diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c
-index 96b5d40..e5db0c1 100644
+index eab05e1..ffe5ea4 100644
--- a/fs/cifs/smb2ops.c
+++ b/fs/cifs/smb2ops.c
@@ -418,8 +418,8 @@ smb2_clear_stats(struct cifs_tcon *tcon)
@@ -80730,7 +80698,7 @@ index 4d078ce..c970f4d 100644
/* flags */
#define CPUFREQ_STICKY (1 << 0) /* driver isn't removed even if
diff --git a/include/linux/cpuidle.h b/include/linux/cpuidle.h
-index ab70f3b..3ef7771 100644
+index 948df62..4602717 100644
--- a/include/linux/cpuidle.h
+++ b/include/linux/cpuidle.h
@@ -50,7 +50,8 @@ struct cpuidle_state {
@@ -80743,7 +80711,7 @@ index ab70f3b..3ef7771 100644
/* Idle State Flags */
#define CPUIDLE_FLAG_COUPLED (0x02) /* state applies to multiple cpus */
-@@ -206,7 +207,7 @@ struct cpuidle_governor {
+@@ -205,7 +206,7 @@ struct cpuidle_governor {
void (*reflect) (struct cpuidle_device *dev, int index);
struct module *owner;
@@ -92720,7 +92688,7 @@ index 607f852..486bc87 100644
unsigned long timeout)
{
diff --git a/kernel/sched/core.c b/kernel/sched/core.c
-index 44dfc8b..56d160d 100644
+index d400c82..50fca96 100644
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -1902,7 +1902,7 @@ void set_numabalancing_state(bool enabled)
@@ -92744,7 +92712,7 @@ index 44dfc8b..56d160d 100644
if (!prev->mm) {
prev->active_mm = NULL;
-@@ -3152,6 +3154,8 @@ int can_nice(const struct task_struct *p, const int nice)
+@@ -3154,6 +3156,8 @@ int can_nice(const struct task_struct *p, const int nice)
/* convert nice value [19,-20] to rlimit style value [1,40] */
int nice_rlim = nice_to_rlimit(nice);
@@ -92753,7 +92721,7 @@ index 44dfc8b..56d160d 100644
return (nice_rlim <= task_rlimit(p, RLIMIT_NICE) ||
capable(CAP_SYS_NICE));
}
-@@ -3178,7 +3182,8 @@ SYSCALL_DEFINE1(nice, int, increment)
+@@ -3180,7 +3184,8 @@ SYSCALL_DEFINE1(nice, int, increment)
nice = task_nice(current) + increment;
nice = clamp_val(nice, MIN_NICE, MAX_NICE);
@@ -92763,7 +92731,7 @@ index 44dfc8b..56d160d 100644
return -EPERM;
retval = security_task_setnice(current, nice);
-@@ -3473,6 +3478,7 @@ recheck:
+@@ -3475,6 +3480,7 @@ recheck:
if (policy != p->policy && !rlim_rtprio)
return -EPERM;
@@ -92771,7 +92739,7 @@ index 44dfc8b..56d160d 100644
/* can't increase priority */
if (attr->sched_priority > p->rt_priority &&
attr->sched_priority > rlim_rtprio)
-@@ -4973,6 +4979,7 @@ void idle_task_exit(void)
+@@ -4975,6 +4981,7 @@ void idle_task_exit(void)
if (mm != &init_mm) {
switch_mm(mm, &init_mm, current);
@@ -92779,7 +92747,7 @@ index 44dfc8b..56d160d 100644
finish_arch_post_lock_switch();
}
mmdrop(mm);
-@@ -5068,7 +5075,7 @@ static void migrate_tasks(unsigned int dead_cpu)
+@@ -5070,7 +5077,7 @@ static void migrate_tasks(unsigned int dead_cpu)
#if defined(CONFIG_SCHED_DEBUG) && defined(CONFIG_SYSCTL)
@@ -92788,7 +92756,7 @@ index 44dfc8b..56d160d 100644
{
.procname = "sched_domain",
.mode = 0555,
-@@ -5085,17 +5092,17 @@ static struct ctl_table sd_ctl_root[] = {
+@@ -5087,17 +5094,17 @@ static struct ctl_table sd_ctl_root[] = {
{}
};
@@ -92810,7 +92778,7 @@ index 44dfc8b..56d160d 100644
/*
* In the intermediate directories, both the child directory and
-@@ -5103,22 +5110,25 @@ static void sd_free_ctl_entry(struct ctl_table **tablep)
+@@ -5105,22 +5112,25 @@ static void sd_free_ctl_entry(struct ctl_table **tablep)
* will always be set. In the lowest directory the names are
* static strings and all have proc handlers.
*/
@@ -92842,7 +92810,7 @@ index 44dfc8b..56d160d 100644
const char *procname, void *data, int maxlen,
umode_t mode, proc_handler *proc_handler,
bool load_idx)
-@@ -5138,7 +5148,7 @@ set_table_entry(struct ctl_table *entry,
+@@ -5140,7 +5150,7 @@ set_table_entry(struct ctl_table *entry,
static struct ctl_table *
sd_alloc_ctl_domain_table(struct sched_domain *sd)
{
@@ -92851,7 +92819,7 @@ index 44dfc8b..56d160d 100644
if (table == NULL)
return NULL;
-@@ -5176,9 +5186,9 @@ sd_alloc_ctl_domain_table(struct sched_domain *sd)
+@@ -5178,9 +5188,9 @@ sd_alloc_ctl_domain_table(struct sched_domain *sd)
return table;
}
@@ -92863,7 +92831,7 @@ index 44dfc8b..56d160d 100644
struct sched_domain *sd;
int domain_num = 0, i;
char buf[32];
-@@ -5205,11 +5215,13 @@ static struct ctl_table_header *sd_sysctl_header;
+@@ -5207,11 +5217,13 @@ static struct ctl_table_header *sd_sysctl_header;
static void register_sched_domain_sysctl(void)
{
int i, cpu_num = num_possible_cpus();
@@ -92878,7 +92846,7 @@ index 44dfc8b..56d160d 100644
if (entry == NULL)
return;
-@@ -5232,8 +5244,12 @@ static void unregister_sched_domain_sysctl(void)
+@@ -5234,8 +5246,12 @@ static void unregister_sched_domain_sysctl(void)
if (sd_sysctl_header)
unregister_sysctl_table(sd_sysctl_header);
sd_sysctl_header = NULL;
@@ -96982,7 +96950,7 @@ index 73cf098..ab547c7 100644
capable(CAP_IPC_LOCK))
ret = do_mlockall(flags);
diff --git a/mm/mmap.c b/mm/mmap.c
-index e5cc3ca..2bfa432 100644
+index 0bc66f1..2bfa432 100644
--- a/mm/mmap.c
+++ b/mm/mmap.c
@@ -41,6 +41,7 @@
@@ -97078,19 +97046,7 @@ index e5cc3ca..2bfa432 100644
mm->end_data, mm->start_data))
goto out;
-@@ -780,10 +809,8 @@ again: remove_next = 1 + (end > next->vm_end);
-
- importer->anon_vma = exporter->anon_vma;
- error = anon_vma_clone(importer, exporter);
-- if (error) {
-- importer->anon_vma = NULL;
-+ if (error)
- return error;
-- }
- }
- }
-
-@@ -978,6 +1005,12 @@ static int
+@@ -976,6 +1005,12 @@ static int
can_vma_merge_before(struct vm_area_struct *vma, unsigned long vm_flags,
struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff)
{
@@ -97103,7 +97059,7 @@ index e5cc3ca..2bfa432 100644
if (is_mergeable_vma(vma, file, vm_flags) &&
is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
if (vma->vm_pgoff == vm_pgoff)
-@@ -997,6 +1030,12 @@ static int
+@@ -995,6 +1030,12 @@ static int
can_vma_merge_after(struct vm_area_struct *vma, unsigned long vm_flags,
struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff)
{
@@ -97116,7 +97072,7 @@ index e5cc3ca..2bfa432 100644
if (is_mergeable_vma(vma, file, vm_flags) &&
is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
pgoff_t vm_pglen;
-@@ -1046,6 +1085,13 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
+@@ -1044,6 +1085,13 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
struct vm_area_struct *area, *next;
int err;
@@ -97130,7 +97086,7 @@ index e5cc3ca..2bfa432 100644
/*
* We later require that vma->vm_flags == vm_flags,
* so this tests vma->vm_flags & VM_SPECIAL, too.
-@@ -1061,6 +1107,15 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
+@@ -1059,6 +1107,15 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
if (next && next->vm_end == end) /* cases 6, 7, 8 */
next = next->vm_next;
@@ -97146,7 +97102,7 @@ index e5cc3ca..2bfa432 100644
/*
* Can it merge with the predecessor?
*/
-@@ -1080,9 +1135,24 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
+@@ -1078,9 +1135,24 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
/* cases 1, 6 */
err = vma_adjust(prev, prev->vm_start,
next->vm_end, prev->vm_pgoff, NULL);
@@ -97172,7 +97128,7 @@ index e5cc3ca..2bfa432 100644
if (err)
return NULL;
khugepaged_enter_vma_merge(prev, vm_flags);
-@@ -1096,12 +1166,27 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
+@@ -1094,12 +1166,27 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
mpol_equal(policy, vma_policy(next)) &&
can_vma_merge_before(next, vm_flags,
anon_vma, file, pgoff+pglen)) {
@@ -97202,7 +97158,7 @@ index e5cc3ca..2bfa432 100644
if (err)
return NULL;
khugepaged_enter_vma_merge(area, vm_flags);
-@@ -1210,8 +1295,10 @@ none:
+@@ -1208,8 +1295,10 @@ none:
void vm_stat_account(struct mm_struct *mm, unsigned long flags,
struct file *file, long pages)
{
@@ -97215,7 +97171,7 @@ index e5cc3ca..2bfa432 100644
mm->total_vm += pages;
-@@ -1219,7 +1306,7 @@ void vm_stat_account(struct mm_struct *mm, unsigned long flags,
+@@ -1217,7 +1306,7 @@ void vm_stat_account(struct mm_struct *mm, unsigned long flags,
mm->shared_vm += pages;
if ((flags & (VM_EXEC|VM_WRITE)) == VM_EXEC)
mm->exec_vm += pages;
@@ -97224,7 +97180,7 @@ index e5cc3ca..2bfa432 100644
mm->stack_vm += pages;
}
#endif /* CONFIG_PROC_FS */
-@@ -1249,6 +1336,7 @@ static inline int mlock_future_check(struct mm_struct *mm,
+@@ -1247,6 +1336,7 @@ static inline int mlock_future_check(struct mm_struct *mm,
locked += mm->locked_vm;
lock_limit = rlimit(RLIMIT_MEMLOCK);
lock_limit >>= PAGE_SHIFT;
@@ -97232,7 +97188,7 @@ index e5cc3ca..2bfa432 100644
if (locked > lock_limit && !capable(CAP_IPC_LOCK))
return -EAGAIN;
}
-@@ -1275,7 +1363,7 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
+@@ -1273,7 +1363,7 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
* (the exception is when the underlying filesystem is noexec
* mounted, in which case we dont add PROT_EXEC.)
*/
@@ -97241,7 +97197,7 @@ index e5cc3ca..2bfa432 100644
if (!(file && (file->f_path.mnt->mnt_flags & MNT_NOEXEC)))
prot |= PROT_EXEC;
-@@ -1301,7 +1389,7 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
+@@ -1299,7 +1389,7 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
/* Obtain the address to map to. we verify (or select) it and ensure
* that it represents a valid section of the address space.
*/
@@ -97250,7 +97206,7 @@ index e5cc3ca..2bfa432 100644
if (addr & ~PAGE_MASK)
return addr;
-@@ -1312,6 +1400,43 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
+@@ -1310,6 +1400,43 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
vm_flags = calc_vm_prot_bits(prot) | calc_vm_flag_bits(flags) |
mm->def_flags | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC;
@@ -97294,7 +97250,7 @@ index e5cc3ca..2bfa432 100644
if (flags & MAP_LOCKED)
if (!can_do_mlock())
return -EPERM;
-@@ -1399,6 +1524,9 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
+@@ -1397,6 +1524,9 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr,
vm_flags |= VM_NORESERVE;
}
@@ -97304,7 +97260,7 @@ index e5cc3ca..2bfa432 100644
addr = mmap_region(file, addr, len, vm_flags, pgoff);
if (!IS_ERR_VALUE(addr) &&
((vm_flags & VM_LOCKED) ||
-@@ -1492,7 +1620,7 @@ int vma_wants_writenotify(struct vm_area_struct *vma)
+@@ -1490,7 +1620,7 @@ int vma_wants_writenotify(struct vm_area_struct *vma)
vm_flags_t vm_flags = vma->vm_flags;
/* If it was private or non-writable, the write bit is already clear */
@@ -97313,7 +97269,7 @@ index e5cc3ca..2bfa432 100644
return 0;
/* The backer wishes to know when pages are first written to? */
-@@ -1543,7 +1671,22 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
+@@ -1541,7 +1671,22 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
struct rb_node **rb_link, *rb_parent;
unsigned long charged = 0;
@@ -97336,7 +97292,7 @@ index e5cc3ca..2bfa432 100644
if (!may_expand_vm(mm, len >> PAGE_SHIFT)) {
unsigned long nr_pages;
-@@ -1562,11 +1705,10 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
+@@ -1560,11 +1705,10 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
/* Clear old maps */
error = -ENOMEM;
@@ -97349,7 +97305,7 @@ index e5cc3ca..2bfa432 100644
}
/*
-@@ -1597,6 +1739,16 @@ munmap_back:
+@@ -1595,6 +1739,16 @@ munmap_back:
goto unacct_error;
}
@@ -97366,7 +97322,7 @@ index e5cc3ca..2bfa432 100644
vma->vm_mm = mm;
vma->vm_start = addr;
vma->vm_end = addr + len;
-@@ -1627,6 +1779,13 @@ munmap_back:
+@@ -1625,6 +1779,13 @@ munmap_back:
if (error)
goto unmap_and_free_vma;
@@ -97380,7 +97336,7 @@ index e5cc3ca..2bfa432 100644
/* Can addr have changed??
*
* Answer: Yes, several device drivers can do it in their
-@@ -1645,6 +1804,12 @@ munmap_back:
+@@ -1643,6 +1804,12 @@ munmap_back:
}
vma_link(mm, vma, prev, rb_link, rb_parent);
@@ -97393,7 +97349,7 @@ index e5cc3ca..2bfa432 100644
/* Once vma denies write, undo our temporary denial count */
if (file) {
if (vm_flags & VM_SHARED)
-@@ -1657,6 +1822,7 @@ out:
+@@ -1655,6 +1822,7 @@ out:
perf_event_mmap(vma);
vm_stat_account(mm, vm_flags, file, len >> PAGE_SHIFT);
@@ -97401,7 +97357,7 @@ index e5cc3ca..2bfa432 100644
if (vm_flags & VM_LOCKED) {
if (!((vm_flags & VM_SPECIAL) || is_vm_hugetlb_page(vma) ||
vma == get_gate_vma(current->mm)))
-@@ -1694,6 +1860,12 @@ allow_write_and_free_vma:
+@@ -1692,6 +1860,12 @@ allow_write_and_free_vma:
if (vm_flags & VM_DENYWRITE)
allow_write_access(file);
free_vma:
@@ -97414,7 +97370,7 @@ index e5cc3ca..2bfa432 100644
kmem_cache_free(vm_area_cachep, vma);
unacct_error:
if (charged)
-@@ -1701,7 +1873,63 @@ unacct_error:
+@@ -1699,7 +1873,63 @@ unacct_error:
return error;
}
@@ -97479,7 +97435,7 @@ index e5cc3ca..2bfa432 100644
{
/*
* We implement the search by looking for an rbtree node that
-@@ -1749,11 +1977,29 @@ unsigned long unmapped_area(struct vm_unmapped_area_info *info)
+@@ -1747,11 +1977,29 @@ unsigned long unmapped_area(struct vm_unmapped_area_info *info)
}
}
@@ -97510,7 +97466,7 @@ index e5cc3ca..2bfa432 100644
if (gap_end >= low_limit && gap_end - gap_start >= length)
goto found;
-@@ -1803,7 +2049,7 @@ found:
+@@ -1801,7 +2049,7 @@ found:
return gap_start;
}
@@ -97519,7 +97475,7 @@ index e5cc3ca..2bfa432 100644
{
struct mm_struct *mm = current->mm;
struct vm_area_struct *vma;
-@@ -1857,6 +2103,24 @@ check_current:
+@@ -1855,6 +2103,24 @@ check_current:
gap_end = vma->vm_start;
if (gap_end < low_limit)
return -ENOMEM;
@@ -97544,7 +97500,7 @@ index e5cc3ca..2bfa432 100644
if (gap_start <= high_limit && gap_end - gap_start >= length)
goto found;
-@@ -1920,6 +2184,7 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
+@@ -1918,6 +2184,7 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
struct mm_struct *mm = current->mm;
struct vm_area_struct *vma;
struct vm_unmapped_area_info info;
@@ -97552,7 +97508,7 @@ index e5cc3ca..2bfa432 100644
if (len > TASK_SIZE - mmap_min_addr)
return -ENOMEM;
-@@ -1927,11 +2192,15 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
+@@ -1925,11 +2192,15 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
if (flags & MAP_FIXED)
return addr;
@@ -97569,7 +97525,7 @@ index e5cc3ca..2bfa432 100644
return addr;
}
-@@ -1940,6 +2209,7 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
+@@ -1938,6 +2209,7 @@ arch_get_unmapped_area(struct file *filp, unsigned long addr,
info.low_limit = mm->mmap_base;
info.high_limit = TASK_SIZE;
info.align_mask = 0;
@@ -97577,7 +97533,7 @@ index e5cc3ca..2bfa432 100644
return vm_unmapped_area(&info);
}
#endif
-@@ -1958,6 +2228,7 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
+@@ -1956,6 +2228,7 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
struct mm_struct *mm = current->mm;
unsigned long addr = addr0;
struct vm_unmapped_area_info info;
@@ -97585,7 +97541,7 @@ index e5cc3ca..2bfa432 100644
/* requested length too big for entire address space */
if (len > TASK_SIZE - mmap_min_addr)
-@@ -1966,12 +2237,16 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
+@@ -1964,12 +2237,16 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
if (flags & MAP_FIXED)
return addr;
@@ -97603,7 +97559,7 @@ index e5cc3ca..2bfa432 100644
return addr;
}
-@@ -1980,6 +2255,7 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
+@@ -1978,6 +2255,7 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
info.low_limit = max(PAGE_SIZE, mmap_min_addr);
info.high_limit = mm->mmap_base;
info.align_mask = 0;
@@ -97611,7 +97567,7 @@ index e5cc3ca..2bfa432 100644
addr = vm_unmapped_area(&info);
/*
-@@ -1992,6 +2268,12 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
+@@ -1990,6 +2268,12 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
VM_BUG_ON(addr != -ENOMEM);
info.flags = 0;
info.low_limit = TASK_UNMAPPED_BASE;
@@ -97624,7 +97580,7 @@ index e5cc3ca..2bfa432 100644
info.high_limit = TASK_SIZE;
addr = vm_unmapped_area(&info);
}
-@@ -2092,6 +2374,28 @@ find_vma_prev(struct mm_struct *mm, unsigned long addr,
+@@ -2090,6 +2374,28 @@ find_vma_prev(struct mm_struct *mm, unsigned long addr,
return vma;
}
@@ -97653,7 +97609,7 @@ index e5cc3ca..2bfa432 100644
/*
* Verify that the stack growth is acceptable and
* update accounting. This is shared with both the
-@@ -2109,8 +2413,7 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
+@@ -2107,8 +2413,7 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
/* Stack limit test */
actual_size = size;
@@ -97663,7 +97619,7 @@ index e5cc3ca..2bfa432 100644
if (actual_size > ACCESS_ONCE(rlim[RLIMIT_STACK].rlim_cur))
return -ENOMEM;
-@@ -2121,6 +2424,7 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
+@@ -2119,6 +2424,7 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
locked = mm->locked_vm + grow;
limit = ACCESS_ONCE(rlim[RLIMIT_MEMLOCK].rlim_cur);
limit >>= PAGE_SHIFT;
@@ -97671,7 +97627,7 @@ index e5cc3ca..2bfa432 100644
if (locked > limit && !capable(CAP_IPC_LOCK))
return -ENOMEM;
}
-@@ -2150,37 +2454,48 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
+@@ -2148,37 +2454,48 @@ static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, uns
* PA-RISC uses this for its stack; IA64 for its Register Backing Store.
* vma is the last one with address > vma->vm_end. Have to extend vma.
*/
@@ -97729,7 +97685,7 @@ index e5cc3ca..2bfa432 100644
unsigned long size, grow;
size = address - vma->vm_start;
-@@ -2215,6 +2530,8 @@ int expand_upwards(struct vm_area_struct *vma, unsigned long address)
+@@ -2213,6 +2530,8 @@ int expand_upwards(struct vm_area_struct *vma, unsigned long address)
}
}
}
@@ -97738,7 +97694,7 @@ index e5cc3ca..2bfa432 100644
vma_unlock_anon_vma(vma);
khugepaged_enter_vma_merge(vma, vma->vm_flags);
validate_mm(vma->vm_mm);
-@@ -2229,6 +2546,8 @@ int expand_downwards(struct vm_area_struct *vma,
+@@ -2227,6 +2546,8 @@ int expand_downwards(struct vm_area_struct *vma,
unsigned long address)
{
int error;
@@ -97747,7 +97703,7 @@ index e5cc3ca..2bfa432 100644
/*
* We must make sure the anon_vma is allocated
-@@ -2242,6 +2561,15 @@ int expand_downwards(struct vm_area_struct *vma,
+@@ -2240,6 +2561,15 @@ int expand_downwards(struct vm_area_struct *vma,
if (error)
return error;
@@ -97763,7 +97719,7 @@ index e5cc3ca..2bfa432 100644
vma_lock_anon_vma(vma);
/*
-@@ -2251,9 +2579,17 @@ int expand_downwards(struct vm_area_struct *vma,
+@@ -2249,9 +2579,17 @@ int expand_downwards(struct vm_area_struct *vma,
*/
/* Somebody else might have raced and expanded it already */
@@ -97782,7 +97738,7 @@ index e5cc3ca..2bfa432 100644
size = vma->vm_end - address;
grow = (vma->vm_start - address) >> PAGE_SHIFT;
-@@ -2278,13 +2614,27 @@ int expand_downwards(struct vm_area_struct *vma,
+@@ -2276,13 +2614,27 @@ int expand_downwards(struct vm_area_struct *vma,
vma->vm_pgoff -= grow;
anon_vma_interval_tree_post_update_vma(vma);
vma_gap_update(vma);
@@ -97810,7 +97766,7 @@ index e5cc3ca..2bfa432 100644
khugepaged_enter_vma_merge(vma, vma->vm_flags);
validate_mm(vma->vm_mm);
return error;
-@@ -2384,6 +2734,13 @@ static void remove_vma_list(struct mm_struct *mm, struct vm_area_struct *vma)
+@@ -2382,6 +2734,13 @@ static void remove_vma_list(struct mm_struct *mm, struct vm_area_struct *vma)
do {
long nrpages = vma_pages(vma);
@@ -97824,7 +97780,7 @@ index e5cc3ca..2bfa432 100644
if (vma->vm_flags & VM_ACCOUNT)
nr_accounted += nrpages;
vm_stat_account(mm, vma->vm_flags, vma->vm_file, -nrpages);
-@@ -2428,6 +2785,16 @@ detach_vmas_to_be_unmapped(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2426,6 +2785,16 @@ detach_vmas_to_be_unmapped(struct mm_struct *mm, struct vm_area_struct *vma,
insertion_point = (prev ? &prev->vm_next : &mm->mmap);
vma->vm_prev = NULL;
do {
@@ -97841,7 +97797,7 @@ index e5cc3ca..2bfa432 100644
vma_rb_erase(vma, &mm->mm_rb);
mm->map_count--;
tail_vma = vma;
-@@ -2455,14 +2822,33 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2453,14 +2822,33 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
struct vm_area_struct *new;
int err = -ENOMEM;
@@ -97875,7 +97831,7 @@ index e5cc3ca..2bfa432 100644
/* most fields are the same, copy all, and then fixup */
*new = *vma;
-@@ -2475,6 +2861,22 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2473,6 +2861,22 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
new->vm_pgoff += ((addr - vma->vm_start) >> PAGE_SHIFT);
}
@@ -97898,7 +97854,7 @@ index e5cc3ca..2bfa432 100644
err = vma_dup_policy(vma, new);
if (err)
goto out_free_vma;
-@@ -2495,6 +2897,38 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2493,6 +2897,38 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
else
err = vma_adjust(vma, vma->vm_start, addr, vma->vm_pgoff, new);
@@ -97937,7 +97893,7 @@ index e5cc3ca..2bfa432 100644
/* Success. */
if (!err)
return 0;
-@@ -2504,10 +2938,18 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2502,10 +2938,18 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
new->vm_ops->close(new);
if (new->vm_file)
fput(new->vm_file);
@@ -97957,7 +97913,7 @@ index e5cc3ca..2bfa432 100644
kmem_cache_free(vm_area_cachep, new);
out_err:
return err;
-@@ -2520,6 +2962,15 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2518,6 +2962,15 @@ static int __split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
int split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
unsigned long addr, int new_below)
{
@@ -97973,7 +97929,7 @@ index e5cc3ca..2bfa432 100644
if (mm->map_count >= sysctl_max_map_count)
return -ENOMEM;
-@@ -2531,11 +2982,30 @@ int split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
+@@ -2529,11 +2982,30 @@ int split_vma(struct mm_struct *mm, struct vm_area_struct *vma,
* work. This now handles partial unmappings.
* Jeremy Fitzhardinge <jeremy@goop.org>
*/
@@ -98004,7 +97960,7 @@ index e5cc3ca..2bfa432 100644
if ((start & ~PAGE_MASK) || start > TASK_SIZE || len > TASK_SIZE-start)
return -EINVAL;
-@@ -2613,6 +3083,8 @@ int do_munmap(struct mm_struct *mm, unsigned long start, size_t len)
+@@ -2611,6 +3083,8 @@ int do_munmap(struct mm_struct *mm, unsigned long start, size_t len)
/* Fix up all other VM information */
remove_vma_list(mm, vma);
@@ -98013,7 +97969,7 @@ index e5cc3ca..2bfa432 100644
return 0;
}
-@@ -2621,6 +3093,13 @@ int vm_munmap(unsigned long start, size_t len)
+@@ -2619,6 +3093,13 @@ int vm_munmap(unsigned long start, size_t len)
int ret;
struct mm_struct *mm = current->mm;
@@ -98027,7 +97983,7 @@ index e5cc3ca..2bfa432 100644
down_write(&mm->mmap_sem);
ret = do_munmap(mm, start, len);
up_write(&mm->mmap_sem);
-@@ -2634,16 +3113,6 @@ SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len)
+@@ -2632,16 +3113,6 @@ SYSCALL_DEFINE2(munmap, unsigned long, addr, size_t, len)
return vm_munmap(addr, len);
}
@@ -98044,7 +98000,7 @@ index e5cc3ca..2bfa432 100644
/*
* this is really a simplified "do_mmap". it only handles
* anonymous maps. eventually we may be able to do some
-@@ -2657,6 +3126,7 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
+@@ -2655,6 +3126,7 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
struct rb_node **rb_link, *rb_parent;
pgoff_t pgoff = addr >> PAGE_SHIFT;
int error;
@@ -98052,7 +98008,7 @@ index e5cc3ca..2bfa432 100644
len = PAGE_ALIGN(len);
if (!len)
-@@ -2664,10 +3134,24 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
+@@ -2662,10 +3134,24 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
flags = VM_DATA_DEFAULT_FLAGS | VM_ACCOUNT | mm->def_flags;
@@ -98077,7 +98033,7 @@ index e5cc3ca..2bfa432 100644
error = mlock_future_check(mm, mm->def_flags, len);
if (error)
return error;
-@@ -2681,21 +3165,20 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
+@@ -2679,21 +3165,20 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
/*
* Clear old maps. this also does some error checking for us
*/
@@ -98102,7 +98058,7 @@ index e5cc3ca..2bfa432 100644
return -ENOMEM;
/* Can we just expand an old private anonymous mapping? */
-@@ -2709,7 +3192,7 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
+@@ -2707,7 +3192,7 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
*/
vma = kmem_cache_zalloc(vm_area_cachep, GFP_KERNEL);
if (!vma) {
@@ -98111,7 +98067,7 @@ index e5cc3ca..2bfa432 100644
return -ENOMEM;
}
-@@ -2723,10 +3206,11 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
+@@ -2721,10 +3206,11 @@ static unsigned long do_brk(unsigned long addr, unsigned long len)
vma_link(mm, vma, prev, rb_link, rb_parent);
out:
perf_event_mmap(vma);
@@ -98125,7 +98081,7 @@ index e5cc3ca..2bfa432 100644
return addr;
}
-@@ -2788,6 +3272,7 @@ void exit_mmap(struct mm_struct *mm)
+@@ -2786,6 +3272,7 @@ void exit_mmap(struct mm_struct *mm)
while (vma) {
if (vma->vm_flags & VM_ACCOUNT)
nr_accounted += vma_pages(vma);
@@ -98133,7 +98089,7 @@ index e5cc3ca..2bfa432 100644
vma = remove_vma(vma);
}
vm_unacct_memory(nr_accounted);
-@@ -2805,6 +3290,13 @@ int insert_vm_struct(struct mm_struct *mm, struct vm_area_struct *vma)
+@@ -2803,6 +3290,13 @@ int insert_vm_struct(struct mm_struct *mm, struct vm_area_struct *vma)
struct vm_area_struct *prev;
struct rb_node **rb_link, *rb_parent;
@@ -98147,7 +98103,7 @@ index e5cc3ca..2bfa432 100644
/*
* The vm_pgoff of a purely anonymous vma should be irrelevant
* until its first write fault, when page's anon_vma and index
-@@ -2828,7 +3320,21 @@ int insert_vm_struct(struct mm_struct *mm, struct vm_area_struct *vma)
+@@ -2826,7 +3320,21 @@ int insert_vm_struct(struct mm_struct *mm, struct vm_area_struct *vma)
security_vm_enough_memory_mm(mm, vma_pages(vma)))
return -ENOMEM;
@@ -98169,7 +98125,7 @@ index e5cc3ca..2bfa432 100644
return 0;
}
-@@ -2847,6 +3353,8 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,
+@@ -2845,6 +3353,8 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,
struct rb_node **rb_link, *rb_parent;
bool faulted_in_anon_vma = true;
@@ -98178,7 +98134,7 @@ index e5cc3ca..2bfa432 100644
/*
* If anonymous vma has not yet been faulted, update new pgoff
* to match new location, to increase its chance of merging.
-@@ -2911,6 +3419,39 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,
+@@ -2909,6 +3419,39 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,
return NULL;
}
@@ -98218,7 +98174,7 @@ index e5cc3ca..2bfa432 100644
/*
* Return true if the calling process may expand its vm space by the passed
* number of pages
-@@ -2922,6 +3463,7 @@ int may_expand_vm(struct mm_struct *mm, unsigned long npages)
+@@ -2920,6 +3463,7 @@ int may_expand_vm(struct mm_struct *mm, unsigned long npages)
lim = rlimit(RLIMIT_AS) >> PAGE_SHIFT;
@@ -98226,7 +98182,7 @@ index e5cc3ca..2bfa432 100644
if (cur + npages > lim)
return 0;
return 1;
-@@ -3004,6 +3546,22 @@ static struct vm_area_struct *__install_special_mapping(
+@@ -3002,6 +3546,22 @@ static struct vm_area_struct *__install_special_mapping(
vma->vm_start = addr;
vma->vm_end = addr + len;
@@ -98653,7 +98609,7 @@ index ae5baae..cbb2ed5 100644
struct mm_struct *mm;
diff --git a/mm/page-writeback.c b/mm/page-writeback.c
-index 6f43352..e44bf41 100644
+index f24d4c9..77820e3 100644
--- a/mm/page-writeback.c
+++ b/mm/page-writeback.c
@@ -664,7 +664,7 @@ static long long pos_ratio_polynom(unsigned long setpoint,
@@ -98863,7 +98819,7 @@ index 5077afc..846c9ef 100644
if (!mm || IS_ERR(mm)) {
rc = IS_ERR(mm) ? PTR_ERR(mm) : -ESRCH;
diff --git a/mm/rmap.c b/mm/rmap.c
-index 71cd5bd..0ff9eb3 100644
+index ecb444a..0ff9eb3 100644
--- a/mm/rmap.c
+++ b/mm/rmap.c
@@ -166,6 +166,10 @@ int anon_vma_prepare(struct vm_area_struct *vma)
@@ -98944,21 +98900,7 @@ index 71cd5bd..0ff9eb3 100644
{
struct anon_vma_chain *avc, *pavc;
struct anon_vma *root = NULL;
-@@ -287,6 +322,13 @@ int anon_vma_clone(struct vm_area_struct *dst, struct vm_area_struct *src)
- return 0;
-
- enomem_failure:
-+ /*
-+ * dst->anon_vma is dropped here otherwise its degree can be incorrectly
-+ * decremented in unlink_anon_vmas().
-+ * We can safely do this because callers of anon_vma_clone() don't care
-+ * about dst->anon_vma if anon_vma_clone() failed.
-+ */
-+ dst->anon_vma = NULL;
- unlink_anon_vmas(dst);
- return -ENOMEM;
- }
-@@ -296,7 +338,7 @@ int anon_vma_clone(struct vm_area_struct *dst, struct vm_area_struct *src)
+@@ -303,7 +338,7 @@ int anon_vma_clone(struct vm_area_struct *dst, struct vm_area_struct *src)
* the corresponding VMA in the parent process is attached to.
* Returns 0 on success, non-zero on failure.
*/
@@ -98967,7 +98909,7 @@ index 71cd5bd..0ff9eb3 100644
{
struct anon_vma_chain *avc;
struct anon_vma *anon_vma;
-@@ -416,8 +458,10 @@ static void anon_vma_ctor(void *data)
+@@ -423,8 +458,10 @@ static void anon_vma_ctor(void *data)
void __init anon_vma_init(void)
{
anon_vma_cachep = kmem_cache_create("anon_vma", sizeof(struct anon_vma),
@@ -101487,7 +101429,7 @@ index 1a19b98..df2b4ec 100644
if (!can_dir) {
printk(KERN_INFO "can: failed to create /proc/net/can . "
diff --git a/net/ceph/messenger.c b/net/ceph/messenger.c
-index 33a2f20..371bd09 100644
+index 74d30ec..25df678 100644
--- a/net/ceph/messenger.c
+++ b/net/ceph/messenger.c
@@ -188,7 +188,7 @@ static void con_fault(struct ceph_connection *con);
@@ -106692,10 +106634,10 @@ index 5199bb1..567a54c 100644
goto out_nomem;
cd->u.procfs.channel_ent = NULL;
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
-index 3f5d4d4..554f997 100644
+index 86e6cc5..f79a7f5 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
-@@ -1438,7 +1438,9 @@ call_start(struct rpc_task *task)
+@@ -1436,7 +1436,9 @@ call_start(struct rpc_task *task)
(RPC_IS_ASYNC(task) ? "async" : "sync"));
/* Increment call count */
@@ -109510,19 +109452,6 @@ index 1450f85..a91e0bc 100644
rt_genid_bump_all(net);
}
rtnl_unlock();
-diff --git a/security/selinux/selinuxfs.c b/security/selinux/selinuxfs.c
-index 33db1ad..138949a 100644
---- a/security/selinux/selinuxfs.c
-+++ b/security/selinux/selinuxfs.c
-@@ -152,7 +152,7 @@ static ssize_t sel_write_enforce(struct file *file, const char __user *buf,
- goto out;
-
- /* No partial writes. */
-- length = EINVAL;
-+ length = -EINVAL;
- if (*ppos != 0)
- goto out;
-
diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c
index a717877..0747450 100644
--- a/security/smack/smack_lsm.c
@@ -116579,10 +116508,10 @@ index 0000000..b8e7188
+}
diff --git a/tools/gcc/size_overflow_plugin/size_overflow_hash.data b/tools/gcc/size_overflow_plugin/size_overflow_hash.data
new file mode 100644
-index 0000000..889a054
+index 0000000..e3e2614
--- /dev/null
+++ b/tools/gcc/size_overflow_plugin/size_overflow_hash.data
-@@ -0,0 +1,27714 @@
+@@ -0,0 +1,27716 @@
+intel_fake_agp_alloc_by_type_1 intel_fake_agp_alloc_by_type 1 1 NULL nohasharray
+iwl_set_tx_power_1 iwl_set_tx_power 0 1 &intel_fake_agp_alloc_by_type_1
+ocfs2_get_refcount_tree_3 ocfs2_get_refcount_tree 0 3 NULL
@@ -134093,7 +134022,8 @@ index 0000000..889a054
+show_dts_mode_41247 show_dts_mode 0 41247 NULL
+ext3_journalled_write_end_41248 ext3_journalled_write_end 0-5 41248 NULL
+send_41249 send 0 41249 NULL
-+degraded_show_41251 degraded_show 0 41251 NULL
++degraded_show_41251 degraded_show 0 41251 NULL nohasharray
++xfs_zero_last_block_41251 xfs_zero_last_block 3-2-0 41251 &degraded_show_41251
+wakeup_abort_count_show_41252 wakeup_abort_count_show 0 41252 NULL
+hiddev_compat_ioctl_41255 hiddev_compat_ioctl 2 41255 NULL
+carmine_check_var_41256 carmine_check_var 0 41256 NULL
@@ -141614,6 +141544,7 @@ index 0000000..889a054
+cpuidle_store_59088 cpuidle_store 0-4 59088 &show_tcrit2_hyst_59088
+snd_cmipci_pcm_trigger_59090 snd_cmipci_pcm_trigger 0 59090 NULL
+nfs4_map_errors_59095 nfs4_map_errors 0-1 59095 NULL
++xfs_zero_eof_59103 xfs_zero_eof 3-2-0 59103 NULL
+tiadc_buffer_preenable_59104 tiadc_buffer_preenable 0 59104 NULL
+hfsplus_trusted_listxattr_59112 hfsplus_trusted_listxattr 0-5 59112 NULL nohasharray
+mmc_sd_num_wr_blocks_59112 mmc_sd_num_wr_blocks 0 59112 &hfsplus_trusted_listxattr_59112
@@ -148035,7 +147966,7 @@ index 0a578fe..b81f62d 100644
})
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
-index ec83b11..3941e06 100644
+index 0fba701..4a3dcd4 100644
--- a/virt/kvm/kvm_main.c
+++ b/virt/kvm/kvm_main.c
@@ -78,12 +78,17 @@ LIST_HEAD(vm_list);
diff --git a/3.19.4/4425_grsec_remove_EI_PAX.patch b/3.19.5/4425_grsec_remove_EI_PAX.patch
index 86e242a..86e242a 100644
--- a/3.19.4/4425_grsec_remove_EI_PAX.patch
+++ b/3.19.5/4425_grsec_remove_EI_PAX.patch
diff --git a/3.19.4/4427_force_XATTR_PAX_tmpfs.patch b/3.19.5/4427_force_XATTR_PAX_tmpfs.patch
index 22c9273..22c9273 100644
--- a/3.19.4/4427_force_XATTR_PAX_tmpfs.patch
+++ b/3.19.5/4427_force_XATTR_PAX_tmpfs.patch
diff --git a/3.19.4/4430_grsec-remove-localversion-grsec.patch b/3.19.5/4430_grsec-remove-localversion-grsec.patch
index 31cf878..31cf878 100644
--- a/3.19.4/4430_grsec-remove-localversion-grsec.patch
+++ b/3.19.5/4430_grsec-remove-localversion-grsec.patch
diff --git a/3.19.4/4435_grsec-mute-warnings.patch b/3.19.5/4435_grsec-mute-warnings.patch
index 0585e08..0585e08 100644
--- a/3.19.4/4435_grsec-mute-warnings.patch
+++ b/3.19.5/4435_grsec-mute-warnings.patch
diff --git a/3.19.4/4440_grsec-remove-protected-paths.patch b/3.19.5/4440_grsec-remove-protected-paths.patch
index 741546d..741546d 100644
--- a/3.19.4/4440_grsec-remove-protected-paths.patch
+++ b/3.19.5/4440_grsec-remove-protected-paths.patch
diff --git a/3.19.4/4450_grsec-kconfig-default-gids.patch b/3.19.5/4450_grsec-kconfig-default-gids.patch
index 5c025da..5c025da 100644
--- a/3.19.4/4450_grsec-kconfig-default-gids.patch
+++ b/3.19.5/4450_grsec-kconfig-default-gids.patch
diff --git a/3.19.4/4465_selinux-avc_audit-log-curr_ip.patch b/3.19.5/4465_selinux-avc_audit-log-curr_ip.patch
index ba89596..ba89596 100644
--- a/3.19.4/4465_selinux-avc_audit-log-curr_ip.patch
+++ b/3.19.5/4465_selinux-avc_audit-log-curr_ip.patch
diff --git a/3.19.4/4470_disable-compat_vdso.patch b/3.19.5/4470_disable-compat_vdso.patch
index 2192180..2192180 100644
--- a/3.19.4/4470_disable-compat_vdso.patch
+++ b/3.19.5/4470_disable-compat_vdso.patch
diff --git a/3.19.4/4475_emutramp_default_on.patch b/3.19.5/4475_emutramp_default_on.patch
index ad4967a..ad4967a 100644
--- a/3.19.4/4475_emutramp_default_on.patch
+++ b/3.19.5/4475_emutramp_default_on.patch