From: Greg Kroah-Hartman Date: Sun, 24 Jan 2021 13:36:12 +0000 (+0100) Subject: 4.14-stable patches X-Git-Tag: v4.19.171~42 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=98ea294e9712340b9755b81920081adccfd0daea;p=thirdparty%2Fkernel%2Fstable-queue.git 4.14-stable patches added patches: acpi-scan-make-acpi_bus_get_device-clear-return-pointer-on-error.patch alsa-hda-via-add-minimum-mute-flag.patch alsa-seq-oss-fix-missing-error-check-in-snd_seq_oss_synth_make_info.patch dm-avoid-filesystem-lookup-in-dm_get_dev_t.patch drm-atomic-put-state-on-error-path.patch i2c-bpmp-tegra-ignore-unknown-i2c_m-flags.patch mmc-sdhci-xenon-fix-1.8v-regulator-stabilization.patch --- diff --git a/queue-4.14/acpi-scan-make-acpi_bus_get_device-clear-return-pointer-on-error.patch b/queue-4.14/acpi-scan-make-acpi_bus_get_device-clear-return-pointer-on-error.patch new file mode 100644 index 00000000000..f9370feae5c --- /dev/null +++ b/queue-4.14/acpi-scan-make-acpi_bus_get_device-clear-return-pointer-on-error.patch @@ -0,0 +1,48 @@ +From 78a18fec5258c8df9435399a1ea022d73d3eceb9 Mon Sep 17 00:00:00 2001 +From: Hans de Goede +Date: Fri, 15 Jan 2021 22:57:52 +0100 +Subject: ACPI: scan: Make acpi_bus_get_device() clear return pointer on error + +From: Hans de Goede + +commit 78a18fec5258c8df9435399a1ea022d73d3eceb9 upstream. + +Set the acpi_device pointer which acpi_bus_get_device() returns-by- +reference to NULL on errors. + +We've recently had 2 cases where callers of acpi_bus_get_device() +did not properly error check the return value, so set the returned- +by-reference acpi_device pointer to NULL, because at least some +callers of acpi_bus_get_device() expect that to be done on errors. + +[ rjw: This issue was exposed by commit 71da201f38df ("ACPI: scan: + Defer enumeration of devices with _DEP lists") which caused it to + be much more likely to occur on some systems, but the real defect + had been introduced by an earlier commit. ] + +Fixes: 40e7fcb19293 ("ACPI: Add _DEP support to fix battery issue on Asus T100TA") +Fixes: bcfcd409d4db ("usb: split code locating ACPI companion into port and device") +Reported-by: Pierre-Louis Bossart +Tested-by: Pierre-Louis Bossart +Diagnosed-by: Rafael J. Wysocki +Signed-off-by: Hans de Goede +Cc: All applicable +[ rjw: Subject and changelog edits ] +Signed-off-by: Rafael J. Wysocki +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/acpi/scan.c | 2 ++ + 1 file changed, 2 insertions(+) + +--- a/drivers/acpi/scan.c ++++ b/drivers/acpi/scan.c +@@ -585,6 +585,8 @@ static int acpi_get_device_data(acpi_han + if (!device) + return -EINVAL; + ++ *device = NULL; ++ + status = acpi_get_data_full(handle, acpi_scan_drop_device, + (void **)device, callback); + if (ACPI_FAILURE(status) || !*device) { diff --git a/queue-4.14/alsa-hda-via-add-minimum-mute-flag.patch b/queue-4.14/alsa-hda-via-add-minimum-mute-flag.patch new file mode 100644 index 00000000000..8b65c42a72b --- /dev/null +++ b/queue-4.14/alsa-hda-via-add-minimum-mute-flag.patch @@ -0,0 +1,33 @@ +From 67ea698c3950d10925be33c21ca49ffb64e21842 Mon Sep 17 00:00:00 2001 +From: Takashi Iwai +Date: Thu, 14 Jan 2021 08:24:53 +0100 +Subject: ALSA: hda/via: Add minimum mute flag + +From: Takashi Iwai + +commit 67ea698c3950d10925be33c21ca49ffb64e21842 upstream. + +It turned out that VIA codecs also mute the sound in the lowest mixer +level. Turn on the dac_min_mute flag to indicate the mute-as-minimum +in TLV like already done in Conexant and IDT codecs. + +BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=210559 +Cc: +Link: https://lore.kernel.org/r/20210114072453.11379-1-tiwai@suse.de +Signed-off-by: Takashi Iwai +Signed-off-by: Greg Kroah-Hartman + +--- + sound/pci/hda/patch_via.c | 1 + + 1 file changed, 1 insertion(+) + +--- a/sound/pci/hda/patch_via.c ++++ b/sound/pci/hda/patch_via.c +@@ -135,6 +135,7 @@ static struct via_spec *via_new_spec(str + spec->codec_type = VT1708S; + spec->gen.indep_hp = 1; + spec->gen.keep_eapd_on = 1; ++ spec->gen.dac_min_mute = 1; + spec->gen.pcm_playback_hook = via_playback_pcm_hook; + spec->gen.add_stereo_mix_input = HDA_HINT_STEREO_MIX_AUTO; + codec->power_save_node = 1; diff --git a/queue-4.14/alsa-seq-oss-fix-missing-error-check-in-snd_seq_oss_synth_make_info.patch b/queue-4.14/alsa-seq-oss-fix-missing-error-check-in-snd_seq_oss_synth_make_info.patch new file mode 100644 index 00000000000..1318e67d426 --- /dev/null +++ b/queue-4.14/alsa-seq-oss-fix-missing-error-check-in-snd_seq_oss_synth_make_info.patch @@ -0,0 +1,38 @@ +From 217bfbb8b0bfa24619b11ab75c135fec99b99b20 Mon Sep 17 00:00:00 2001 +From: Takashi Iwai +Date: Fri, 15 Jan 2021 10:34:28 +0100 +Subject: ALSA: seq: oss: Fix missing error check in snd_seq_oss_synth_make_info() + +From: Takashi Iwai + +commit 217bfbb8b0bfa24619b11ab75c135fec99b99b20 upstream. + +snd_seq_oss_synth_make_info() didn't check the error code from +snd_seq_oss_midi_make_info(), and this leads to the call of strlcpy() +with the uninitialized string as the source, which may lead to the +access over the limit. + +Add the proper error check for avoiding the failure. + +Reported-by: syzbot+e42504ff21cff05a595f@syzkaller.appspotmail.com +Cc: +Link: https://lore.kernel.org/r/20210115093428.15882-1-tiwai@suse.de +Signed-off-by: Takashi Iwai +Signed-off-by: Greg Kroah-Hartman + +--- + sound/core/seq/oss/seq_oss_synth.c | 3 ++- + 1 file changed, 2 insertions(+), 1 deletion(-) + +--- a/sound/core/seq/oss/seq_oss_synth.c ++++ b/sound/core/seq/oss/seq_oss_synth.c +@@ -624,7 +624,8 @@ snd_seq_oss_synth_make_info(struct seq_o + + if (info->is_midi) { + struct midi_info minf; +- snd_seq_oss_midi_make_info(dp, info->midi_mapped, &minf); ++ if (snd_seq_oss_midi_make_info(dp, info->midi_mapped, &minf)) ++ return -ENXIO; + inf->synth_type = SYNTH_TYPE_MIDI; + inf->synth_subtype = 0; + inf->nr_voices = 16; diff --git a/queue-4.14/dm-avoid-filesystem-lookup-in-dm_get_dev_t.patch b/queue-4.14/dm-avoid-filesystem-lookup-in-dm_get_dev_t.patch new file mode 100644 index 00000000000..2a7661f23cc --- /dev/null +++ b/queue-4.14/dm-avoid-filesystem-lookup-in-dm_get_dev_t.patch @@ -0,0 +1,66 @@ +From 809b1e4945774c9ec5619a8f4e2189b7b3833c0c Mon Sep 17 00:00:00 2001 +From: Hannes Reinecke +Date: Thu, 21 Jan 2021 18:50:56 +0100 +Subject: dm: avoid filesystem lookup in dm_get_dev_t() + +From: Hannes Reinecke + +commit 809b1e4945774c9ec5619a8f4e2189b7b3833c0c upstream. + +This reverts commit +644bda6f3460 ("dm table: fall back to getting device using name_to_dev_t()") + +dm_get_dev_t() is just used to convert an arbitrary 'path' string +into a dev_t. It doesn't presume that the device is present; that +check will be done later, as the only caller is dm_get_device(), +which does a dm_get_table_device() later on, which will properly +open the device. + +So if the path string already _is_ in major:minor representation +we can convert it directly, avoiding a recursion into the filesystem +to lookup the block device. + +This avoids a hang in multipath_message() when the filesystem is +inaccessible. + +Fixes: 644bda6f3460 ("dm table: fall back to getting device using name_to_dev_t()") +Cc: stable@vger.kernel.org +Signed-off-by: Hannes Reinecke +Signed-off-by: Martin Wilck +Reviewed-by: Christoph Hellwig +Signed-off-by: Mike Snitzer +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/md/dm-table.c | 15 ++++++++++++--- + 1 file changed, 12 insertions(+), 3 deletions(-) + +--- a/drivers/md/dm-table.c ++++ b/drivers/md/dm-table.c +@@ -431,14 +431,23 @@ int dm_get_device(struct dm_target *ti, + { + int r; + dev_t dev; ++ unsigned int major, minor; ++ char dummy; + struct dm_dev_internal *dd; + struct dm_table *t = ti->table; + + BUG_ON(!t); + +- dev = dm_get_dev_t(path); +- if (!dev) +- return -ENODEV; ++ if (sscanf(path, "%u:%u%c", &major, &minor, &dummy) == 2) { ++ /* Extract the major/minor numbers */ ++ dev = MKDEV(major, minor); ++ if (MAJOR(dev) != major || MINOR(dev) != minor) ++ return -EOVERFLOW; ++ } else { ++ dev = dm_get_dev_t(path); ++ if (!dev) ++ return -ENODEV; ++ } + + dd = find_device(&t->devices, dev); + if (!dd) { diff --git a/queue-4.14/drm-atomic-put-state-on-error-path.patch b/queue-4.14/drm-atomic-put-state-on-error-path.patch new file mode 100644 index 00000000000..6a0f27bd02b --- /dev/null +++ b/queue-4.14/drm-atomic-put-state-on-error-path.patch @@ -0,0 +1,33 @@ +From 43b67309b6b2a3c08396cc9b3f83f21aa529d273 Mon Sep 17 00:00:00 2001 +From: Pan Bian +Date: Tue, 19 Jan 2021 04:11:27 -0800 +Subject: drm/atomic: put state on error path + +From: Pan Bian + +commit 43b67309b6b2a3c08396cc9b3f83f21aa529d273 upstream. + +Put the state before returning error code. + +Fixes: 44596b8c4750 ("drm/atomic: Unify conflicting encoder handling.") +Signed-off-by: Pan Bian +Cc: stable@vger.kernel.org +Signed-off-by: Daniel Vetter +Link: https://patchwork.freedesktop.org/patch/msgid/20210119121127.84127-1-bianpan2016@163.com +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/gpu/drm/drm_atomic_helper.c | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +--- a/drivers/gpu/drm/drm_atomic_helper.c ++++ b/drivers/gpu/drm/drm_atomic_helper.c +@@ -2608,7 +2608,7 @@ int drm_atomic_helper_set_config(struct + + ret = handle_conflicting_encoders(state, true); + if (ret) +- return ret; ++ goto fail; + + ret = drm_atomic_commit(state); + diff --git a/queue-4.14/i2c-bpmp-tegra-ignore-unknown-i2c_m-flags.patch b/queue-4.14/i2c-bpmp-tegra-ignore-unknown-i2c_m-flags.patch new file mode 100644 index 00000000000..46fc6e457d9 --- /dev/null +++ b/queue-4.14/i2c-bpmp-tegra-ignore-unknown-i2c_m-flags.patch @@ -0,0 +1,34 @@ +From bc1c2048abbe3c3074b4de91d213595c57741a6b Mon Sep 17 00:00:00 2001 +From: Mikko Perttunen +Date: Tue, 12 Jan 2021 12:22:25 +0200 +Subject: i2c: bpmp-tegra: Ignore unknown I2C_M flags + +From: Mikko Perttunen + +commit bc1c2048abbe3c3074b4de91d213595c57741a6b upstream. + +In order to not to start returning errors when new I2C_M flags are +added, change behavior to just ignore all flags that we don't know +about. This includes the I2C_M_DMA_SAFE flag that already exists but +causes -EINVAL to be returned for valid transactions. + +Cc: stable@vger.kernel.org # v4.19+ +Signed-off-by: Mikko Perttunen +Signed-off-by: Wolfram Sang +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/i2c/busses/i2c-tegra-bpmp.c | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +--- a/drivers/i2c/busses/i2c-tegra-bpmp.c ++++ b/drivers/i2c/busses/i2c-tegra-bpmp.c +@@ -91,7 +91,7 @@ static int tegra_bpmp_xlate_flags(u16 fl + flags &= ~I2C_M_RECV_LEN; + } + +- return (flags != 0) ? -EINVAL : 0; ++ return 0; + } + + /** diff --git a/queue-4.14/mmc-sdhci-xenon-fix-1.8v-regulator-stabilization.patch b/queue-4.14/mmc-sdhci-xenon-fix-1.8v-regulator-stabilization.patch new file mode 100644 index 00000000000..8550b118b2d --- /dev/null +++ b/queue-4.14/mmc-sdhci-xenon-fix-1.8v-regulator-stabilization.patch @@ -0,0 +1,45 @@ +From 1a3ed0dc3594d99ff341ec63865a40519ea24b8d Mon Sep 17 00:00:00 2001 +From: Alex Leibovich +Date: Fri, 11 Dec 2020 15:16:56 +0100 +Subject: mmc: sdhci-xenon: fix 1.8v regulator stabilization + +From: Alex Leibovich + +commit 1a3ed0dc3594d99ff341ec63865a40519ea24b8d upstream. + +Automatic Clock Gating is a feature used for the power consumption +optimisation. It turned out that during early init phase it may prevent the +stable voltage switch to 1.8V - due to that on some platforms an endless +printout in dmesg can be observed: "mmc1: 1.8V regulator output did not +became stable" Fix the problem by disabling the ACG at very beginning of +the sdhci_init and let that be enabled later. + +Fixes: 3a3748dba881 ("mmc: sdhci-xenon: Add Marvell Xenon SDHC core functionality") +Signed-off-by: Alex Leibovich +Signed-off-by: Marcin Wojtas +Cc: stable@vger.kernel.org +Acked-by: Adrian Hunter +Link: https://lore.kernel.org/r/20201211141656.24915-1-mw@semihalf.com +Signed-off-by: Ulf Hansson +Signed-off-by: Greg Kroah-Hartman + +--- + drivers/mmc/host/sdhci-xenon.c | 7 ++++++- + 1 file changed, 6 insertions(+), 1 deletion(-) + +--- a/drivers/mmc/host/sdhci-xenon.c ++++ b/drivers/mmc/host/sdhci-xenon.c +@@ -170,7 +170,12 @@ static void xenon_reset_exit(struct sdhc + /* Disable tuning request and auto-retuning again */ + xenon_retune_setup(host); + +- xenon_set_acg(host, true); ++ /* ++ * The ACG should be turned off at the early init time, in order ++ * to solve a possible issues with the 1.8V regulator stabilization. ++ * The feature is enabled in later stage. ++ */ ++ xenon_set_acg(host, false); + + xenon_set_sdclk_off_idle(host, sdhc_id, false); +