0d3f01dcdc
After carefully checking, it appears that both tdmout and tdmin require the
rising edge of the sclk they get to be synchronized with the frame sync
event (which should be a rising edge of lrclk).
TDMIN was improperly set before this patch. Remove the sclk_invert quirk
which is no longer needed and fix the sclk phase.
Fixes: 1a11d88f49
("ASoC: meson: add tdm formatter base driver")
Signed-off-by: Jerome Brunet <jbrunet@baylibre.com>
Link: https://lore.kernel.org/r/20200729154456.1983396-4-jbrunet@baylibre.com
Signed-off-by: Mark Brown <broonie@kernel.org>
46 lines
1.2 KiB
C
46 lines
1.2 KiB
C
/* SPDX-License-Identifier: (GPL-2.0 OR MIT)
|
|
*
|
|
* Copyright (c) 2018 Baylibre SAS.
|
|
* Author: Jerome Brunet <jbrunet@baylibre.com>
|
|
*/
|
|
|
|
#ifndef _MESON_AXG_TDM_FORMATTER_H
|
|
#define _MESON_AXG_TDM_FORMATTER_H
|
|
|
|
#include "axg-tdm.h"
|
|
|
|
struct platform_device;
|
|
struct regmap;
|
|
struct snd_soc_dapm_widget;
|
|
struct snd_kcontrol;
|
|
|
|
struct axg_tdm_formatter_hw {
|
|
unsigned int skew_offset;
|
|
};
|
|
|
|
struct axg_tdm_formatter_ops {
|
|
struct axg_tdm_stream *(*get_stream)(struct snd_soc_dapm_widget *w);
|
|
void (*enable)(struct regmap *map);
|
|
void (*disable)(struct regmap *map);
|
|
int (*prepare)(struct regmap *map,
|
|
const struct axg_tdm_formatter_hw *quirks,
|
|
struct axg_tdm_stream *ts);
|
|
};
|
|
|
|
struct axg_tdm_formatter_driver {
|
|
const struct snd_soc_component_driver *component_drv;
|
|
const struct regmap_config *regmap_cfg;
|
|
const struct axg_tdm_formatter_ops *ops;
|
|
const struct axg_tdm_formatter_hw *quirks;
|
|
};
|
|
|
|
int axg_tdm_formatter_set_channel_masks(struct regmap *map,
|
|
struct axg_tdm_stream *ts,
|
|
unsigned int offset);
|
|
int axg_tdm_formatter_event(struct snd_soc_dapm_widget *w,
|
|
struct snd_kcontrol *control,
|
|
int event);
|
|
int axg_tdm_formatter_probe(struct platform_device *pdev);
|
|
|
|
#endif /* _MESON_AXG_TDM_FORMATTER_H */
|