From: "Leo (Sunpeng) Li" <sunpeng...@amd.com>

To conform to DRM's new API, we should not be accessing a DRM object's
internal state directly. Rather, the DRM for_each_old/new_* iterators,
and drm_atomic_get_old/new_* interface should be used.

This is an ongoing process. For now, update the DRM-facing atomic
functions, where the atomic state object is given.

Signed-off-by: Leo (Sunpeng) Li <sunpeng...@amd.com>
Reviewed-by: Sun peng Li <sunpeng...@amd.com>
Acked-by: Harry Wentland <harry.wentl...@amd.com>
---
 drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 139 +++++++++++-----------
 1 file changed, 72 insertions(+), 67 deletions(-)

diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c 
b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
index bf232e131db1..924e33211f8b 100644
--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
@@ -3915,29 +3915,32 @@ static void amdgpu_dm_commit_planes(struct 
drm_atomic_state *state,
 {
        uint32_t i;
        struct drm_plane *plane;
-       struct drm_plane_state *old_plane_state;
+       struct drm_plane_state *old_plane_state, *new_plane_state;
        struct dc_stream_state *dc_stream_attach;
        struct dc_plane_state *plane_states_constructed[MAX_SURFACES];
        struct amdgpu_crtc *acrtc_attach = to_amdgpu_crtc(pcrtc);
-       struct dm_crtc_state *acrtc_state = to_dm_crtc_state(pcrtc->state);
+       struct drm_crtc_state *new_pcrtc_state =
+                       drm_atomic_get_new_crtc_state(state, pcrtc);
+       struct dm_crtc_state *acrtc_state = to_dm_crtc_state(new_pcrtc_state);
        struct dm_atomic_state *dm_state = to_dm_atomic_state(state);
        int planes_count = 0;
        unsigned long flags;
 
        /* update planes when needed */
-       for_each_old_plane_in_state(state, plane, old_plane_state, i) {
-               struct drm_plane_state *plane_state = plane->state;
-               struct drm_crtc *crtc = plane_state->crtc;
-               struct drm_framebuffer *fb = plane_state->fb;
+       for_each_oldnew_plane_in_state(state, plane, old_plane_state, 
new_plane_state, i) {
+               struct drm_crtc *crtc = new_plane_state->crtc;
+               struct drm_crtc_state *new_crtc_state =
+                               drm_atomic_get_new_crtc_state(state, crtc);
+               struct drm_framebuffer *fb = new_plane_state->fb;
                bool pflip_needed;
-               struct dm_plane_state *dm_plane_state = 
to_dm_plane_state(plane_state);
+               struct dm_plane_state *dm_plane_state = 
to_dm_plane_state(new_plane_state);
 
                if (plane->type == DRM_PLANE_TYPE_CURSOR) {
                        handle_cursor_update(plane, old_plane_state);
                        continue;
                }
 
-               if (!fb || !crtc || pcrtc != crtc || !crtc->state->active)
+               if (!fb || !crtc || pcrtc != crtc || !new_crtc_state->active)
                        continue;
 
                pflip_needed = !state->allow_modeset;
@@ -3961,13 +3964,13 @@ static void amdgpu_dm_commit_planes(struct 
drm_atomic_state *state,
                        dc_stream_attach = acrtc_state->stream;
                        planes_count++;
 
-               } else if (crtc->state->planes_changed) {
+               } else if (new_crtc_state->planes_changed) {
                        /* Assume even ONE crtc with immediate flip means
                         * entire can't wait for VBLANK
                         * TODO Check if it's correct
                         */
                        *wait_for_vblank =
-                                       pcrtc->state->pageflip_flags & 
DRM_MODE_PAGE_FLIP_ASYNC ?
+                                       new_pcrtc_state->pageflip_flags & 
DRM_MODE_PAGE_FLIP_ASYNC ?
                                false : true;
 
                        /* TODO: Needs rework for multiplane flip */
@@ -3986,7 +3989,7 @@ static void amdgpu_dm_commit_planes(struct 
drm_atomic_state *state,
        if (planes_count) {
                unsigned long flags;
 
-               if (pcrtc->state->event) {
+               if (new_pcrtc_state->event) {
 
                        drm_crtc_vblank_get(pcrtc);
 
@@ -4012,7 +4015,7 @@ static int amdgpu_dm_atomic_commit(struct drm_device *dev,
                                   bool nonblock)
 {
        struct drm_crtc *crtc;
-       struct drm_crtc_state *new_state;
+       struct drm_crtc_state *old_crtc_state, *new_state;
        struct amdgpu_device *adev = dev->dev_private;
        int i;
 
@@ -4023,8 +4026,8 @@ static int amdgpu_dm_atomic_commit(struct drm_device *dev,
         * it will update crtc->dm_crtc_state->stream pointer which is used in
         * the ISRs.
         */
-       for_each_new_crtc_in_state(state, crtc, new_state, i) {
-               struct dm_crtc_state *old_acrtc_state = 
to_dm_crtc_state(crtc->state);
+       for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_state, 
i) {
+               struct dm_crtc_state *old_acrtc_state = 
to_dm_crtc_state(old_crtc_state);
                struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
                if (drm_atomic_crtc_needs_modeset(new_state) && 
old_acrtc_state->stream)
@@ -4047,13 +4050,13 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
        uint32_t i, j;
        uint32_t new_crtcs_count = 0;
        struct drm_crtc *crtc, *pcrtc;
-       struct drm_crtc_state *old_crtc_state;
+       struct drm_crtc_state *old_crtc_state, *new_crtc_state;
        struct amdgpu_crtc *new_crtcs[MAX_STREAMS];
        struct dc_stream_state *new_stream = NULL;
        unsigned long flags;
        bool wait_for_vblank = true;
        struct drm_connector *connector;
-       struct drm_connector_state *old_conn_state;
+       struct drm_connector_state *old_conn_state, *new_con_state;
        struct dm_crtc_state *old_acrtc_state, *new_acrtc_state;
 
        drm_atomic_helper_update_legacy_modeset_state(dev, state);
@@ -4061,11 +4064,10 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
        dm_state = to_dm_atomic_state(state);
 
        /* update changed items */
-       for_each_old_crtc_in_state(state, crtc, old_crtc_state, i) {
+       for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, 
new_crtc_state, i) {
                struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
-               struct drm_crtc_state *new_state = crtc->state;
 
-               new_acrtc_state = to_dm_crtc_state(new_state);
+               new_acrtc_state = to_dm_crtc_state(new_crtc_state);
                old_acrtc_state = to_dm_crtc_state(old_crtc_state);
 
                DRM_DEBUG_DRIVER(
@@ -4073,18 +4075,18 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                        "planes_changed:%d, mode_changed:%d,active_changed:%d,"
                        "connectors_changed:%d\n",
                        acrtc->crtc_id,
-                       new_state->enable,
-                       new_state->active,
-                       new_state->planes_changed,
-                       new_state->mode_changed,
-                       new_state->active_changed,
-                       new_state->connectors_changed);
+                       new_crtc_state->enable,
+                       new_crtc_state->active,
+                       new_crtc_state->planes_changed,
+                       new_crtc_state->mode_changed,
+                       new_crtc_state->active_changed,
+                       new_crtc_state->connectors_changed);
 
                /* handles headless hotplug case, updating new_state and
                 * aconnector as needed
                 */
 
-               if (modeset_required(new_state, new_acrtc_state->stream, 
old_acrtc_state->stream)) {
+               if (modeset_required(new_crtc_state, new_acrtc_state->stream, 
old_acrtc_state->stream)) {
 
                        DRM_DEBUG_DRIVER("Atomic commit: SET crtc id %d: 
[%p]\n", acrtc->crtc_id, acrtc);
 
@@ -4127,10 +4129,11 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                        new_crtcs[new_crtcs_count] = acrtc;
                        new_crtcs_count++;
 
+                       new_crtc_state = drm_atomic_get_new_crtc_state(state, 
crtc);
                        acrtc->enabled = true;
-                       acrtc->hw_mode = crtc->state->mode;
-                       crtc->hwmode = crtc->state->mode;
-               } else if (modereset_required(new_state)) {
+                       acrtc->hw_mode = new_crtc_state->mode;
+                       crtc->hwmode = new_crtc_state->mode;
+               } else if (modereset_required(new_crtc_state)) {
                        DRM_DEBUG_DRIVER("Atomic commit: RESET. crtc id 
%d:[%p]\n", acrtc->crtc_id, acrtc);
 
                        /* i.e. reset mode */
@@ -4147,7 +4150,9 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                for (i = 0; i < new_crtcs_count; i++) {
                        struct amdgpu_dm_connector *aconnector = NULL;
 
-                       new_acrtc_state = 
to_dm_crtc_state(new_crtcs[i]->base.state);
+                       new_crtc_state = drm_atomic_get_new_crtc_state(
+                                       state, &new_crtcs[i]->base);
+                       new_acrtc_state = to_dm_crtc_state(new_crtc_state);
 
                        new_stream = new_acrtc_state->stream;
                        aconnector =
@@ -4172,7 +4177,9 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                        struct dm_connector_state *conn_state = NULL;
                        struct dm_crtc_state *acrtc_state = NULL;
 
-                       acrtc_state = to_dm_crtc_state(acrtc->base.state);
+                       new_crtc_state = drm_atomic_get_new_crtc_state(
+                                       state, &acrtc->base);
+                       acrtc_state = to_dm_crtc_state(new_crtc_state);
 
 
                        aconnector =
@@ -4180,7 +4187,9 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                                        state,
                                        crtc);
                        if (aconnector) {
-                               conn_state = 
to_dm_connector_state(aconnector->base.state);
+                               new_con_state = 
drm_atomic_get_new_connector_state(
+                                               state, &aconnector->base);
+                               conn_state = 
to_dm_connector_state(new_con_state);
 
                                if (new_stream) {
                                        
mod_freesync_set_user_enable(adev->dm.freesync_module,
@@ -4195,11 +4204,10 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
        if (dm_state->context)
                WARN_ON(!dc_commit_state(dm->dc, dm_state->context));
 
-
-       list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
+       for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) {
                struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
-               new_acrtc_state = to_dm_crtc_state(crtc->state);
+               new_acrtc_state = to_dm_crtc_state(new_crtc_state);
 
                if (new_acrtc_state->stream != NULL) {
                        const struct dc_stream_status *status =
@@ -4213,24 +4221,24 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
        }
 
        /* Handle scaling and undersacn changes*/
-       for_each_old_connector_in_state(state, connector, old_conn_state, i) {
-               struct amdgpu_dm_connector *aconnector = 
to_amdgpu_dm_connector(connector);
-               struct dm_connector_state *con_new_state =
-                               to_dm_connector_state(aconnector->base.state);
-               struct dm_connector_state *con_old_state =
-                               to_dm_connector_state(old_conn_state);
+       for_each_oldnew_connector_in_state(state, connector, old_conn_state, 
new_con_state, i) {
+               struct dm_connector_state *con_new_state = 
to_dm_connector_state(new_con_state);
+               struct dm_connector_state *con_old_state = 
to_dm_connector_state(old_conn_state);
                struct amdgpu_crtc *acrtc = 
to_amdgpu_crtc(con_new_state->base.crtc);
                struct dc_stream_status *status = NULL;
 
+               if (acrtc)
+                       new_crtc_state = drm_atomic_get_new_crtc_state(state, 
&acrtc->base);
+
                /* Skip any modesets/resets */
-               if (!acrtc || drm_atomic_crtc_needs_modeset(acrtc->base.state))
+               if (!acrtc || drm_atomic_crtc_needs_modeset(new_crtc_state))
                        continue;
 
                /* Skip any thing not scale or underscan changes */
                if (!is_scaling_state_different(con_new_state, con_old_state))
                        continue;
 
-               new_acrtc_state = to_dm_crtc_state(acrtc->base.state);
+               new_acrtc_state = to_dm_crtc_state(new_crtc_state);
 
                update_stream_scaling_settings(&con_new_state->base.crtc->mode,
                                con_new_state, (struct dc_stream_state 
*)new_acrtc_state->stream);
@@ -4258,7 +4266,8 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
                 */
                struct amdgpu_crtc *acrtc = new_crtcs[i];
 
-               new_acrtc_state = to_dm_crtc_state(acrtc->base.state);
+               new_crtc_state = drm_atomic_get_new_crtc_state(state, 
&acrtc->base);
+               new_acrtc_state = to_dm_crtc_state(new_crtc_state);
 
                if (adev->dm.freesync_module)
                        mod_freesync_notify_mode_change(
@@ -4268,8 +4277,8 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
        }
 
        /* update planes when needed per crtc*/
-       for_each_old_crtc_in_state(state, pcrtc, old_crtc_state, j) {
-               new_acrtc_state = to_dm_crtc_state(pcrtc->state);
+       for_each_new_crtc_in_state(state, pcrtc, new_crtc_state, j) {
+               new_acrtc_state = to_dm_crtc_state(new_crtc_state);
 
                if (new_acrtc_state->stream)
                        amdgpu_dm_commit_planes(state, dev, dm, pcrtc, 
&wait_for_vblank);
@@ -4281,13 +4290,12 @@ static void amdgpu_dm_atomic_commit_tail(struct 
drm_atomic_state *state)
         * mark consumed event for drm_atomic_helper_commit_hw_done
         */
        spin_lock_irqsave(&adev->ddev->event_lock, flags);
-       for_each_old_crtc_in_state(state, crtc, old_crtc_state, i) {
-               struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
+       for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) {
 
-               if (acrtc->base.state->event)
-                       drm_send_event_locked(dev, &crtc->state->event->base);
+               if (new_crtc_state->event)
+                       drm_send_event_locked(dev, 
&new_crtc_state->event->base);
 
-               acrtc->base.state->event = NULL;
+               new_crtc_state->event = NULL;
        }
        spin_unlock_irqrestore(&adev->ddev->event_lock, flags);
 
@@ -4443,7 +4451,7 @@ static int dm_update_crtcs_state(struct dc *dc,
                                 bool *lock_and_validation_needed)
 {
        struct drm_crtc *crtc;
-       struct drm_crtc_state *crtc_state;
+       struct drm_crtc_state *old_crtc_state, *crtc_state;
        int i;
        struct dm_crtc_state *old_acrtc_state, *new_acrtc_state;
        struct dm_atomic_state *dm_state = to_dm_atomic_state(state);
@@ -4452,7 +4460,7 @@ static int dm_update_crtcs_state(struct dc *dc,
 
        /*TODO Move this code into dm_crtc_atomic_check once we get rid of 
dc_validation_set */
        /* update changed items */
-       for_each_new_crtc_in_state(state, crtc, crtc_state, i) {
+       for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, crtc_state, 
i) {
                struct amdgpu_crtc *acrtc = NULL;
                struct amdgpu_dm_connector *aconnector = NULL;
                struct drm_connector_state *conn_state = NULL;
@@ -4460,7 +4468,7 @@ static int dm_update_crtcs_state(struct dc *dc,
 
                new_stream = NULL;
 
-               old_acrtc_state = to_dm_crtc_state(crtc->state);
+               old_acrtc_state = to_dm_crtc_state(old_crtc_state);
                new_acrtc_state = to_dm_crtc_state(crtc_state);
                acrtc = to_amdgpu_crtc(crtc);
 
@@ -4600,7 +4608,7 @@ static int dm_update_planes_state(struct dc *dc,
                                  bool *lock_and_validation_needed)
 {
        struct drm_crtc *new_plane_crtc, *old_plane_crtc;
-       struct drm_crtc_state *new_crtc_state;
+       struct drm_crtc_state *old_crtc_state, *new_crtc_state;
        struct drm_plane *plane;
        struct drm_plane_state *old_plane_state, *new_plane_state;
        struct dm_crtc_state *new_acrtc_state, *old_acrtc_state;
@@ -4631,10 +4639,9 @@ static int dm_update_planes_state(struct dc *dc,
                        if (!old_plane_crtc)
                                continue;
 
-                       old_acrtc_state = to_dm_crtc_state(
-                                       drm_atomic_get_old_crtc_state(
-                                                       state,
-                                                       old_plane_crtc));
+                       old_crtc_state = drm_atomic_get_old_crtc_state(
+                                       state, old_plane_crtc);
+                       old_acrtc_state = to_dm_crtc_state(old_crtc_state);
 
                        if (!old_acrtc_state->stream)
                                continue;
@@ -4722,7 +4729,7 @@ static int amdgpu_dm_atomic_check(struct drm_device *dev,
        struct dc *dc = adev->dm.dc;
        struct dm_atomic_state *dm_state = to_dm_atomic_state(state);
        struct drm_connector *connector;
-       struct drm_connector_state *conn_state;
+       struct drm_connector_state *old_con_state, *conn_state;
        struct drm_crtc *crtc;
        struct drm_crtc_state *old_crtc_state, *crtc_state;
 
@@ -4805,16 +4812,14 @@ static int amdgpu_dm_atomic_check(struct drm_device 
*dev,
         * new stream into context w\o causing full reset. Need to
         * decide how to handle.
         */
-       for_each_new_connector_in_state(state, connector, conn_state, i) {
-               struct amdgpu_dm_connector *aconnector = 
to_amdgpu_dm_connector(connector);
-               struct dm_connector_state *con_old_state =
-                               to_dm_connector_state(aconnector->base.state);
-               struct dm_connector_state *con_new_state =
-                                               
to_dm_connector_state(conn_state);
+       for_each_oldnew_connector_in_state(state, connector, old_con_state, 
conn_state, i) {
+               struct dm_connector_state *con_old_state = 
to_dm_connector_state(old_con_state);
+               struct dm_connector_state *con_new_state = 
to_dm_connector_state(conn_state);
                struct amdgpu_crtc *acrtc = 
to_amdgpu_crtc(con_new_state->base.crtc);
 
                /* Skip any modesets/resets */
-               if (!acrtc || drm_atomic_crtc_needs_modeset(acrtc->base.state))
+               if (!acrtc || drm_atomic_crtc_needs_modeset(
+                               drm_atomic_get_new_crtc_state(state, 
&acrtc->base)))
                        continue;
 
                /* Skip any thing not scale or underscan changes */
-- 
2.14.1

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to