Skip to content
  1. Jan 12, 2021
  2. Jan 04, 2021
    • Takashi Iwai's avatar
      ALSA: hda/via: Fix runtime PM for Clevo W35xSS · 4bfd6247
      Takashi Iwai authored
      
      
      Clevo W35xSS_370SS with VIA codec has had the runtime PM problem that
      looses the power state of some nodes after the runtime resume.  This
      was worked around by disabling the default runtime PM via a denylist
      entry.  Since 5.10.x made the runtime PM applied (casually) even
      though it's disabled in the denylist, this problem was revisited.  The
      result was that disabling power_save_node feature suffices for the
      runtime PM problem.
      
      This patch implements the disablement of power_save_node feature in
      VIA codec for the device.  It also drops the former denylist entry,
      too, as the runtime PM should work in the codec side properly now.
      
      Fixes: b529ef24 ("ALSA: hda: Add Clevo W35xSS_370SS to the power_save blacklist")
      Reported-by: default avatarChristian Labisch <clnetbox@gmail.com>
      Cc: <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/20210104153046.19993-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      4bfd6247
  3. Nov 16, 2020
  4. Oct 28, 2020
  5. Oct 12, 2020
  6. Sep 21, 2020
  7. Sep 02, 2020
  8. Aug 25, 2020
    • Tiezhu Yang's avatar
      Revert "ALSA: hda: Add support for Loongson 7A1000 controller" · eed8f88b
      Tiezhu Yang authored
      
      
      This reverts commit 61eee4a7 ("ALSA: hda: Add support for Loongson
      7A1000 controller") to fix the following error on the Loongson LS7A
      platform:
      
      rcu: INFO: rcu_preempt self-detected stall on CPU
      <SNIP>
      NMI backtrace for cpu 0
      CPU: 0 PID: 68 Comm: kworker/0:2 Not tainted 5.8.0+ #3
      Hardware name:  , BIOS
      Workqueue: events azx_probe_work [snd_hda_intel]
      <SNIP>
      Call Trace:
      [<ffffffff80211a64>] show_stack+0x9c/0x130
      [<ffffffff8065a740>] dump_stack+0xb0/0xf0
      [<ffffffff80665774>] nmi_cpu_backtrace+0x134/0x140
      [<ffffffff80665910>] nmi_trigger_cpumask_backtrace+0x190/0x200
      [<ffffffff802b1abc>] rcu_dump_cpu_stacks+0x12c/0x190
      [<ffffffff802b08cc>] rcu_sched_clock_irq+0xa2c/0xfc8
      [<ffffffff802b91d4>] update_process_times+0x2c/0xb8
      [<ffffffff802cad80>] tick_sched_timer+0x40/0xb8
      [<ffffffff802ba5f0>] __hrtimer_run_queues+0x118/0x1d0
      [<ffffffff802bab74>] hrtimer_interrupt+0x12c/0x2d8
      [<ffffffff8021547c>] c0_compare_interrupt+0x74/0xa0
      [<ffffffff80296bd0>] __handle_irq_event_percpu+0xa8/0x198
      [<ffffffff80296cf0>] handle_irq_event_percpu+0x30/0x90
      [<ffffffff8029d958>] handle_percpu_irq+0x88/0xb8
      [<ffffffff80296124>] generic_handle_irq+0x44/0x60
      [<ffffffff80b3cfd0>] do_IRQ+0x18/0x28
      [<ffffffff8067ace4>] plat_irq_dispatch+0x64/0x100
      [<ffffffff80209a20>] handle_int+0x140/0x14c
      [<ffffffff802402e8>] irq_exit+0xf8/0x100
      
      Because AZX_DRIVER_GENERIC can not work well for Loongson LS7A HDA
      controller, it needs some workarounds which are not merged into the
      upstream kernel at this time, so it should revert this patch now.
      
      Fixes: 61eee4a7 ("ALSA: hda: Add support for Loongson 7A1000 controller")
      Cc: <stable@vger.kernel.org> # 5.9-rc1+
      Signed-off-by: default avatarTiezhu Yang <yangtiezhu@loongson.cn>
      Link: https://lore.kernel.org/r/1598348388-2518-1-git-send-email-yangtiezhu@loongson.cn
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      eed8f88b
  9. Aug 03, 2020
  10. Jul 27, 2020
    • Takashi Iwai's avatar
      ALSA: hda: Workaround for spurious wakeups on some Intel platforms · a6630529
      Takashi Iwai authored
      We've received a regression report on Intel HD-audio controller that
      wakes up immediately after S3 suspend.  The bisection leads to the
      commit c4c8dd6e ("ALSA: hda: Skip controller resume if not
      needed").  This commit replaces the system-suspend to use
      pm_runtime_force_suspend() instead of the direct call of
      __azx_runtime_suspend().  However, by some really mysterious reason,
      pm_runtime_force_suspend() causes a spurious wakeup (although it calls
      the same __azx_runtime_suspend() internally).
      
      As an ugly workaround for now, revert the behavior to call
      __azx_runtime_suspend() and __azx_runtime_resume() for those old Intel
      platforms that may exhibit such a problem, while keeping the new
      standard pm_runtime_force_suspend() and pm_runtime_force_resume()
      pair for the remaining chips.
      
      Fixes: c4c8dd6e ("ALSA: hda: Skip controller resume if not needed")
      BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=208649
      Cc: <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/20200727164443.4233-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      a6630529
  11. Jul 17, 2020
  12. Jul 15, 2020
  13. Jun 19, 2020
  14. Jun 18, 2020
  15. Jun 09, 2020
    • Mike Rapoport's avatar
      mm: reorder includes after introduction of linux/pgtable.h · 65fddcfc
      Mike Rapoport authored
      
      
      The replacement of <asm/pgrable.h> with <linux/pgtable.h> made the include
      of the latter in the middle of asm includes.  Fix this up with the aid of
      the below script and manual adjustments here and there.
      
      	import sys
      	import re
      
      	if len(sys.argv) is not 3:
      	    print "USAGE: %s <file> <header>" % (sys.argv[0])
      	    sys.exit(1)
      
      	hdr_to_move="#include <linux/%s>" % sys.argv[2]
      	moved = False
      	in_hdrs = False
      
      	with open(sys.argv[1], "r") as f:
      	    lines = f.readlines()
      	    for _line in lines:
      		line = _line.rstrip('
      ')
      		if line == hdr_to_move:
      		    continue
      		if line.startswith("#include <linux/"):
      		    in_hdrs = True
      		elif not moved and in_hdrs:
      		    moved = True
      		    print hdr_to_move
      		print line
      
      Signed-off-by: default avatarMike Rapoport <rppt@linux.ibm.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Borislav Petkov <bp@alien8.de>
      Cc: Brian Cain <bcain@codeaurora.org>
      Cc: Catalin Marinas <catalin.marinas@arm.com>
      Cc: Chris Zankel <chris@zankel.net>
      Cc: "David S. Miller" <davem@davemloft.net>
      Cc: Geert Uytterhoeven <geert@linux-m68k.org>
      Cc: Greentime Hu <green.hu@gmail.com>
      Cc: Greg Ungerer <gerg@linux-m68k.org>
      Cc: Guan Xuetao <gxt@pku.edu.cn>
      Cc: Guo Ren <guoren@kernel.org>
      Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
      Cc: Helge Deller <deller@gmx.de>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Ley Foon Tan <ley.foon.tan@intel.com>
      Cc: Mark Salter <msalter@redhat.com>
      Cc: Matthew Wilcox <willy@infradead.org>
      Cc: Matt Turner <mattst88@gmail.com>
      Cc: Max Filippov <jcmvbkbc@gmail.com>
      Cc: Michael Ellerman <mpe@ellerman.id.au>
      Cc: Michal Simek <monstr@monstr.eu>
      Cc: Nick Hu <nickhu@andestech.com>
      Cc: Paul Walmsley <paul.walmsley@sifive.com>
      Cc: Richard Weinberger <richard@nod.at>
      Cc: Rich Felker <dalias@libc.org>
      Cc: Russell King <linux@armlinux.org.uk>
      Cc: Stafford Horne <shorne@gmail.com>
      Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Tony Luck <tony.luck@intel.com>
      Cc: Vincent Chen <deanbo422@gmail.com>
      Cc: Vineet Gupta <vgupta@synopsys.com>
      Cc: Will Deacon <will@kernel.org>
      Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
      Link: http://lkml.kernel.org/r/20200514170327.31389-4-rppt@kernel.org
      
      
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      65fddcfc
    • Mike Rapoport's avatar
      mm: introduce include/linux/pgtable.h · ca5999fd
      Mike Rapoport authored
      
      
      The include/linux/pgtable.h is going to be the home of generic page table
      manipulation functions.
      
      Start with moving asm-generic/pgtable.h to include/linux/pgtable.h and
      make the latter include asm/pgtable.h.
      
      Signed-off-by: default avatarMike Rapoport <rppt@linux.ibm.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Borislav Petkov <bp@alien8.de>
      Cc: Brian Cain <bcain@codeaurora.org>
      Cc: Catalin Marinas <catalin.marinas@arm.com>
      Cc: Chris Zankel <chris@zankel.net>
      Cc: "David S. Miller" <davem@davemloft.net>
      Cc: Geert Uytterhoeven <geert@linux-m68k.org>
      Cc: Greentime Hu <green.hu@gmail.com>
      Cc: Greg Ungerer <gerg@linux-m68k.org>
      Cc: Guan Xuetao <gxt@pku.edu.cn>
      Cc: Guo Ren <guoren@kernel.org>
      Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
      Cc: Helge Deller <deller@gmx.de>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Ley Foon Tan <ley.foon.tan@intel.com>
      Cc: Mark Salter <msalter@redhat.com>
      Cc: Matthew Wilcox <willy@infradead.org>
      Cc: Matt Turner <mattst88@gmail.com>
      Cc: Max Filippov <jcmvbkbc@gmail.com>
      Cc: Michael Ellerman <mpe@ellerman.id.au>
      Cc: Michal Simek <monstr@monstr.eu>
      Cc: Nick Hu <nickhu@andestech.com>
      Cc: Paul Walmsley <paul.walmsley@sifive.com>
      Cc: Richard Weinberger <richard@nod.at>
      Cc: Rich Felker <dalias@libc.org>
      Cc: Russell King <linux@armlinux.org.uk>
      Cc: Stafford Horne <shorne@gmail.com>
      Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Tony Luck <tony.luck@intel.com>
      Cc: Vincent Chen <deanbo422@gmail.com>
      Cc: Vineet Gupta <vgupta@synopsys.com>
      Cc: Will Deacon <will@kernel.org>
      Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
      Link: http://lkml.kernel.org/r/20200514170327.31389-3-rppt@kernel.org
      
      
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      ca5999fd
  16. Jun 03, 2020
  17. Apr 24, 2020
    • Takashi Iwai's avatar
      ALSA: hda: Match both PCI ID and SSID for driver blacklist · 977dfef4
      Takashi Iwai authored
      The commit 3c6fd1f0 ("ALSA: hda: Add driver blacklist") added a
      new blacklist for the devices that are known to have empty codecs, and
      one of the entries was ASUS ROG Zenith II (PCI SSID 1043:874f).
      However, it turned out that the very same PCI SSID is used for the
      previous model that does have the valid HD-audio codecs and the change
      broke the sound on it.
      
      Since the empty codec problem appear on the certain AMD platform (PCI
      ID 1022:1487), this patch changes the blacklist matching to both PCI
      ID and SSID using pci_match_id().  Also, the entry that was removed by
      the previous fix for ASUS ROG Zenigh II is re-added.
      
      Link: https://lore.kernel.org/r/20200424061222.19792-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      977dfef4
  18. Apr 23, 2020
    • Takashi Iwai's avatar
      ALSA: hda: Always use jackpoll helper for jack update after resume · 8d6762af
      Takashi Iwai authored
      HD-audio codec driver applies a tricky procedure to forcibly perform
      the runtime resume by mimicking the usage count even if the device has
      been runtime-suspended beforehand.  This was needed to assure to
      trigger the jack detection update after the system resume.
      
      And recently we also applied the similar logic to the HD-audio
      controller side.  However this seems leading to some inconsistency,
      and eventually PCI controller gets screwed up.
      
      This patch is an attempt to fix and clean up those behavior: instead
      of the tricky runtime resume procedure, the existing jackpoll work is
      scheduled when such a forced codec resume is required.  The jackpoll
      work will power up the codec, and this alone should suffice for the
      jack status update in usual cases.  If the extra polling is requested
      (by checking codec->jackpoll_interval), the manual update is invoked
      after that, and the codec is powered down again.
      
      Also, we filter the spurious wake up of the codec from the controller
      runtime resume by checking codec->relaxed_resume flag.  If this flag
      is set, basically we don't need to wake up explicitly, but it's
      supposed to be done via the audio component notifier.
      
      Fixes: c4c8dd6e ("ALSA: hda: Skip controller resume if not needed")
      Link: https://lore.kernel.org/r/20200422203744.26299-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      8d6762af
  19. Apr 19, 2020
  20. Apr 14, 2020
    • Hui Wang's avatar
      ALSA: hda: call runtime_allow() for all hda controllers · 9a641848
      Hui Wang authored
      
      
      Before the pci_driver->probe() is called, the pci subsystem calls
      runtime_forbid() and runtime_get_sync() on this pci dev, so only call
      runtime_put_autosuspend() is not enough to enable the runtime_pm on
      this device.
      
      For controllers with vgaswitcheroo feature, the pci/quirks.c will call
      runtime_allow() for this dev, then the controllers could enter
      rt_idle/suspend/resume, but for non-vgaswitcheroo controllers like
      Intel hda controllers, the runtime_pm is not enabled because the
      runtime_allow() is not called.
      
      Since it is no harm calling runtime_allow() twice, here let hda
      driver call runtime_allow() for all controllers. Then the runtime_pm
      is enabled on all controllers after the put_autosuspend() is called.
      
      Signed-off-by: default avatarHui Wang <hui.wang@canonical.com>
      Link: https://lore.kernel.org/r/20200414142725.6020-1-hui.wang@canonical.com
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      9a641848
  21. Apr 13, 2020
  22. Apr 08, 2020
  23. Feb 01, 2020
  24. Jan 26, 2020
  25. Jan 11, 2020
    • Takashi Iwai's avatar
      ALSA: hda: Rename back to dmic_detect option · 7fba6aea
      Takashi Iwai authored
      We've got quite a few bug reports showing the SOF driver being loaded
      unintentionally recently, and the reason seems to be that users didn't
      know the module option change: with the recent kernel, a new option
      dsp_driver=1 has to be passed to a new module snd-intel-dspcfg
      instead of snd_hda_intel.dmic_detect=0 option.
      
      That is, actually there are two tricky things here:
      - We changed the whole detection in another module and another
        option semantics.
      - The existing option for skipping the DSP probe was also renamed.
      
      For avoiding the confusion and giving user more hint, this patch
      reverts the renamed option dsp_driver back to dmic_detect for
      snd-hda-intel module, and show the warning about the module option
      change when the non-default value is passed.
      
      Fixes: 82d9d54a ("ALSA: hda: add Intel DSP configuration / probe code")
      Link: https://lore.kernel.org/r/20200109082000.26729-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      7fba6aea
  26. Jan 05, 2020
  27. Jan 03, 2020
  28. Dec 23, 2019
    • Takashi Iwai's avatar
      ALSA: hda - Apply sync-write workaround to old Intel platforms, too · c366b3db
      Takashi Iwai authored
      
      
      Klaus Ethgen reported occasional high CPU usages in his system that
      seem caused by HD-audio driver.  The perf output revealed that it's
      in the unsolicited event handling in the workqueue, and the problem
      seems triggered by some communication stall between the controller and
      the codec at the runtime or system resume.
      
      Actually a similar phenomenon was seen in the past for other Intel
      platforms, and we already applied the workaround to enforce sync-write
      for CORB/RIRB verbs for Skylake and newer chipsets (commit
      2756d914 "ALSA: hda - Fix intermittent CORB/RIRB stall on Intel
      chips").  Fortunately, the same workaround is applicable to the old
      chipset, and the experiment showed the positive effect.
      
      Based on the experiment result, this patch enables the sync-write
      workaround for all Intel chipsets.  The only reason I hesitated to
      apply this workaround was about the possibly slightly higher CPU usage.
      But if the lack of sync causes a much severer problem even for quite
      old chip, we should think this would be necessary for all Intel chips.
      
      Reported-by: default avatarKlaus Ethgen <Klaus@ethgen.ch>
      Cc: <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/20191223171833.GA17053@chua
      Link: https://lore.kernel.org/r/20191223221816.32572-1-tiwai@suse.de
      
      
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      c366b3db
  29. Dec 21, 2019
  30. Dec 13, 2019
  31. Dec 11, 2019
Loading