drm: replace strcpy() with strscpy()

To prevent errors from occurring when the src string is longer than the
dst string in strcpy(), we should use strscpy() instead.  This approach
also facilitates future extensions to the task comm.

Link: https://lkml.kernel.org/r/20241007144911.27693-8-laoar.shao@gmail.com
Signed-off-by: Yafang Shao <laoar.shao@gmail.com>
Suggested-by: Justin Stitt <justinstitt@google.com>
Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Reviewed-by: Justin Stitt <justinstitt@google.com>
Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Maxime Ripard <mripard@kernel.org>
Cc: Thomas Zimmermann <tzimmermann@suse.de>
Cc: David Airlie <airlied@gmail.com>
Cc: Alejandro Colomar <alx@kernel.org>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Cc: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Cc: Andy Shevchenko <andy.shevchenko@gmail.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christian Brauner <brauner@kernel.org>
Cc: Eric Biederman <ebiederm@xmission.com>
Cc: Eric Paris <eparis@redhat.com>
Cc: James Morris <jmorris@namei.org>
Cc: Jan Kara <jack@suse.cz>
Cc: Kees Cook <keescook@chromium.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Matus Jokay <matus.jokay@stuba.sk>
Cc: Ondrej Mosnacek <omosnace@redhat.com>
Cc: Paul Moore <paul@paul-moore.com>
Cc: Quentin Monnet <qmo@kernel.org>
Cc: "Serge E. Hallyn" <serge@hallyn.com>
Cc: Simon Horman <horms@kernel.org>
Cc: Stephen Smalley <stephen.smalley.work@gmail.com>
Cc: Steven Rostedt (Google) <rostedt@goodmis.org>
Cc: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
Yafang Shao 2024-10-07 22:49:11 +08:00 committed by Andrew Morton
parent 43731516fa
commit 3240aadacc
2 changed files with 4 additions and 4 deletions

View File

@ -868,7 +868,7 @@ int drm_framebuffer_init(struct drm_device *dev, struct drm_framebuffer *fb,
INIT_LIST_HEAD(&fb->filp_head); INIT_LIST_HEAD(&fb->filp_head);
fb->funcs = funcs; fb->funcs = funcs;
strcpy(fb->comm, current->comm); strscpy(fb->comm, current->comm);
ret = __drm_mode_object_add(dev, &fb->base, DRM_MODE_OBJECT_FB, ret = __drm_mode_object_add(dev, &fb->base, DRM_MODE_OBJECT_FB,
false, drm_framebuffer_free); false, drm_framebuffer_free);

View File

@ -1113,7 +1113,7 @@ i915_vma_coredump_create(const struct intel_gt *gt,
} }
INIT_LIST_HEAD(&dst->page_list); INIT_LIST_HEAD(&dst->page_list);
strcpy(dst->name, name); strscpy(dst->name, name);
dst->next = NULL; dst->next = NULL;
dst->gtt_offset = vma_res->start; dst->gtt_offset = vma_res->start;
@ -1413,7 +1413,7 @@ static bool record_context(struct i915_gem_context_coredump *e,
rcu_read_lock(); rcu_read_lock();
task = pid_task(ctx->pid, PIDTYPE_PID); task = pid_task(ctx->pid, PIDTYPE_PID);
if (task) { if (task) {
strcpy(e->comm, task->comm); strscpy(e->comm, task->comm);
e->pid = task->pid; e->pid = task->pid;
} }
rcu_read_unlock(); rcu_read_unlock();
@ -1459,7 +1459,7 @@ capture_vma_snapshot(struct intel_engine_capture_vma *next,
return next; return next;
} }
strcpy(c->name, name); strscpy(c->name, name);
c->vma_res = i915_vma_resource_get(vma_res); c->vma_res = i915_vma_resource_get(vma_res);
c->next = next; c->next = next;