]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
ASoC: cs35l35: Add for configuring drive mode in unused slots
authorCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Wed, 8 Mar 2017 16:42:49 +0000 (16:42 +0000)
committerMark Brown <broonie@kernel.org>
Mon, 13 Mar 2017 16:09:17 +0000 (16:09 +0000)
Add support for setting how the I2S pins are driven in unused slots,
currently the chip will just use the default of drive 0, however this
causes issues when multiple devices are attached to the same bus.

Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com>
Acked-by: Brian Austin <brian.austin@cirrus.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
include/sound/cs35l35.h
sound/soc/codecs/cs35l35.c
sound/soc/codecs/cs35l35.h

index de92e452bf934f31c461136d35b041016889c522..983c610eba2e0243652cfc3298ff06beb1429a23 100644 (file)
@@ -80,6 +80,8 @@ struct cs35l35_platform_data {
        bool stereo;
        /* serial port drive strength */
        int sp_drv_str;
+       /* serial port drive in unused slots */
+       int sp_drv_unused;
        /* Boost Power Down with FET */
        bool bst_pdn_fet_on;
        /* Boost Voltage : used if ClassH Algo Enabled */
index 48b45dc904ea80dd03f405cd6ce09e68d3ddcab1..5a9fe5addb8641d792257365a45053b6bab7e0eb 100644 (file)
@@ -789,6 +789,11 @@ static int cs35l35_codec_probe(struct snd_soc_codec *codec)
                                CS35L35_SP_DRV_MASK,
                                cs35l35->pdata.sp_drv_str <<
                                CS35L35_SP_DRV_SHIFT);
+       if (cs35l35->pdata.sp_drv_unused)
+               regmap_update_bits(cs35l35->regmap, CS35L35_SP_FMT_CTL3,
+                                  CS35L35_SP_I2S_DRV_MASK,
+                                  cs35l35->pdata.sp_drv_unused <<
+                                  CS35L35_SP_I2S_DRV_SHIFT);
 
        if (classh->classh_algo_enable) {
                if (classh->classh_bst_override)
@@ -1169,6 +1174,8 @@ static int cs35l35_handle_of_data(struct i2c_client *i2c_client,
 
        if (of_property_read_u32(np, "cirrus,sp-drv-strength", &val32) >= 0)
                pdata->sp_drv_str = val32;
+       if (of_property_read_u32(np, "cirrus,sp-drv-unused", &val32) >= 0)
+               pdata->sp_drv_unused = val32 | CS35L35_VALID_PDATA;
 
        pdata->stereo = of_property_read_bool(np, "cirrus,stereo-config");
 
index e27a7fef5fb153d5a8c25f7b88428d53ec201ab7..c203081fc94c3bff2d1343b44b50a69655a27030 100644 (file)
 #define CS35L35_AMP_GAIN_ZC_MASK       0x10
 #define CS35L35_AMP_GAIN_ZC_SHIFT      4
 
+/* CS35L35_SP_FMT_CTL3 */
+#define CS35L35_SP_I2S_DRV_MASK                0x03
+#define CS35L35_SP_I2S_DRV_SHIFT       0
+
 /* Class H Algorithm Control */
 #define CS35L35_CH_STEREO_MASK         0x40
 #define CS35L35_CH_STEREO_SHIFT                6