1. 15 Mar, 2024 2 commits
  2. 13 Mar, 2024 3 commits
  3. 12 Mar, 2024 1 commit
  4. 11 Mar, 2024 12 commits
  5. 08 Mar, 2024 4 commits
  6. 07 Mar, 2024 8 commits
  7. 06 Mar, 2024 5 commits
    • Stuart Henderson's avatar
      ASoC: wm8962: Fix up incorrect error message in wm8962_set_fll · 96e202f8
      Stuart Henderson authored
      Use source instead of ret, which seems to be unrelated and will always
      be zero.
      Signed-off-by: default avatarStuart Henderson <stuarth@opensource.cirrus.com>
      Link: https://msgid.link/r/20240306161439.1385643-5-stuarth@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      96e202f8
    • Stuart Henderson's avatar
    • Stuart Henderson's avatar
    • Luca Ceresoli's avatar
      ASoC: trace: add event to snd_soc_dapm trace events · 7df3eb4c
      Luca Ceresoli authored
      Add the event value to the snd_soc_dapm_start and snd_soc_dapm_done trace
      events to make them more informative.
      
      Trace before:
      
                 aplay-229   [000]   250.140309: snd_soc_dapm_start:   card=vscn-2046
                 aplay-229   [000]   250.167531: snd_soc_dapm_done:    card=vscn-2046
                 aplay-229   [000]   251.169588: snd_soc_dapm_start:   card=vscn-2046
                 aplay-229   [000]   251.195245: snd_soc_dapm_done:    card=vscn-2046
      
      Trace after:
      
                 aplay-214   [000]   693.290612: snd_soc_dapm_start:   card=vscn-2046 event=1
                 aplay-214   [000]   693.315508: snd_soc_dapm_done:    card=vscn-2046 event=1
                 aplay-214   [000]   694.537349: snd_soc_dapm_start:   card=vscn-2046 event=2
                 aplay-214   [000]   694.563241: snd_soc_dapm_done:    card=vscn-2046 event=2
      Signed-off-by: default avatarLuca Ceresoli <luca.ceresoli@bootlin.com>
      Link: https://msgid.link/r/20240306-improve-asoc-trace-events-v1-2-edb252bbeb10@bootlin.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      7df3eb4c
    • Luca Ceresoli's avatar
      ASoC: trace: add component to set_bias_level trace events · 6ef46a69
      Luca Ceresoli authored
      The snd_soc_bias_level_start and snd_soc_bias_level_done trace events
      currently look like:
      
                 aplay-229   [000]  1250.140778: snd_soc_bias_level_start: card=vscn-2046 val=1
                 aplay-229   [000]  1250.140784: snd_soc_bias_level_done: card=vscn-2046 val=1
                 aplay-229   [000]  1250.140786: snd_soc_bias_level_start: card=vscn-2046 val=2
                 aplay-229   [000]  1250.140788: snd_soc_bias_level_done: card=vscn-2046 val=2
          kworker/u8:1-21    [000]  1250.140871: snd_soc_bias_level_start: card=vscn-2046 val=1
          kworker/u8:0-11    [000]  1250.140951: snd_soc_bias_level_start: card=vscn-2046 val=1
          kworker/u8:0-11    [000]  1250.140956: snd_soc_bias_level_done: card=vscn-2046 val=1
          kworker/u8:0-11    [000]  1250.140959: snd_soc_bias_level_start: card=vscn-2046 val=2
          kworker/u8:0-11    [000]  1250.140961: snd_soc_bias_level_done: card=vscn-2046 val=2
          kworker/u8:1-21    [000]  1250.167219: snd_soc_bias_level_done: card=vscn-2046 val=1
          kworker/u8:1-21    [000]  1250.167222: snd_soc_bias_level_start: card=vscn-2046 val=2
          kworker/u8:1-21    [000]  1250.167232: snd_soc_bias_level_done: card=vscn-2046 val=2
          kworker/u8:0-11    [000]  1250.167440: snd_soc_bias_level_start: card=vscn-2046 val=3
          kworker/u8:0-11    [000]  1250.167444: snd_soc_bias_level_done: card=vscn-2046 val=3
          kworker/u8:1-21    [000]  1250.167497: snd_soc_bias_level_start: card=vscn-2046 val=3
          kworker/u8:1-21    [000]  1250.167506: snd_soc_bias_level_done: card=vscn-2046 val=3
      
      There are clearly multiple calls, one per component, but they cannot be
      discriminated from each other.
      
      Change the ftrace events to also print the component name, to make it clear
      which part of the code is involved. This requires changing the passed value
      from a struct snd_soc_card, where the DAPM context is not kwown, to a
      struct snd_soc_dapm_context where it is obviously known but the a card
      pointer is also available.
      
      With this change, the resulting trace becomes:
      
                 aplay-247   [000]  1436.357332: snd_soc_bias_level_start: card=vscn-2046 component=(none) val=1
                 aplay-247   [000]  1436.357338: snd_soc_bias_level_done: card=vscn-2046 component=(none) val=1
                 aplay-247   [000]  1436.357340: snd_soc_bias_level_start: card=vscn-2046 component=(none) val=2
                 aplay-247   [000]  1436.357343: snd_soc_bias_level_done: card=vscn-2046 component=(none) val=2
          kworker/u8:4-215   [000]  1436.357437: snd_soc_bias_level_start: card=vscn-2046 component=ff560000.codec val=1
          kworker/u8:5-231   [000]  1436.357518: snd_soc_bias_level_start: card=vscn-2046 component=ff320000.i2s val=1
          kworker/u8:5-231   [000]  1436.357523: snd_soc_bias_level_done: card=vscn-2046 component=ff320000.i2s val=1
          kworker/u8:5-231   [000]  1436.357526: snd_soc_bias_level_start: card=vscn-2046 component=ff320000.i2s val=2
          kworker/u8:5-231   [000]  1436.357528: snd_soc_bias_level_done: card=vscn-2046 component=ff320000.i2s val=2
          kworker/u8:4-215   [000]  1436.383217: snd_soc_bias_level_done: card=vscn-2046 component=ff560000.codec val=1
          kworker/u8:4-215   [000]  1436.383221: snd_soc_bias_level_start: card=vscn-2046 component=ff560000.codec val=2
          kworker/u8:4-215   [000]  1436.383231: snd_soc_bias_level_done: card=vscn-2046 component=ff560000.codec val=2
          kworker/u8:5-231   [000]  1436.383468: snd_soc_bias_level_start: card=vscn-2046 component=ff320000.i2s val=3
          kworker/u8:5-231   [000]  1436.383472: snd_soc_bias_level_done: card=vscn-2046 component=ff320000.i2s val=3
          kworker/u8:4-215   [000]  1436.383503: snd_soc_bias_level_start: card=vscn-2046 component=ff560000.codec val=3
          kworker/u8:4-215   [000]  1436.383513: snd_soc_bias_level_done: card=vscn-2046 component=ff560000.codec val=3
      Signed-off-by: default avatarLuca Ceresoli <luca.ceresoli@bootlin.com>
      Link: https://msgid.link/r/20240306-improve-asoc-trace-events-v1-1-edb252bbeb10@bootlin.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      6ef46a69
  8. 05 Mar, 2024 4 commits
  9. 04 Mar, 2024 1 commit
    • Chancel Liu's avatar
      ASoC: soc-core.c: Prefer to return dai->driver->name in snd_soc_dai_name_get() · 755bb9a4
      Chancel Liu authored
      ASoC machine driver can use snd_soc_{of_}get_dlc() (A) to get DAI name
      for dlc (snd_soc_dai_link_component). In this function call
      dlc->dai_name is parsed via snd_soc_dai_name_get() (B).
      
      (A)	int snd_soc_get_dlc(...)
      	{
      		...
      (B)		dlc->dai_name = snd_soc_dai_name_get(dai);
      		...
      	}
      
      (B) has a priority to return dai->name as dlc->dai_name. In most cases
      card can probe successfully. However it has an issue that ASoC tries to
      rebind card. Here is a simplified flow for example:
      
       |	a) Card probes successfully at first
       |	b) One of the component bound to this card is removed for some
       |	   reason the component->dev is released
       |	c) That component is re-registered
       v	d) ASoC calls snd_soc_try_rebind_card()
      
      a) points dlc->dai_name to dai->name. b) releases all resource of the
      old DAI. c) creates new DAI structure. In result d) can not use
      dlc->dai_name to add new created DAI.
      
      So it's reasonable that prefer to return dai->driver->name in
      snd_soc_dai_name_get() because dai->driver is a pre-defined global
      variable. Also update snd_soc_is_matching_dai() for alignment.
      Signed-off-by: default avatarChancel Liu <chancel.liu@nxp.com>
      Link: https://msgid.link/r/20240304072128.2845432-1-chancel.liu@nxp.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      755bb9a4