mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-13 09:15:02 +08:00
a095f15c00
Add support for TI's sn65dsi86 dsi2edp bridge chip. The chip converts DSI transmitted signal to eDP signal, which is fed to the connected eDP panel. This chip can be controlled via either i2c interface or dsi interface. Currently in driver all the control registers are being accessed through i2c interface only. Also as of now HPD support has not been added to bridge chip driver. Changes in v1: - Split the dt-bindings and the driver support into separate patches (Andrzej Hajda). - Use of gpiod APIs to parse and configure gpios instead of obsolete ones (Andrzej Hajda). - Use macros to define the register offsets (Andrzej Hajda). Changes in v2: - Separate out edp panel specific HW resource handling from bridge driver and create a separate edp panel drivers to handle panel specific mode information and HW resources (Sean Paul). - Replace pr_* APIs to DRM_* APIs to log error or debug information (Sean Paul). - Remove some of the unnecessary structure/variable from driver (Sean Paul). - Rename the function and structure prefix "sn65dsi86" to "ti_sn_bridge" (Sean Paul / Rob Herring). - Remove most of the hard-coding and modified the bridge init sequence based on current mode (Sean Paul). - Remove the existing function to retrieve the EDID data and implemented this as an i2c_adapter and use drm_get_edid() (Sean Paul). - Remove the dummy irq handler implementation, will add back the proper irq handling later (Sean Paul). - Capture the required enable gpios in a single array based on dt entry instead of having individual descriptor for each gpio (Sean Paul). Changes in v3: - Remove usage of irq_gpio and replace it as "interrupts" property (Rob Herring). - Remove the unnecessary header file inclusions (Sean Paul). - Rearrange the header files in alphabetical order (Sean Paul). - Use regmap interface to perform i2c transactions. - Update Copyright/License field and address other review comments (Jordan Crouse). Changes in v4: - Update License/Copyright (Sean Paul). - Add Kconfig and Makefile changes (Sean Paul). - Drop i2c gpio handling from this bridge driver, since i2c sda/scl gpios will be handled by i2c master. - Update required supplies names. - Remove unnecessary goto statements (Sean Paul). - Add mutex lock to power_ctrl API to avoid race conditions (Sean Paul). - Add support to parse reference clk frequency from dt(optional). - Update the bridge chip enable/disable sequence. Changes in v5: - Fixed Kbuild test service reported warnings. Changes in v6: - Use PM runtime based ref-counting instead of local ref_count mechanism (Stephen Boyd). - Clean up some debug logs and indentations (Sean Paul). - Simplify dp rate calculation (Sean Paul). - Add support to configure refclk based on input REFCLK pin or DACP/N pin (Stephen Boyd). Changes in v7: - Use static supply entries instead of dynamic allocation (Andrzej Hajda). - Defer bridge driver probe if panel is not probed (Andrzej Hajda). - Update of_graph APIs for correct node reference management. (Andrzej Hajda). - Remove local display_mode object (Andrzej Hajda). - Remove version id check function from driver. Changes in v8: - Move dsi register/attach function to bridge driver probe (Andrzej Hajda). - Introduce a new helper function to write 16bit words into consecutive registers (Andrzej Hajda). - Remove unnecessary macros (Andrzej Hajda). Changes in v9: - Remove dsi register/attach from bridge probe, since dsi dev register completion also waits for any panel or bridge to get added. This creates deadlock situation when bridge driver calls dsi dev register and attach before bridge add, in its probe function. - Fix issues faced during testing of bridge driver on actual HW. - Remove unnecessary initializations (Stephen Boyd). - Use local refclk lut size instead of global macro (Sean Paul). Changes in v10: - Use refclk to determine if continuous dsi clock is needed or not. Changes in v11: - Read DPPLL_SRC register to determine continuous clock instead of using refclk handle (Stephen Boyd). Changes in v12: - Explain in comment as in why dsi dev registration is done in bridge_attach (Andrzej Hajda). - Move HPD disable to bridge_pre_enable (Andrzej Hajda). - Make panel/DDC exclusive until HPD support is added (Andrzej Hajda). Changes in v13: - eDP panels report EDID via DP-AUX channel, so remove support for dedicated DDC line (Andrzej Hajda). Changes in v14: - Remove unnecessary drm_panel checks (Andrzej Hajda). Signed-off-by: Sandeep Panda <spanda@codeaurora.org> Reviewed-by: Andrzej Hajda <a.hajda@samsung.com> Signed-off-by: Andrzej Hajda <a.hajda@samsung.com> Link: https://patchwork.freedesktop.org/patch/msgid/1532069642-21392-1-git-send-email-spanda@codeaurora.org
147 lines
3.6 KiB
Plaintext
147 lines
3.6 KiB
Plaintext
config DRM_BRIDGE
|
|
def_bool y
|
|
depends on DRM
|
|
help
|
|
Bridge registration and lookup framework.
|
|
|
|
config DRM_PANEL_BRIDGE
|
|
def_bool y
|
|
depends on DRM_BRIDGE
|
|
depends on DRM_KMS_HELPER
|
|
select DRM_PANEL
|
|
help
|
|
DRM bridge wrapper of DRM panels
|
|
|
|
menu "Display Interface Bridges"
|
|
depends on DRM && DRM_BRIDGE
|
|
|
|
config DRM_ANALOGIX_ANX78XX
|
|
tristate "Analogix ANX78XX bridge"
|
|
select DRM_KMS_HELPER
|
|
select REGMAP_I2C
|
|
---help---
|
|
ANX78XX is an ultra-low Full-HD SlimPort transmitter
|
|
designed for portable devices. The ANX78XX transforms
|
|
the HDMI output of an application processor to MyDP
|
|
or DisplayPort.
|
|
|
|
config DRM_CDNS_DSI
|
|
tristate "Cadence DPI/DSI bridge"
|
|
select DRM_KMS_HELPER
|
|
select DRM_MIPI_DSI
|
|
select DRM_PANEL_BRIDGE
|
|
depends on OF
|
|
help
|
|
Support Cadence DPI to DSI bridge. This is an internal
|
|
bridge and is meant to be directly embedded in a SoC.
|
|
|
|
config DRM_DUMB_VGA_DAC
|
|
tristate "Dumb VGA DAC Bridge support"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
help
|
|
Support for non-programmable RGB to VGA DAC bridges, such as ADI
|
|
ADV7123, TI THS8134 and THS8135 or passive resistor ladder DACs.
|
|
|
|
config DRM_LVDS_ENCODER
|
|
tristate "Transparent parallel to LVDS encoder support"
|
|
depends on OF
|
|
select DRM_PANEL_BRIDGE
|
|
help
|
|
Support for transparent parallel to LVDS encoders that don't require
|
|
any configuration.
|
|
|
|
config DRM_MEGACHIPS_STDPXXXX_GE_B850V3_FW
|
|
tristate "MegaChips stdp4028-ge-b850v3-fw and stdp2690-ge-b850v3-fw"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
select DRM_PANEL
|
|
---help---
|
|
This is a driver for the display bridges of
|
|
GE B850v3 that convert dual channel LVDS
|
|
to DP++. This is used with the i.MX6 imx-ldb
|
|
driver. You are likely to say N here.
|
|
|
|
config DRM_NXP_PTN3460
|
|
tristate "NXP PTN3460 DP/LVDS bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
select DRM_PANEL
|
|
---help---
|
|
NXP PTN3460 eDP-LVDS bridge chip driver.
|
|
|
|
config DRM_PARADE_PS8622
|
|
tristate "Parade eDP/LVDS bridge"
|
|
depends on OF
|
|
select DRM_PANEL
|
|
select DRM_KMS_HELPER
|
|
select BACKLIGHT_LCD_SUPPORT
|
|
select BACKLIGHT_CLASS_DEVICE
|
|
---help---
|
|
Parade eDP-LVDS bridge chip driver.
|
|
|
|
config DRM_SIL_SII8620
|
|
tristate "Silicon Image SII8620 HDMI/MHL bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
imply EXTCON
|
|
select INPUT
|
|
select RC_CORE
|
|
help
|
|
Silicon Image SII8620 HDMI/MHL bridge chip driver.
|
|
|
|
config DRM_SII902X
|
|
tristate "Silicon Image sii902x RGB/HDMI bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
select REGMAP_I2C
|
|
---help---
|
|
Silicon Image sii902x bridge chip driver.
|
|
|
|
config DRM_SII9234
|
|
tristate "Silicon Image SII9234 HDMI/MHL bridge"
|
|
depends on OF
|
|
---help---
|
|
Say Y here if you want support for the MHL interface.
|
|
It is an I2C driver, that detects connection of MHL bridge
|
|
and starts encapsulation of HDMI signal.
|
|
|
|
config DRM_THINE_THC63LVD1024
|
|
tristate "Thine THC63LVD1024 LVDS decoder bridge"
|
|
depends on OF
|
|
---help---
|
|
Thine THC63LVD1024 LVDS/parallel converter driver.
|
|
|
|
config DRM_TOSHIBA_TC358767
|
|
tristate "Toshiba TC358767 eDP bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
select REGMAP_I2C
|
|
select DRM_PANEL
|
|
---help---
|
|
Toshiba TC358767 eDP bridge chip driver.
|
|
|
|
config DRM_TI_TFP410
|
|
tristate "TI TFP410 DVI/HDMI bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
---help---
|
|
Texas Instruments TFP410 DVI/HDMI Transmitter driver
|
|
|
|
config DRM_TI_SN65DSI86
|
|
tristate "TI SN65DSI86 DSI to eDP bridge"
|
|
depends on OF
|
|
select DRM_KMS_HELPER
|
|
select REGMAP_I2C
|
|
select DRM_PANEL
|
|
help
|
|
Texas Instruments SN65DSI86 DSI to eDP Bridge driver
|
|
|
|
source "drivers/gpu/drm/bridge/analogix/Kconfig"
|
|
|
|
source "drivers/gpu/drm/bridge/adv7511/Kconfig"
|
|
|
|
source "drivers/gpu/drm/bridge/synopsys/Kconfig"
|
|
|
|
endmenu
|