From: Yakir Yang <ykk@rock-chips.com> To: Heiko Stuebner <heiko@sntech.de>, Thierry Reding <treding@nvidia.com>, Jingoo Han <jingoohan1@gmail.com>, Fabio Estevam <fabio.estevam@freescale.com>, Inki Dae <inki.dae@samsung.com>, joe@perches.com, Russell King <rmk+kernel@arm.linux.org.uk> Cc: djkurtz@google.com, dianders@google.com, seanpaul@google.com, Takashi Iwai <tiwai@suse.de>, ajaynumb@gmail.com, Andrzej Hajda <a.hajda@samsung.com>, Kyungmin Park <kyungmin.park@samsung.com>, Philipp Zabel <p.zabel@pengutronix.de>, David Airlie <airlied@linux.ie>, Gustavo Padovan <gustavo.padovan@collabora.co.uk>, Vincent Palatin <vpalatin@chromium.org>, Mark Yao <mark.yao@rock-chips.com>, Andy Yan <andy.yan@rock-chips.com>, Kumar Gala <galak@codeaurora.org>, Ian Campbell <ijc+devicetree@hellion.org.uk>, Rob Herring <robh+dt@kernel.org>, Pawel Moll <pawel.moll@arm.com>, Kishon Vijay Abraham I <kishon@ti.com>, dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-samsung-soc@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-arm-kernel@lists.infradead.org, Yakir Yang <ykk@rock-chips.com> Subject: [PATCH v3 02/14] drm: exynos/dp: convert to drm bridge mode Date: Wed, 19 Aug 2015 09:49:50 -0500 [thread overview] Message-ID: <1439995790-18155-1-git-send-email-ykk@rock-chips.com> (raw) In-Reply-To: <1439995728-18046-1-git-send-email-ykk@rock-chips.com> In order to move exynos dp code to bridge directory, we need to convert driver drm bridge mode first. As dp driver already have a ptn3460 bridge, so we need to move ptn bridge to the next bridge of dp bridge. Signed-off-by: Yakir Yang <ykk@rock-chips.com> --- Changes in v3: None Changes in v2: - Take Jingoo Han suggest, just remove my name from author list. drivers/gpu/drm/exynos/exynos_dp_core.c | 194 ++++++++++++++++++++------------ drivers/gpu/drm/exynos/exynos_dp_core.h | 1 + 2 files changed, 123 insertions(+), 72 deletions(-) diff --git a/drivers/gpu/drm/exynos/exynos_dp_core.c b/drivers/gpu/drm/exynos/exynos_dp_core.c index 562f4a8..2b87406 100644 --- a/drivers/gpu/drm/exynos/exynos_dp_core.c +++ b/drivers/gpu/drm/exynos/exynos_dp_core.c @@ -997,59 +997,6 @@ static struct drm_connector_helper_funcs exynos_dp_connector_helper_funcs = { .best_encoder = exynos_dp_best_encoder, }; -/* returns the number of bridges attached */ -static int exynos_drm_attach_lcd_bridge(struct exynos_dp_device *dp, - struct drm_encoder *encoder) -{ - int ret; - - encoder->bridge = dp->bridge; - dp->bridge->encoder = encoder; - ret = drm_bridge_attach(encoder->dev, dp->bridge); - if (ret) { - DRM_ERROR("Failed to attach bridge to drm\n"); - return ret; - } - - return 0; -} - -static int exynos_dp_create_connector(struct exynos_drm_display *display, - struct drm_encoder *encoder) -{ - struct exynos_dp_device *dp = display_to_dp(display); - struct drm_connector *connector = &dp->connector; - int ret; - - dp->encoder = encoder; - - /* Pre-empt DP connector creation if there's a bridge */ - if (dp->bridge) { - ret = exynos_drm_attach_lcd_bridge(dp, encoder); - if (!ret) - return 0; - } - - connector->polled = DRM_CONNECTOR_POLL_HPD; - - ret = drm_connector_init(dp->drm_dev, connector, - &exynos_dp_connector_funcs, - DRM_MODE_CONNECTOR_eDP); - if (ret) { - DRM_ERROR("Failed to initialize connector with drm\n"); - return ret; - } - - drm_connector_helper_add(connector, &exynos_dp_connector_helper_funcs); - drm_connector_register(connector); - drm_mode_connector_attach_encoder(connector, encoder); - - if (dp->panel) - ret = drm_panel_attach(dp->panel, &dp->connector); - - return ret; -} - static void exynos_dp_phy_init(struct exynos_dp_device *dp) { if (dp->phy) @@ -1114,23 +1061,126 @@ static void exynos_dp_poweroff(struct exynos_dp_device *dp) } } -static void exynos_dp_dpms(struct exynos_drm_display *display, int mode) +/* returns the number of bridges attached */ +static int exynos_drm_attach_lcd_bridge(struct exynos_dp_device *dp, + struct drm_encoder *encoder) +{ + int ret; + + dp->bridge->next = dp->ptn_bridge; + dp->bridge->encoder = encoder; + ret = drm_bridge_attach(encoder->dev, dp->bridge); + if (ret) { + DRM_ERROR("Failed to attach ptn bridge to drm\n"); + return ret; + } + + return 0; +} + +static int exynos_dp_bridge_attach(struct drm_bridge *bridge) +{ + + struct exynos_dp_device *dp = bridge->driver_private; + struct drm_encoder *encoder = dp->encoder; + struct drm_connector *connector = &dp->connector; + int ret; + + if (!bridge->encoder) { + DRM_ERROR("Parent encoder object not found"); + return -ENODEV; + } + + encoder->bridge = bridge; + + /* Pre-empt DP connector creation if there's a bridge */ + if (dp->ptn_bridge) { + ret = exynos_drm_attach_lcd_bridge(dp, encoder); + if (ret) + return -ENODEV; + } + + connector->polled = DRM_CONNECTOR_POLL_HPD; + + ret = drm_connector_init(dp->drm_dev, connector, + &exynos_dp_connector_funcs, DRM_MODE_CONNECTOR_eDP); + if (ret) { + DRM_ERROR("Failed to initialize connector with drm\n"); + return ret; + } + + drm_connector_helper_add(connector, &exynos_dp_connector_helper_funcs); + drm_connector_register(connector); + drm_mode_connector_attach_encoder(connector, encoder); + + if (dp->panel) + ret = drm_panel_attach(dp->panel, &dp->connector); + + return ret; +} + +static void exynos_dp_bridge_nop(struct drm_bridge *bridge) +{ + /* do nothing */ +} + +static void exynos_dp_bridge_enable(struct drm_bridge *bridge) +{ + struct exynos_dp_device *dp = bridge->driver_private; + + exynos_dp_poweron(dp); + dp->dpms_mode = DRM_MODE_DPMS_ON; +} + +static void exynos_dp_bridge_disable(struct drm_bridge *bridge) +{ + struct exynos_dp_device *dp = bridge->driver_private; + + exynos_dp_poweroff(dp); + dp->dpms_mode = DRM_MODE_DPMS_OFF; +} + +static const struct drm_bridge_funcs exynos_dp_bridge_funcs = { + .enable = exynos_dp_bridge_enable, + .disable = exynos_dp_bridge_disable, + .pre_enable = exynos_dp_bridge_nop, + .post_disable = exynos_dp_bridge_nop, + .attach = exynos_dp_bridge_attach, +}; + +static int exynos_dp_create_connector(struct exynos_drm_display *display, + struct drm_encoder *encoder) { struct exynos_dp_device *dp = display_to_dp(display); + struct drm_device *drm_dev = dp->drm_dev; + struct drm_bridge *bridge; + int ret; - switch (mode) { - case DRM_MODE_DPMS_ON: - exynos_dp_poweron(dp); - break; - case DRM_MODE_DPMS_STANDBY: - case DRM_MODE_DPMS_SUSPEND: - case DRM_MODE_DPMS_OFF: - exynos_dp_poweroff(dp); - break; - default: - break; + bridge = devm_kzalloc(drm_dev->dev, sizeof(*bridge), GFP_KERNEL); + if (!bridge) { + DRM_ERROR("failed to allocate for drm bridge\n"); + return -ENOMEM; } - dp->dpms_mode = mode; + + dp->bridge = bridge; + dp->encoder = encoder; + + bridge->driver_private = dp; + bridge->encoder = dp->encoder; + bridge->funcs = &exynos_dp_bridge_funcs; + + ret = drm_bridge_attach(drm_dev, bridge); + if (ret) { + DRM_ERROR("failed to attach drm bridge\n"); + return -EINVAL; + } + + return 0; +} + +static void exynos_dp_dpms(struct exynos_drm_display *display, int mode) +{ + /* do nothing */ } static struct exynos_drm_display_ops exynos_dp_display_ops = { @@ -1242,7 +1292,7 @@ static int exynos_dp_bind(struct device *dev, struct device *master, void *data) } } - if (!dp->panel && !dp->bridge) { + if (!dp->panel && !dp->ptn_bridge) { ret = exynos_dp_dt_parse_panel(dp); if (ret) return ret; @@ -1315,7 +1365,7 @@ static void exynos_dp_unbind(struct device *dev, struct device *master, { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_OFF); + exynos_dp_bridge_disable(dp->bridge); } static const struct component_ops exynos_dp_ops = { @@ -1350,9 +1400,9 @@ static int exynos_dp_probe(struct platform_device *pdev) if (endpoint) { bridge_node = of_graph_get_remote_port_parent(endpoint); if (bridge_node) { - dp->bridge = of_drm_find_bridge(bridge_node); + dp->ptn_bridge = of_drm_find_bridge(bridge_node); of_node_put(bridge_node); - if (!dp->bridge) + if (!dp->ptn_bridge) return -EPROBE_DEFER; } else { return -EPROBE_DEFER; @@ -1374,7 +1424,7 @@ static int exynos_dp_suspend(struct device *dev) { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_OFF); + exynos_dp_bridge_disable(dp->bridge); return 0; } @@ -1382,7 +1432,7 @@ static int exynos_dp_resume(struct device *dev) { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_ON); + exynos_dp_bridge_enable(dp->bridge); return 0; } #endif diff --git a/drivers/gpu/drm/exynos/exynos_dp_core.h b/drivers/gpu/drm/exynos/exynos_dp_core.h index c321ad5..29bd56e 100644 --- a/drivers/gpu/drm/exynos/exynos_dp_core.h +++ b/drivers/gpu/drm/exynos/exynos_dp_core.h @@ -154,6 +154,7 @@ struct exynos_dp_device { struct drm_encoder *encoder; struct drm_panel *panel; struct drm_bridge *bridge; + struct drm_bridge *ptn_bridge; struct clk *clock; unsigned int irq; void __iomem *reg_base; -- 1.9.1
WARNING: multiple messages have this Message-ID (diff)
From: ykk@rock-chips.com (Yakir Yang) To: linux-arm-kernel@lists.infradead.org Subject: [PATCH v3 02/14] drm: exynos/dp: convert to drm bridge mode Date: Wed, 19 Aug 2015 09:49:50 -0500 [thread overview] Message-ID: <1439995790-18155-1-git-send-email-ykk@rock-chips.com> (raw) In-Reply-To: <1439995728-18046-1-git-send-email-ykk@rock-chips.com> In order to move exynos dp code to bridge directory, we need to convert driver drm bridge mode first. As dp driver already have a ptn3460 bridge, so we need to move ptn bridge to the next bridge of dp bridge. Signed-off-by: Yakir Yang <ykk@rock-chips.com> --- Changes in v3: None Changes in v2: - Take Jingoo Han suggest, just remove my name from author list. drivers/gpu/drm/exynos/exynos_dp_core.c | 194 ++++++++++++++++++++------------ drivers/gpu/drm/exynos/exynos_dp_core.h | 1 + 2 files changed, 123 insertions(+), 72 deletions(-) diff --git a/drivers/gpu/drm/exynos/exynos_dp_core.c b/drivers/gpu/drm/exynos/exynos_dp_core.c index 562f4a8..2b87406 100644 --- a/drivers/gpu/drm/exynos/exynos_dp_core.c +++ b/drivers/gpu/drm/exynos/exynos_dp_core.c @@ -997,59 +997,6 @@ static struct drm_connector_helper_funcs exynos_dp_connector_helper_funcs = { .best_encoder = exynos_dp_best_encoder, }; -/* returns the number of bridges attached */ -static int exynos_drm_attach_lcd_bridge(struct exynos_dp_device *dp, - struct drm_encoder *encoder) -{ - int ret; - - encoder->bridge = dp->bridge; - dp->bridge->encoder = encoder; - ret = drm_bridge_attach(encoder->dev, dp->bridge); - if (ret) { - DRM_ERROR("Failed to attach bridge to drm\n"); - return ret; - } - - return 0; -} - -static int exynos_dp_create_connector(struct exynos_drm_display *display, - struct drm_encoder *encoder) -{ - struct exynos_dp_device *dp = display_to_dp(display); - struct drm_connector *connector = &dp->connector; - int ret; - - dp->encoder = encoder; - - /* Pre-empt DP connector creation if there's a bridge */ - if (dp->bridge) { - ret = exynos_drm_attach_lcd_bridge(dp, encoder); - if (!ret) - return 0; - } - - connector->polled = DRM_CONNECTOR_POLL_HPD; - - ret = drm_connector_init(dp->drm_dev, connector, - &exynos_dp_connector_funcs, - DRM_MODE_CONNECTOR_eDP); - if (ret) { - DRM_ERROR("Failed to initialize connector with drm\n"); - return ret; - } - - drm_connector_helper_add(connector, &exynos_dp_connector_helper_funcs); - drm_connector_register(connector); - drm_mode_connector_attach_encoder(connector, encoder); - - if (dp->panel) - ret = drm_panel_attach(dp->panel, &dp->connector); - - return ret; -} - static void exynos_dp_phy_init(struct exynos_dp_device *dp) { if (dp->phy) @@ -1114,23 +1061,126 @@ static void exynos_dp_poweroff(struct exynos_dp_device *dp) } } -static void exynos_dp_dpms(struct exynos_drm_display *display, int mode) +/* returns the number of bridges attached */ +static int exynos_drm_attach_lcd_bridge(struct exynos_dp_device *dp, + struct drm_encoder *encoder) +{ + int ret; + + dp->bridge->next = dp->ptn_bridge; + dp->bridge->encoder = encoder; + ret = drm_bridge_attach(encoder->dev, dp->bridge); + if (ret) { + DRM_ERROR("Failed to attach ptn bridge to drm\n"); + return ret; + } + + return 0; +} + +static int exynos_dp_bridge_attach(struct drm_bridge *bridge) +{ + + struct exynos_dp_device *dp = bridge->driver_private; + struct drm_encoder *encoder = dp->encoder; + struct drm_connector *connector = &dp->connector; + int ret; + + if (!bridge->encoder) { + DRM_ERROR("Parent encoder object not found"); + return -ENODEV; + } + + encoder->bridge = bridge; + + /* Pre-empt DP connector creation if there's a bridge */ + if (dp->ptn_bridge) { + ret = exynos_drm_attach_lcd_bridge(dp, encoder); + if (ret) + return -ENODEV; + } + + connector->polled = DRM_CONNECTOR_POLL_HPD; + + ret = drm_connector_init(dp->drm_dev, connector, + &exynos_dp_connector_funcs, DRM_MODE_CONNECTOR_eDP); + if (ret) { + DRM_ERROR("Failed to initialize connector with drm\n"); + return ret; + } + + drm_connector_helper_add(connector, &exynos_dp_connector_helper_funcs); + drm_connector_register(connector); + drm_mode_connector_attach_encoder(connector, encoder); + + if (dp->panel) + ret = drm_panel_attach(dp->panel, &dp->connector); + + return ret; +} + +static void exynos_dp_bridge_nop(struct drm_bridge *bridge) +{ + /* do nothing */ +} + +static void exynos_dp_bridge_enable(struct drm_bridge *bridge) +{ + struct exynos_dp_device *dp = bridge->driver_private; + + exynos_dp_poweron(dp); + dp->dpms_mode = DRM_MODE_DPMS_ON; +} + +static void exynos_dp_bridge_disable(struct drm_bridge *bridge) +{ + struct exynos_dp_device *dp = bridge->driver_private; + + exynos_dp_poweroff(dp); + dp->dpms_mode = DRM_MODE_DPMS_OFF; +} + +static const struct drm_bridge_funcs exynos_dp_bridge_funcs = { + .enable = exynos_dp_bridge_enable, + .disable = exynos_dp_bridge_disable, + .pre_enable = exynos_dp_bridge_nop, + .post_disable = exynos_dp_bridge_nop, + .attach = exynos_dp_bridge_attach, +}; + +static int exynos_dp_create_connector(struct exynos_drm_display *display, + struct drm_encoder *encoder) { struct exynos_dp_device *dp = display_to_dp(display); + struct drm_device *drm_dev = dp->drm_dev; + struct drm_bridge *bridge; + int ret; - switch (mode) { - case DRM_MODE_DPMS_ON: - exynos_dp_poweron(dp); - break; - case DRM_MODE_DPMS_STANDBY: - case DRM_MODE_DPMS_SUSPEND: - case DRM_MODE_DPMS_OFF: - exynos_dp_poweroff(dp); - break; - default: - break; + bridge = devm_kzalloc(drm_dev->dev, sizeof(*bridge), GFP_KERNEL); + if (!bridge) { + DRM_ERROR("failed to allocate for drm bridge\n"); + return -ENOMEM; } - dp->dpms_mode = mode; + + dp->bridge = bridge; + dp->encoder = encoder; + + bridge->driver_private = dp; + bridge->encoder = dp->encoder; + bridge->funcs = &exynos_dp_bridge_funcs; + + ret = drm_bridge_attach(drm_dev, bridge); + if (ret) { + DRM_ERROR("failed to attach drm bridge\n"); + return -EINVAL; + } + + return 0; +} + +static void exynos_dp_dpms(struct exynos_drm_display *display, int mode) +{ + /* do nothing */ } static struct exynos_drm_display_ops exynos_dp_display_ops = { @@ -1242,7 +1292,7 @@ static int exynos_dp_bind(struct device *dev, struct device *master, void *data) } } - if (!dp->panel && !dp->bridge) { + if (!dp->panel && !dp->ptn_bridge) { ret = exynos_dp_dt_parse_panel(dp); if (ret) return ret; @@ -1315,7 +1365,7 @@ static void exynos_dp_unbind(struct device *dev, struct device *master, { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_OFF); + exynos_dp_bridge_disable(dp->bridge); } static const struct component_ops exynos_dp_ops = { @@ -1350,9 +1400,9 @@ static int exynos_dp_probe(struct platform_device *pdev) if (endpoint) { bridge_node = of_graph_get_remote_port_parent(endpoint); if (bridge_node) { - dp->bridge = of_drm_find_bridge(bridge_node); + dp->ptn_bridge = of_drm_find_bridge(bridge_node); of_node_put(bridge_node); - if (!dp->bridge) + if (!dp->ptn_bridge) return -EPROBE_DEFER; } else { return -EPROBE_DEFER; @@ -1374,7 +1424,7 @@ static int exynos_dp_suspend(struct device *dev) { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_OFF); + exynos_dp_bridge_disable(dp->bridge); return 0; } @@ -1382,7 +1432,7 @@ static int exynos_dp_resume(struct device *dev) { struct exynos_dp_device *dp = dev_get_drvdata(dev); - exynos_dp_dpms(&dp->display, DRM_MODE_DPMS_ON); + exynos_dp_bridge_enable(dp->bridge); return 0; } #endif diff --git a/drivers/gpu/drm/exynos/exynos_dp_core.h b/drivers/gpu/drm/exynos/exynos_dp_core.h index c321ad5..29bd56e 100644 --- a/drivers/gpu/drm/exynos/exynos_dp_core.h +++ b/drivers/gpu/drm/exynos/exynos_dp_core.h @@ -154,6 +154,7 @@ struct exynos_dp_device { struct drm_encoder *encoder; struct drm_panel *panel; struct drm_bridge *bridge; + struct drm_bridge *ptn_bridge; struct clk *clock; unsigned int irq; void __iomem *reg_base; -- 1.9.1
next prev parent reply other threads:[~2015-08-19 14:50 UTC|newest] Thread overview: 187+ messages / expand[flat|nested] mbox.gz Atom feed top 2015-08-19 14:48 [PATCH v3 0/14] Add Analogix Core Display Port Driver Yakir Yang 2015-08-19 14:48 ` Yakir Yang 2015-08-19 14:49 ` [PATCH v3 01/14] drm: exynos/dp: fix code style Yakir Yang 2015-08-19 14:49 ` Yakir Yang 2015-08-19 14:49 ` Yakir Yang [this message] 2015-08-19 14:49 ` [PATCH v3 02/14] drm: exynos/dp: convert to drm bridge mode Yakir Yang 2015-08-19 14:50 ` [PATCH v3 03/14] drm: bridge: analogix_dp: split exynos dp driver to bridge dir Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-19 14:50 ` [PATCH v3 04/14] drm: bridge/analogix_dp: dynamic parse sync_pol & interlace & colorimetry Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-19 14:50 ` [PATCH v3 05/14] drm: bridge/analogix_dp: fix link_rate & lane_count bug Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-20 7:22 ` Jingoo Han 2015-08-20 7:22 ` Jingoo Han 2015-08-20 7:22 ` Jingoo Han 2015-08-20 8:04 ` Yakir Yang 2015-08-20 8:04 ` Yakir Yang 2015-08-20 8:04 ` Yakir Yang 2015-08-19 14:50 ` [PATCH v3 06/14] Documentation: drm/bridge: add document for analogix_dp Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-23 23:23 ` Rob Herring 2015-08-23 23:23 ` Rob Herring 2015-08-23 23:23 ` Rob Herring 2015-08-24 0:43 ` Krzysztof Kozlowski 2015-08-24 0:43 ` Krzysztof Kozlowski 2015-08-24 0:43 ` Krzysztof Kozlowski 2015-08-24 2:42 ` Yakir Yang 2015-08-24 2:42 ` Yakir Yang 2015-08-24 4:20 ` Krzysztof Kozlowski 2015-08-24 4:20 ` Krzysztof Kozlowski 2015-08-24 4:20 ` Krzysztof Kozlowski 2015-08-24 12:48 ` Yakir Yang 2015-08-24 12:48 ` Yakir Yang 2015-08-24 12:48 ` Yakir Yang 2015-08-24 13:03 ` Heiko Stuebner 2015-08-24 13:03 ` Heiko Stuebner 2015-08-24 13:03 ` Heiko Stuebner 2015-08-25 1:37 ` Yakir Yang 2015-08-25 1:37 ` Yakir Yang 2015-08-25 1:37 ` Yakir Yang 2015-08-24 23:49 ` Krzysztof Kozlowski 2015-08-24 23:49 ` Krzysztof Kozlowski 2015-08-24 23:49 ` Krzysztof Kozlowski [not found] ` <55DBAD90.3040901-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org> 2015-08-25 1:32 ` Yakir Yang 2015-08-25 1:33 ` Yakir Yang 2015-08-25 1:33 ` Yakir Yang 2015-08-25 1:33 ` Yakir Yang 2015-08-25 1:35 ` Krzysztof Kozlowski 2015-08-25 1:35 ` Krzysztof Kozlowski 2015-08-25 1:35 ` Krzysztof Kozlowski 2015-08-24 7:40 ` Jingoo Han 2015-08-24 7:40 ` Jingoo Han 2015-08-24 7:40 ` Jingoo Han 2015-08-24 12:55 ` Yakir Yang 2015-08-24 12:55 ` Yakir Yang 2015-08-24 12:55 ` Yakir Yang 2015-08-24 2:19 ` Yakir Yang 2015-08-24 2:19 ` Yakir Yang 2015-08-24 12:57 ` Russell King - ARM Linux 2015-08-24 12:57 ` Russell King - ARM Linux 2015-08-24 12:57 ` Russell King - ARM Linux 2015-08-24 14:48 ` Rob Herring 2015-08-24 14:48 ` Rob Herring 2015-08-24 14:48 ` Rob Herring 2015-08-24 16:16 ` Heiko Stuebner 2015-08-24 16:16 ` Heiko Stuebner 2015-08-24 16:16 ` Heiko Stuebner 2015-08-25 1:21 ` Yakir Yang 2015-08-25 1:21 ` Yakir Yang 2015-08-25 1:21 ` Yakir Yang 2015-08-25 9:12 ` Thierry Reding 2015-08-25 9:12 ` Thierry Reding 2015-08-25 9:12 ` Thierry Reding 2015-08-25 9:29 ` Russell King - ARM Linux 2015-08-25 9:29 ` Russell King - ARM Linux 2015-08-25 9:29 ` Russell King - ARM Linux 2015-08-25 10:40 ` Thierry Reding 2015-08-25 10:40 ` Thierry Reding 2015-08-25 10:40 ` Thierry Reding 2015-08-25 10:52 ` Russell King - ARM Linux 2015-08-25 10:52 ` Russell King - ARM Linux 2015-08-25 10:52 ` Russell King - ARM Linux 2015-08-25 9:41 ` Yakir Yang 2015-08-25 9:41 ` Yakir Yang 2015-08-25 10:06 ` Thierry Reding 2015-08-25 10:06 ` Thierry Reding 2015-08-25 10:06 ` Thierry Reding 2015-08-25 14:02 ` Yakir Yang 2015-08-25 14:02 ` Yakir Yang 2015-08-25 9:15 ` Thierry Reding 2015-08-25 9:15 ` Thierry Reding 2015-08-25 9:15 ` Thierry Reding 2015-08-25 9:37 ` Yakir Yang 2015-08-25 9:37 ` Yakir Yang 2015-08-25 13:27 ` Rob Herring 2015-08-25 13:27 ` Rob Herring 2015-08-25 13:27 ` Rob Herring 2015-08-25 13:48 ` Yakir Yang 2015-08-25 14:16 ` Thierry Reding 2015-08-25 14:16 ` Thierry Reding 2015-08-25 14:16 ` Thierry Reding 2015-08-25 14:23 ` Yakir Yang 2015-08-25 14:23 ` Yakir Yang 2015-08-25 9:58 ` Thierry Reding 2015-08-25 9:58 ` Thierry Reding 2015-08-25 9:58 ` Thierry Reding 2015-08-25 14:03 ` Yakir Yang 2015-08-25 14:03 ` Yakir Yang 2015-08-25 14:21 ` Thierry Reding 2015-08-25 14:21 ` Thierry Reding 2015-08-25 14:21 ` Thierry Reding 2015-08-25 15:57 ` Russell King - ARM Linux 2015-08-25 15:57 ` Russell King - ARM Linux 2015-08-25 15:57 ` Russell King - ARM Linux 2015-08-19 14:50 ` [PATCH v3 07/14] drm: rockchip/dp: add rockchip platform dp driver Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-19 14:50 ` Yakir Yang 2015-08-19 14:51 ` [PATCH v3 08/14] phy: Add driver for rockchip Display Port PHY Yakir Yang 2015-08-19 14:51 ` Yakir Yang 2015-08-20 4:40 ` Kishon Vijay Abraham I 2015-08-20 4:40 ` Kishon Vijay Abraham I 2015-08-20 4:40 ` Kishon Vijay Abraham I 2015-08-20 6:56 ` Yakir Yang 2015-08-20 7:01 ` Yakir Yang 2015-08-19 14:51 ` [PATCH v3 09/14] drm: bridge/analogix_dp: add platform device type support Yakir Yang 2015-08-19 14:51 ` Yakir Yang 2015-08-19 14:51 ` Yakir Yang 2015-08-19 14:51 ` [PATCH v3 10/14] drm: bridge: analogix_dp: add some rk3288 special registers setting Yakir Yang 2015-08-19 14:51 ` Yakir Yang 2015-08-19 14:51 ` [PATCH v3 11/14] drm: bridge: analogix_dp: try force hpd after plug in lookup failed Yakir Yang 2015-08-19 14:51 ` Yakir Yang 2015-08-19 14:52 ` [PATCH v3 12/14] drm: bridge/analogix_dp: expand the delay time for hpd detect Yakir Yang 2015-08-19 14:52 ` Yakir Yang 2015-08-19 14:52 ` Yakir Yang 2015-08-20 6:11 ` Jingoo Han 2015-08-20 6:11 ` Jingoo Han 2015-08-20 6:11 ` Jingoo Han 2015-08-20 8:02 ` Yakir Yang 2015-08-20 8:02 ` Yakir Yang 2015-08-20 8:02 ` Yakir Yang 2015-08-19 14:52 ` [PATCH v3 13/14] drm: bridge/analogix_dp: move hpd detect to connector detect function Yakir Yang 2015-08-19 14:52 ` Yakir Yang 2015-08-20 7:49 ` Jingoo Han 2015-08-20 7:49 ` Jingoo Han 2015-08-20 7:49 ` Jingoo Han 2015-08-20 8:18 ` Yakir Yang 2015-08-20 8:18 ` Yakir Yang 2015-08-20 8:18 ` Yakir Yang 2015-08-19 14:52 ` [PATCH v3 14/14] drm: bridge/analogix_dp: add edid modes parse in get_modes method Yakir Yang 2015-08-19 14:52 ` Yakir Yang 2015-08-19 23:54 ` [PATCH v3 0/14] Add Analogix Core Display Port Driver Dave Airlie 2015-08-19 23:54 ` Dave Airlie 2015-08-19 23:54 ` Dave Airlie 2015-08-20 1:02 ` Yakir Yang 2015-08-20 1:02 ` Yakir Yang 2015-08-20 1:02 ` Yakir Yang 2015-08-20 4:29 ` Archit Taneja 2015-08-20 4:29 ` Archit Taneja 2015-08-20 4:29 ` Archit Taneja 2015-08-20 5:54 ` Jingoo Han 2015-08-20 5:54 ` Jingoo Han 2015-08-20 5:54 ` Jingoo Han 2015-08-20 6:23 ` Yakir Yang 2015-08-20 6:23 ` Yakir Yang 2015-08-20 6:23 ` Yakir Yang 2015-08-20 6:55 ` Jingoo Han 2015-08-20 6:55 ` Jingoo Han 2015-08-20 6:55 ` Jingoo Han 2015-08-20 8:03 ` Yakir Yang 2015-08-20 8:03 ` Yakir Yang 2015-08-20 8:03 ` Yakir Yang 2015-08-21 8:20 ` Jingoo Han 2015-08-21 8:20 ` Jingoo Han 2015-08-21 8:20 ` Jingoo Han 2015-08-21 10:01 ` Yakir Yang 2015-08-21 11:24 ` Jingoo Han 2015-08-21 13:16 ` Thierry Reding 2015-08-21 13:16 ` Thierry Reding 2015-08-21 13:16 ` Thierry Reding 2015-08-22 10:13 ` Yakir Yang 2015-08-30 12:16 ` Romain Perier 2015-08-30 12:16 ` Romain Perier 2015-08-30 12:16 ` Romain Perier 2015-08-31 2:40 ` Yakir Yang 2015-08-31 2:40 ` Yakir Yang 2015-08-31 2:40 ` Yakir Yang 2015-08-22 9:42 ` Yakir Yang
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1439995790-18155-1-git-send-email-ykk@rock-chips.com \ --to=ykk@rock-chips.com \ --cc=a.hajda@samsung.com \ --cc=airlied@linux.ie \ --cc=ajaynumb@gmail.com \ --cc=andy.yan@rock-chips.com \ --cc=devicetree@vger.kernel.org \ --cc=dianders@google.com \ --cc=djkurtz@google.com \ --cc=dri-devel@lists.freedesktop.org \ --cc=fabio.estevam@freescale.com \ --cc=galak@codeaurora.org \ --cc=gustavo.padovan@collabora.co.uk \ --cc=heiko@sntech.de \ --cc=ijc+devicetree@hellion.org.uk \ --cc=inki.dae@samsung.com \ --cc=jingoohan1@gmail.com \ --cc=joe@perches.com \ --cc=kishon@ti.com \ --cc=kyungmin.park@samsung.com \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-rockchip@lists.infradead.org \ --cc=linux-samsung-soc@vger.kernel.org \ --cc=mark.yao@rock-chips.com \ --cc=p.zabel@pengutronix.de \ --cc=pawel.moll@arm.com \ --cc=rmk+kernel@arm.linux.org.uk \ --cc=robh+dt@kernel.org \ --cc=seanpaul@google.com \ --cc=tiwai@suse.de \ --cc=treding@nvidia.com \ --cc=vpalatin@chromium.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.