drm/panel: Changes for v4.3-rc1
This introduces support for a couple of new panels and also contains some work to restructure the directories to get more consistency, to deal better with more panel and bridge drivers getting added. -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQIcBAABCAAGBQJVzkSDAAoJEN0jrNd/PrOhdS4P/18WQMe+AzVXNjZXjBDv5v4s TtgHv4q0j93pZ0etBfeNCkYQpRAZUIv8bUPc7hr9tkWoz5GZRO4IjRmiWT+VaTib tQq+tU4mTjaHgsSY1NkxDWouBk6chQTIQWIgoh1hI9cu2koZc1lxu1I25hO+jOUD PBTsQca1uSSKppL5o9KHuy0IQSV6B7tWIrM0euNCmE+EG5b8dhbRZSakASF2KlUs +Xk8itX2E2DzBrCXGjM7kpEglHx9/1c1FsJQhgu7r8o952oLVPPn3M/OKRLyHoEz jdQyB8rODl6CEgoPOZCCw7HLAmBqf97ngxGcVf6XDOqqVv/B6FKDV0KsnvtKy4h4 DQarImGOlBiSxLah0nLPnUG7+a6a62Ji1Gr5JP+xPJgbpxZvhgQzbRQPhM6KiTiR 9+gG0qr/H2rm09C3PnixfL3D/QpZt2GWMDlX7qXWMzIrJRbrpsn2q7VdY+dBx0wx llKhY8aZod0CMYGFftZNr3beHJU05YcVDWftF8JfGEZmWWIhGesB6r3lE8k/t5c5 6CJlq3Uzrh+nf+7zUq+lUzPpQmahPHcGp1eiSOzk1GQ+RAY/ZscUQYrUxqpY1a2R 889Ip9cPUZiZdQFRkcpCRy5MUdX3/GNCluCINrDXK0j1xnzUzZOo81jhCG0xwVOF JuhSi/Zka7UoHQ1/jSwA =Dee7 -----END PGP SIGNATURE----- Merge tag 'drm/panel/for-4.3-rc1' of git://anongit.freedesktop.org/tegra/linux into drm-next drm/panel: Changes for v4.3-rc1 This introduces support for a couple of new panels and also contains some work to restructure the directories to get more consistency, to deal better with more panel and bridge drivers getting added. * tag 'drm/panel/for-4.3-rc1' of git://anongit.freedesktop.org/tegra/linux: drm/bridge: Put Kconfig entries in a separate menu drm/panel: Add support for LG LG4573 480x800 4.3" panel drm/panel: Add display timing for Okaya RS800480T-7X0GP of: Add Okaya Electric America vendor prefix drm/panel: simple: Add support for NEC NL4827HC19-05B 480x272 panel drm/panel: simple: Add support for AUO B080UAN01 drm/panel: simple: Correct minimum hsync length of the HannStar HSD070PWW1 panel drm/panel: simple: Add bus format for HannStar HSD070PWW1 LVDS panel drm/bridge: Add vendor prefixes drm/panel: Add Samsung prefix to panel drivers drm/exynos: Remove PTN3460 dependency
This commit is contained in:
commit
6406e45cc6
@ -0,0 +1,7 @@
|
|||||||
|
AU Optronics Corporation 8.0" WUXGA TFT LCD panel
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: should be "auo,b101ean01"
|
||||||
|
|
||||||
|
This binding is compatible with the simple-panel binding, which is specified
|
||||||
|
in simple-panel.txt in this directory.
|
19
Documentation/devicetree/bindings/panel/lg,lg4573.txt
Normal file
19
Documentation/devicetree/bindings/panel/lg,lg4573.txt
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
LG LG4573 TFT Liquid Crystal Display with SPI control bus
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: "lg,lg4573"
|
||||||
|
- reg: address of the panel on the SPI bus
|
||||||
|
|
||||||
|
The panel must obey rules for SPI slave device specified in document [1].
|
||||||
|
|
||||||
|
[1]: Documentation/devicetree/bindings/spi/spi-bus.txt
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
lcd_panel: display@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
compatible = "lg,lg4573";
|
||||||
|
spi-max-frequency = <10000000>;
|
||||||
|
reg = <0>;
|
||||||
|
};
|
@ -0,0 +1,7 @@
|
|||||||
|
NEC LCD Technologies,Ltd. WQVGA TFT LCD panel
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: should be "nec,nl4827hc19-05b"
|
||||||
|
|
||||||
|
This binding is compatible with the simple-panel binding, which is specified
|
||||||
|
in simple-panel.txt in this directory.
|
@ -0,0 +1,7 @@
|
|||||||
|
OKAYA Electric America, Inc. RS800480T-7X0GP 7" WVGA LCD panel
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: should be "okaya,rs800480t-7x0gp"
|
||||||
|
|
||||||
|
This binding is compatible with the simple-panel binding, which is specified
|
||||||
|
in simple-panel.txt in this directory.
|
@ -148,6 +148,7 @@ nintendo Nintendo
|
|||||||
nokia Nokia
|
nokia Nokia
|
||||||
nvidia NVIDIA
|
nvidia NVIDIA
|
||||||
nxp NXP Semiconductors
|
nxp NXP Semiconductors
|
||||||
|
okaya Okaya Electric America, Inc.
|
||||||
onnn ON Semiconductor Corp.
|
onnn ON Semiconductor Corp.
|
||||||
opencores OpenCores.org
|
opencores OpenCores.org
|
||||||
ortustech Ortus Technology Co., Ltd.
|
ortustech Ortus Technology Co., Ltd.
|
||||||
|
@ -124,14 +124,14 @@ CONFIG_REGULATOR_S2MPS11=y
|
|||||||
CONFIG_REGULATOR_S5M8767=y
|
CONFIG_REGULATOR_S5M8767=y
|
||||||
CONFIG_REGULATOR_TPS65090=y
|
CONFIG_REGULATOR_TPS65090=y
|
||||||
CONFIG_DRM=y
|
CONFIG_DRM=y
|
||||||
CONFIG_DRM_PTN3460=y
|
CONFIG_DRM_NXP_PTN3460=y
|
||||||
CONFIG_DRM_PS8622=y
|
CONFIG_DRM_PARADE_PS8622=y
|
||||||
CONFIG_DRM_EXYNOS=y
|
CONFIG_DRM_EXYNOS=y
|
||||||
CONFIG_DRM_EXYNOS_FIMD=y
|
CONFIG_DRM_EXYNOS_FIMD=y
|
||||||
CONFIG_DRM_EXYNOS_DSI=y
|
CONFIG_DRM_EXYNOS_DSI=y
|
||||||
CONFIG_DRM_EXYNOS_HDMI=y
|
CONFIG_DRM_EXYNOS_HDMI=y
|
||||||
CONFIG_DRM_PANEL_SIMPLE=y
|
CONFIG_DRM_PANEL_SIMPLE=y
|
||||||
CONFIG_DRM_PANEL_S6E8AA0=y
|
CONFIG_DRM_PANEL_SAMSUNG_S6E8AA0=y
|
||||||
CONFIG_FB_SIMPLE=y
|
CONFIG_FB_SIMPLE=y
|
||||||
CONFIG_EXYNOS_VIDEO=y
|
CONFIG_EXYNOS_VIDEO=y
|
||||||
CONFIG_EXYNOS_MIPI_DSI=y
|
CONFIG_EXYNOS_MIPI_DSI=y
|
||||||
|
@ -429,15 +429,15 @@ CONFIG_VIDEO_RENESAS_VSP1=m
|
|||||||
CONFIG_VIDEO_ADV7180=m
|
CONFIG_VIDEO_ADV7180=m
|
||||||
CONFIG_VIDEO_ML86V7667=m
|
CONFIG_VIDEO_ML86V7667=m
|
||||||
CONFIG_DRM=y
|
CONFIG_DRM=y
|
||||||
CONFIG_DRM_PTN3460=m
|
CONFIG_DRM_NXP_PTN3460=m
|
||||||
CONFIG_DRM_PS8622=m
|
CONFIG_DRM_PARADE_PS8622=m
|
||||||
CONFIG_DRM_EXYNOS=m
|
CONFIG_DRM_EXYNOS=m
|
||||||
CONFIG_DRM_EXYNOS_DSI=y
|
CONFIG_DRM_EXYNOS_DSI=y
|
||||||
CONFIG_DRM_EXYNOS_FIMD=y
|
CONFIG_DRM_EXYNOS_FIMD=y
|
||||||
CONFIG_DRM_EXYNOS_HDMI=y
|
CONFIG_DRM_EXYNOS_HDMI=y
|
||||||
CONFIG_DRM_RCAR_DU=m
|
CONFIG_DRM_RCAR_DU=m
|
||||||
CONFIG_DRM_TEGRA=y
|
CONFIG_DRM_TEGRA=y
|
||||||
CONFIG_DRM_PANEL_S6E8AA0=m
|
CONFIG_DRM_PANEL_SAMSUNG_S6E8AA0=m
|
||||||
CONFIG_DRM_PANEL_SIMPLE=y
|
CONFIG_DRM_PANEL_SIMPLE=y
|
||||||
CONFIG_FB_ARMCLCD=y
|
CONFIG_FB_ARMCLCD=y
|
||||||
CONFIG_FB_WM8505=y
|
CONFIG_FB_WM8505=y
|
||||||
|
@ -99,8 +99,6 @@ config DRM_KMS_CMA_HELPER
|
|||||||
|
|
||||||
source "drivers/gpu/drm/i2c/Kconfig"
|
source "drivers/gpu/drm/i2c/Kconfig"
|
||||||
|
|
||||||
source "drivers/gpu/drm/bridge/Kconfig"
|
|
||||||
|
|
||||||
config DRM_TDFX
|
config DRM_TDFX
|
||||||
tristate "3dfx Banshee/Voodoo3+"
|
tristate "3dfx Banshee/Voodoo3+"
|
||||||
depends on DRM && PCI
|
depends on DRM && PCI
|
||||||
@ -255,6 +253,8 @@ source "drivers/gpu/drm/tegra/Kconfig"
|
|||||||
|
|
||||||
source "drivers/gpu/drm/panel/Kconfig"
|
source "drivers/gpu/drm/panel/Kconfig"
|
||||||
|
|
||||||
|
source "drivers/gpu/drm/bridge/Kconfig"
|
||||||
|
|
||||||
source "drivers/gpu/drm/sti/Kconfig"
|
source "drivers/gpu/drm/sti/Kconfig"
|
||||||
|
|
||||||
source "drivers/gpu/drm/amd/amdkfd/Kconfig"
|
source "drivers/gpu/drm/amd/amdkfd/Kconfig"
|
||||||
|
@ -1,24 +1,32 @@
|
|||||||
|
config DRM_BRIDGE
|
||||||
|
def_bool y
|
||||||
|
depends on DRM
|
||||||
|
help
|
||||||
|
Bridge registration and lookup framework.
|
||||||
|
|
||||||
|
menu "Display Interface Bridges"
|
||||||
|
depends on DRM && DRM_BRIDGE
|
||||||
|
|
||||||
config DRM_DW_HDMI
|
config DRM_DW_HDMI
|
||||||
tristate
|
tristate
|
||||||
depends on DRM
|
|
||||||
select DRM_KMS_HELPER
|
select DRM_KMS_HELPER
|
||||||
|
|
||||||
config DRM_PTN3460
|
config DRM_NXP_PTN3460
|
||||||
tristate "PTN3460 DP/LVDS bridge"
|
tristate "NXP PTN3460 DP/LVDS bridge"
|
||||||
depends on DRM
|
|
||||||
depends on OF
|
depends on OF
|
||||||
select DRM_KMS_HELPER
|
select DRM_KMS_HELPER
|
||||||
select DRM_PANEL
|
select DRM_PANEL
|
||||||
---help---
|
---help---
|
||||||
ptn3460 eDP-LVDS bridge chip driver.
|
NXP PTN3460 eDP-LVDS bridge chip driver.
|
||||||
|
|
||||||
config DRM_PS8622
|
config DRM_PARADE_PS8622
|
||||||
tristate "Parade eDP/LVDS bridge"
|
tristate "Parade eDP/LVDS bridge"
|
||||||
depends on DRM
|
|
||||||
depends on OF
|
depends on OF
|
||||||
select DRM_PANEL
|
select DRM_PANEL
|
||||||
select DRM_KMS_HELPER
|
select DRM_KMS_HELPER
|
||||||
select BACKLIGHT_LCD_SUPPORT
|
select BACKLIGHT_LCD_SUPPORT
|
||||||
select BACKLIGHT_CLASS_DEVICE
|
select BACKLIGHT_CLASS_DEVICE
|
||||||
---help---
|
---help---
|
||||||
parade eDP-LVDS bridge chip driver.
|
Parade eDP-LVDS bridge chip driver.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
ccflags-y := -Iinclude/drm
|
ccflags-y := -Iinclude/drm
|
||||||
|
|
||||||
obj-$(CONFIG_DRM_PS8622) += ps8622.o
|
|
||||||
obj-$(CONFIG_DRM_PTN3460) += ptn3460.o
|
|
||||||
obj-$(CONFIG_DRM_DW_HDMI) += dw_hdmi.o
|
obj-$(CONFIG_DRM_DW_HDMI) += dw_hdmi.o
|
||||||
|
obj-$(CONFIG_DRM_NXP_PTN3460) += nxp-ptn3460.o
|
||||||
|
obj-$(CONFIG_DRM_PARADE_PS8622) += parade-ps8622.o
|
||||||
|
@ -56,7 +56,7 @@ config DRM_EXYNOS_DSI
|
|||||||
|
|
||||||
config DRM_EXYNOS_DP
|
config DRM_EXYNOS_DP
|
||||||
bool "EXYNOS DRM DP driver support"
|
bool "EXYNOS DRM DP driver support"
|
||||||
depends on DRM_EXYNOS && (DRM_EXYNOS_FIMD || DRM_EXYNOS7_DECON) && (DRM_PTN3460=n || DRM_PTN3460=y || DRM_PTN3460=DRM_EXYNOS)
|
depends on DRM_EXYNOS && (DRM_EXYNOS_FIMD || DRM_EXYNOS7_DECON)
|
||||||
default DRM_EXYNOS
|
default DRM_EXYNOS
|
||||||
select DRM_PANEL
|
select DRM_PANEL
|
||||||
help
|
help
|
||||||
|
@ -18,13 +18,21 @@ config DRM_PANEL_SIMPLE
|
|||||||
that it can be automatically turned off when the panel goes into a
|
that it can be automatically turned off when the panel goes into a
|
||||||
low power state.
|
low power state.
|
||||||
|
|
||||||
config DRM_PANEL_LD9040
|
config DRM_PANEL_SAMSUNG_LD9040
|
||||||
tristate "LD9040 RGB/SPI panel"
|
tristate "Samsung LD9040 RGB/SPI panel"
|
||||||
depends on OF && SPI
|
depends on OF && SPI
|
||||||
select VIDEOMODE_HELPERS
|
select VIDEOMODE_HELPERS
|
||||||
|
|
||||||
config DRM_PANEL_S6E8AA0
|
config DRM_PANEL_LG_LG4573
|
||||||
tristate "S6E8AA0 DSI video mode panel"
|
tristate "LG4573 RGB/SPI panel"
|
||||||
|
depends on OF && SPI
|
||||||
|
select VIDEOMODE_HELPERS
|
||||||
|
help
|
||||||
|
Say Y here if you want to enable support for LG4573 RGB panel.
|
||||||
|
To compile this driver as a module, choose M here.
|
||||||
|
|
||||||
|
config DRM_PANEL_SAMSUNG_S6E8AA0
|
||||||
|
tristate "Samsung S6E8AA0 DSI video mode panel"
|
||||||
depends on OF
|
depends on OF
|
||||||
select DRM_MIPI_DSI
|
select DRM_MIPI_DSI
|
||||||
select VIDEOMODE_HELPERS
|
select VIDEOMODE_HELPERS
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
obj-$(CONFIG_DRM_PANEL_SIMPLE) += panel-simple.o
|
obj-$(CONFIG_DRM_PANEL_SIMPLE) += panel-simple.o
|
||||||
obj-$(CONFIG_DRM_PANEL_LD9040) += panel-ld9040.o
|
obj-$(CONFIG_DRM_PANEL_LG_LG4573) += panel-lg-lg4573.o
|
||||||
obj-$(CONFIG_DRM_PANEL_S6E8AA0) += panel-s6e8aa0.o
|
obj-$(CONFIG_DRM_PANEL_SAMSUNG_LD9040) += panel-samsung-ld9040.o
|
||||||
|
obj-$(CONFIG_DRM_PANEL_SAMSUNG_S6E8AA0) += panel-samsung-s6e8aa0.o
|
||||||
obj-$(CONFIG_DRM_PANEL_SHARP_LQ101R1SX01) += panel-sharp-lq101r1sx01.o
|
obj-$(CONFIG_DRM_PANEL_SHARP_LQ101R1SX01) += panel-sharp-lq101r1sx01.o
|
||||||
|
298
drivers/gpu/drm/panel/panel-lg-lg4573.c
Normal file
298
drivers/gpu/drm/panel/panel-lg-lg4573.c
Normal file
@ -0,0 +1,298 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2015 Heiko Schocher <hs@denx.de>
|
||||||
|
*
|
||||||
|
* from:
|
||||||
|
* drivers/gpu/drm/panel/panel-ld9040.c
|
||||||
|
* ld9040 AMOLED LCD drm_panel driver.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014 Samsung Electronics Co., Ltd
|
||||||
|
* Derived from drivers/video/backlight/ld9040.c
|
||||||
|
*
|
||||||
|
* Andrzej Hajda <a.hajda@samsung.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <drm/drmP.h>
|
||||||
|
#include <drm/drm_panel.h>
|
||||||
|
|
||||||
|
#include <linux/gpio/consumer.h>
|
||||||
|
#include <linux/regulator/consumer.h>
|
||||||
|
#include <linux/spi/spi.h>
|
||||||
|
|
||||||
|
#include <video/mipi_display.h>
|
||||||
|
#include <video/of_videomode.h>
|
||||||
|
#include <video/videomode.h>
|
||||||
|
|
||||||
|
struct lg4573 {
|
||||||
|
struct drm_panel panel;
|
||||||
|
struct spi_device *spi;
|
||||||
|
struct videomode vm;
|
||||||
|
};
|
||||||
|
|
||||||
|
static inline struct lg4573 *panel_to_lg4573(struct drm_panel *panel)
|
||||||
|
{
|
||||||
|
return container_of(panel, struct lg4573, panel);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_spi_write_u16(struct lg4573 *ctx, u16 data)
|
||||||
|
{
|
||||||
|
struct spi_transfer xfer = {
|
||||||
|
.len = 2,
|
||||||
|
};
|
||||||
|
u16 temp = cpu_to_be16(data);
|
||||||
|
struct spi_message msg;
|
||||||
|
|
||||||
|
dev_dbg(ctx->panel.dev, "writing data: %x\n", data);
|
||||||
|
xfer.tx_buf = &temp;
|
||||||
|
spi_message_init(&msg);
|
||||||
|
spi_message_add_tail(&xfer, &msg);
|
||||||
|
|
||||||
|
return spi_sync(ctx->spi, &msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_spi_write_u16_array(struct lg4573 *ctx, const u16 *buffer,
|
||||||
|
unsigned int count)
|
||||||
|
{
|
||||||
|
unsigned int i;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
for (i = 0; i < count; i++) {
|
||||||
|
ret = lg4573_spi_write_u16(ctx, buffer[i]);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_spi_write_dcs(struct lg4573 *ctx, u8 dcs)
|
||||||
|
{
|
||||||
|
return lg4573_spi_write_u16(ctx, (0x70 << 8 | dcs));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_display_on(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = lg4573_spi_write_dcs(ctx, MIPI_DCS_EXIT_SLEEP_MODE);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
msleep(5);
|
||||||
|
|
||||||
|
return lg4573_spi_write_dcs(ctx, MIPI_DCS_SET_DISPLAY_ON);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_display_off(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = lg4573_spi_write_dcs(ctx, MIPI_DCS_SET_DISPLAY_OFF);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
msleep(120);
|
||||||
|
|
||||||
|
return lg4573_spi_write_dcs(ctx, MIPI_DCS_ENTER_SLEEP_MODE);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_display_mode_settings(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
static const u16 display_mode_settings[] = {
|
||||||
|
0x703A, 0x7270, 0x70B1, 0x7208,
|
||||||
|
0x723B, 0x720F, 0x70B2, 0x7200,
|
||||||
|
0x72C8, 0x70B3, 0x7200, 0x70B4,
|
||||||
|
0x7200, 0x70B5, 0x7242, 0x7210,
|
||||||
|
0x7210, 0x7200, 0x7220, 0x70B6,
|
||||||
|
0x720B, 0x720F, 0x723C, 0x7213,
|
||||||
|
0x7213, 0x72E8, 0x70B7, 0x7246,
|
||||||
|
0x7206, 0x720C, 0x7200, 0x7200,
|
||||||
|
};
|
||||||
|
|
||||||
|
dev_dbg(ctx->panel.dev, "transfer display mode settings\n");
|
||||||
|
return lg4573_spi_write_u16_array(ctx, display_mode_settings,
|
||||||
|
ARRAY_SIZE(display_mode_settings));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_power_settings(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
static const u16 power_settings[] = {
|
||||||
|
0x70C0, 0x7201, 0x7211, 0x70C3,
|
||||||
|
0x7207, 0x7203, 0x7204, 0x7204,
|
||||||
|
0x7204, 0x70C4, 0x7212, 0x7224,
|
||||||
|
0x7218, 0x7218, 0x7202, 0x7249,
|
||||||
|
0x70C5, 0x726F, 0x70C6, 0x7241,
|
||||||
|
0x7263,
|
||||||
|
};
|
||||||
|
|
||||||
|
dev_dbg(ctx->panel.dev, "transfer power settings\n");
|
||||||
|
return lg4573_spi_write_u16_array(ctx, power_settings,
|
||||||
|
ARRAY_SIZE(power_settings));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_gamma_settings(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
static const u16 gamma_settings[] = {
|
||||||
|
0x70D0, 0x7203, 0x7207, 0x7273,
|
||||||
|
0x7235, 0x7200, 0x7201, 0x7220,
|
||||||
|
0x7200, 0x7203, 0x70D1, 0x7203,
|
||||||
|
0x7207, 0x7273, 0x7235, 0x7200,
|
||||||
|
0x7201, 0x7220, 0x7200, 0x7203,
|
||||||
|
0x70D2, 0x7203, 0x7207, 0x7273,
|
||||||
|
0x7235, 0x7200, 0x7201, 0x7220,
|
||||||
|
0x7200, 0x7203, 0x70D3, 0x7203,
|
||||||
|
0x7207, 0x7273, 0x7235, 0x7200,
|
||||||
|
0x7201, 0x7220, 0x7200, 0x7203,
|
||||||
|
0x70D4, 0x7203, 0x7207, 0x7273,
|
||||||
|
0x7235, 0x7200, 0x7201, 0x7220,
|
||||||
|
0x7200, 0x7203, 0x70D5, 0x7203,
|
||||||
|
0x7207, 0x7273, 0x7235, 0x7200,
|
||||||
|
0x7201, 0x7220, 0x7200, 0x7203,
|
||||||
|
};
|
||||||
|
|
||||||
|
dev_dbg(ctx->panel.dev, "transfer gamma settings\n");
|
||||||
|
return lg4573_spi_write_u16_array(ctx, gamma_settings,
|
||||||
|
ARRAY_SIZE(gamma_settings));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_init(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
dev_dbg(ctx->panel.dev, "initializing LCD\n");
|
||||||
|
|
||||||
|
ret = lg4573_display_mode_settings(ctx);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
ret = lg4573_power_settings(ctx);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
return lg4573_gamma_settings(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_power_on(struct lg4573 *ctx)
|
||||||
|
{
|
||||||
|
return lg4573_display_on(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_disable(struct drm_panel *panel)
|
||||||
|
{
|
||||||
|
struct lg4573 *ctx = panel_to_lg4573(panel);
|
||||||
|
|
||||||
|
return lg4573_display_off(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_enable(struct drm_panel *panel)
|
||||||
|
{
|
||||||
|
struct lg4573 *ctx = panel_to_lg4573(panel);
|
||||||
|
|
||||||
|
lg4573_init(ctx);
|
||||||
|
|
||||||
|
return lg4573_power_on(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct drm_display_mode default_mode = {
|
||||||
|
.clock = 27000,
|
||||||
|
.hdisplay = 480,
|
||||||
|
.hsync_start = 480 + 10,
|
||||||
|
.hsync_end = 480 + 10 + 59,
|
||||||
|
.htotal = 480 + 10 + 59 + 10,
|
||||||
|
.vdisplay = 800,
|
||||||
|
.vsync_start = 800 + 15,
|
||||||
|
.vsync_end = 800 + 15 + 15,
|
||||||
|
.vtotal = 800 + 15 + 15 + 15,
|
||||||
|
.vrefresh = 60,
|
||||||
|
};
|
||||||
|
|
||||||
|
static int lg4573_get_modes(struct drm_panel *panel)
|
||||||
|
{
|
||||||
|
struct drm_connector *connector = panel->connector;
|
||||||
|
struct drm_display_mode *mode;
|
||||||
|
|
||||||
|
mode = drm_mode_duplicate(panel->drm, &default_mode);
|
||||||
|
if (!mode) {
|
||||||
|
dev_err(panel->drm->dev, "failed to add mode %ux%ux@%u\n",
|
||||||
|
default_mode.hdisplay, default_mode.vdisplay,
|
||||||
|
default_mode.vrefresh);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
drm_mode_set_name(mode);
|
||||||
|
|
||||||
|
mode->type = DRM_MODE_TYPE_DRIVER | DRM_MODE_TYPE_PREFERRED;
|
||||||
|
drm_mode_probed_add(connector, mode);
|
||||||
|
|
||||||
|
panel->connector->display_info.width_mm = 61;
|
||||||
|
panel->connector->display_info.height_mm = 103;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct drm_panel_funcs lg4573_drm_funcs = {
|
||||||
|
.disable = lg4573_disable,
|
||||||
|
.enable = lg4573_enable,
|
||||||
|
.get_modes = lg4573_get_modes,
|
||||||
|
};
|
||||||
|
|
||||||
|
static int lg4573_probe(struct spi_device *spi)
|
||||||
|
{
|
||||||
|
struct lg4573 *ctx;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ctx = devm_kzalloc(&spi->dev, sizeof(*ctx), GFP_KERNEL);
|
||||||
|
if (!ctx)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
ctx->spi = spi;
|
||||||
|
|
||||||
|
spi_set_drvdata(spi, ctx);
|
||||||
|
spi->bits_per_word = 8;
|
||||||
|
|
||||||
|
ret = spi_setup(spi);
|
||||||
|
if (ret < 0) {
|
||||||
|
dev_err(&spi->dev, "SPI setup failed: %d\n", ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
drm_panel_init(&ctx->panel);
|
||||||
|
ctx->panel.dev = &spi->dev;
|
||||||
|
ctx->panel.funcs = &lg4573_drm_funcs;
|
||||||
|
|
||||||
|
return drm_panel_add(&ctx->panel);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int lg4573_remove(struct spi_device *spi)
|
||||||
|
{
|
||||||
|
struct lg4573 *ctx = spi_get_drvdata(spi);
|
||||||
|
|
||||||
|
lg4573_display_off(ctx);
|
||||||
|
drm_panel_remove(&ctx->panel);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct of_device_id lg4573_of_match[] = {
|
||||||
|
{ .compatible = "lg,lg4573" },
|
||||||
|
{ }
|
||||||
|
};
|
||||||
|
MODULE_DEVICE_TABLE(of, lg4573_of_match);
|
||||||
|
|
||||||
|
static struct spi_driver lg4573_driver = {
|
||||||
|
.probe = lg4573_probe,
|
||||||
|
.remove = lg4573_remove,
|
||||||
|
.driver = {
|
||||||
|
.name = "lg4573",
|
||||||
|
.owner = THIS_MODULE,
|
||||||
|
.of_match_table = lg4573_of_match,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
module_spi_driver(lg4573_driver);
|
||||||
|
|
||||||
|
MODULE_AUTHOR("Heiko Schocher <hs@denx.de>");
|
||||||
|
MODULE_DESCRIPTION("lg4573 LCD Driver");
|
||||||
|
MODULE_LICENSE("GPL v2");
|
@ -377,7 +377,7 @@ static struct spi_driver ld9040_driver = {
|
|||||||
.probe = ld9040_probe,
|
.probe = ld9040_probe,
|
||||||
.remove = ld9040_remove,
|
.remove = ld9040_remove,
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "ld9040",
|
.name = "panel-samsung-ld9040",
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.of_match_table = ld9040_of_match,
|
.of_match_table = ld9040_of_match,
|
||||||
},
|
},
|
@ -1051,7 +1051,7 @@ static struct mipi_dsi_driver s6e8aa0_driver = {
|
|||||||
.probe = s6e8aa0_probe,
|
.probe = s6e8aa0_probe,
|
||||||
.remove = s6e8aa0_remove,
|
.remove = s6e8aa0_remove,
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "panel_s6e8aa0",
|
.name = "panel-samsung-s6e8aa0",
|
||||||
.of_match_table = s6e8aa0_of_match,
|
.of_match_table = s6e8aa0_of_match,
|
||||||
},
|
},
|
||||||
};
|
};
|
@ -713,7 +713,12 @@ static const struct display_timing hannstar_hsd070pww1_timing = {
|
|||||||
.hactive = { 1280, 1280, 1280 },
|
.hactive = { 1280, 1280, 1280 },
|
||||||
.hfront_porch = { 1, 1, 10 },
|
.hfront_porch = { 1, 1, 10 },
|
||||||
.hback_porch = { 1, 1, 10 },
|
.hback_porch = { 1, 1, 10 },
|
||||||
.hsync_len = { 52, 158, 661 },
|
/*
|
||||||
|
* According to the data sheet, the minimum horizontal blanking interval
|
||||||
|
* is 54 clocks (1 + 52 + 1), but tests with a Nitrogen6X have shown the
|
||||||
|
* minimum working horizontal blanking interval to be 60 clocks.
|
||||||
|
*/
|
||||||
|
.hsync_len = { 58, 158, 661 },
|
||||||
.vactive = { 800, 800, 800 },
|
.vactive = { 800, 800, 800 },
|
||||||
.vfront_porch = { 1, 1, 10 },
|
.vfront_porch = { 1, 1, 10 },
|
||||||
.vback_porch = { 1, 1, 10 },
|
.vback_porch = { 1, 1, 10 },
|
||||||
@ -729,6 +734,7 @@ static const struct panel_desc hannstar_hsd070pww1 = {
|
|||||||
.width = 151,
|
.width = 151,
|
||||||
.height = 94,
|
.height = 94,
|
||||||
},
|
},
|
||||||
|
.bus_format = MEDIA_BUS_FMT_RGB666_1X7X3_SPWG,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct display_timing hannstar_hsd100pxn1_timing = {
|
static const struct display_timing hannstar_hsd100pxn1_timing = {
|
||||||
@ -943,6 +949,60 @@ static const struct panel_desc lg_lp129qe = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct drm_display_mode nec_nl4827hc19_05b_mode = {
|
||||||
|
.clock = 10870,
|
||||||
|
.hdisplay = 480,
|
||||||
|
.hsync_start = 480 + 2,
|
||||||
|
.hsync_end = 480 + 2 + 41,
|
||||||
|
.htotal = 480 + 2 + 41 + 2,
|
||||||
|
.vdisplay = 272,
|
||||||
|
.vsync_start = 272 + 2,
|
||||||
|
.vsync_end = 272 + 2 + 4,
|
||||||
|
.vtotal = 272 + 2 + 4 + 2,
|
||||||
|
.vrefresh = 74,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct panel_desc nec_nl4827hc19_05b = {
|
||||||
|
.modes = &nec_nl4827hc19_05b_mode,
|
||||||
|
.num_modes = 1,
|
||||||
|
.bpc = 8,
|
||||||
|
.size = {
|
||||||
|
.width = 95,
|
||||||
|
.height = 54,
|
||||||
|
},
|
||||||
|
.bus_format = MEDIA_BUS_FMT_RGB888_1X24
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct display_timing okaya_rs800480t_7x0gp_timing = {
|
||||||
|
.pixelclock = { 30000000, 30000000, 40000000 },
|
||||||
|
.hactive = { 800, 800, 800 },
|
||||||
|
.hfront_porch = { 40, 40, 40 },
|
||||||
|
.hback_porch = { 40, 40, 40 },
|
||||||
|
.hsync_len = { 1, 48, 48 },
|
||||||
|
.vactive = { 480, 480, 480 },
|
||||||
|
.vfront_porch = { 13, 13, 13 },
|
||||||
|
.vback_porch = { 29, 29, 29 },
|
||||||
|
.vsync_len = { 3, 3, 3 },
|
||||||
|
.flags = DISPLAY_FLAGS_DE_HIGH,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct panel_desc okaya_rs800480t_7x0gp = {
|
||||||
|
.timings = &okaya_rs800480t_7x0gp_timing,
|
||||||
|
.num_timings = 1,
|
||||||
|
.bpc = 6,
|
||||||
|
.size = {
|
||||||
|
.width = 154,
|
||||||
|
.height = 87,
|
||||||
|
},
|
||||||
|
.delay = {
|
||||||
|
.prepare = 41,
|
||||||
|
.enable = 50,
|
||||||
|
.unprepare = 41,
|
||||||
|
.disable = 50,
|
||||||
|
},
|
||||||
|
.bus_format = MEDIA_BUS_FMT_RGB666_1X18,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct drm_display_mode ortustech_com43h4m85ulc_mode = {
|
static const struct drm_display_mode ortustech_com43h4m85ulc_mode = {
|
||||||
.clock = 25000,
|
.clock = 25000,
|
||||||
.hdisplay = 480,
|
.hdisplay = 480,
|
||||||
@ -1112,6 +1172,12 @@ static const struct of_device_id platform_of_match[] = {
|
|||||||
}, {
|
}, {
|
||||||
.compatible = "lg,lp129qe",
|
.compatible = "lg,lp129qe",
|
||||||
.data = &lg_lp129qe,
|
.data = &lg_lp129qe,
|
||||||
|
}, {
|
||||||
|
.compatible = "nec,nl4827hc19-05b",
|
||||||
|
.data = &nec_nl4827hc19_05b,
|
||||||
|
}, {
|
||||||
|
.compatible = "okaya,rs800480t-7x0gp",
|
||||||
|
.data = &okaya_rs800480t_7x0gp,
|
||||||
}, {
|
}, {
|
||||||
.compatible = "ortustech,com43h4m85ulc",
|
.compatible = "ortustech,com43h4m85ulc",
|
||||||
.data = &ortustech_com43h4m85ulc,
|
.data = &ortustech_com43h4m85ulc,
|
||||||
@ -1169,6 +1235,34 @@ struct panel_desc_dsi {
|
|||||||
unsigned int lanes;
|
unsigned int lanes;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct drm_display_mode auo_b080uan01_mode = {
|
||||||
|
.clock = 154500,
|
||||||
|
.hdisplay = 1200,
|
||||||
|
.hsync_start = 1200 + 62,
|
||||||
|
.hsync_end = 1200 + 62 + 4,
|
||||||
|
.htotal = 1200 + 62 + 4 + 62,
|
||||||
|
.vdisplay = 1920,
|
||||||
|
.vsync_start = 1920 + 9,
|
||||||
|
.vsync_end = 1920 + 9 + 2,
|
||||||
|
.vtotal = 1920 + 9 + 2 + 8,
|
||||||
|
.vrefresh = 60,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct panel_desc_dsi auo_b080uan01 = {
|
||||||
|
.desc = {
|
||||||
|
.modes = &auo_b080uan01_mode,
|
||||||
|
.num_modes = 1,
|
||||||
|
.bpc = 8,
|
||||||
|
.size = {
|
||||||
|
.width = 108,
|
||||||
|
.height = 272,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
.flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_CLOCK_NON_CONTINUOUS,
|
||||||
|
.format = MIPI_DSI_FMT_RGB888,
|
||||||
|
.lanes = 4,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct drm_display_mode lg_ld070wx3_sl01_mode = {
|
static const struct drm_display_mode lg_ld070wx3_sl01_mode = {
|
||||||
.clock = 71000,
|
.clock = 71000,
|
||||||
.hdisplay = 800,
|
.hdisplay = 800,
|
||||||
@ -1256,6 +1350,9 @@ static const struct panel_desc_dsi panasonic_vvx10f004b00 = {
|
|||||||
|
|
||||||
static const struct of_device_id dsi_of_match[] = {
|
static const struct of_device_id dsi_of_match[] = {
|
||||||
{
|
{
|
||||||
|
.compatible = "auo,b080uan01",
|
||||||
|
.data = &auo_b080uan01
|
||||||
|
}, {
|
||||||
.compatible = "lg,ld070wx3-sl01",
|
.compatible = "lg,ld070wx3-sl01",
|
||||||
.data = &lg_ld070wx3_sl01
|
.data = &lg_ld070wx3_sl01
|
||||||
}, {
|
}, {
|
||||||
|
Loading…
Reference in New Issue
Block a user