Commit ad86ebe7 authored by Linus Walleij's avatar Linus Walleij

drm/pl111: Add optional variant display en/disable callbacks

The silcon and components around the PL111 may require some
variants to perform special set-up of the display. Add two
callbacks to manage this.
Reviewed-by: default avatarEric Anholt <eric@anholt.net>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20170908124709.4758-6-linus.walleij@linaro.org
parent 52289a07
...@@ -208,6 +208,9 @@ static void pl111_display_enable(struct drm_simple_display_pipe *pipe, ...@@ -208,6 +208,9 @@ static void pl111_display_enable(struct drm_simple_display_pipe *pipe,
*/ */
msleep(20); msleep(20);
if (priv->variant_display_enable)
priv->variant_display_enable(drm, fb->format->format);
/* Power Up */ /* Power Up */
cntl |= CNTL_LCDPWR; cntl |= CNTL_LCDPWR;
writel(cntl, priv->regs + priv->ctrl); writel(cntl, priv->regs + priv->ctrl);
...@@ -237,6 +240,9 @@ void pl111_display_disable(struct drm_simple_display_pipe *pipe) ...@@ -237,6 +240,9 @@ void pl111_display_disable(struct drm_simple_display_pipe *pipe)
*/ */
msleep(20); msleep(20);
if (priv->variant_display_disable)
priv->variant_display_disable(drm);
/* Disable */ /* Disable */
writel(0, priv->regs + priv->ctrl); writel(0, priv->regs + priv->ctrl);
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include <drm/drm_panel.h> #include <drm/drm_panel.h>
#include <drm/drm_bridge.h> #include <drm/drm_bridge.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/interrupt.h>
#define CLCD_IRQ_NEXTBASE_UPDATE BIT(2) #define CLCD_IRQ_NEXTBASE_UPDATE BIT(2)
...@@ -66,6 +67,8 @@ struct pl111_drm_dev_private { ...@@ -66,6 +67,8 @@ struct pl111_drm_dev_private {
*/ */
spinlock_t tim2_lock; spinlock_t tim2_lock;
const struct pl111_variant_data *variant; const struct pl111_variant_data *variant;
void (*variant_display_enable) (struct drm_device *drm, u32 format);
void (*variant_display_disable) (struct drm_device *drm);
}; };
int pl111_display_init(struct drm_device *dev); int pl111_display_init(struct drm_device *dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment