summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLinux Build Service Account <lnxbuild@localhost>2016-08-29 00:49:29 -0700
committerGerrit - the friendly Code Review server <code-review@localhost>2016-08-29 00:49:28 -0700
commit436eeda4f16fcd12f1a8be22866969066c164e94 (patch)
treef718a497dfba31b989dd2c13be0d96534987714b
parent37d7004cec12489cd6ddba1b10f0c534f281e3a5 (diff)
parentb428b24214c2d4140b2e066a8dc250f55bcd55e4 (diff)
Merge "drivers: mfd: Add 1.6MHz clk support for wcd934x codec"
-rw-r--r--drivers/mfd/wcd9xxx-utils.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/drivers/mfd/wcd9xxx-utils.c b/drivers/mfd/wcd9xxx-utils.c
index 38286831a02c..fab594992df3 100644
--- a/drivers/mfd/wcd9xxx-utils.c
+++ b/drivers/mfd/wcd9xxx-utils.c
@@ -265,8 +265,17 @@ static u32 wcd9xxx_validate_dmic_sample_rate(struct device *dev,
__func__, div_factor, mclk_rate);
break;
case 6:
- /* DIV 6 is valid only for 12.288 MCLK */
- if (mclk_rate != WCD9XXX_MCLK_CLK_12P288MHZ)
+ /*
+ * DIV 6 is valid for both 9.6MHz and 12.288MHz
+ * MCLK on Tavil. Older codecs support DIV6 only
+ * for 12.288MHz MCLK.
+ */
+ if ((mclk_rate == WCD9XXX_MCLK_CLK_9P6HZ) &&
+ (of_device_is_compatible(dev->of_node,
+ "qcom,tavil-slim-pgd")))
+ dev_dbg(dev, "%s: DMIC_DIV = %u, mclk_rate = %u\n",
+ __func__, div_factor, mclk_rate);
+ else if (mclk_rate != WCD9XXX_MCLK_CLK_12P288MHZ)
goto undefined_rate;
break;
default: