The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/contrib/device-tree/Bindings/sound/cs35l36.txt

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 CS35L36 Speaker Amplifier
    2 
    3 Required properties:
    4 
    5   - compatible : "cirrus,cs35l36"
    6 
    7   - reg : the I2C address of the device for I2C
    8 
    9   - VA-supply, VP-supply : power supplies for the device,
   10   as covered in
   11   Documentation/devicetree/bindings/regulator/regulator.txt.
   12 
   13   - cirrus,boost-ctl-millivolt : Boost Voltage Value.  Configures the boost
   14   converter's output voltage in mV. The range is from 2550mV to 12000mV with
   15   increments of 50mV.
   16   (Default) VP
   17 
   18   - cirrus,boost-peak-milliamp : Boost-converter peak current limit in mA.
   19   Configures the peak current by monitoring the current through the boost FET.
   20   Range starts at 1600mA and goes to a maximum of 4500mA with increments of
   21   50mA.
   22   (Default) 4.50 Amps
   23 
   24   - cirrus,boost-ind-nanohenry : Inductor estimation LBST reference value.
   25   Seeds the digital boost converter's inductor estimation block with the initial
   26   inductance value to reference.
   27 
   28   1000 = 1uH (Default)
   29   1200 = 1.2uH
   30 
   31 Optional properties:
   32   - cirrus,multi-amp-mode : Boolean to determine if there are more than
   33   one amplifier in the system. If more than one it is best to Hi-Z the ASP
   34   port to prevent bus contention on the output signal
   35 
   36   - cirrus,boost-ctl-select : Boost conerter control source selection.
   37   Selects the source of the BST_CTL target VBST voltage for the boost
   38   converter to generate.
   39   0x00 - Control Port Value
   40   0x01 - Class H Tracking (Default)
   41   0x10 - MultiDevice Sync Value
   42 
   43   - cirrus,amp-pcm-inv : Boolean to determine Amplifier will invert incoming
   44   PCM data
   45 
   46   - cirrus,imon-pol-inv : Boolean to determine Amplifier will invert the
   47   polarity of outbound IMON feedback data
   48 
   49   - cirrus,vmon-pol-inv : Boolean to determine Amplifier will invert the
   50   polarity of outbound VMON feedback data
   51 
   52   - cirrus,dcm-mode-enable : Boost converter automatic DCM Mode enable.
   53   This enables the digital boost converter to operate in a low power
   54   (Discontinuous Conduction) mode during low loading conditions.
   55 
   56   - cirrus,weak-fet-disable : Boolean : The strength of the output drivers is
   57   reduced when operating in a Weak-FET Drive Mode and must not be used to drive
   58   a large load.
   59 
   60   - cirrus,classh-wk-fet-delay :  Weak-FET entry delay. Controls the delay
   61   (in ms) before the Class H algorithm switches to the weak-FET voltage
   62   (after the audio falls and remains below the value specified in WKFET_AMP_THLD).
   63 
   64   0 = 0ms
   65   1 = 5ms
   66   2 = 10ms
   67   3 = 50ms
   68   4 = 100ms (Default)
   69   5 = 200ms
   70   6 = 500ms
   71   7 = 1000ms
   72 
   73   - cirrus,classh-weak-fet-thld-millivolt : Weak-FET amplifier drive threshold.
   74   Configures the signal threshold at which the PWM output stage enters
   75   weak-FET operation. The range is 50mV to 700mV in 50mV increments.
   76 
   77   - cirrus,temp-warn-threshold :  Amplifier overtemperature warning threshold.
   78   Configures the threshold at which the overtemperature warning condition occurs.
   79   When the threshold is met, the overtemperature warning attenuation is applied
   80   and the TEMP_WARN_EINT interrupt status bit is set.
   81   If TEMP_WARN_MASK = 0, INTb is asserted.
   82 
   83   0 = 105C
   84   1 = 115C
   85   2 = 125C (Default)
   86   3 = 135C
   87 
   88   - cirrus,irq-drive-select : Selects the driver type of the selected interrupt
   89   output.
   90 
   91   0 = Open-drain
   92   1 = Push-pull (Default)
   93 
   94   - cirrus,irq-gpio-select : Selects the pin to serve as the programmable
   95   interrupt output.
   96 
   97   0 = PDM_DATA / SWIRE_SD / INT (Default)
   98   1 = GPIO
   99 
  100 Optional properties for the "cirrus,vpbr-config" Sub-node
  101 
  102   - cirrus,vpbr-en : VBST brownout prevention enable. Configures whether the
  103   VBST brownout prevention algorithm is enabled or disabled.
  104 
  105   0 = VBST brownout prevention disabled (default)
  106   1 = VBST brownout prevention enabled
  107 
  108   See Section 7.31.1 VPBR Config for configuration options & further details
  109 
  110   - cirrus,vpbr-thld : Initial VPBR threshold. Configures the VP brownout
  111   threshold voltage
  112 
  113   - cirrus,cirrus,vpbr-atk-rate : Attenuation attack step rate. Configures the
  114   amount delay between consecutive volume attenuation steps when a brownout
  115   condition is present and the VP brownout condition is in an attacking state.
  116 
  117   - cirrus,vpbr-atk-vol : VP brownout prevention step size. Configures the VP
  118   brownout prevention attacking attenuation step size when operating in either
  119   digital volume or analog gain modes.
  120 
  121   - cirrus,vpbr-max-attn : Maximum attenuation that the VP brownout prevention
  122   can apply to the audio signal.
  123 
  124   - cirrus,vpbr-wait : Configures the delay time between a brownout condition
  125   no longer being present and the VP brownout prevention entering an attenuation
  126   release state.
  127 
  128   - cirrus,vpbr-rel-rate : Attenuation release step rate. Configures the delay
  129   between consecutive volume attenuation release steps when a brownout condition
  130   is not longer present and the VP brownout is in an attenuation release state.
  131 
  132   - cirrus,vpbr-mute-en : During the attack state, if the vpbr-max-attn value
  133   is reached, the error condition still remains, and this bit is set, the audio
  134   is muted.
  135 
  136 Example:
  137 
  138 cs35l36: cs35l36@40 {
  139         compatible = "cirrus,cs35l36";
  140         reg = <0x40>;
  141         VA-supply = <&dummy_vreg>;
  142         VP-supply = <&dummy_vreg>;
  143         reset-gpios = <&gpio0 54 0>;
  144         interrupt-parent = <&gpio8>;
  145         interrupts = <3 IRQ_TYPE_LEVEL_LOW>;
  146 
  147         cirrus,boost-ind-nanohenry = <1000>;
  148         cirrus,boost-ctl-millivolt = <10000>;
  149         cirrus,boost-peak-milliamp = <4500>;
  150         cirrus,boost-ctl-select = <0x00>;
  151         cirrus,weak-fet-delay = <0x04>;
  152         cirrus,weak-fet-thld = <0x01>;
  153         cirrus,temp-warn-threshold = <0x01>;
  154         cirrus,multi-amp-mode;
  155         cirrus,irq-drive-select = <0x01>;
  156         cirrus,irq-gpio-select = <0x01>;
  157 
  158         cirrus,vpbr-config {
  159                 cirrus,vpbr-en = <0x00>;
  160                 cirrus,vpbr-thld = <0x05>;
  161                 cirrus,vpbr-atk-rate = <0x02>;
  162                 cirrus,vpbr-atk-vol = <0x01>;
  163                 cirrus,vpbr-max-attn = <0x09>;
  164                 cirrus,vpbr-wait = <0x01>;
  165                 cirrus,vpbr-rel-rate = <0x05>;
  166                 cirrus,vpbr-mute-en = <0x00>;
  167         };
  168 };

Cache object: 8be9ddcd27f6abd5fd21856d22f8f551


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.