2014-11-18 17:49:49 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2014 The Linux Foundation. All rights reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 and
|
|
|
|
* only 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MDP5_CTL_H__
|
|
|
|
#define __MDP5_CTL_H__
|
|
|
|
|
|
|
|
#include "msm_drv.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CTL Manager prototypes:
|
|
|
|
* mdp5_ctlm_init() returns a ctlm (CTL Manager) handler,
|
|
|
|
* which is then used to call the other mdp5_ctlm_*(ctlm, ...) functions.
|
|
|
|
*/
|
2014-11-18 19:28:43 +00:00
|
|
|
struct mdp5_ctl_manager;
|
|
|
|
struct mdp5_ctl_manager *mdp5_ctlm_init(struct drm_device *dev,
|
2015-06-26 20:03:26 +00:00
|
|
|
void __iomem *mmio_base, struct mdp5_cfg_handler *cfg_hnd);
|
2014-11-18 19:28:43 +00:00
|
|
|
void mdp5_ctlm_hw_reset(struct mdp5_ctl_manager *ctlm);
|
|
|
|
void mdp5_ctlm_destroy(struct mdp5_ctl_manager *ctlm);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* CTL prototypes:
|
|
|
|
* mdp5_ctl_request(ctlm, ...) returns a ctl (CTL resource) handler,
|
|
|
|
* which is then used to call the other mdp5_ctl_*(ctl, ...) functions.
|
|
|
|
*/
|
2015-06-26 20:03:25 +00:00
|
|
|
struct mdp5_ctl *mdp5_ctlm_request(struct mdp5_ctl_manager *ctlm, int intf_num);
|
2015-06-26 20:03:26 +00:00
|
|
|
|
2015-03-13 19:49:33 +00:00
|
|
|
int mdp5_ctl_get_ctl_id(struct mdp5_ctl *ctl);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
2015-03-13 19:49:32 +00:00
|
|
|
struct mdp5_interface;
|
2017-03-23 10:28:06 +00:00
|
|
|
struct mdp5_pipeline;
|
|
|
|
int mdp5_ctl_set_pipeline(struct mdp5_ctl *ctl, struct mdp5_pipeline *p);
|
|
|
|
int mdp5_ctl_set_encoder_state(struct mdp5_ctl *ctl, struct mdp5_pipeline *p,
|
|
|
|
bool enabled);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
2017-03-23 10:28:06 +00:00
|
|
|
int mdp5_ctl_set_cursor(struct mdp5_ctl *ctl, struct mdp5_pipeline *pipeline,
|
|
|
|
int cursor_id, bool enable);
|
2015-06-26 20:03:26 +00:00
|
|
|
int mdp5_ctl_pair(struct mdp5_ctl *ctlx, struct mdp5_ctl *ctly, bool enable);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
drm/msm/mdp5: Add optional 'right' Layer Mixer in CRTC state
Add another mdp5_hw_mixer pointer (r_mixer) in mdp5_crtc_state.
This mixer will be used to generate the right half of the scanout.
With Source Split, a SSPP can now be connected to 2 Layer Mixers, but
has to be at the same blend level (stage #) on both Layer Mixers.
A drm_plane that has a lesser width than the max width supported, will
comprise of a single SSPP/hwpipe, staged on both the Layer Mixers at
the same blend level. A plane that is greater than max width will comprise
of 2 SSPPs, with the 'left' SSPP staged on the left LM, and the 'right'
SSPP staged on the right LM at the same blend level.
For now, the drm_plane consists of only one SSPP, therefore, it
needs to be staged on both the LMs in blend_setup() and mdp5_ctl_blend().
We'll extend this logic to support 2 hwpipes per plane later.
The crtc cursor ops (using the LM cursors, not SSPP cursors) simply
return an error if they're called when the right mixer is assigned to
the CRTC state. With source split is enabled, we're expected to only
SSPP cursors.
This commit adds code that configures the right mixer, but the r_mixer
itself isn't assigned at the moment.
Signed-off-by: Archit Taneja <architt@codeaurora.org>
Signed-off-by: Rob Clark <robdclark@gmail.com>
2017-03-23 10:28:08 +00:00
|
|
|
#define MAX_PIPE_STAGE 2
|
|
|
|
|
2014-11-18 17:49:49 +00:00
|
|
|
/*
|
2015-03-13 19:49:33 +00:00
|
|
|
* mdp5_ctl_blend() - Blend multiple layers on a Layer Mixer (LM)
|
|
|
|
*
|
2015-06-25 21:37:42 +00:00
|
|
|
* @stage: array to contain the pipe num for each stage
|
|
|
|
* @stage_cnt: valid stage number in stage array
|
|
|
|
* @ctl_blend_op_flags: blender operation mode flags
|
2014-11-18 17:49:49 +00:00
|
|
|
*
|
2015-03-13 19:49:33 +00:00
|
|
|
* Note:
|
|
|
|
* CTL registers need to be flushed after calling this function
|
|
|
|
* (call mdp5_ctl_commit() with mdp_ctl_flush_mask_ctl() mask)
|
2014-11-18 17:49:49 +00:00
|
|
|
*/
|
2015-06-25 21:37:42 +00:00
|
|
|
#define MDP5_CTL_BLEND_OP_FLAG_BORDER_OUT BIT(0)
|
2017-03-23 10:28:06 +00:00
|
|
|
int mdp5_ctl_blend(struct mdp5_ctl *ctl, struct mdp5_pipeline *pipeline,
|
drm/msm/mdp5: Add optional 'right' Layer Mixer in CRTC state
Add another mdp5_hw_mixer pointer (r_mixer) in mdp5_crtc_state.
This mixer will be used to generate the right half of the scanout.
With Source Split, a SSPP can now be connected to 2 Layer Mixers, but
has to be at the same blend level (stage #) on both Layer Mixers.
A drm_plane that has a lesser width than the max width supported, will
comprise of a single SSPP/hwpipe, staged on both the Layer Mixers at
the same blend level. A plane that is greater than max width will comprise
of 2 SSPPs, with the 'left' SSPP staged on the left LM, and the 'right'
SSPP staged on the right LM at the same blend level.
For now, the drm_plane consists of only one SSPP, therefore, it
needs to be staged on both the LMs in blend_setup() and mdp5_ctl_blend().
We'll extend this logic to support 2 hwpipes per plane later.
The crtc cursor ops (using the LM cursors, not SSPP cursors) simply
return an error if they're called when the right mixer is assigned to
the CRTC state. With source split is enabled, we're expected to only
SSPP cursors.
This commit adds code that configures the right mixer, but the r_mixer
itself isn't assigned at the moment.
Signed-off-by: Archit Taneja <architt@codeaurora.org>
Signed-off-by: Rob Clark <robdclark@gmail.com>
2017-03-23 10:28:08 +00:00
|
|
|
enum mdp5_pipe stage[][MAX_PIPE_STAGE],
|
|
|
|
enum mdp5_pipe r_stage[][MAX_PIPE_STAGE],
|
|
|
|
u32 stage_cnt, u32 ctl_blend_op_flags);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
2015-03-13 19:49:33 +00:00
|
|
|
/**
|
|
|
|
* mdp_ctl_flush_mask...() - Register FLUSH masks
|
|
|
|
*
|
|
|
|
* These masks are used to specify which block(s) need to be flushed
|
|
|
|
* through @flush_mask parameter in mdp5_ctl_commit(.., flush_mask).
|
|
|
|
*/
|
|
|
|
u32 mdp_ctl_flush_mask_lm(int lm);
|
|
|
|
u32 mdp_ctl_flush_mask_pipe(enum mdp5_pipe pipe);
|
|
|
|
u32 mdp_ctl_flush_mask_cursor(int cursor_id);
|
|
|
|
u32 mdp_ctl_flush_mask_encoder(struct mdp5_interface *intf);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
2015-03-13 19:49:33 +00:00
|
|
|
/* @flush_mask: see CTL flush masks definitions below */
|
2017-03-23 10:28:06 +00:00
|
|
|
u32 mdp5_ctl_commit(struct mdp5_ctl *ctl, struct mdp5_pipeline *pipeline,
|
2018-02-19 13:17:06 +00:00
|
|
|
u32 flush_mask, bool start);
|
2015-04-28 23:35:37 +00:00
|
|
|
u32 mdp5_ctl_get_commit_status(struct mdp5_ctl *ctl);
|
2014-11-18 17:49:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* __MDP5_CTL_H__ */
|