Alsa and alsactl: init, store and default configuration of control file












0














The target kernel is: 2.6.35.14 (old) and its running on an embedded platform and the codec is a wm8753.



I am trying to understand how the alsactl system works. I found a file asound.play @ etc/alsa and this is the configuration file the man pages refer to. I am not sure why mine is called asound.play instead of asound.state but running:



#alsactl init
#alsactl -f /etc/alsa/asound.play store


will default the asound.play file. With the customized version sound works but it doesn't with the default configuration. Here is an excerpt from the asound.play file for a default configuration and the custom configuration. Keep in mind this is just one control block of 85:



Default:



control.1 {
comment.access 'read write'
comment.type INTEGER
comment.count 2
comment.range '0 - 255'
comment.dbmin -12750
comment.dbmax 0
iface MIXER
name 'PCM Volume'
value.0 215
value.1 215
}


custom:



control.1 {
comment.access 'read write'
comment.type INTEGER
comment.count 2
comment.range '0 - 255'
iface MIXER
name 'PCM Volume'
value.0 250
value.1 250
}


It isn't obvious to me how the person who originally customized the file knew that she/he needed to get rid of comment.dbmin and dbmax. So how might one go about figuring out how they should be customizing this file so that sound works? Guess and check?










share|improve this question





























    0














    The target kernel is: 2.6.35.14 (old) and its running on an embedded platform and the codec is a wm8753.



    I am trying to understand how the alsactl system works. I found a file asound.play @ etc/alsa and this is the configuration file the man pages refer to. I am not sure why mine is called asound.play instead of asound.state but running:



    #alsactl init
    #alsactl -f /etc/alsa/asound.play store


    will default the asound.play file. With the customized version sound works but it doesn't with the default configuration. Here is an excerpt from the asound.play file for a default configuration and the custom configuration. Keep in mind this is just one control block of 85:



    Default:



    control.1 {
    comment.access 'read write'
    comment.type INTEGER
    comment.count 2
    comment.range '0 - 255'
    comment.dbmin -12750
    comment.dbmax 0
    iface MIXER
    name 'PCM Volume'
    value.0 215
    value.1 215
    }


    custom:



    control.1 {
    comment.access 'read write'
    comment.type INTEGER
    comment.count 2
    comment.range '0 - 255'
    iface MIXER
    name 'PCM Volume'
    value.0 250
    value.1 250
    }


    It isn't obvious to me how the person who originally customized the file knew that she/he needed to get rid of comment.dbmin and dbmax. So how might one go about figuring out how they should be customizing this file so that sound works? Guess and check?










    share|improve this question



























      0












      0








      0







      The target kernel is: 2.6.35.14 (old) and its running on an embedded platform and the codec is a wm8753.



      I am trying to understand how the alsactl system works. I found a file asound.play @ etc/alsa and this is the configuration file the man pages refer to. I am not sure why mine is called asound.play instead of asound.state but running:



      #alsactl init
      #alsactl -f /etc/alsa/asound.play store


      will default the asound.play file. With the customized version sound works but it doesn't with the default configuration. Here is an excerpt from the asound.play file for a default configuration and the custom configuration. Keep in mind this is just one control block of 85:



      Default:



      control.1 {
      comment.access 'read write'
      comment.type INTEGER
      comment.count 2
      comment.range '0 - 255'
      comment.dbmin -12750
      comment.dbmax 0
      iface MIXER
      name 'PCM Volume'
      value.0 215
      value.1 215
      }


      custom:



      control.1 {
      comment.access 'read write'
      comment.type INTEGER
      comment.count 2
      comment.range '0 - 255'
      iface MIXER
      name 'PCM Volume'
      value.0 250
      value.1 250
      }


      It isn't obvious to me how the person who originally customized the file knew that she/he needed to get rid of comment.dbmin and dbmax. So how might one go about figuring out how they should be customizing this file so that sound works? Guess and check?










      share|improve this question















      The target kernel is: 2.6.35.14 (old) and its running on an embedded platform and the codec is a wm8753.



      I am trying to understand how the alsactl system works. I found a file asound.play @ etc/alsa and this is the configuration file the man pages refer to. I am not sure why mine is called asound.play instead of asound.state but running:



      #alsactl init
      #alsactl -f /etc/alsa/asound.play store


      will default the asound.play file. With the customized version sound works but it doesn't with the default configuration. Here is an excerpt from the asound.play file for a default configuration and the custom configuration. Keep in mind this is just one control block of 85:



      Default:



      control.1 {
      comment.access 'read write'
      comment.type INTEGER
      comment.count 2
      comment.range '0 - 255'
      comment.dbmin -12750
      comment.dbmax 0
      iface MIXER
      name 'PCM Volume'
      value.0 215
      value.1 215
      }


      custom:



      control.1 {
      comment.access 'read write'
      comment.type INTEGER
      comment.count 2
      comment.range '0 - 255'
      iface MIXER
      name 'PCM Volume'
      value.0 250
      value.1 250
      }


      It isn't obvious to me how the person who originally customized the file knew that she/he needed to get rid of comment.dbmin and dbmax. So how might one go about figuring out how they should be customizing this file so that sound works? Guess and check?







      linux-kernel audio alsa






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Dec 18 '18 at 21:01

























      asked Dec 18 '18 at 20:14









      Rob

      1065




      1065






















          1 Answer
          1






          active

          oldest

          votes


















          1














          I'd guess that the dbmin/dbmax comments are missing because that file was generated with an older version of the driver that did not yet have dB information.
          Anyway, comments are ignored by alsactl restore, so this does not matter.



          The iface and name entries identify a mixer control; the value values specify the value(s) of that control.



          To get the sound to work, you have to know how these mixer controls affect the hardware. Obviously, whoever created those customized settings did know.






          share|improve this answer





















          • So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
            – Rob
            Dec 18 '18 at 21:46










          • Yes. Yes. That would be the documentation of your embedded platform.
            – CL.
            Dec 18 '18 at 21:55











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "106"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489760%2falsa-and-alsactl-init-store-and-default-configuration-of-control-file%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          1














          I'd guess that the dbmin/dbmax comments are missing because that file was generated with an older version of the driver that did not yet have dB information.
          Anyway, comments are ignored by alsactl restore, so this does not matter.



          The iface and name entries identify a mixer control; the value values specify the value(s) of that control.



          To get the sound to work, you have to know how these mixer controls affect the hardware. Obviously, whoever created those customized settings did know.






          share|improve this answer





















          • So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
            – Rob
            Dec 18 '18 at 21:46










          • Yes. Yes. That would be the documentation of your embedded platform.
            – CL.
            Dec 18 '18 at 21:55
















          1














          I'd guess that the dbmin/dbmax comments are missing because that file was generated with an older version of the driver that did not yet have dB information.
          Anyway, comments are ignored by alsactl restore, so this does not matter.



          The iface and name entries identify a mixer control; the value values specify the value(s) of that control.



          To get the sound to work, you have to know how these mixer controls affect the hardware. Obviously, whoever created those customized settings did know.






          share|improve this answer





















          • So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
            – Rob
            Dec 18 '18 at 21:46










          • Yes. Yes. That would be the documentation of your embedded platform.
            – CL.
            Dec 18 '18 at 21:55














          1












          1








          1






          I'd guess that the dbmin/dbmax comments are missing because that file was generated with an older version of the driver that did not yet have dB information.
          Anyway, comments are ignored by alsactl restore, so this does not matter.



          The iface and name entries identify a mixer control; the value values specify the value(s) of that control.



          To get the sound to work, you have to know how these mixer controls affect the hardware. Obviously, whoever created those customized settings did know.






          share|improve this answer












          I'd guess that the dbmin/dbmax comments are missing because that file was generated with an older version of the driver that did not yet have dB information.
          Anyway, comments are ignored by alsactl restore, so this does not matter.



          The iface and name entries identify a mixer control; the value values specify the value(s) of that control.



          To get the sound to work, you have to know how these mixer controls affect the hardware. Obviously, whoever created those customized settings did know.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Dec 18 '18 at 21:36









          CL.

          2,116913




          2,116913












          • So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
            – Rob
            Dec 18 '18 at 21:46










          • Yes. Yes. That would be the documentation of your embedded platform.
            – CL.
            Dec 18 '18 at 21:55


















          • So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
            – Rob
            Dec 18 '18 at 21:46










          • Yes. Yes. That would be the documentation of your embedded platform.
            – CL.
            Dec 18 '18 at 21:55
















          So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
          – Rob
          Dec 18 '18 at 21:46




          So anything that says comment.(stuff) is insignificant? All I need to worry about is: iface, name, value.0 and value.1? Do you know off hand if there is somewhere I can go to learn how these mixer controls effect the hardware?
          – Rob
          Dec 18 '18 at 21:46












          Yes. Yes. That would be the documentation of your embedded platform.
          – CL.
          Dec 18 '18 at 21:55




          Yes. Yes. That would be the documentation of your embedded platform.
          – CL.
          Dec 18 '18 at 21:55


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.





          Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


          Please pay close attention to the following guidance:


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489760%2falsa-and-alsactl-init-store-and-default-configuration-of-control-file%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Morgemoulin

          Scott Moir

          Souastre