Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp4736635rdb; Fri, 15 Sep 2023 10:39:18 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFA2r7cCpTs685cAN5ziY7/BKwwYCn+yd+fvUzYTDsKJZWz8OxXxj1oB9PojaL0eCzAAHqs X-Received: by 2002:a05:6a20:244e:b0:134:8d7f:f4d9 with SMTP id t14-20020a056a20244e00b001348d7ff4d9mr2947893pzc.52.1694799558246; Fri, 15 Sep 2023 10:39:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694799558; cv=none; d=google.com; s=arc-20160816; b=YZm5ax0zwKi/MH+6a4pnBunXbq2EA01r+7jlBgga0IMg4wJxMRustdZrwW7FN7s7FQ j6EvmIzmuvZXqRkjRoXsN9uFQJQVXrrxBoKrfhkvHGQXJCQ6fZPuwyTV7GOSU7gjNac3 KV5RNQToj3QJrGp5n4W2dOf9+r3B2Zyb+bbc5h1Mmr+PStOPs5BfIKhVqUd+fC5d6MHF LM76QftVtPGWB1q/JB2zl7QmLSC7iuFhbbEOVjFrC8RrWGN5ofNzPqz3DcCV4Tv6ZyHC Ju7l2LcNQUASgv49WIZcPfdq5kuDRz85p4QnLIwwPilZFjw88KlZhtmfOmiPDGAwiLep Wqeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent :content-transfer-encoding:organization:references:in-reply-to:date :cc:to:from:subject:message-id:dkim-signature; bh=WlpIc4DwS1d7tWoYWtATBVAp1YG/9Jib85DcTdMBUWQ=; fh=mkywvh4li5fymmeIevwZKLs76ZxdCcRvwyVyJg4B5F4=; b=fzXioK5Q4id/5Ki4S6Dnom7b6DCfgNqMIDgSI0JkyP1BRlKenchj7zH7I7H/8vqsrE fsOSATelMELeBkYXZ4ViBO59yPcU6MMrzfMdd7Qv6/yioW0tait7IA5QqyvsIaGmnUS4 p64HJXfvhwz5OTOm0YwtUTbe0Clx48tvbx7a3+bwmPSngihDlGZkcveUDk3TM19R9BOk g3d08QOvjKsTDqQIJlUPOiXlAe0lJp/ZatCA3rZhO8l+Kr1jNyE9H6ybxz7MGiAU1u/s sR30J3stNvUfJ+mR0dRfYbGWA6GMnF2OToJ/w8+xjDrq4E2jtgqUBH0hIgR12npaf95C cGEA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=P0064uwe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id z16-20020a656650000000b00577723d24b0si646521pgv.46.2023.09.15.10.39.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Sep 2023 10:39:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=P0064uwe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 5702D8038B2B; Fri, 15 Sep 2023 10:36:40 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235944AbjIORgN (ORCPT + 99 others); Fri, 15 Sep 2023 13:36:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48620 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236363AbjIORf6 (ORCPT ); Fri, 15 Sep 2023 13:35:58 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 79FF430E9 for ; Fri, 15 Sep 2023 10:33:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1694799215; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=WlpIc4DwS1d7tWoYWtATBVAp1YG/9Jib85DcTdMBUWQ=; b=P0064uweYcVfMTVYtnfsOT4fGf3B1yTDMSW1fQLcQ3PamZVW22+GIuFg2sM58eVn+M5Uii MFdBliweBzOkGDWehF3qdP7y2Hw41KnXRY7LApY2DSUwwxQrfDDNNSd7fW2w2wRLK/5TU1 PGKNCQciOKq/N/C9l5AuDcVNtMWZ2OM= Received: from mail-ua1-f70.google.com (mail-ua1-f70.google.com [209.85.222.70]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-602-c_J5kVWAMWieZCWcH6G3Tg-1; Fri, 15 Sep 2023 13:33:34 -0400 X-MC-Unique: c_J5kVWAMWieZCWcH6G3Tg-1 Received: by mail-ua1-f70.google.com with SMTP id a1e0cc1a2514c-7a85544b8d4so937909241.3 for ; Fri, 15 Sep 2023 10:33:34 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1694799213; x=1695404013; h=mime-version:user-agent:content-transfer-encoding:organization :references:in-reply-to:date:cc:to:from:subject:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=WlpIc4DwS1d7tWoYWtATBVAp1YG/9Jib85DcTdMBUWQ=; b=vT+XVVhF6MpHbBrWtmAz3EhsJdZo9x9ac3DSKHLJ4BguJaUPFd6NmGX+dzGmQ3gGqw Om5x1f+KoqspPaJ47HeGCqD8L8iyF8nRdaaN4KPL09hvpEKvMEezCEQmyecdPuHGH0EW icqSUH1mQP3nwZn0GVcls1ZZhFLMNxueWyWy5QPuOf1MTrLehFFSfp5Is98FbslIfBQg GXnpg3B+L+Mdt35H5ceA04oU7PfD0O3L3lA7iam6h1TLeyaJZFHGDMxjJJHgqX/5f8gC hJyOypGnUK41dhsOQ0ieSzeQRyjYqZHNXjmduzlB+HZGfqKgmIrxqmkImfqtMSQFEK7v HiXw== X-Gm-Message-State: AOJu0Yz+zomuhsm5LULSxGid53zu1Le7GbUHHj8FwvtH9iU+JKIZ9NpE aPJwkf6zxzJg4j47RUH8RGIujkg4kTZf8dJUB3Qo2/OyYHA9M+7UrWMZ+FlnScK87oRuwYHRtEr Thdw7Pbvy/5BPnIKUWmPTrxxT X-Received: by 2002:a05:6102:445:b0:44e:b11a:8b16 with SMTP id e5-20020a056102044500b0044eb11a8b16mr2136900vsq.13.1694799213552; Fri, 15 Sep 2023 10:33:33 -0700 (PDT) X-Received: by 2002:a05:6102:445:b0:44e:b11a:8b16 with SMTP id e5-20020a056102044500b0044eb11a8b16mr2136872vsq.13.1694799213203; Fri, 15 Sep 2023 10:33:33 -0700 (PDT) Received: from ?IPv6:2600:4040:5c6c:a300::feb? ([2600:4040:5c6c:a300::feb]) by smtp.gmail.com with ESMTPSA id r19-20020a0ccc13000000b0064f91d410b9sm1409818qvk.128.2023.09.15.10.33.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Sep 2023 10:33:32 -0700 (PDT) Message-ID: <00fba033910961bac96dabe9d7e0435342fd021d.camel@redhat.com> Subject: Re: [PATCH] drm/nouveau/core: refactor deprecated strncpy From: Lyude Paul To: Justin Stitt , Ben Skeggs , Karol Herbst , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, nouveau@lists.freedesktop.org, linux-kernel@vger.kernel.org, linux-hardening@vger.kernel.org Date: Fri, 15 Sep 2023 13:33:32 -0400 In-Reply-To: <20230914-strncpy-drivers-gpu-drm-nouveau-nvkm-core-firmware-c-v1-1-3aeae46c032f@google.com> References: <20230914-strncpy-drivers-gpu-drm-nouveau-nvkm-core-firmware-c-v1-1-3aeae46c032f@google.com> Organization: Red Hat Inc. Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.48.4 (3.48.4-1.fc38) MIME-Version: 1.0 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Fri, 15 Sep 2023 10:36:40 -0700 (PDT) Eek, I didn't realize how many instances of this we had. Thanks for doing t= his :) Reviewed-by: Lyude Paul On Thu, 2023-09-14 at 21:40 +0000, Justin Stitt wrote: > `strncpy` is deprecated for use on NUL-terminated destination strings [1]= . >=20 > We should prefer more robust and less ambiguous string interfaces. >=20 > A suitable replacement is `strscpy` [2] due to the fact that it guarantee= s > NUL-termination on the destination buffer without unnecessarily NUL-paddi= ng. >=20 > There is likely no bug in the current implementation due to the safeguard= : > > cname[sizeof(cname) - 1] =3D '\0'; > ... however we can provide simpler and easier to understand code using > the newer (and recommended) `strscpy` api. >=20 > Link: https://www.kernel.org/doc/html/latest/process/deprecated.html#strn= cpy-on-nul-terminated-strings [1] > Link: https://manpages.debian.org/testing/linux-manual-4.8/strscpy.9.en.h= tml [2] > Link: https://github.com/KSPP/linux/issues/90 > Cc: linux-hardening@vger.kernel.org > Signed-off-by: Justin Stitt > --- > drivers/gpu/drm/nouveau/nvkm/core/firmware.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) >=20 > diff --git a/drivers/gpu/drm/nouveau/nvkm/core/firmware.c b/drivers/gpu/d= rm/nouveau/nvkm/core/firmware.c > index 91fb494d4009..374212da9e95 100644 > --- a/drivers/gpu/drm/nouveau/nvkm/core/firmware.c > +++ b/drivers/gpu/drm/nouveau/nvkm/core/firmware.c > @@ -79,8 +79,7 @@ nvkm_firmware_get(const struct nvkm_subdev *subdev, con= st char *fwname, int ver, > int i; > =20 > /* Convert device name to lowercase */ > - strncpy(cname, device->chip->name, sizeof(cname)); > - cname[sizeof(cname) - 1] =3D '\0'; > + strscpy(cname, device->chip->name, sizeof(cname)); > i =3D strlen(cname); > while (i) { > --i; >=20 > --- > base-commit: 3669558bdf354cd352be955ef2764cde6a9bf5ec > change-id: 20230914-strncpy-drivers-gpu-drm-nouveau-nvkm-core-firmware-c-= 791223838b72 >=20 > Best regards, > -- > Justin Stitt >=20 --=20 Cheers, Lyude Paul (she/her) Software Engineer at Red Hat