drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Red Hat
|
|
|
|
* Author: Rob Clark <robdclark@gmail.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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MDP4_KMS_H__
|
|
|
|
#define __MDP4_KMS_H__
|
|
|
|
|
|
|
|
#include "msm_drv.h"
|
2013-11-30 21:12:10 +00:00
|
|
|
#include "msm_kms.h"
|
2013-11-30 19:58:23 +00:00
|
|
|
#include "mdp/mdp_kms.h"
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
#include "mdp4.xml.h"
|
|
|
|
|
2014-08-01 17:08:11 +00:00
|
|
|
#include "drm_panel.h"
|
|
|
|
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
struct mdp4_kms {
|
2013-11-30 22:24:22 +00:00
|
|
|
struct mdp_kms base;
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
|
|
|
|
struct drm_device *dev;
|
|
|
|
|
|
|
|
int rev;
|
|
|
|
|
|
|
|
/* mapper-id used to request GEM buffer mapped for scanout: */
|
|
|
|
int id;
|
|
|
|
|
|
|
|
void __iomem *mmio;
|
|
|
|
|
|
|
|
struct regulator *vdd;
|
|
|
|
|
|
|
|
struct clk *clk;
|
|
|
|
struct clk *pclk;
|
|
|
|
struct clk *lut_clk;
|
2014-06-30 22:50:51 +00:00
|
|
|
struct clk *axi_clk;
|
2016-09-28 23:58:32 +00:00
|
|
|
struct msm_gem_address_space *aspace;
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
|
2013-11-30 22:24:22 +00:00
|
|
|
struct mdp_irq error_handler;
|
2014-04-22 16:27:28 +00:00
|
|
|
|
2016-06-15 12:34:31 +00:00
|
|
|
bool rpm_enabled;
|
|
|
|
|
2014-04-22 16:27:28 +00:00
|
|
|
/* empty/blank cursor bo to use when cursor is "disabled" */
|
|
|
|
struct drm_gem_object *blank_cursor_bo;
|
2016-11-11 17:06:46 +00:00
|
|
|
uint64_t blank_cursor_iova;
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
};
|
|
|
|
#define to_mdp4_kms(x) container_of(x, struct mdp4_kms, base)
|
|
|
|
|
|
|
|
/* platform config data (ie. from DT, or pdata) */
|
|
|
|
struct mdp4_platform_config {
|
|
|
|
struct iommu_domain *iommu;
|
|
|
|
uint32_t max_clk;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline void mdp4_write(struct mdp4_kms *mdp4_kms, u32 reg, u32 data)
|
|
|
|
{
|
|
|
|
msm_writel(data, mdp4_kms->mmio + reg);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline u32 mdp4_read(struct mdp4_kms *mdp4_kms, u32 reg)
|
|
|
|
{
|
|
|
|
return msm_readl(mdp4_kms->mmio + reg);
|
|
|
|
}
|
|
|
|
|
2013-10-07 16:42:27 +00:00
|
|
|
static inline uint32_t pipe2flush(enum mdp4_pipe pipe)
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
{
|
|
|
|
switch (pipe) {
|
|
|
|
case VG1: return MDP4_OVERLAY_FLUSH_VG1;
|
|
|
|
case VG2: return MDP4_OVERLAY_FLUSH_VG2;
|
|
|
|
case RGB1: return MDP4_OVERLAY_FLUSH_RGB1;
|
2014-08-01 12:26:56 +00:00
|
|
|
case RGB2: return MDP4_OVERLAY_FLUSH_RGB2;
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint32_t ovlp2flush(int ovlp)
|
|
|
|
{
|
|
|
|
switch (ovlp) {
|
|
|
|
case 0: return MDP4_OVERLAY_FLUSH_OVLP0;
|
|
|
|
case 1: return MDP4_OVERLAY_FLUSH_OVLP1;
|
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint32_t dma2irq(enum mdp4_dma dma)
|
|
|
|
{
|
|
|
|
switch (dma) {
|
|
|
|
case DMA_P: return MDP4_IRQ_DMA_P_DONE;
|
|
|
|
case DMA_S: return MDP4_IRQ_DMA_S_DONE;
|
|
|
|
case DMA_E: return MDP4_IRQ_DMA_E_DONE;
|
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint32_t dma2err(enum mdp4_dma dma)
|
|
|
|
{
|
|
|
|
switch (dma) {
|
|
|
|
case DMA_P: return MDP4_IRQ_PRIMARY_INTF_UDERRUN;
|
|
|
|
case DMA_S: return 0; // ???
|
|
|
|
case DMA_E: return MDP4_IRQ_EXTERNAL_INTF_UDERRUN;
|
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-06 11:43:12 +00:00
|
|
|
static inline uint32_t mixercfg(uint32_t mixer_cfg, int mixer,
|
|
|
|
enum mdp4_pipe pipe, enum mdp_mixer_stage_id stage)
|
2013-10-08 16:57:48 +00:00
|
|
|
{
|
|
|
|
switch (pipe) {
|
|
|
|
case VG1:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE0__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE0_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE0(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE0_MIXER1);
|
|
|
|
break;
|
|
|
|
case VG2:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE1__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE1_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE1(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE1_MIXER1);
|
|
|
|
break;
|
|
|
|
case RGB1:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE2__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE2_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE2(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE2_MIXER1);
|
|
|
|
break;
|
|
|
|
case RGB2:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE3__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE3_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE3(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE3_MIXER1);
|
|
|
|
break;
|
|
|
|
case RGB3:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE4__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE4_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE4(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE4_MIXER1);
|
|
|
|
break;
|
|
|
|
case VG3:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE5__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE5_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE5(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE5_MIXER1);
|
|
|
|
break;
|
|
|
|
case VG4:
|
2014-08-06 11:43:12 +00:00
|
|
|
mixer_cfg &= ~(MDP4_LAYERMIXER_IN_CFG_PIPE6__MASK |
|
|
|
|
MDP4_LAYERMIXER_IN_CFG_PIPE6_MIXER1);
|
|
|
|
mixer_cfg |= MDP4_LAYERMIXER_IN_CFG_PIPE6(stage) |
|
2013-10-08 16:57:48 +00:00
|
|
|
COND(mixer == 1, MDP4_LAYERMIXER_IN_CFG_PIPE6_MIXER1);
|
|
|
|
break;
|
|
|
|
default:
|
2015-11-25 13:12:14 +00:00
|
|
|
WARN(1, "invalid pipe");
|
2013-10-08 16:57:48 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return mixer_cfg;
|
|
|
|
}
|
|
|
|
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
int mdp4_disable(struct mdp4_kms *mdp4_kms);
|
|
|
|
int mdp4_enable(struct mdp4_kms *mdp4_kms);
|
|
|
|
|
2015-08-05 19:33:29 +00:00
|
|
|
void mdp4_set_irqmask(struct mdp_kms *mdp_kms, uint32_t irqmask,
|
|
|
|
uint32_t old_irqmask);
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
void mdp4_irq_preinstall(struct msm_kms *kms);
|
|
|
|
int mdp4_irq_postinstall(struct msm_kms *kms);
|
|
|
|
void mdp4_irq_uninstall(struct msm_kms *kms);
|
|
|
|
irqreturn_t mdp4_irq(struct msm_kms *kms);
|
|
|
|
int mdp4_enable_vblank(struct msm_kms *kms, struct drm_crtc *crtc);
|
|
|
|
void mdp4_disable_vblank(struct msm_kms *kms, struct drm_crtc *crtc);
|
|
|
|
|
2015-07-08 22:12:40 +00:00
|
|
|
static inline uint32_t mdp4_pipe_caps(enum mdp4_pipe pipe)
|
2014-12-08 15:48:57 +00:00
|
|
|
{
|
|
|
|
switch (pipe) {
|
|
|
|
case VG1:
|
|
|
|
case VG2:
|
|
|
|
case VG3:
|
|
|
|
case VG4:
|
2015-07-08 22:12:40 +00:00
|
|
|
return MDP_PIPE_CAP_HFLIP | MDP_PIPE_CAP_VFLIP |
|
|
|
|
MDP_PIPE_CAP_SCALE | MDP_PIPE_CAP_CSC;
|
|
|
|
case RGB1:
|
|
|
|
case RGB2:
|
|
|
|
case RGB3:
|
|
|
|
return MDP_PIPE_CAP_SCALE;
|
2014-12-08 15:48:57 +00:00
|
|
|
default:
|
2015-07-08 22:12:40 +00:00
|
|
|
return 0;
|
2014-12-08 15:48:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-07 16:42:27 +00:00
|
|
|
enum mdp4_pipe mdp4_plane_pipe(struct drm_plane *plane);
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
struct drm_plane *mdp4_plane_init(struct drm_device *dev,
|
2013-10-07 16:42:27 +00:00
|
|
|
enum mdp4_pipe pipe_id, bool private_plane);
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
|
|
|
|
uint32_t mdp4_crtc_vblank(struct drm_crtc *crtc);
|
|
|
|
void mdp4_crtc_set_config(struct drm_crtc *crtc, uint32_t config);
|
2014-08-06 11:43:12 +00:00
|
|
|
void mdp4_crtc_set_intf(struct drm_crtc *crtc, enum mdp4_intf intf, int mixer);
|
2015-04-28 23:35:37 +00:00
|
|
|
void mdp4_crtc_wait_for_commit_done(struct drm_crtc *crtc);
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
struct drm_crtc *mdp4_crtc_init(struct drm_device *dev,
|
|
|
|
struct drm_plane *plane, int id, int ovlp_id,
|
|
|
|
enum mdp4_dma dma_id);
|
|
|
|
|
|
|
|
long mdp4_dtv_round_pixclk(struct drm_encoder *encoder, unsigned long rate);
|
|
|
|
struct drm_encoder *mdp4_dtv_encoder_init(struct drm_device *dev);
|
|
|
|
|
2014-08-01 17:08:11 +00:00
|
|
|
long mdp4_lcdc_round_pixclk(struct drm_encoder *encoder, unsigned long rate);
|
|
|
|
struct drm_encoder *mdp4_lcdc_encoder_init(struct drm_device *dev,
|
2015-11-18 11:45:50 +00:00
|
|
|
struct device_node *panel_node);
|
2014-08-01 17:08:11 +00:00
|
|
|
|
|
|
|
struct drm_connector *mdp4_lvds_connector_init(struct drm_device *dev,
|
2015-11-18 11:45:50 +00:00
|
|
|
struct device_node *panel_node, struct drm_encoder *encoder);
|
2014-08-01 17:08:11 +00:00
|
|
|
|
2015-10-19 06:57:11 +00:00
|
|
|
#ifdef CONFIG_DRM_MSM_DSI
|
|
|
|
struct drm_encoder *mdp4_dsi_encoder_init(struct drm_device *dev);
|
|
|
|
#else
|
|
|
|
static inline struct drm_encoder *mdp4_dsi_encoder_init(struct drm_device *dev)
|
|
|
|
{
|
|
|
|
return ERR_PTR(-ENODEV);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2014-08-01 17:08:11 +00:00
|
|
|
#ifdef CONFIG_COMMON_CLK
|
|
|
|
struct clk *mpd4_lvds_pll_init(struct drm_device *dev);
|
|
|
|
#else
|
|
|
|
static inline struct clk *mpd4_lvds_pll_init(struct drm_device *dev)
|
|
|
|
{
|
|
|
|
return ERR_PTR(-ENODEV);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-06-04 14:26:37 +00:00
|
|
|
#ifdef DOWNSTREAM_CONFIG_MSM_BUS_SCALING
|
drm/msm: basic KMS driver for snapdragon
The snapdragon chips have multiple different display controllers,
depending on which chip variant/version. (As far as I can tell, current
devices have either MDP3 or MDP4, and upcoming devices have MDSS.) And
then external to the display controller are HDMI, DSI, etc. blocks which
may be shared across devices which have different display controller
blocks.
To more easily add support for different display controller blocks, the
display controller specific bits are split out into a "kms" module,
which provides the kms plane/crtc/encoder objects.
The external HDMI, DSI, etc. blocks are part encoder, and part connector
currently. But I think I will pull in the drm_bridge patches from
chromeos tree, and split them into a bridge+connector, with the
registers that need to be set in modeset handled by the bridge. This
would remove the 'msm_connector' base class. But some things need to be
double checked to make sure I could get the correct ON/OFF sequencing..
This patch adds support for mdp4 crtc (including hw cursor), dtv encoder
(part of MDP4 block), and hdmi.
Signed-off-by: Rob Clark <robdclark@gmail.com>
2013-06-26 16:44:06 +00:00
|
|
|
static inline int match_dev_name(struct device *dev, void *data)
|
|
|
|
{
|
|
|
|
return !strcmp(dev_name(dev), data);
|
|
|
|
}
|
|
|
|
/* bus scaling data is associated with extra pointless platform devices,
|
|
|
|
* "dtv", etc.. this is a bit of a hack, but we need a way for encoders
|
|
|
|
* to find their pdata to make the bus-scaling stuff work.
|
|
|
|
*/
|
|
|
|
static inline void *mdp4_find_pdata(const char *devname)
|
|
|
|
{
|
|
|
|
struct device *dev;
|
|
|
|
dev = bus_find_device(&platform_bus_type, NULL,
|
|
|
|
(void *)devname, match_dev_name);
|
|
|
|
return dev ? dev->platform_data : NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* __MDP4_KMS_H__ */
|