123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608 |
- /*
- * Copyright (c) 2015-2018, The Linux Foundation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 and
- * only version 2 as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
- #ifndef _MSM_DBA_H
- #define _MSM_DBA_H
- #include <linux/types.h>
- #include <linux/bitops.h>
- #define MSM_DBA_CHIP_NAME_MAX_LEN 20
- #define MSM_DBA_CLIENT_NAME_LEN 20
- #define MSM_DBA_DEFER_PROPERTY_FLAG 0x1
- #define MSM_DBA_ASYNC_FLAG 0x2
- /**
- * enum msm_dba_callback_event - event types for callback notification
- * @MSM_DBA_CB_REMOTE_INT: Event associated with remote devices on an interface
- * that supports a bi-directional control channel.
- * @MSM_DBA_CB_HDCP_LINK_AUTHENTICATED: Authentication session is successful.
- * The link is authenticated and encryption
- * can be enabled if not enabled already.
- * @MSM_DBA_CB_HDCP_LINK_UNAUTHENTICATED: A previously authenticated link has
- * failed. The content on the interface
- * is no longer secure.
- * @MSM_DBA_CB_HPD_CONNECT: Detected a cable connect event.
- * @MSM_DBA_CB_HPD_DISCONNECT: Detected a cable disconnect event.
- * @MSM_DBA_CB_VIDEO_FAILURE: Detected a failure with respect to video data on
- * the interface. This is a generic failure and
- * client should request a debug dump to debug the
- * issue. Client can also attempt a reset to recover
- * the device.
- * @MSM_DBA_CB_AUDIO_FAILURE: Detected a failure with respect to audio data on
- * the interface. This is a generic failure and
- * client should request a debug dump. Client can
- * also attempt a reset to recover the device.
- * @MSM_DBA_CB_CEC_WRITE_SUCCESS: The asynchronous CEC write request is
- * successful.
- * @MSM_DBA_CB_CEC_WRITE_FAIL: The asynchronous CEC write request failed.
- * @MSM_DBA_CB_CEC_READ_PENDING: There is a pending CEC read message.
- * @MSM_DBA_CB_PRE_RESET: This callback is called just before the device is
- * being reset.
- * @MSM_DBA_CB_POST_RESET: This callback is called after device reset is
- * complete and the driver has applied back all the
- * properties.
- *
- * Clients for this driver can register for receiving callbacks for specific
- * events. This enum defines the type of events supported by the driver. An
- * event mask is typically used to denote multiple events.
- */
- enum msm_dba_callback_event {
- MSM_DBA_CB_REMOTE_INT = BIT(0),
- MSM_DBA_CB_HDCP_LINK_AUTHENTICATED = BIT(1),
- MSM_DBA_CB_HDCP_LINK_UNAUTHENTICATED = BIT(2),
- MSM_DBA_CB_HPD_CONNECT = BIT(3),
- MSM_DBA_CB_HPD_DISCONNECT = BIT(4),
- MSM_DBA_CB_VIDEO_FAILURE = BIT(5),
- MSM_DBA_CB_AUDIO_FAILURE = BIT(6),
- MSM_DBA_CB_CEC_WRITE_SUCCESS = BIT(7),
- MSM_DBA_CB_CEC_WRITE_FAIL = BIT(8),
- MSM_DBA_CB_CEC_READ_PENDING = BIT(9),
- MSM_DBA_CB_PRE_RESET = BIT(10),
- MSM_DBA_CB_POST_RESET = BIT(11),
- };
- /**
- * enum msm_dba_audio_interface_type - audio interface type
- * @MSM_DBA_AUDIO_I2S_INTERFACE: I2S interface for audio
- * @MSM_DBA_AUDIO_SPDIF_INTERFACE: SPDIF interface for audio
- */
- enum msm_dba_audio_interface_type {
- MSM_DBA_AUDIO_I2S_INTERFACE = BIT(0),
- MSM_DBA_AUDIO_SPDIF_INTERFACE = BIT(1),
- };
- /**
- * enum msm_dba_audio_format_type - audio format type
- * @MSM_DBA_AUDIO_FMT_UNCOMPRESSED_LPCM: uncompressed format
- * @MSM_DBA_AUDIO_FMT_COMPRESSED: compressed formats
- */
- enum msm_dba_audio_format_type {
- MSM_DBA_AUDIO_FMT_UNCOMPRESSED_LPCM = BIT(0),
- MSM_DBA_AUDIO_FMT_COMPRESSED = BIT(1),
- };
- /**
- * enum msm_dba_audio_copyright_type - audio copyright
- * @MSM_DBA_AUDIO_COPYRIGHT_PROTECTED: copy right protected
- * @MSM_DBA_AUDIO_COPYRIGHT_NOT_PROTECTED: not copy right protected
- */
- enum msm_dba_audio_copyright_type {
- MSM_DBA_AUDIO_COPYRIGHT_PROTECTED = BIT(0),
- MSM_DBA_AUDIO_COPYRIGHT_NOT_PROTECTED = BIT(1),
- };
- /**
- * enum msm_dba_audio_pre_emphasis_type - pre-emphasis
- * @MSM_DBA_AUDIO_NO_PRE_EMPHASIS: 2 audio channels w/o pre-emphasis
- * @MSM_DBA_AUDIO_PRE_EMPHASIS_50_15us: 2 audio channels with 50/15uS
- */
- enum msm_dba_audio_pre_emphasis_type {
- MSM_DBA_AUDIO_NO_PRE_EMPHASIS = BIT(0),
- MSM_DBA_AUDIO_PRE_EMPHASIS_50_15us = BIT(1),
- };
- /**
- * enum msm_dba_audio_clock_accuracy - Audio Clock Accuracy
- * @MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL1: normal accuracy +/-1000 x 10^-6
- * @MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL2: high accuracy +/- 50 x 10^-6
- * @MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL3: variable pitch shifted clock
- */
- enum msm_dba_audio_clock_accuracy {
- MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL1 = BIT(1),
- MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL2 = BIT(0),
- MSM_DBA_AUDIO_CLOCK_ACCURACY_LVL3 = BIT(2),
- };
- /**
- * enum msm_dba_channel_status_source - CS override
- * @MSM_DBA_AUDIO_CS_SOURCE_I2S_STREAM: use channel status bits from I2S stream
- * @MSM_DBA_AUDIO_CS_SOURCE_REGISTERS: use channel status bits from registers
- */
- enum msm_dba_channel_status_source {
- MSM_DBA_AUDIO_CS_SOURCE_I2S_STREAM,
- MSM_DBA_AUDIO_CS_SOURCE_REGISTERS
- };
- /**
- * enum msm_dba_audio_sampling_rates_type - audio sampling rates
- * @MSM_DBA_AUDIO_32KHZ: 32KHz sampling rate
- * @MSM_DBA_AUDIO_44P1KHZ: 44.1KHz sampling rate
- * @MSM_DBA_AUDIO_48KHZ: 48KHz sampling rate
- * @MSM_DBA_AUDIO_96KHZ: 96KHz sampling rate
- * @MSM_DBA_AUDIO_192KHZ: 192KHz sampling rate
- */
- enum msm_dba_audio_sampling_rates_type {
- MSM_DBA_AUDIO_32KHZ = BIT(0),
- MSM_DBA_AUDIO_44P1KHZ = BIT(1),
- MSM_DBA_AUDIO_48KHZ = BIT(2),
- MSM_DBA_AUDIO_88P2KHZ = BIT(1),
- MSM_DBA_AUDIO_96KHZ = BIT(3),
- MSM_DBA_AUDIO_176P4KHZ = BIT(1),
- MSM_DBA_AUDIO_192KHZ = BIT(4),
- };
- /**
- * enum msm_dba_audio_word_bit_depth - audio word size
- * @MSM_DBA_AUDIO_WORD_16BIT: 16 bits per word
- * @MSM_DBA_AUDIO_WORD_24BIT: 24 bits per word
- * @MSM_DBA_AUDIO_WORD_32BIT: 32 bits per word
- */
- enum msm_dba_audio_word_bit_depth {
- MSM_DBA_AUDIO_WORD_16BIT = BIT(1),
- MSM_DBA_AUDIO_WORD_24BIT = BIT(2),
- MSM_DBA_AUDIO_WORD_32BIT = BIT(3),
- };
- /**
- * enum msm_dba_audio_channel_count - audio channel count
- * @MSM_DBA_AUDIO_CHANNEL_2: 2 channel audio
- * @MSM_DBA_AUDIO_CHANNEL_4: 4 channel audio
- * @MSM_DBA_AUDIO_CHANNEL_8: 8 channel audio
- */
- enum msm_dba_audio_channel_count {
- MSM_DBA_AUDIO_CHANNEL_2 = BIT(0),
- MSM_DBA_AUDIO_CHANNEL_4 = BIT(1),
- MSM_DBA_AUDIO_CHANNEL_8 = BIT(2),
- };
- /**
- * enum msm_dba_audio_i2s_format - i2s audio data format
- * @MSM_DBA_AUDIO_I2S_FMT_STANDARD: Standard format
- * @MSM_DBA_AUDIO_I2S_FMT_RIGHT_JUSTIFIED: i2s data is right justified
- * @MSM_DBA_AUDIO_I2S_FMT_LEFT_JUSTIFIED: i2s data is left justified
- * @MSM_DBA_AUDIO_I2S_FMT_AES3_DIRECT: AES signal format
- */
- enum msm_dba_audio_i2s_format {
- MSM_DBA_AUDIO_I2S_FMT_STANDARD = 0,
- MSM_DBA_AUDIO_I2S_FMT_RIGHT_JUSTIFIED,
- MSM_DBA_AUDIO_I2S_FMT_LEFT_JUSTIFIED,
- MSM_DBA_AUDIO_I2S_FMT_AES3_DIRECT,
- MSM_DBA_AUDIO_I2S_FMT_MAX,
- };
- enum msm_dba_video_aspect_ratio {
- MSM_DBA_AR_UNKNOWN = 0,
- MSM_DBA_AR_4_3,
- MSM_DBA_AR_5_4,
- MSM_DBA_AR_16_9,
- MSM_DBA_AR_16_10,
- MSM_DBA_AR_64_27,
- MSM_DBA_AR_256_135,
- MSM_DBA_AR_MAX
- };
- enum msm_dba_audio_word_endian_type {
- MSM_DBA_AUDIO_WORD_LITTLE_ENDIAN = 0,
- MSM_DBA_AUDIO_WORD_BIG_ENDIAN,
- MSM_DBA_AUDIO_WORD_ENDIAN_MAX
- };
- /**
- * msm_dba_audio_op_mode - i2s audio operation mode
- * @MSM_DBA_AUDIO_MODE_MANUAL: Manual mode
- * @MSM_DBA_AUDIO_MODE_AUTOMATIC: Automatic mode
- */
- enum msm_dba_audio_op_mode {
- MSM_DBA_AUDIO_MODE_MANUAL,
- MSM_DBA_AUDIO_MODE_AUTOMATIC,
- };
- /**
- * typedef *msm_dba_cb() - Prototype for callback function
- * @data: Pointer to user data provided with register API
- * @event: Event type associated with callback. This can be a bitmask.
- */
- typedef void (*msm_dba_cb)(void *data, enum msm_dba_callback_event event);
- /**
- * struct msm_dba_reg_info - Client information used with register API
- * @client_name: Name of the client for debug purposes
- * @chip_name: Bridge chip ID
- * @instance_id: Instance ID of the bridge chip in case of multiple instances
- * @cb: callback function called in case of events.
- * @cb_data: pointer to a data structure that will be returned with callback
- *
- * msm_dba_reg_info structure will be used to provide information during
- * registering with driver. This structure will contain the information required
- * to identify the specific bridge chip the client wants to use.
- *
- * Client should also specify the callback function which needs to be called in
- * case of events. There is an optional data field which is a pointer that will
- * be returned as one of arguments in the callback function. This data field can
- * be NULL if client does not wish to use it.
- */
- struct msm_dba_reg_info {
- char client_name[MSM_DBA_CLIENT_NAME_LEN];
- char chip_name[MSM_DBA_CHIP_NAME_MAX_LEN];
- u32 instance_id;
- msm_dba_cb cb;
- void *cb_data;
- };
- /**
- * struct msm_dba_video_caps_info - video capabilities of the bridge chip
- * @hdcp_support: if hdcp is supported
- * @edid_support: if reading edid from sink is supported
- * @data_lanes_lp_support: if low power mode is supported on data lanes
- * @clock_lanes_lp_support: If low power mode is supported on clock lanes
- * @max_pclk_khz: maximum pixel clock supported
- * @num_of_input_lanes: Number of input data lanes supported by the bridge chip
- */
- struct msm_dba_video_caps_info {
- bool hdcp_support;
- bool edid_support;
- bool data_lanes_lp_support;
- bool clock_lanes_lp_support;
- u32 max_pclk_khz;
- u32 num_of_input_lanes;
- };
- /**
- * struct msm_dba_audio_caps_info - audio capabilities of the bridge chip
- * @audio_support: if audio is supported
- * @audio_rates: audio sampling rates supported
- * @audio_fmts: audio formats supported
- */
- struct msm_dba_audio_caps_info {
- u32 audio_support;
- u32 audio_rates;
- u32 audio_fmts;
- };
- /**
- * struct msm_dba_capabilities - general capabilities of the bridge chip
- * @vid_caps: video capabilities
- * @aud_caps: audio capabilities
- * @av_mute_support: av mute support in bridge chip
- * @deferred_commit_support: support for deferred commit
- */
- struct msm_dba_capabilities {
- struct msm_dba_video_caps_info vid_caps;
- struct msm_dba_audio_caps_info aud_caps;
- bool av_mute_support;
- bool deferred_commit_support;
- };
- /**
- * struct msm_dba_audio_cfg - Structure for audio configuration
- * @interface: Specifies audio interface type. Client should check the
- * capabilities for the interfaces supported by the bridge.
- * @format: Compressed vs Uncompressed formats.
- * @channels: Number of channels.
- * @i2s_fmt: I2S data packing format. This is valid only if interface is I2S.
- * @sampling_rate: sampling rate of audio data
- * @word_size: word size
- * @word_endianness: little or big endian words
- */
- struct msm_dba_audio_cfg {
- enum msm_dba_audio_interface_type interface;
- enum msm_dba_audio_format_type format;
- enum msm_dba_audio_channel_count channels;
- enum msm_dba_audio_i2s_format i2s_fmt;
- enum msm_dba_audio_sampling_rates_type sampling_rate;
- enum msm_dba_audio_word_bit_depth word_size;
- enum msm_dba_audio_word_endian_type word_endianness;
- enum msm_dba_audio_copyright_type copyright;
- enum msm_dba_audio_pre_emphasis_type pre_emphasis;
- enum msm_dba_audio_clock_accuracy clock_accuracy;
- enum msm_dba_channel_status_source channel_status_source;
- enum msm_dba_audio_op_mode mode;
- u32 channel_status_category_code;
- u32 channel_status_source_number;
- u32 channel_status_v_bit;
- u32 channel_allocation;
- u32 channel_status_word_length;
- u32 n;
- u32 cts;
- };
- /**
- * struct msm_dba_video_cfg - video configuration data
- * @h_active: active width of the video signal
- * @h_front_porch: horizontal front porch in pixels
- * @h_pulse_width: pulse width of hsync in pixels
- * @h_back_porch: horizontal back porch in pixels
- * @h_polarity: polarity of hsync signal
- * @v_active: active height of the video signal
- * @v_front_porch: vertical front porch in lines
- * @v_pulse_width: pulse width of vsync in lines
- * @v_back_porch: vertical back porch in lines
- * @v_polarity: polarity of vsync signal
- * @pclk_khz: pixel clock in KHz
- * @interlaced: if video is interlaced
- * @vic: video indetification code
- * @hdmi_mode: hdmi or dvi mode for the sink
- * @ar: aspect ratio of the signal
- * @num_of_input_lanes: number of input lanes in case of DSI/LVDS
- */
- struct msm_dba_video_cfg {
- u32 h_active;
- u32 h_front_porch;
- u32 h_pulse_width;
- u32 h_back_porch;
- bool h_polarity;
- u32 v_active;
- u32 v_front_porch;
- u32 v_pulse_width;
- u32 v_back_porch;
- bool v_polarity;
- u32 pclk_khz;
- bool interlaced;
- u32 vic;
- bool hdmi_mode;
- enum msm_dba_video_aspect_ratio ar;
- u32 num_of_input_lanes;
- u8 scaninfo;
- };
- struct mdss_dba_timing_info {
- u16 xres;
- u16 yres;
- u8 bpp;
- u8 fps;
- u8 lanes;
- };
- /**
- * struct msm_dba_ops- operation supported by bridge chip
- * @get_caps: returns the bridge chip capabilities
- * DEFER and ASYNC flags are not supported.
- * @power_on: powers on/off the bridge chip. This usually involves turning on
- * the power regulators and bringing the chip out of reset. Chip
- * should be capable of raising interrupts at this point.
- * DEFER and ASYNC flags are supported.
- * @video_on: turn on/off video stream. This function also requires the video
- * timing information that might be needed for programming the bridge
- * chip.
- * DEFER flag is supported.
- * ASYNC flag is not supported.
- * @audio_on: turn on/off audio stream.
- * DEFER flag is supported.
- * ASYNC flag is not supported.
- * @configure_audio: setup audio configuration
- * DEFER flag is supported.
- * ASYNC flag is not supported.
- * @av_mute: controls av mute functionalities if supported. AV mute is different
- * from audio_on and video_on where in even though the actual data is
- * sent, mute is specified through control packets.
- * DEFER flag is supported.
- * ASYNC flag is not supported.
- * @interupts_enable: enables interrupts to get event callbacks. Clients need
- * to specify an event mask of the events they are
- * interested in. If a client provides an event as part of
- * the mask, it will receive the interrupt regardless of the
- * client modifying the property.
- * DEFER flag is supported.
- * ASYNC flag is not supported.
- * @hdcp_enable: enable/disable hdcp. If HDCP is enabled, this function will
- * start a new authentication session. There is a separate
- * argument for enabling encryption. Encryption can be enabled any
- * time after HDCP has been fully authenticated. This function
- * will support an asynchronous mode where calling this function
- * will kick off HDCP and return to the caller. Caller has to wait
- * for MSM_DBA_CB_HDCP_SUCCESS callback to ensure link is
- * authenticated.
- * DEFER flag is not supported.
- * ASYNC flag is supported.
- * @hdcp_get_ksv_list_size: returns the KSV list size. In case of a simple sink
- * the size will be 1. In case of a repeater, this can
- * be more than one.
- * DEFER and ASYNC flags are not supported.
- * @hdcp_get_ksv_list: return the KSV list. Client can query the KSV information
- * from the bridge. Client should call
- * hdcp_get_ksv_list_size first and then allocate 40*size
- * bytes to hold all the KSVs.
- * DEFER and ASYNC flags are not supported.
- * @hdmi_cec_on: enable or disable cec module. Clients need to enable CEC
- * feature before they do read or write CEC messages.
- * @hdmi_cec_write: perform a CEC write. For bridges with HDMI as output
- * interface, this function allows clients to send a CEC
- * message. Client should pack the data according to the CEC
- * specification and provide the final buffer. Since CEC writes
- * can take longer time to ascertaining if they are successful,
- * this function supports the ASYNC flag. Driver will return
- * either MSM_DBA_CB_CEC_WRITE_SUCCESS or
- * MSM_DBA_CB_CEC_WRITE_FAIL callbacks.
- * DEFER is not supported.
- * ASYNC flag is supported.
- * @hdmi_cec_read: get a pending CEC read message. In case of an incoming CEC
- * message, driver will return MSM_DBA_CB_CEC_READ_PENDING
- * callback. On getting this event callback, client should call
- * hdmi_cec_read to get the message. The buffer should at least
- * be 15 bytes or more. Client should read the CEC message from
- * a thread different from the callback.
- * DEFER and ASYNC flags are not supported.
- * @get_edid_size: returns size of the edid.
- * DEFER and ASYNC flags are not supported.
- * @get_raw_edid: returns raw edid data.
- * DEFER and ASYNC flags are not supported.
- * @enable_remote_comm: enable/disable remote communication. Some interfaces
- * like FPDLINK III support a bi-directional control
- * channel that could be used to send control data using an
- * I2C or SPI protocol. This Function will enable this
- * control channel if supported.
- * DEFER and ASYNC flags are not supported.
- * @add_remote_device: add slaves on remote side for enabling communication. For
- * interfaces that support bi directional control channel,
- * this function allows clients to specify slave IDs of
- * devices on remote bus. Messages addressed to these IDs
- * will be trapped by the bridge chip and put on the remote
- * bus.
- * DEFER and ASYNC flags are not supported.
- * @commit_deferred_props: commits deferred properties
- * DEFER and ASYNC flags are not supported.
- * @force_reset: reset the device forcefully. In case the device goes into a bad
- * state, a client can force reset to try and recover the device.
- * The reset will be applied in spite of different configurations
- * from other clients. Driver will apply all the properties that
- * have been applied so far after the reset is complete. In case
- * of multiple clients, driver will issue a reset callback.
- * @dump_debug_info: dumps debug information to dmesg.
- * @check_hpd: Check if cable is connected or not. if cable is connected we
- * send notification to display framework.
- * @set_audio_block: This function will populate the raw audio speaker block
- * data along with size of each block in bridgechip buffer.
- * @get_audio_block: This function will return the raw audio speaker block
- * along with size of each block.
- *
- * The msm_dba_ops structure represents a set of operations that can be
- * supported by each bridge chip. Depending on the functionality supported by a
- * specific bridge chip, some of the operations need not be supported. For
- * example if a bridge chip does not support reading EDID from a sink device,
- * get_edid_size and get_raw_edid can be NULL.
- *
- * Deferring properties: The deferred flag allows us to address any quirks with
- * respect to specific bridge chips. If there is a need for some properties to
- * be committed together, turning on video and audio at the same time, the
- * deferred flag can be used. Properties that are set using a DEFER flag will
- * not be committed to hardware until commit_deferred_props() function is
- * called.
- *
- */
- struct msm_dba_ops {
- int (*get_caps)(void *client,
- struct msm_dba_capabilities *caps);
- int (*power_on)(void *client,
- bool on,
- u32 flags);
- int (*video_on)(void *client,
- bool on,
- struct msm_dba_video_cfg *cfg,
- u32 flags);
- int (*audio_on)(void *client,
- bool on,
- u32 flags);
- int (*configure_audio)(void *client,
- struct msm_dba_audio_cfg *cfg,
- u32 flags);
- int (*av_mute)(void *client,
- bool video_mute,
- bool audio_mute,
- u32 flags);
- int (*interrupts_enable)(void *client,
- bool on,
- u32 event_mask,
- u32 flags);
- int (*hdcp_enable)(void *client,
- bool hdcp_on,
- bool enc_on,
- u32 flags);
- int (*hdcp_get_ksv_list_size)(void *client,
- u32 *count,
- u32 flags);
- int (*hdcp_get_ksv_list)(void *client,
- u32 count,
- char *buf,
- u32 flags);
- int (*hdmi_cec_on)(void *client,
- bool enable,
- u32 flags);
- int (*hdmi_cec_write)(void *client,
- u32 size,
- char *buf,
- u32 flags);
- int (*hdmi_cec_read)(void *client,
- u32 *size,
- char *buf,
- u32 flags);
- int (*get_edid_size)(void *client,
- u32 *size,
- u32 flags);
- int (*get_raw_edid)(void *client,
- u32 size,
- char *buf,
- u32 flags);
- int (*enable_remote_comm)(void *client,
- bool on,
- u32 flags);
- int (*add_remote_device)(void *client,
- u32 *slave_ids,
- u32 count,
- u32 flags);
- int (*commit_deferred_props)(void *client,
- u32 flags);
- int (*force_reset)(void *client, u32 flags);
- int (*dump_debug_info)(void *client, u32 flags);
- int (*check_hpd)(void *client, u32 flags);
- void (*set_audio_block)(void *client, u32 size, void *buf);
- void (*get_audio_block)(void *client, u32 size, void *buf);
- void* (*get_supp_timing_info)(void);
- };
- /**
- * msm_dba_register_client() - Allows a client to register with the driver.
- * @info: Client information along with the bridge chip id the client wishes to
- * program.
- * @ops: Function pointers to bridge chip operations. Some function pointers can
- * be NULL depending on the functionalities supported by bridge chip.
- *
- * The register API supports multiple clients to register for the same bridge
- * chip. If Successful, this will return a pointer that should be used as a
- * handle for all subsequent function calls.
- */
- void *msm_dba_register_client(struct msm_dba_reg_info *info,
- struct msm_dba_ops *ops);
- /**
- * msm_dba_deregister_client() - Allows client to de-register with the driver.
- * @client: client handle returned by register API.
- *
- * This function will release all the resources used by a particular client. If
- * it is the only client using the bridge chip, the bridge chip will be powered
- * down and put into reset.
- */
- int msm_dba_deregister_client(void *client);
- #endif /* _MSM_DBA_H */
|