All of lore.kernel.org
 help / color / mirror / Atom feed
* [Intel-gfx] [PATCH][next] drm/i915/uapi: Replace fake flex-array with flexible-array member
@ 2023-03-17 18:18 ` Gustavo A. R. Silva
  0 siblings, 0 replies; 23+ messages in thread
From: Gustavo A. R. Silva @ 2023-03-17 18:18 UTC (permalink / raw)
  To: Jani Nikula, Joonas Lahtinen, Rodrigo Vivi, Tvrtko Ursulin,
	David Airlie, Daniel Vetter
  Cc: intel-gfx, linux-hardening, linux-kernel, dri-devel,
	Gustavo A. R. Silva

Zero-length arrays as fake flexible arrays are deprecated and we are
moving towards adopting C99 flexible-array members instead.

Address the following warning found with GCC-13 and
-fstrict-flex-arrays=3 enabled:
drivers/gpu/drm/i915/gem/i915_gem_context.c: In function ‘set_proto_ctx_engines.isra’:
drivers/gpu/drm/i915/gem/i915_gem_context.c:769:41: warning: array subscript n is outside array bounds of ‘struct i915_engine_class_instance[0]’ [-Warray-bounds=]
  769 |                 if (copy_from_user(&ci, &user->engines[n], sizeof(ci))) {
      |                                         ^~~~~~~~~~~~~~~~~
./include/uapi/drm/i915_drm.h:2494:43: note: while referencing ‘engines’
 2494 |         struct i915_engine_class_instance engines[0];

This helps with the ongoing efforts to tighten the FORTIFY_SOURCE
routines on memcpy() and help us make progress towards globally
enabling -fstrict-flex-arrays=3 [1].

Link: https://github.com/KSPP/linux/issues/21
Link: https://github.com/KSPP/linux/issues/271
Link: https://gcc.gnu.org/pipermail/gcc-patches/2022-October/602902.html [1]
Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
---
 include/uapi/drm/i915_drm.h | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/include/uapi/drm/i915_drm.h b/include/uapi/drm/i915_drm.h
index 8df261c5ab9b..5e458d6f2895 100644
--- a/include/uapi/drm/i915_drm.h
+++ b/include/uapi/drm/i915_drm.h
@@ -2491,7 +2491,7 @@ struct i915_context_param_engines {
 #define I915_CONTEXT_ENGINES_EXT_LOAD_BALANCE 0 /* see i915_context_engines_load_balance */
 #define I915_CONTEXT_ENGINES_EXT_BOND 1 /* see i915_context_engines_bond */
 #define I915_CONTEXT_ENGINES_EXT_PARALLEL_SUBMIT 2 /* see i915_context_engines_parallel_submit */
-	struct i915_engine_class_instance engines[0];
+	struct i915_engine_class_instance engines[];
 } __attribute__((packed));
 
 #define I915_DEFINE_CONTEXT_PARAM_ENGINES(name__, N__) struct { \
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 23+ messages in thread

end of thread, other threads:[~2023-04-06 18:18 UTC | newest]

Thread overview: 23+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-03-17 18:18 [Intel-gfx] [PATCH][next] drm/i915/uapi: Replace fake flex-array with flexible-array member Gustavo A. R. Silva
2023-03-17 18:18 ` Gustavo A. R. Silva
2023-03-17 18:18 ` Gustavo A. R. Silva
2023-03-17 18:43 ` [Intel-gfx] ✗ Fi.CI.CHECKPATCH: warning for " Patchwork
2023-03-17 18:43 ` [Intel-gfx] ✗ Fi.CI.SPARSE: " Patchwork
2023-03-17 18:43 ` [Intel-gfx] ✗ Fi.CI.DOCS: " Patchwork
2023-03-17 18:54 ` [Intel-gfx] ✓ Fi.CI.BAT: success " Patchwork
2023-03-17 21:48 ` [Intel-gfx] ✓ Fi.CI.IGT: " Patchwork
2023-03-20 17:36 ` [Intel-gfx] [PATCH][next] " Kees Cook
2023-03-20 17:36   ` Kees Cook
2023-03-20 17:36   ` Kees Cook
2023-03-21  8:43   ` [Intel-gfx] " Tvrtko Ursulin
2023-03-21  8:43     ` Tvrtko Ursulin
2023-03-21  8:43     ` Tvrtko Ursulin
2023-03-30 20:13 ` [Intel-gfx] " Gustavo A. R. Silva
2023-03-30 20:13   ` Gustavo A. R. Silva
2023-03-30 20:13   ` Gustavo A. R. Silva
2023-03-31  7:02   ` [Intel-gfx] " Jani Nikula
2023-03-31  7:02     ` Jani Nikula
2023-03-31  7:02     ` Jani Nikula
2023-04-06 16:27     ` [Intel-gfx] " Gustavo A. R. Silva
2023-04-06 16:27       ` Gustavo A. R. Silva
2023-04-06 16:27       ` Gustavo A. R. Silva

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.