]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/gt: use designated initializers for intel_gt_debugfs_file
authorSebastian Brzezinka <sebastian.brzezinka@intel.com>
Tue, 16 Dec 2025 15:11:45 +0000 (16:11 +0100)
committerAndi Shyti <andi.shyti@kernel.org>
Thu, 1 Jan 2026 12:14:50 +0000 (13:14 +0100)
CONFIG_RANDSTRUCT may reorder structure fields, which makes positional
initializers unsafe. The i915 GT debugfs tables were using positional
initializers for `struct intel_gt_debugfs_file`, and on configs where
the layout differs (e.g., presence/absence of the `.eval` callback),
this can lead to fields being initialized incorrectly and trigger
randstruct warnings such as:

```
  drivers/gpu/drm/i915/gt/intel_gt_debugfs.c:75:51: note: randstruct:
  casting between randomized structure pointer types (constructor)
```

Switch all the GT debugfs file arrays to designated initializers. This
binds each value to the intended member regardless of structure
reordering or optional members and removes the warning while preserving
the intended initialization. Also drops the '&' from
intel_eval_slpc_support so .eval receives the function pointer directly.

No functional change, only initialization style is updated.

Signed-off-by: Sebastian Brzezinka <sebastian.brzezinka@intel.com>
Reviewed-by: Krzysztof Karas <krzysztof.karas@intel.com>
Reviewed-by: Andi Shyti <andi.shyti@linux.intel.com>
Signed-off-by: Andi Shyti <andi.shyti@linux.intel.com>
Link: https://lore.kernel.org/r/bae491e8098705a87304a7c94573b377e8c8fa37.1765897826.git.sebastian.brzezinka@intel.com
drivers/gpu/drm/i915/gt/intel_gt_debugfs.c
drivers/gpu/drm/i915/gt/intel_gt_engines_debugfs.c
drivers/gpu/drm/i915/gt/intel_gt_pm_debugfs.c
drivers/gpu/drm/i915/gt/intel_sseu_debugfs.c
drivers/gpu/drm/i915/gt/uc/intel_gsc_uc_debugfs.c
drivers/gpu/drm/i915/gt/uc/intel_guc_debugfs.c
drivers/gpu/drm/i915/gt/uc/intel_guc_log_debugfs.c
drivers/gpu/drm/i915/gt/uc/intel_huc_debugfs.c
drivers/gpu/drm/i915/gt/uc/intel_uc_debugfs.c

index dcd40b30a96ba8589407fd49043588dcca846ec7..71ebdd76ff372580e35e19a7aad8b2e9ba1234e8 100644 (file)
@@ -73,8 +73,8 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(steering);
 static void gt_debugfs_register(struct intel_gt *gt, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "reset", &reset_fops, NULL },
-               { "steering", &steering_fops },
+               { .name = "reset", .fops = &reset_fops },
+               { .name = "steering", .fops = &steering_fops },
        };
 
        intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), gt);
index 3aa1d014c14dfe98f5eedcd408240f1b5be8349e..ae6c78dfe4524eda256d2bcffd9331b6265f78ba 100644 (file)
@@ -29,7 +29,7 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(engines);
 void intel_gt_engines_debugfs_register(struct intel_gt *gt, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "engines", &engines_fops },
+               { .name = "engines", .fops = &engines_fops },
        };
 
        intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), gt);
index 87ef85483baec5a08de8c26642ab2f7a823c131c..b2640cf17d9be1d42fa1d988687519dc59037823 100644 (file)
@@ -586,13 +586,14 @@ DEFINE_SIMPLE_ATTRIBUTE(perf_limit_reasons_fops, perf_limit_reasons_get,
 void intel_gt_pm_debugfs_register(struct intel_gt *gt, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "drpc", &drpc_fops, NULL },
-               { "frequency", &frequency_fops, NULL },
-               { "forcewake", &fw_domains_fops, NULL },
-               { "forcewake_user", &forcewake_user_fops, NULL},
-               { "llc", &llc_fops, llc_eval },
-               { "rps_boost", &rps_boost_fops, rps_eval },
-               { "perf_limit_reasons", &perf_limit_reasons_fops, perf_limit_reasons_eval },
+               { .name = "drpc", .fops = &drpc_fops },
+               { .name = "frequency", .fops = &frequency_fops },
+               { .name = "forcewake", .fops = &fw_domains_fops },
+               { .name = "forcewake_user", .fops = &forcewake_user_fops},
+               { .name = "llc", .fops = &llc_fops, .eval = llc_eval },
+               { .name = "rps_boost", .fops = &rps_boost_fops, .eval = rps_eval },
+               { .name = "perf_limit_reasons", .fops = &perf_limit_reasons_fops,
+                 .eval = perf_limit_reasons_eval },
        };
 
        intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), gt);
index c2ee5e1826b5dcbd8b99b5acb71e7270f26591dc..bfdfd92ce2095244f1c514cb50c4bd393d751d48 100644 (file)
@@ -291,8 +291,8 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(sseu_topology);
 void intel_sseu_debugfs_register(struct intel_gt *gt, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "sseu_status", &sseu_status_fops, NULL },
-               { "sseu_topology", &sseu_topology_fops, NULL },
+               { .name = "sseu_status", .fops = &sseu_status_fops },
+               { .name = "sseu_topology", .fops = &sseu_topology_fops },
        };
 
        intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), gt);
index 5baacd822a1c82922edf4182105285acbdd4b3ac..0ca811e8f3142db4ca1949559fd98cbd77af2136 100644 (file)
@@ -29,7 +29,7 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(gsc_info);
 void intel_gsc_uc_debugfs_register(struct intel_gsc_uc *gsc_uc, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "gsc_info", &gsc_info_fops, NULL },
+               { .name = "gsc_info", .fops = &gsc_info_fops },
        };
 
        if (!intel_gsc_uc_is_supported(gsc_uc))
index 7269eb0bbedf51714d0b09a40ea4e8cec63bd646..a30e1397029873ebcb2109c6fd187eeac5c52eaf 100644 (file)
@@ -132,12 +132,13 @@ DEFINE_SIMPLE_ATTRIBUTE(guc_sched_disable_gucid_threshold_fops,
 void intel_guc_debugfs_register(struct intel_guc *guc, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "guc_info", &guc_info_fops, NULL },
-               { "guc_registered_contexts", &guc_registered_contexts_fops, NULL },
-               { "guc_slpc_info", &guc_slpc_info_fops, &intel_eval_slpc_support},
-               { "guc_sched_disable_delay_ms", &guc_sched_disable_delay_ms_fops, NULL },
-               { "guc_sched_disable_gucid_threshold", &guc_sched_disable_gucid_threshold_fops,
-                  NULL },
+               { .name = "guc_info", .fops = &guc_info_fops },
+               { .name = "guc_registered_contexts", .fops = &guc_registered_contexts_fops },
+               { .name = "guc_slpc_info", .fops = &guc_slpc_info_fops,
+                 .eval = intel_eval_slpc_support },
+               { .name = "guc_sched_disable_delay_ms", .fops = &guc_sched_disable_delay_ms_fops },
+               { .name = "guc_sched_disable_gucid_threshold",
+                 .fops = &guc_sched_disable_gucid_threshold_fops },
        };
 
        if (!intel_guc_is_supported(guc))
index ddfbe334689f6a9a8754a0e8864b86f393fa8da5..b4f3961a94c2998c741e160d0905bfce3508a55e 100644 (file)
@@ -162,10 +162,10 @@ void intel_guc_log_debugfs_register(struct intel_guc_log *log,
                                    struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "guc_log_dump", &guc_log_dump_fops, NULL },
-               { "guc_load_err_log_dump", &guc_load_err_log_dump_fops, NULL },
-               { "guc_log_level", &guc_log_level_fops, NULL },
-               { "guc_log_relay", &guc_log_relay_fops, NULL },
+               { .name = "guc_log_dump", .fops = &guc_log_dump_fops },
+               { .name = "guc_load_err_log_dump", .fops = &guc_load_err_log_dump_fops},
+               { .name = "guc_log_level", .fops = &guc_log_level_fops },
+               { .name = "guc_log_relay", .fops = &guc_log_relay_fops },
        };
 
        if (!intel_guc_is_supported(log_to_guc(log)))
index 15998963b86366b582ebaf410939897bf0fd50a5..da67854a9432bf75eee2d205e2bbb33dc42c3667 100644 (file)
@@ -26,7 +26,7 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(huc_info);
 void intel_huc_debugfs_register(struct intel_huc *huc, struct dentry *root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "huc_info", &huc_info_fops, NULL },
+               { .name = "huc_info", .fops = &huc_info_fops },
        };
 
        if (!intel_huc_is_supported(huc))
index 6d541c866edb9ee72f462cb7072268edbf718882..d7499fcebe1dd6b1710e4c1ac20e8cd543281734 100644 (file)
@@ -40,7 +40,7 @@ DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(uc_usage);
 void intel_uc_debugfs_register(struct intel_uc *uc, struct dentry *gt_root)
 {
        static const struct intel_gt_debugfs_file files[] = {
-               { "usage", &uc_usage_fops, NULL },
+               { .name = "usage", .fops = &uc_usage_fops },
        };
        struct dentry *root;