Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 14a998be authored by Jyri Sarha's avatar Jyri Sarha Committed by Mark Brown
Browse files

ASoC: davinci-mcasp: Get rid of bclk_lrclk_ratio in private data



The slot_width is for essentially same thing. Instead of storing
bclk_lrclk_ratio, just store the slot_width. Comments has been updated
accordingly and some variable names changed to more descriptive.

Signed-off-by: default avatarJyri Sarha <jsarha@ti.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent dd55ff83
Loading
Loading
Loading
Loading
+31 −25
Original line number Original line Diff line number Diff line
@@ -87,7 +87,6 @@ struct davinci_mcasp {
	u8	*serial_dir;
	u8	*serial_dir;
	u8	version;
	u8	version;
	u8	bclk_div;
	u8	bclk_div;
	u16	bclk_lrclk_ratio;
	int	streams;
	int	streams;
	u32	irq_request[2];
	u32	irq_request[2];
	int	dma_request[2];
	int	dma_request[2];
@@ -558,8 +557,21 @@ static int __davinci_mcasp_set_clkdiv(struct snd_soc_dai *dai, int div_id,
			mcasp->bclk_div = div;
			mcasp->bclk_div = div;
		break;
		break;


	case 2:		/* BCLK/LRCLK ratio */
	case 2:	/*
		mcasp->bclk_lrclk_ratio = div;
		 * BCLK/LRCLK ratio descries how many bit-clock cycles
		 * fit into one frame. The clock ratio is given for a
		 * full period of data (for I2S format both left and
		 * right channels), so it has to be divided by number
		 * of tdm-slots (for I2S - divided by 2).
		 * Instead of storing this ratio, we calculate a new
		 * tdm_slot width by dividing the the ratio by the
		 * number of configured tdm slots.
		 */
		mcasp->slot_width = div / mcasp->tdm_slots;
		if (div % mcasp->tdm_slots)
			dev_warn(mcasp->dev,
				 "%s(): BCLK/LRCLK %d is not divisible by %d tdm slots",
				 __func__, div, mcasp->tdm_slots);
		break;
		break;


	default:
	default:
@@ -677,11 +689,13 @@ static int davinci_mcasp_set_tdm_slot(struct snd_soc_dai *dai,
}
}


static int davinci_config_channel_size(struct davinci_mcasp *mcasp,
static int davinci_config_channel_size(struct davinci_mcasp *mcasp,
				       int word_length)
				       int sample_width)
{
{
	u32 fmt;
	u32 fmt;
	u32 tx_rotate = (word_length / 4) & 0x7;
	u32 tx_rotate = (sample_width / 4) & 0x7;
	u32 mask = (1ULL << word_length) - 1;
	u32 mask = (1ULL << sample_width) - 1;
	u32 slot_width = sample_width;

	/*
	/*
	 * For captured data we should not rotate, inversion and masking is
	 * For captured data we should not rotate, inversion and masking is
	 * enoguh to get the data to the right position:
	 * enoguh to get the data to the right position:
@@ -694,31 +708,23 @@ static int davinci_config_channel_size(struct davinci_mcasp *mcasp,
	u32 rx_rotate = 0;
	u32 rx_rotate = 0;


	/*
	/*
	 * if s BCLK-to-LRCLK ratio has been configured via the set_clkdiv()
	 * Setting the tdm slot width either with set_clkdiv() or
	 * callback, take it into account here. That allows us to for example
	 * set_tdm_slot() allows us to for example send 32 bits per
	 * send 32 bits per channel to the codec, while only 16 of them carry
	 * channel to the codec, while only 16 of them carry audio
	 * audio payload.
	 * payload.
	 * The clock ratio is given for a full period of data (for I2S format
	 * both left and right channels), so it has to be divided by number of
	 * tdm-slots (for I2S - divided by 2).
	 */
	 */
	if (mcasp->bclk_lrclk_ratio) {
	if (mcasp->slot_width) {
		u32 slot_length = mcasp->bclk_lrclk_ratio / mcasp->tdm_slots;

		/*
		/*
		 * When we have more bclk then it is needed for the data, we
		 * When we have more bclk then it is needed for the
		 * need to use the rotation to move the received samples to have
		 * data, we need to use the rotation to move the
		 * correct alignment.
		 * received samples to have correct alignment.
		 */
		 */
		rx_rotate = (slot_length - word_length) / 4;
		slot_width = mcasp->slot_width;
		word_length = slot_length;
		rx_rotate = (slot_width - sample_width) / 4;
	} else if (mcasp->slot_width) {
		rx_rotate = (mcasp->slot_width - word_length) / 4;
		word_length = mcasp->slot_width;
	}
	}


	/* mapping of the XSSZ bit-field as described in the datasheet */
	/* mapping of the XSSZ bit-field as described in the datasheet */
	fmt = (word_length >> 1) - 1;
	fmt = (slot_width >> 1) - 1;


	if (mcasp->op_mode != DAVINCI_MCASP_DIT_MODE) {
	if (mcasp->op_mode != DAVINCI_MCASP_DIT_MODE) {
		mcasp_mod_bits(mcasp, DAVINCI_MCASP_RXFMT_REG, RXSSZ(fmt),
		mcasp_mod_bits(mcasp, DAVINCI_MCASP_RXFMT_REG, RXSSZ(fmt),