disp: msm: sde: add check to avoid multiple active CWB

Add check to avoid more than 1 CWB active per commit as
hardware doesn't support multiple CWB even if they are
on different OP.

Change-Id: I13416cc2af881de0d8bdd6544a4fdc180fb7a050
Signed-off-by: Amine Najahi <quic_anajahi@quicinc.com>
这个提交包含在:
Amine Najahi
2022-01-10 21:52:09 -05:00
父节点 90bfd286b6
当前提交 91e45e818f
修改 3 个文件,包含 47 行新增1 行删除

查看文件

@@ -2968,7 +2968,6 @@ static int sde_kms_check_vm_request(struct msm_kms *kms,
return rc;
}
static int sde_kms_check_secure_transition(struct msm_kms *kms,
struct drm_atomic_state *state)
{
@@ -3083,6 +3082,44 @@ static void sde_kms_vm_res_release(struct msm_kms *kms,
sde_vm_unlock(sde_kms);
}
static int sde_kms_check_cwb_concurreny(struct msm_kms *kms,
struct drm_atomic_state *state)
{
struct sde_kms *sde_kms;
struct drm_crtc *crtc;
struct drm_crtc_state *old_crtc_state, *new_crtc_state;
struct drm_encoder *encoder;
struct sde_crtc_state *cstate;
int i = 0, cnt = 0, max_cwb = 0;
if (!kms || !state) {
SDE_ERROR("invalid arguments\n");
return -EINVAL;
}
sde_kms = to_sde_kms(kms);
max_cwb = sde_kms->catalog->max_cwb;
if (!max_cwb)
return 0;
for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) {
cstate = to_sde_crtc_state(new_crtc_state);
drm_for_each_encoder_mask(encoder, crtc->dev, cstate->cwb_enc_mask) {
cnt++;
SDE_DEBUG("crtc%d has cwb%d attached to it\n", crtc->base.id,
encoder->base.id);
}
if (cnt > max_cwb) {
SDE_ERROR("found %d cwb in the atomic state, max supported %d\n",
cnt, max_cwb);
return -EOPNOTSUPP;
}
}
return 0;
}
static int sde_kms_atomic_check(struct msm_kms *kms,
struct drm_atomic_state *state)
{
@@ -3123,6 +3160,11 @@ static int sde_kms_atomic_check(struct msm_kms *kms,
if (ret)
goto vm_clean_up;
ret = sde_kms_check_cwb_concurreny(kms, state);
if (ret)
goto vm_clean_up;
goto end;
vm_clean_up: