Skip to content

Commit

Permalink
ASoC: tas2562: Add voltage sense slot configuration
Browse files Browse the repository at this point in the history
Add Vsense slot configuration based on the device tree.  Adding this
property enables the slot programming to be moved to the tdm_set_slot
callback.  This in affect sets the slots for the Isense and Vsense and
enabling this these modes are now based on whether these features were
powered on or not.

Signed-off-by: Dan Murphy <dmurphy@ti.com>
Link: https://lore.kernel.org/r/20200626154143.20351-3-dmurphy@ti.com
Signed-off-by: Mark Brown <broonie@kernel.org>
  • Loading branch information
Dan Murphy authored and Mark Brown committed Jun 29, 2020
1 parent d7bd40a commit 09ed395
Showing 1 changed file with 51 additions and 14 deletions.
65 changes: 51 additions & 14 deletions sound/soc/codecs/tas2562.c
Original file line number Diff line number Diff line change
@@ -250,52 +250,73 @@ static int tas2562_set_dai_tdm_slot(struct snd_soc_dai *dai,
if (ret < 0)
return ret;

ret = snd_soc_component_update_bits(component, TAS2562_TDM_CFG5,
TAS2562_TDM_CFG5_VSNS_SLOT_MASK,
tas2562->v_sense_slot);
if (ret < 0)
return ret;

ret = snd_soc_component_update_bits(component, TAS2562_TDM_CFG6,
TAS2562_TDM_CFG6_ISNS_SLOT_MASK,
tas2562->i_sense_slot);
if (ret < 0)
return ret;

return 0;
}

static int tas2562_set_bitwidth(struct tas2562_data *tas2562, int bitwidth)
{
int ret;
int val;
int sense_en;

switch (bitwidth) {
case SNDRV_PCM_FORMAT_S16_LE:
snd_soc_component_update_bits(tas2562->component,
TAS2562_TDM_CFG2,
TAS2562_TDM_CFG2_RXWLEN_MASK,
TAS2562_TDM_CFG2_RXWLEN_16B);
tas2562->v_sense_slot = tas2562->i_sense_slot + 2;
break;
case SNDRV_PCM_FORMAT_S24_LE:
snd_soc_component_update_bits(tas2562->component,
TAS2562_TDM_CFG2,
TAS2562_TDM_CFG2_RXWLEN_MASK,
TAS2562_TDM_CFG2_RXWLEN_24B);
tas2562->v_sense_slot = tas2562->i_sense_slot + 4;
break;
case SNDRV_PCM_FORMAT_S32_LE:
snd_soc_component_update_bits(tas2562->component,
TAS2562_TDM_CFG2,
TAS2562_TDM_CFG2_RXWLEN_MASK,
TAS2562_TDM_CFG2_RXWLEN_32B);
tas2562->v_sense_slot = tas2562->i_sense_slot + 4;
break;

default:
dev_info(tas2562->dev, "Unsupported bitwidth format\n");
return -EINVAL;
}

ret = snd_soc_component_update_bits(tas2562->component,
TAS2562_TDM_CFG5,
TAS2562_TDM_CFG5_VSNS_EN | TAS2562_TDM_CFG5_VSNS_SLOT_MASK,
TAS2562_TDM_CFG5_VSNS_EN | tas2562->v_sense_slot);
val = snd_soc_component_read(tas2562->component, TAS2562_PWR_CTRL);
if (val < 0)
return val;

if (val & (1 << TAS2562_VSENSE_POWER_EN))
sense_en = 0;
else
sense_en = TAS2562_TDM_CFG5_VSNS_EN;

ret = snd_soc_component_update_bits(tas2562->component, TAS2562_TDM_CFG5,
TAS2562_TDM_CFG5_VSNS_EN, sense_en);
if (ret < 0)
return ret;

ret = snd_soc_component_update_bits(tas2562->component,
TAS2562_TDM_CFG6,
TAS2562_TDM_CFG6_ISNS_EN | TAS2562_TDM_CFG6_ISNS_SLOT_MASK,
TAS2562_TDM_CFG6_ISNS_EN | tas2562->i_sense_slot);
if (val & (1 << TAS2562_ISENSE_POWER_EN))
sense_en = 0;
else
sense_en = TAS2562_TDM_CFG6_ISNS_EN;

ret = snd_soc_component_update_bits(tas2562->component, TAS2562_TDM_CFG6,
TAS2562_TDM_CFG6_ISNS_EN, sense_en);
if (ret < 0)
return ret;

@@ -669,9 +690,25 @@ static int tas2562_parse_dt(struct tas2562_data *tas2562)

ret = fwnode_property_read_u32(dev->fwnode, "ti,imon-slot-no",
&tas2562->i_sense_slot);
if (ret)
dev_err(dev, "Looking up %s property failed %d\n",
"ti,imon-slot-no", ret);
if (ret) {
dev_err(dev, "Property %s is missing setting default slot\n",
"ti,imon-slot-no");
tas2562->i_sense_slot = 0;
}


ret = fwnode_property_read_u32(dev->fwnode, "ti,vmon-slot-no",
&tas2562->v_sense_slot);
if (ret) {
dev_info(dev, "Property %s is missing setting default slot\n",
"ti,vmon-slot-no");
tas2562->v_sense_slot = 2;
}

if (tas2562->v_sense_slot < tas2562->i_sense_slot) {
dev_err(dev, "Vsense slot must be greater than Isense slot\n");
return -EINVAL;
}

return ret;
}

0 comments on commit 09ed395

Please sign in to comment.