Received: by 2002:a05:7412:cfc7:b0:fc:a2b0:25d7 with SMTP id by7csp1620892rdb; Tue, 20 Feb 2024 01:36:52 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCWQighkKDqgzUNNAWXKk6VsyEHHazjoNlSViKVZ3r8j/eyfKU0dLOV473rUosYzhbuROUbvllcoptLq/SgiqXhlknoBWvnfq9yF0g4noA== X-Google-Smtp-Source: AGHT+IF3UONv4Zqe75hMSG5nz76oyTWoKbVrjhsK/9WHVdLROgkl3OmsSOK4qQ676hdSVJ6k+35H X-Received: by 2002:a05:6870:232a:b0:21e:a6fb:28eb with SMTP id w42-20020a056870232a00b0021ea6fb28ebmr6510906oao.35.1708421811938; Tue, 20 Feb 2024 01:36:51 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708421811; cv=pass; d=google.com; s=arc-20160816; b=tg0Ziaip7E9QlgaL+FGrAsvWmHcrbEo+EcMWHr9APv2+KIjzGIGU2/CKXBYXf1MWY1 qtRSOGoGJpuQebbr9yFN5GsQd95vkRw4aE/wUa3ucSWnO6fikQfzRZC2+62Cxt5r8HPE pr6hf32F04+53tyeb17AdnqYoflJ/w3Fq7oV+YiQK0p3rvC7o26FdUsqXwISBhOJIsMt rTulYG7VheuyI7zAK0dbMcZNIU6b5WK8rkIRyCCQDvZkj2FvKrkD0jrnKFZIcbBn0+iP FJshpfsHdyufgiRKIapOaDiMzvOKT5eqdwfLG2YkeJQkNlv3uLJ/GjaVoH1bCsW/ngZ/ msIQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=cc:to:from:subject:message-id:references:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:in-reply-to:date :dkim-signature; bh=eGvW91C4grW9jhiVdhrUhasqpBxGbw0RjsBpYtBt9c0=; fh=8QksNHAy4xKnuk40TK2vCnI5xgmbfwhnBp1FGT3o2KE=; b=ujR8O2v6Ph52ydR/aIWl//tQ28TIW1VUGdXIcn/jf1WXy2hIAqMJI2Pai+w+h+mmvI UBDX5ns8zM1MTGnO9MBLZrRa249d0gOn+Fna5qiouJWVqd5m88IAl6TeD3zTVZfaUKib 2mpFZKa0qsWIJ0kLJ3cgwHuSRIWBPmELxes7JTjqDMT3jjqOaom+NTswV0NDdaH8hCP0 Rgcz2cMlh9355QoqdF2OU7GkmOqGjgJ9HblUtpJkE8BAuZe75eHFf5O3YAiFsLCWv+c3 qyiKESyrwGadfDKhXNpk9cSSqeCoXvRcbclCtqNaSk3gPWbVny3j2bSQduaarRHdczzP daKA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=mJ7JAnEG; arc=pass (i=1 spf=pass spfdomain=flex--aliceryhl.bounces.google.com dkim=pass dkdomain=google.com dmarc=pass fromdomain=google.com); spf=pass (google.com: domain of linux-kernel+bounces-72702-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-72702-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id s7-20020a635e07000000b005cd77a0fd8dsi5778374pgb.484.2024.02.20.01.36.51 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Feb 2024 01:36:51 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-72702-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=mJ7JAnEG; arc=pass (i=1 spf=pass spfdomain=flex--aliceryhl.bounces.google.com dkim=pass dkdomain=google.com dmarc=pass fromdomain=google.com); spf=pass (google.com: domain of linux-kernel+bounces-72702-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-72702-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id F3CE8284265 for ; Tue, 20 Feb 2024 09:36:02 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B3B1160867; Tue, 20 Feb 2024 09:35:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="mJ7JAnEG" Received: from mail-lj1-f201.google.com (mail-lj1-f201.google.com [209.85.208.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3369F5F542 for ; Tue, 20 Feb 2024 09:35:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708421749; cv=none; b=IAv3kU9lnVuGzIwbcXufFx+V4HgfYkY+rrV7MgCmJ8EEbrDQ6q/KLJBsq4SkCRIlqujPxb073MqWkuoiDjVmzsYyu1ubzL6vJxdTzNvHBp7GjHyaLThpIAMFT/DnHVONvgUEdtgXQMcZdOm9GviHZIJvRzI3WblixQgue7VkIaQ= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708421749; c=relaxed/simple; bh=Hq0Cmy5FJkYWn0RlKLg2mQTAvevk9epBCAsv3Id1SNs=; h=Date:In-Reply-To:Mime-Version:References:Message-ID:Subject:From: To:Cc:Content-Type; b=ZDhKz+QqltQ0YF1O8c51vjc/5ue2p3ZpfLaus6L6KDPc2SbSJcKYb9fp8U7JM1sAC/DHTsaPvZXVbiAfsi92Ayqxe/NiaU+I9gKhJqskp/YPU/Pa+2RpbFlbZU6UMC8NXJshFw8bmTXcyEJq8rVjOwqdCRwWRXMSxdfpPu7H56s= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com; spf=pass smtp.mailfrom=flex--aliceryhl.bounces.google.com; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b=mJ7JAnEG; arc=none smtp.client-ip=209.85.208.201 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=flex--aliceryhl.bounces.google.com Received: by mail-lj1-f201.google.com with SMTP id 38308e7fff4ca-2d055407fa4so46758921fa.0 for ; Tue, 20 Feb 2024 01:35:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1708421746; x=1709026546; darn=vger.kernel.org; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=eGvW91C4grW9jhiVdhrUhasqpBxGbw0RjsBpYtBt9c0=; b=mJ7JAnEGg8quhRSBGZ0cFaVNo1ORtCAEQZWEMIGqwIjqTLBupG1hH1fbzd4RCNCIH9 3shfCSFinYbnuVbmsA2ECa+cvBNE405ALB00uVo8yICpYHibHgcfdoEaTlXGBrdLpHNL kwvvagJ+nvbu04131o1fgB+Lan7DkatzkPhy5oM0i7i7kjBMrDjXqw8opTiKhQo3M+i0 H0WFhVrjMOSniRIcB+DcYgzXHysNgp0f/yQ3CMbZdE31n3BnP0PzMUjvxnqbzW5zQF80 F1JiKn2I8y4HHFGZQPMyjl5tRwWVOfFko5PcwwKRMV6Z7Ib97hf3r4Qhr/KRh479WXl1 Ieuw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1708421746; x=1709026546; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=eGvW91C4grW9jhiVdhrUhasqpBxGbw0RjsBpYtBt9c0=; b=JhIP+tYT97osR3cU5pSP0qTgpjMCHK8MMXy+ZdJp45Qz3PerOsg1pc4enEDkIa0Ezg v+9mnE5Av7fJUBvXuo9Y/KtZZabPfJPcuZzYo1GTwV69puglzR+pr3aC3mQXMohSCyUd gGrqCAMvLzhFl4SFDXZxvcpFxGkA+oEl1amKrAoQKYpW42Tc8FGoH8CIl72E/8PmTgx4 +4s8EzEVIMuMhmxTv/XyGU/j2zkVO22rUiI8yZsBJoHxEli9td0iwT4Pef5+3m3grnaS HMwsWcg78jokYU3Mxa3DRHrRApoXbaNh/4NETTAn5D8gG8+coel0nJ9lIJsXM43KE+7H edmw== X-Forwarded-Encrypted: i=1; AJvYcCVG8Y/XDM3FMul6sRZl5I8V1jXgUuk4IRagKdozJCPzl2eFRSwSbrnvUnoWfuRPggmYe35m+LFAQwJMgFtmQ0VgENweeH8uh8pZlANN X-Gm-Message-State: AOJu0YyBXQHn/r18AtmX2Xg2zNlpaMm/YLCrFO+RPRJB1YY8PDIveSrd 5IZZdKdIgLK55Kqs0zMf0fpSRFSvb06xuA0bHGZuWft58bbZTuJJ2m5R5hZLKNxm4co7cIhtH1b oyJZny4jzQPWaGA== X-Received: from aliceryhl2.c.googlers.com ([fda3:e722:ac3:cc00:68:949d:c0a8:572]) (user=aliceryhl job=sendgmr) by 2002:a05:651c:104e:b0:2d2:c6a:5731 with SMTP id x14-20020a05651c104e00b002d20c6a5731mr15606ljm.9.1708421746047; Tue, 20 Feb 2024 01:35:46 -0800 (PST) Date: Tue, 20 Feb 2024 09:35:40 +0000 In-Reply-To: <20240219163915.2705-1-dakr@redhat.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Mime-Version: 1.0 References: <20240219163915.2705-1-dakr@redhat.com> X-Mailer: git-send-email 2.44.0.rc0.258.g7320e95886-goog Message-ID: <20240220093541.280140-1-aliceryhl@google.com> Subject: Re: [PATCH v4] rust: str: add {make,to}_{upper,lower}case() to CString From: Alice Ryhl To: dakr@redhat.com Cc: a.hindborg@samsung.com, alex.gaynor@gmail.com, aliceryhl@google.com, benno.lossin@proton.me, bjorn3_gh@protonmail.com, boqun.feng@gmail.com, gary@garyguo.net, linux-kernel@vger.kernel.org, ojeda@kernel.org, rust-for-linux@vger.kernel.org, wedsonaf@gmail.com Content-Type: text/plain; charset="utf-8" > Add functions to convert a CString to upper- / lowercase, either > in-place or by creating a copy of the original CString. > > Naming followes the one from the Rust stdlib, where functions starting > with 'to' create a copy and functions starting with 'make' perform an > in-place conversion. > > This is required by the Nova project (GSP only Rust successor of > Nouveau) to convert stringified enum values (representing different GPU > chipsets) to strings in order to generate the corresponding firmware > paths. See also [1]. > > [1] https://rust-for-linux.zulipchat.com/#narrow/stream/288089-General/topic/String.20manipulation.20in.20kernel.20Rust > > Signed-off-by: Danilo Krummrich This looks good to me, so you may add my Reviewed-by: Alice Ryhl However, it looks like this patch has some clippy warnings that need to be fixed before it can be merged. $ make LLVM=1 CLIPPY=1 error: unneeded `return` statement --> rust/kernel/str.rs:267:9 | 267 | return Ok(s); | ^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return = note: `-D clippy::needless-return` implied by `-D clippy::style` = help: to override `-D clippy::style` add `#[allow(clippy::needless_return)]` help: remove `return` | 267 - return Ok(s); 267 + Ok(s) | error: unneeded `return` statement --> rust/kernel/str.rs:284:9 | 284 | return Ok(s); | ^^^^^^^^^^^^ | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return help: remove `return` | 284 - return Ok(s); 284 + Ok(s) | error: deref which would be done by auto-deref --> rust/kernel/str.rs:677:58 | 677 | unsafe { CStr::from_bytes_with_nul_unchecked_mut(&mut *self.buf) } | ^^^^^^^^^^^^^^ help: try: `&mut self.buf` | = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#explicit_auto_deref = note: `-D clippy::explicit-auto-deref` implied by `-D clippy::complexity` = help: to override `-D clippy::complexity` add `#[allow(clippy::explicit_auto_deref)]` error: aborting due to 3 previous errors Alice