]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
drm/i915/psr: clean up PSR debugfs sink status error handling
authorJani Nikula <jani.nikula@intel.com>
Fri, 17 Mar 2023 13:41:44 +0000 (15:41 +0200)
committerJani Nikula <jani.nikula@intel.com>
Mon, 20 Mar 2023 09:50:44 +0000 (11:50 +0200)
Handle errors first and return early, and reduce indentation on the
happy day code path.

Cc: Jouni Högander <jouni.hogander@intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Jouni Högander <jouni.hogander@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230317134144.223936-3-jani.nikula@intel.com
drivers/gpu/drm/i915/display/intel_psr.c

index bd1a1a2524b50c44f4288b33939d2ad7c2a199b4..31084d95711d12904a3d0d4520aa15572579f6d8 100644 (file)
@@ -2891,6 +2891,7 @@ static int i915_psr_sink_status_show(struct seq_file *m, void *data)
                "reserved",
                "sink internal error",
        };
+       const char *str;
        int ret;
        u8 val;
 
@@ -2903,17 +2904,16 @@ static int i915_psr_sink_status_show(struct seq_file *m, void *data)
                return -ENODEV;
 
        ret = drm_dp_dpcd_readb(&intel_dp->aux, DP_PSR_STATUS, &val);
+       if (ret != 1)
+               return ret < 0 ? ret : -EIO;
 
-       if (ret == 1) {
-               const char *str = "unknown";
+       val &= DP_PSR_SINK_STATE_MASK;
+       if (val < ARRAY_SIZE(sink_status))
+               str = sink_status[val];
+       else
+               str = "unknown";
 
-               val &= DP_PSR_SINK_STATE_MASK;
-               if (val < ARRAY_SIZE(sink_status))
-                       str = sink_status[val];
-               seq_printf(m, "Sink PSR status: 0x%x [%s]\n", val, str);
-       } else {
-               return ret;
-       }
+       seq_printf(m, "Sink PSR status: 0x%x [%s]\n", val, str);
 
        return 0;
 }