• Peter Ujfalusi's avatar
    ASoC: ti: Add custom machine driver for j721e EVM (CPB and IVI) · 6748d055
    Peter Ujfalusi authored
    The audio support on the board is using pcm3168a codec connected to McASP10
    serializers in parallel setup.
    The pcm3168a SCKI clock is coming via the j721e AUDIO_REFCLK2 pin.
    In order to support 48KHz and 44.1KHz family of sampling rates the parent clock
    for AUDIO_REFCLK2 needs to be changed between PLL4 (for 48KHz) and PLL15 (for
    44.1KHz). The same PLLs are used for McASP10's AUXCLK clock via different
    HSDIVIDER.
    
    Generic card can not be used for the board as we need to switch between
    clock paths for different sampling rate families and also need to change
    the slot_width between 16 and 24 bit audio.
    
    The audio support on the Infotainment Expansion Board consists of McASP0
    connected to two pcm3168a codecs with dedicated set of serializers to each.
    The SCKI for pcm3168a is sourced from j721e AUDIO_REFCLK0 pin.
    It is extending the audio support on the CPB.
    
    Due to the fact that the same PLL4/15 is used by both domains (CPB/IVI)
    there are cross restriction on sampling rates.
    
    The IVI side is represented as multicodec setup.
    
    PCMs available on a plain CPB (no IVI addon):
    hw:0,0 - cpb playback (8 channels)
    hw:0,1 - cpb capture (6 channels)
    
    When the IVI addon is present, additional two PCMs will be present:
    hw:0,2 - ivi multicodec playback (16 channels)
    hw:0,3 - ivi multicodec capture (12 channels)
    Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@ti.com>
    Link: https://lore.kernel.org/r/20200630125843.11561-4-peter.ujfalusi@ti.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
    6748d055
j721e-evm.c 25.6 KB