From patchwork Thu Jul 26 08:13:26 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Arnd Bergmann X-Patchwork-Id: 142945 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp177549ljj; Thu, 26 Jul 2018 01:19:56 -0700 (PDT) X-Google-Smtp-Source: AAOMgpd19/R7pyW7/9I7v43+perhKiE/91SLXDF2nkRSjbymL2U+scoJz6e7lYYD6W4Uz+TNnDrK X-Received: by 2002:a17:902:43a4:: with SMTP id j33-v6mr1045136pld.118.1532593196848; Thu, 26 Jul 2018 01:19:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532593196; cv=none; d=google.com; s=arc-20160816; b=B0OOsRQcOFJe+w865ZTe3qk1erBVHflcXGxf/FidSsfiJ6YfkqlqZ+ADPrF/l/535P flnr63ZFjIWg3HEM8ytaraQlnB2CTjoYtoIXQ5JsNuMJLob2cMez+te85SCE7IDqPZ9L L9Mq2bX9/JbGr3KHvI8AFrHCkovUteA8ucuVtAmwh0F7A1Q5j8DFm4ySc9k6zxSYXxq2 R/1wXu8GwGBjyWa7FftGy8gC34Wtjg2meGFReOQ2L11ymYwqpIpqzdIOYoC0+Ga/Q/1S AdkTbUAZRK37CCB4UlwNXvPBeeo9/boK6z3/Do7Q9fYDCMPu7LagLynRQdjL9uWtANnK v4mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=WPUKofCHKBt1ymmc/uzUWnpTLMP+SsS/pAFTKJcOBf8=; b=0445rOAG1RSLPM7+nLKXxaChfwYGoLeKkIHezgkcGkU/3jCkgI9zGVKdz5s04cd2Ji HWoLy8Nvr4s40o2PPQGCK3ky6MPzzEY3lUNjfBWdy3jROCqAYq+vZWILvab1PqenjKde UvhAX4BTLXW16pI6AdqIan73dOcdn1Fp3Bkalg31PNIuPilyhheA3EP7lYq1oh7ls7Ic vZaNoF4y0s2/4a+c5mYuZC3BtT34+A9lFIHVUWPrQjifCk4NCJYuo7EKDGIyiCLi7YjX DhHCc8U0hH/4DXOfhOk+GdbeeVNzgfQox8KNavdItj3Hq9F+JdwLpw90smz6j5MP8t/N Dbpg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of stable-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 65-v6si775999pld.451.2018.07.26.01.19.56; Thu, 26 Jul 2018 01:19:56 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of stable-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of stable-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729103AbeGZJfi (ORCPT + 13 others); Thu, 26 Jul 2018 05:35:38 -0400 Received: from mout.kundenserver.de ([217.72.192.75]:43425 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727790AbeGZJfh (ORCPT ); Thu, 26 Jul 2018 05:35:37 -0400 Received: from wuerfel.lan ([109.193.40.16]) by mrelayeu.kundenserver.de (mreue105 [212.227.15.145]) with ESMTPA (Nemesis) id 0Lutsn-1g8gw70ABF-0104xc; Thu, 26 Jul 2018 10:15:22 +0200 From: Arnd Bergmann To: stable@vger.kernel.org Cc: gregkh@linuxfoundation.org, Arnd Bergmann , Alexander Viro , Peter Zijlstra , Serge Hallyn , James Morris , Aleksa Sarai , "Eric W. Biederman" , Frederic Weisbecker , Thomas Gleixner , Andrew Morton , Linus Torvalds Subject: [PATCH 2/2] [stable-4.9] exec: avoid gcc-8 warning for get_task_comm Date: Thu, 26 Jul 2018 10:13:26 +0200 Message-Id: <20180726081358.3829157-5-arnd@arndb.de> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180726081358.3829157-1-arnd@arndb.de> References: <20180726081358.3829157-1-arnd@arndb.de> X-Provags-ID: V03:K1:ygwcy1pEtdaiy91b1W5kuw7bd72pA/4vKfZ09R8yKGuZLUtEPsY hVxD2Iy8mdKSii+ri98EHXf8WLwF2md5900dqUrqPnijRye8PNfmrGVyKhyaV8oqlFT+37g xDZc3a95HvxwXaIUM+Ch1KDzvv6LE76soCyRMdKuywA/VV+gfL1Zs/DuVT3JWah3wnsUeFZ ETbK22auCv3HMcjJRii9w== X-UI-Out-Filterresults: notjunk:1; V01:K0:xHRr5YkpUp0=:0SjgYHYU07n+Po0Qv7OhYo +3lJOuaZNwaUQRQztymRx3j1B5VT06vz0qSVy5G+eUqaYs+T7gFzqI9i9gxEWC3ZwfLICnyXX El272K6avnTJpGUQ4xgofHNBwmH9z5NuFOaJO7zoVce4jvZxwBWRbux4pSFSuYziT6LT8FSCy bW2MhbfD0cYiH4iklLfzEQtaRwBbwMWIJl7GsGPXiXyBHXDKgTsFBa2FncH50VK/Wluslx8x4 QUM/Rn64wYy32UpnZZpSFQuZ3oRVALlrVM1ksKfYSSt2qXtlMKW0WWMgkD4V03GdioaG10Ak2 2L/fp3ZDU+lSD273Bt7u3uBCy9SjzSGcg3D6Y+1zFtV3Jggv5U44EJG+XoPWZv1+xpDVa0x6T nSGwqzoUCiwILREtIRAKRHd+bSPyUr/NqQP47rMxA1sp8mr9MYTDIUTooIOSO0iyfuZ+VZxTB Yuqbpgy/ijO3oDHfkWm+8+tKyXRdbJFkRUELdmhp1F1P2uth+ecg/A3wJ3Syut1v9E0PLXmRF k2Of67norojLYrW8RnjNLF8+VzK2OzjkdEFW0MMFX+YZZVB30yUbRmO2O0hEcgjtpj0STMKkQ YirJeT0Mo9vyu2+gwpSSzh8C8d5Ol56aTWWBA6mhy3CIC0rF/o7d81ffDXuAnue8+1XfMis7r 2ACQYOtTtq754CuYqvI5B6AamGo86yddlawyboP5WX5Dxk4oejvHHtxLzrFhhuKyDeTk= Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org Commit 3756f6401c302617c5e091081ca4d26ab604bec5 upstream. gcc-8 warns about using strncpy() with the source size as the limit: fs/exec.c:1223:32: error: argument to 'sizeof' in 'strncpy' call is the same expression as the source; did you mean to use the size of the destination? [-Werror=sizeof-pointer-memaccess] This is indeed slightly suspicious, as it protects us from source arguments without NUL-termination, but does not guarantee that the destination is terminated. This keeps the strncpy() to ensure we have properly padded target buffer, but ensures that we use the correct length, by passing the actual length of the destination buffer as well as adding a build-time check to ensure it is exactly TASK_COMM_LEN. There are only 23 callsites which I all reviewed to ensure this is currently the case. We could get away with doing only the check or passing the right length, but it doesn't hurt to do both. Link: http://lkml.kernel.org/r/20171205151724.1764896-1-arnd@arndb.de Signed-off-by: Arnd Bergmann Suggested-by: Kees Cook Acked-by: Kees Cook Acked-by: Ingo Molnar Cc: Alexander Viro Cc: Peter Zijlstra Cc: Serge Hallyn Cc: James Morris Cc: Aleksa Sarai Cc: "Eric W. Biederman" Cc: Frederic Weisbecker Cc: Thomas Gleixner Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Arnd Bergmann --- fs/exec.c | 7 +++---- include/linux/sched.h | 6 +++++- 2 files changed, 8 insertions(+), 5 deletions(-) -- 2.18.0 diff --git a/fs/exec.c b/fs/exec.c index b8c43be24751..fcd8642ef2d2 100644 --- a/fs/exec.c +++ b/fs/exec.c @@ -1228,15 +1228,14 @@ static int de_thread(struct task_struct *tsk) return -EAGAIN; } -char *get_task_comm(char *buf, struct task_struct *tsk) +char *__get_task_comm(char *buf, size_t buf_size, struct task_struct *tsk) { - /* buf must be at least sizeof(tsk->comm) in size */ task_lock(tsk); - strncpy(buf, tsk->comm, sizeof(tsk->comm)); + strncpy(buf, tsk->comm, buf_size); task_unlock(tsk); return buf; } -EXPORT_SYMBOL_GPL(get_task_comm); +EXPORT_SYMBOL_GPL(__get_task_comm); /* * These functions flushes out all traces of the currently running executable diff --git a/include/linux/sched.h b/include/linux/sched.h index 5ebef8c86c26..1cc5723a7821 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -2999,7 +2999,11 @@ static inline void set_task_comm(struct task_struct *tsk, const char *from) { __set_task_comm(tsk, from, false); } -extern char *get_task_comm(char *to, struct task_struct *tsk); +extern char *__get_task_comm(char *to, size_t len, struct task_struct *tsk); +#define get_task_comm(buf, tsk) ({ \ + BUILD_BUG_ON(sizeof(buf) != TASK_COMM_LEN); \ + __get_task_comm(buf, sizeof(buf), tsk); \ +}) #ifdef CONFIG_SMP void scheduler_ipi(void);