You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
609 lines
22 KiB
609 lines
22 KiB
7 years ago
|
/*
|
||
|
* 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 */
|