1. 18 2月, 2012 4 次提交
    • M
      ASoC: dapm: Implement and instantiate DAI widgets · 888df395
      Mark Brown 提交于
      In order to allow us to do smarter things with DAI links create DAPM
      widgets which directly represent the DAIs in the DAPM graph. These are
      automatically created from the DAIs as we probe the card with references
      held in both directions between the widget and the DAI.
      
      The widgets are not made available for direct instantiation by drivers,
      they are created automatically from the DAIs.  Drivers should be updated
      to create stream routes using DAPM maps rather than by annotating AIF
      and DAC widgets with streams.
      
      In order to ease transition to this model from existing drivers we
      automatically create DAPM routes between the DAI widgets and the existing
      stream widgets which are started and stopped by the DAI widgets, though
      the old stream handling mechanism is still in place.  This also has the
      nice effect of removing non-DAPM devices as any device with a DAI
      acquires a widget automatically which will allow future simplifications
      to the core DAPM logic.
      
      The intention is that in future the AIF and DAI widgets will gain the
      ability to interact such that we are able to manage activity on
      individual channels independantly rather than powering up and down the
      entire AIF as we do currently.
      
      Currently we only generate these for CODECs, mostly as I have no systems
      with non-CODEC DAPM to integrate with. It should be a simple matter of
      programming to add the additional hookup for these.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@ti.com>
      888df395
    • M
      ASoC: dapm: Constify lots of names that are never modified · 3056557f
      Mark Brown 提交于
      Neater and avoids warnings when used in other places where const strings
      are desired.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@ti.com>
      3056557f
    • M
      ASoC: dapm: Supply the DAI and substream when calling stream events · 7bd3a6f3
      Mark Brown 提交于
      In order to allow us to do something smarter than iterate through widgets
      doing strcmp() to work out what to power up for stream events change the
      interface used to generate them to be based on the combination of a DAI
      and a stream direction rather than just a simple string identifying the
      stream.
      
      At some point we'll probably want a set of channels too.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@ti.com>
      7bd3a6f3
    • M
      ASoC: dapm: Unexport snd_soc_dapm_new_control() · ce0e9f0e
      Mark Brown 提交于
      Everything now uses snd_soc_dapm_new_controls() instead so we don't need
      to make it part of the external API.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@ti.com>
      ce0e9f0e
  2. 07 2月, 2012 1 次提交
  3. 27 1月, 2012 1 次提交
    • M
      ASoC: Provide REGULATOR_SUPPLY widget type · 62ea874a
      Mark Brown 提交于
      Modern devices allow systems to enable and disable individual supplies on
      the device, allowing additional power saving by switching off regulators
      which power portions of the device which are not currently in use. Add a
      new SND_SOC_DAPM_REGULATOR_SUPPLY widget type factoring out the code for
      managing such widgets from individual drivers.
      
      The widget name will be used as the supply name when requesting the
      regulator from the regulator API.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@ti.com>
      62ea874a
  4. 02 12月, 2011 1 次提交
  5. 24 11月, 2011 1 次提交
    • S
      ASoC: Implement fully_routed card property · 1633281b
      Stephen Warren 提交于
      A card is fully routed if the DAPM route table describes all connections on
      the board.
      
      When a card is fully routed, some operations can be automated by the ASoC
      core. The first, and currently only, such operation is described below, and
      implemented by this patch.
      
      Codecs often have a large number of external pins, and not all of these pins
      will be connected on all board designs. Some machine drivers therefore call
      snd_soc_dapm_nc_pin() for all the unused pins, in order to tell the ASoC core
      never to activate them.
      
      However, when a card is fully routed, the information needed to derive the
      set of unused pins is present in card->dapm_routes. In this case, have
      the ASoC core automatically call snd_soc_dapm_nc_pin() for each unused
      codec pin.
      
      This has been tested with soc/tegra/tegra_wm8903.c and soc/tegra/trimslice.c.
      Signed-off-by: NStephen Warren <swarren@nvidia.com>
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      1633281b
  6. 10 10月, 2011 1 次提交
  7. 09 10月, 2011 1 次提交
    • M
      ASoC: Cache connected input and output recursions · 024dc078
      Mark Brown 提交于
      The number of connected input and output endpoints for a given widgets
      can't change during a DAPM run so there is no need to redo the recursion
      through branches of the tree we've already visited. Doing this on one of
      my test systems gives an improvement of:
      
               Power    Path   Neighbour
      Before:  63       607    731
      After:   63       141    181
      
      which scales up well as more widgets are involved in paths.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      024dc078
  8. 05 10月, 2011 1 次提交
    • M
      ASoC: Only run power_check() on a widget once per run · 9b8a83b2
      Mark Brown 提交于
      Some widgets will get power_check() run on them more than once during a
      DAPM run, most commonly due to supply widgets checking to see if their
      consumers are powered up. It's wasteful to do this so cache the result
      of power_check() during a run. For one system I tested this on I got an
      improvement of:
      
                 Power    Path   Neighbour
      Before:    106      970    1186
      After:     69       727    905
      
      from this.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      9b8a83b2
  9. 04 10月, 2011 1 次提交
    • M
      ASoC: Do DAPM power checks only for widgets changed since last run · db432b41
      Mark Brown 提交于
      In order to reduce the number of DAPM power checks we run keep a list of
      widgets which have been changed since the last DAPM run and iterate over
      that rather than the full widget list. Whenever we change the power state
      for a widget we add all the source and sink widgets it has to the dirty
      list, ensuring that all widgets in the path are checked.
      
      This covers more widgets than we need to as some of the neighbour widgets
      won't be connected but it's simpler as a first step. On one system I tried
      this gave:
      
                 Power    Path   Neighbour
      Before:    207      1939   2461
      After:     114      1066   1327
      
      which seems useful.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      db432b41
  10. 23 9月, 2011 1 次提交
  11. 21 9月, 2011 1 次提交
    • M
      ASoC: Trace and collect statistics for DAPM graph walking · de02d078
      Mark Brown 提交于
      One of the longest standing areas for improvement in ASoC has been the
      DAPM algorithm - it repeats the same checks many times whenever it is run
      and makes no effort to limit the areas of the graph it checks meaning we
      do an awful lot of walks over the full graph. This has never mattered too
      much as the size of the graph has generally been small in relation to the
      size of the devices supported and the speed of CPUs but it is annoying.
      
      In preparation for work on improving this insert a trace point after the
      graph walk has been done. This gives us specific timing information for
      the walk, and in order to give quantifiable (non-benchmark) numbers also
      count every time we check a link or check the power for a widget and report
      those numbers. Substantial changes in the algorithm may require tweaks to
      the stats but they should be useful for simpler things.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      de02d078
  12. 26 7月, 2011 1 次提交
  13. 21 7月, 2011 1 次提交
  14. 06 7月, 2011 1 次提交
  15. 14 6月, 2011 2 次提交
  16. 07 6月, 2011 1 次提交
  17. 04 5月, 2011 4 次提交
  18. 20 4月, 2011 1 次提交
  19. 31 3月, 2011 1 次提交
  20. 24 3月, 2011 1 次提交
  21. 27 1月, 2011 1 次提交
  22. 25 1月, 2011 1 次提交
  23. 19 1月, 2011 2 次提交
    • M
      ASoC: Provide per widget type callback when executing DAPM sequences · 474b62d6
      Mark Brown 提交于
      Many modern devices have features such as DC servos which take time to start.
      Currently these are handled by per-widget events but this makes it difficult
      to paralleise operations on multiple widgets, meaning delays can end up
      being needlessly serialised. By providing a callback to drivers when all
      widgets of a given type have been handled during a DAPM sequence the core
      allows drivers to start operations separately and wait for them to complete
      much more simply.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@slimlogic.co.uk>
      474b62d6
    • M
      ASoC: Add support for sequencing within · 20e4859d
      Mark Brown 提交于
      With larger devices there may be many widgets of the same type in series
      in an audio path. Allow drivers to specify an additional level of ordering
      within each widget type by adding a subsequence number to widgets and then
      splitting operations on widgets so that widgets of the same type but
      different sequence numbers are processed separately.  A typical example
      would be a supply widget which requires that another widget be enabled
      to provide power or clocking.
      
      SND_SOC_DAPM_PGA_S() and SND_SOC_DAPM_SUPPLY_S() macros are provided
      allowing this to be used with PGAs and supplies as these are the most
      commonly affected widgets.
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      Acked-by: NLiam Girdwood <lrg@slimlogic.co.uk>
      20e4859d
  24. 18 12月, 2010 1 次提交
  25. 17 12月, 2010 1 次提交
  26. 16 12月, 2010 3 次提交
    • J
      ASoC: Extend DAPM to handle power changes on cross-device paths · 7be31be8
      Jarkko Nikula 提交于
      Power change event like stream start/stop or kcontrol change in a
      cross-device path originates from one device but codec bias and widget power
      changes must be populated to another devices on that path as well.
      
      This patch modifies the dapm_power_widgets so that all the widgets on a
      sound card are checked for a power change, not just those that are specific
      to originating device. Also bias management is extended to check all the
      devices. Only exception in bias management are widgetless codecs whose bias
      state is changed only if power change is originating from that context.
      
      DAPM context test is added to dapm_seq_run to take care of if power sequence
      extends to an another device which requires separate register writes.
      Signed-off-by: NJarkko Nikula <jhnikula@gmail.com>
      Acked-by: NLiam Girdwood <lrg@slimlogic.co.uk>
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      7be31be8
    • J
      ASoC: Move widgets from DAPM context to snd_soc_card · 97c866de
      Jarkko Nikula 提交于
      Decoupling widgets from DAPM context is required when extending the ASoC
      core to cross-device paths. Even the list of widgets are now kept in
      struct snd_soc_card, the widget listing in sysfs and debugs remain sorted
      per device.
      
      This patch makes possible to build cross-device paths but does not extend
      yet the DAPM to handle codec bias and widget power changes of an another
      device.
      
      Cross-device paths are registered by listing the widgets from device A in
      a map for device B. In case of conflicting widget names between the devices,
      a uniform name prefix is needed to separate them. See commit ead9b919
      "ASoC: Add optional name_prefix for kcontrol, widget and route names" for
      help.
      
      An example below shows a path that connects MONO out of A into Line In of B:
      
      static const struct snd_soc_dapm_route mapA[] = {
      	{"MONO", NULL, "DAC"},
      };
      
      static const struct snd_soc_dapm_route mapB[] = {
      	{"Line In", NULL, "MONO"},
      };
      Signed-off-by: NJarkko Nikula <jhnikula@gmail.com>
      Acked-by: NLiam Girdwood <lrg@slimlogic.co.uk>
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      97c866de
    • J
      ASoC: Move DAPM paths from DAPM context to snd_soc_card · 8ddab3f5
      Jarkko Nikula 提交于
      Decoupling DAPM paths from DAPM context is a first prerequisite when
      extending ASoC core to cross-device paths. This patch is almost a nullop and
      does not allow to construct cross-device setup but the path clean-up part in
      dapm_free_widgets is prepared to remove cross-device paths between a device
      being removed and others.
      Signed-off-by: NJarkko Nikula <jhnikula@gmail.com>
      Acked-by: NLiam Girdwood <lrg@slimlogic.co.uk>
      Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
      8ddab3f5
  27. 15 12月, 2010 1 次提交
  28. 14 12月, 2010 1 次提交
  29. 22 11月, 2010 1 次提交
  30. 06 11月, 2010 1 次提交