Skip to content

Commit 7907a0d

Browse files
boddobrobclark
authored andcommitted
drm/msm/mdp5: Use the new private_obj state
This replaces the usage of the subclassed atomic state (mdp5_state) with a private_obj state embedded within drm_atomic_state. The latter method is the preferred approach, since it's simpler to implement and less prone to errors. The new API replaces the older and equivalent mdp5_state usage in the following pattern: - References to "mdp5_kms->state" (i.e, the old/existing state) is replaced with mdp5_get_existing_global_state(). In the atomic_check path, this should be called with the glob_state_lock drm_modeset_lock alredy taken. - References to "mdp5_get_state()" are replaced with mdp5_get_global_state(). This acquires glob_state_lock and uses drm_atomic_get_private_obj_state() to create a new duplicated state. Changes in v3: - Acquire glob_state_lock in mdp5_smp.c - Added to the msm atomic helper patch set Changes in v4: - None Signed-off-by: Archit Taneja <[email protected]> Signed-off-by: Rob Clark <[email protected]> Signed-off-by: Sean Paul <[email protected]>
1 parent 8d58ef3 commit 7907a0d

File tree

4 files changed

+37
-22
lines changed

4 files changed

+37
-22
lines changed

drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -190,20 +190,26 @@ static void mdp5_prepare_commit(struct msm_kms *kms, struct drm_atomic_state *st
190190
{
191191
struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(kms));
192192
struct device *dev = &mdp5_kms->pdev->dev;
193+
struct mdp5_global_state *global_state;
194+
195+
global_state = mdp5_get_existing_global_state(mdp5_kms);
193196

194197
pm_runtime_get_sync(dev);
195198

196199
if (mdp5_kms->smp)
197-
mdp5_smp_prepare_commit(mdp5_kms->smp, &mdp5_kms->state->smp);
200+
mdp5_smp_prepare_commit(mdp5_kms->smp, &global_state->smp);
198201
}
199202

200203
static void mdp5_complete_commit(struct msm_kms *kms, struct drm_atomic_state *state)
201204
{
202205
struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(kms));
203206
struct device *dev = &mdp5_kms->pdev->dev;
207+
struct mdp5_global_state *global_state;
208+
209+
global_state = mdp5_get_existing_global_state(mdp5_kms);
204210

205211
if (mdp5_kms->smp)
206-
mdp5_smp_complete_commit(mdp5_kms->smp, &mdp5_kms->state->smp);
212+
mdp5_smp_complete_commit(mdp5_kms->smp, &global_state->smp);
207213

208214
pm_runtime_put_sync(dev);
209215
}

drivers/gpu/drm/msm/disp/mdp5/mdp5_mixer.c

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -52,14 +52,14 @@ int mdp5_mixer_assign(struct drm_atomic_state *s, struct drm_crtc *crtc,
5252
{
5353
struct msm_drm_private *priv = s->dev->dev_private;
5454
struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(priv->kms));
55-
struct mdp5_state *state = mdp5_get_state(s);
55+
struct mdp5_global_state *global_state = mdp5_get_global_state(s);
5656
struct mdp5_hw_mixer_state *new_state;
5757
int i;
5858

59-
if (IS_ERR(state))
60-
return PTR_ERR(state);
59+
if (IS_ERR(global_state))
60+
return PTR_ERR(global_state);
6161

62-
new_state = &state->hwmixer;
62+
new_state = &global_state->hwmixer;
6363

6464
for (i = 0; i < mdp5_kms->num_hwmixers; i++) {
6565
struct mdp5_hw_mixer *cur = mdp5_kms->hwmixers[i];
@@ -129,8 +129,8 @@ int mdp5_mixer_assign(struct drm_atomic_state *s, struct drm_crtc *crtc,
129129

130130
void mdp5_mixer_release(struct drm_atomic_state *s, struct mdp5_hw_mixer *mixer)
131131
{
132-
struct mdp5_state *state = mdp5_get_state(s);
133-
struct mdp5_hw_mixer_state *new_state = &state->hwmixer;
132+
struct mdp5_global_state *global_state = mdp5_get_global_state(s);
133+
struct mdp5_hw_mixer_state *new_state = &global_state->hwmixer;
134134

135135
if (!mixer)
136136
return;

drivers/gpu/drm/msm/disp/mdp5/mdp5_pipe.c

Lines changed: 11 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -24,17 +24,19 @@ int mdp5_pipe_assign(struct drm_atomic_state *s, struct drm_plane *plane,
2424
{
2525
struct msm_drm_private *priv = s->dev->dev_private;
2626
struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(priv->kms));
27-
struct mdp5_state *state;
27+
struct mdp5_global_state *new_global_state, *old_global_state;
2828
struct mdp5_hw_pipe_state *old_state, *new_state;
2929
int i, j;
3030

31-
state = mdp5_get_state(s);
32-
if (IS_ERR(state))
33-
return PTR_ERR(state);
31+
new_global_state = mdp5_get_global_state(s);
32+
if (IS_ERR(new_global_state))
33+
return PTR_ERR(new_global_state);
3434

35-
/* grab old_state after mdp5_get_state(), since now we hold lock: */
36-
old_state = &mdp5_kms->state->hwpipe;
37-
new_state = &state->hwpipe;
35+
/* grab old_state after mdp5_get_global_state(), since now we hold lock: */
36+
old_global_state = mdp5_get_existing_global_state(mdp5_kms);
37+
38+
old_state = &old_global_state->hwpipe;
39+
new_state = &new_global_state->hwpipe;
3840

3941
for (i = 0; i < mdp5_kms->num_hwpipes; i++) {
4042
struct mdp5_hw_pipe *cur = mdp5_kms->hwpipes[i];
@@ -107,7 +109,7 @@ int mdp5_pipe_assign(struct drm_atomic_state *s, struct drm_plane *plane,
107109
WARN_ON(r_hwpipe);
108110

109111
DBG("%s: alloc SMP blocks", (*hwpipe)->name);
110-
ret = mdp5_smp_assign(mdp5_kms->smp, &state->smp,
112+
ret = mdp5_smp_assign(mdp5_kms->smp, &new_global_state->smp,
111113
(*hwpipe)->pipe, blkcfg);
112114
if (ret)
113115
return -ENOMEM;
@@ -132,7 +134,7 @@ void mdp5_pipe_release(struct drm_atomic_state *s, struct mdp5_hw_pipe *hwpipe)
132134
{
133135
struct msm_drm_private *priv = s->dev->dev_private;
134136
struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(priv->kms));
135-
struct mdp5_state *state = mdp5_get_state(s);
137+
struct mdp5_global_state *state = mdp5_get_global_state(s);
136138
struct mdp5_hw_pipe_state *new_state = &state->hwpipe;
137139

138140
if (!hwpipe)

drivers/gpu/drm/msm/disp/mdp5/mdp5_smp.c

Lines changed: 12 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -340,17 +340,20 @@ void mdp5_smp_dump(struct mdp5_smp *smp, struct drm_printer *p)
340340
struct mdp5_kms *mdp5_kms = get_kms(smp);
341341
struct mdp5_hw_pipe_state *hwpstate;
342342
struct mdp5_smp_state *state;
343+
struct mdp5_global_state *global_state;
343344
int total = 0, i, j;
344345

345346
drm_printf(p, "name\tinuse\tplane\n");
346347
drm_printf(p, "----\t-----\t-----\n");
347348

348349
if (drm_can_sleep())
349-
drm_modeset_lock(&mdp5_kms->state_lock, NULL);
350+
drm_modeset_lock(&mdp5_kms->glob_state_lock, NULL);
351+
352+
global_state = mdp5_get_existing_global_state(mdp5_kms);
350353

351354
/* grab these *after* we hold the state_lock */
352-
hwpstate = &mdp5_kms->state->hwpipe;
353-
state = &mdp5_kms->state->smp;
355+
hwpstate = &global_state->hwpipe;
356+
state = &global_state->smp;
354357

355358
for (i = 0; i < mdp5_kms->num_hwpipes; i++) {
356359
struct mdp5_hw_pipe *hwpipe = mdp5_kms->hwpipes[i];
@@ -374,7 +377,7 @@ void mdp5_smp_dump(struct mdp5_smp *smp, struct drm_printer *p)
374377
bitmap_weight(state->state, smp->blk_cnt));
375378

376379
if (drm_can_sleep())
377-
drm_modeset_unlock(&mdp5_kms->state_lock);
380+
drm_modeset_unlock(&mdp5_kms->glob_state_lock);
378381
}
379382

380383
void mdp5_smp_destroy(struct mdp5_smp *smp)
@@ -384,7 +387,8 @@ void mdp5_smp_destroy(struct mdp5_smp *smp)
384387

385388
struct mdp5_smp *mdp5_smp_init(struct mdp5_kms *mdp5_kms, const struct mdp5_smp_block *cfg)
386389
{
387-
struct mdp5_smp_state *state = &mdp5_kms->state->smp;
390+
struct mdp5_smp_state *state;
391+
struct mdp5_global_state *global_state;
388392
struct mdp5_smp *smp = NULL;
389393
int ret;
390394

@@ -398,6 +402,9 @@ struct mdp5_smp *mdp5_smp_init(struct mdp5_kms *mdp5_kms, const struct mdp5_smp_
398402
smp->blk_cnt = cfg->mmb_count;
399403
smp->blk_size = cfg->mmb_size;
400404

405+
global_state = mdp5_get_existing_global_state(mdp5_kms);
406+
state = &global_state->smp;
407+
401408
/* statically tied MMBs cannot be re-allocated: */
402409
bitmap_copy(state->state, cfg->reserved_state, smp->blk_cnt);
403410
memcpy(smp->reserved, cfg->reserved, sizeof(smp->reserved));

0 commit comments

Comments
 (0)