2019-05-27 09:55:21 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2016-03-31 16:36:00 +03:00
/*
* hdmi - codec . h - HDMI Codec driver API
*
2020-07-19 18:17:05 +03:00
* Copyright ( C ) 2014 Texas Instruments Incorporated - https : //www.ti.com
2016-03-31 16:36:00 +03:00
*
* Author : Jyri Sarha < jsarha @ ti . com >
*/
# ifndef __HDMI_CODEC_H__
# define __HDMI_CODEC_H__
2017-05-18 04:40:20 +03:00
# include <linux/of_graph.h>
2016-03-31 16:36:00 +03:00
# include <linux/hdmi.h>
# include <drm/drm_edid.h>
# include <sound/asoundef.h>
2017-05-18 04:40:20 +03:00
# include <sound/soc.h>
2016-03-31 16:36:00 +03:00
# include <uapi/sound/asound.h>
/*
* Protocol between ASoC cpu - dai and HDMI - encoder
*/
struct hdmi_codec_daifmt {
enum {
HDMI_I2S ,
HDMI_RIGHT_J ,
HDMI_LEFT_J ,
HDMI_DSP_A ,
HDMI_DSP_B ,
HDMI_AC97 ,
HDMI_SPDIF ,
} fmt ;
2016-12-16 12:26:54 +03:00
unsigned int bit_clk_inv : 1 ;
unsigned int frame_clk_inv : 1 ;
2022-06-02 13:30:29 +03:00
unsigned int bit_clk_provider : 1 ;
unsigned int frame_clk_provider : 1 ;
2021-02-04 04:42:55 +03:00
/* bit_fmt could be standard PCM format or
* IEC958 encoded format . ALSA IEC958 plugin will pass
* IEC958_SUBFRAME format to the underneath driver .
*/
snd_pcm_format_t bit_fmt ;
2016-03-31 16:36:00 +03:00
} ;
/*
* HDMI audio parameters
*/
struct hdmi_codec_params {
struct hdmi_audio_infoframe cea ;
struct snd_aes_iec958 iec ;
int sample_rate ;
int sample_width ;
int channels ;
} ;
2019-07-17 11:33:23 +03:00
typedef void ( * hdmi_codec_plugged_cb ) ( struct device * dev ,
bool plugged ) ;
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
struct hdmi_codec_pdata ;
2016-03-31 16:36:00 +03:00
struct hdmi_codec_ops {
/*
* Called when ASoC starts an audio stream setup .
* Optional
*/
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
int ( * audio_startup ) ( struct device * dev , void * data ) ;
2016-03-31 16:36:00 +03:00
/*
* Configures HDMI - encoder for audio stream .
2021-05-25 16:23:47 +03:00
* Having either prepare or hw_params is mandatory .
2016-03-31 16:36:00 +03:00
*/
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
int ( * hw_params ) ( struct device * dev , void * data ,
2016-03-31 16:36:00 +03:00
struct hdmi_codec_daifmt * fmt ,
struct hdmi_codec_params * hparms ) ;
2021-05-25 16:23:47 +03:00
/*
* Configures HDMI - encoder for audio stream . Can be called
* multiple times for each setup .
*
* Having either prepare or hw_params is mandatory .
*/
int ( * prepare ) ( struct device * dev , void * data ,
struct hdmi_codec_daifmt * fmt ,
struct hdmi_codec_params * hparms ) ;
2016-03-31 16:36:00 +03:00
/*
* Shuts down the audio stream .
* Mandatory
*/
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
void ( * audio_shutdown ) ( struct device * dev , void * data ) ;
2016-03-31 16:36:00 +03:00
/*
* Mute / unmute HDMI audio stream .
* Optional
*/
2020-07-09 04:55:45 +03:00
int ( * mute_stream ) ( struct device * dev , void * data ,
bool enable , int direction ) ;
2016-03-31 16:36:00 +03:00
/*
* Provides EDID - Like - Data from connected HDMI device .
* Optional
*/
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
int ( * get_eld ) ( struct device * dev , void * data ,
uint8_t * buf , size_t len ) ;
2017-05-18 04:40:20 +03:00
/*
* Getting DAI ID
* Optional
*/
int ( * get_dai_id ) ( struct snd_soc_component * comment ,
struct device_node * endpoint ) ;
2019-07-17 11:33:23 +03:00
/*
* Hook callback function to handle connector plug event .
* Optional
*/
int ( * hook_plugged_cb ) ( struct device * dev , void * data ,
hdmi_codec_plugged_cb fn ,
struct device * codec_dev ) ;
2020-07-09 04:55:45 +03:00
/* bit field */
unsigned int no_capture_mute : 1 ;
2016-03-31 16:36:00 +03:00
} ;
/* HDMI codec initalization data */
struct hdmi_codec_pdata {
const struct hdmi_codec_ops * ops ;
uint i2s : 1 ;
2022-11-30 21:46:43 +03:00
uint no_i2s_playback : 1 ;
uint no_i2s_capture : 1 ;
2016-03-31 16:36:00 +03:00
uint spdif : 1 ;
2022-11-30 21:46:43 +03:00
uint no_spdif_playback : 1 ;
uint no_spdif_capture : 1 ;
2016-03-31 16:36:00 +03:00
int max_i2s_channels ;
ASoC: hdmi-codec: callback function will be called with private data
Current hdmi-codec driver is assuming that it will be registered
from HDMI driver. Because of this assumption, each callback function
has struct device pointer which is parent device (= HDMI).
Then, it can use dev_get_drvdata() to get private data.
OTOH, on some SoC/HDMI case, SoC has VIDEO/SOUND and HDMI IPs.
This case, it needs SoC VIDEO, SoC SOUND and HDMI video, HDMI codec
driver. In DesignWare HDMI IP case, SoC VIDEO (= DRM/KMS) driver tries
to bind DesignWare HDMI video driver, and HDMI codec driver
(= hdmi-codec). This case, above "parent device" of HDMI codec driver
is DRM/KMS driver and its "device" already has private data.
And, from DT and ASoC CPU/Codec/Card binding point of view, HDMI codec
(= hdmi-codec) needs to have "parent device" (= DRM/KMS), otherwise,
it never detect sound card.
Because of these reasons, some driver can't use dev_get_drvdata() to
get private data on hdmi-codec driver. This patch add new void pointer
on hdmi_codec_pdata for private data, and callback function will be
called with it.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
2016-06-24 05:47:55 +03:00
void * data ;
2016-03-31 16:36:00 +03:00
} ;
2019-07-17 11:33:23 +03:00
struct snd_soc_component ;
struct snd_soc_jack ;
2016-03-31 16:36:00 +03:00
# define HDMI_CODEC_DRV_NAME "hdmi-audio-codec"
# endif /* __HDMI_CODEC_H__ */