linux_dsm_epyc7002/drivers/gpu/drm/i2c
Russell King a03a915b83 drm/i2c: tda998x: derive CTS_N value from aclk sample rate ratio
The TDA998x derives the CTS value using the supplied I2S bit clock
(ACLK, in TDA998x parlence) rather than 128·fs.  TDA998x uses two
constants named m and k in the CTS generator such that we have this
relationship between the I2S source ACLK and the sink fs:

	128·fs_sink = ACLK·m / k

Where ACLK = aclk_ratio·fs_source.

When audio support was originally added, we supported a fixed ratio
of 64·fs, intending to support the Kirkwood I2S on Dove.  However,
when hdmi-codec support was added, this was changed to scale the
ratio with the sample width, which would've broken its use with
Kirkwood I2S.

We are now starting to see other users whose I2S blocks send at 64·fs
for 16-bit samples, so we need to reinstate the support for the fixed
ratio I2S bit clock.

This commit takes a step towards supporting these configurations by
selecting the CTS_N register m and k values based on the bit clock
ratio.  However, as the driver is not given the bit clock ratio from
ALSA, continue deriving this from the sample width.  This will be
addressed in a later commit.

Tested-by: Sven Van Asbroeck <TheSven73@gmail.com>
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
2019-06-13 21:54:41 +01:00
..
ch7006_drv.c drm/ch7006: Stop using drm_crtc_force_disable 2019-01-11 15:56:40 +01:00
ch7006_mode.c drm/i2c/ch7006: Constify ch7006_tv_norms[] and ch7006_modes[] 2015-09-08 13:45:53 +02:00
ch7006_priv.h drm: Split out drm_probe_helper.h 2019-01-24 13:20:42 +01:00
Kconfig drm/i2c: tda998x: add CEC support 2018-04-24 10:44:32 +01:00
Makefile drm/i2c: tda9950: add CEC driver 2018-04-24 10:44:25 +01:00
sil164_drv.c drm: Split out drm_probe_helper.h 2019-01-24 13:20:42 +01:00
tda998x_drv.c drm/i2c: tda998x: derive CTS_N value from aclk sample rate ratio 2019-06-13 21:54:41 +01:00
tda9950.c Merge branch 'drm-tda9950-fixes' of git://git.armlinux.org.uk/~rmk/linux-arm into drm-fixes 2018-10-04 10:32:14 +10:00