Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4168070rwd; Tue, 23 May 2023 04:17:59 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5ge1fFiGZLxcfTb3GwTzNgkLsZuluSloFF9+kSO13m7COfu5cmbqkMAJlGbctVRJpCtw5Y X-Received: by 2002:a17:90b:1b4a:b0:255:5f47:c85c with SMTP id nv10-20020a17090b1b4a00b002555f47c85cmr5967355pjb.30.1684840679084; Tue, 23 May 2023 04:17:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684840679; cv=none; d=google.com; s=arc-20160816; b=qOT1q9lqa4eykhbYhyBI1JcSTR9sXfHVomuMZMdggkaSJGDfnXiQeFL6+BrW+Hlsm4 j41P35MB9mHG2wGOeyR1PmgkNQR0UXS3ML1RAdttWIB6vRRIQYgzVqlrpsZnm6AQwBqe 82z3AbJcENOapz/DLkO/TtxXiru9op4VHUQcaTbsfjy6VKqIBE6AJ50Z/0Y7Wz9HTf9c XUps4ZzkyEbVoTIkiwbYGng9Sztno9IlHVhNF+Z/3nRPPGlegxK4RpSkdnv8njr6Iliv TEcmiQZhxgUJZuGiC8fuy2zoySHlQZx4CWI8M4MYvxuDoqonI7ByjEvUl2BkiiXtsRgU ulpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:message-id:references :mime-version:in-reply-to:date:dkim-signature; bh=2XgBvS7Dq5efKHkw7EY0MhJdVq0k/8wvd67gGiWjjGY=; b=fPrfmEtYZ0cwIYnBS5RNQrTrYAGOskS/755qTcxuQoazpwGt3A7H11XDBLO2JEeO7F 899VffulRg36RSPs2cyxrVLLGbM/rlr72pNS+GyRLxHBksBRbv8lw92oRG+tUxALb3UC GjzgUfX4KEJRSx9his9OZ3WU6WkoDkySxITnVnxJ5IUgUkB7B+BBnqgGQ+dw0rki0L7X dA9saKE08cXXT2E1+VAlme8nkzUUlQzjG4Vn3o6BjpVsagFvCkvgt6LKbq5i+WxLjXJo w7wZXL1/6jRJ7r+3MB7gTJbeFkAxEt9JgauAIDkZCmt+Qg3mm9RfUut6CYTrTXX8JwU5 HIrg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=I2NuidGB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i22-20020a17090adc1600b00247a0928f5dsi8142250pjv.184.2023.05.23.04.17.43; Tue, 23 May 2023 04:17:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=I2NuidGB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236428AbjEWLHO (ORCPT + 99 others); Tue, 23 May 2023 07:07:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43548 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230168AbjEWLHN (ORCPT ); Tue, 23 May 2023 07:07:13 -0400 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F2AC3FF for ; Tue, 23 May 2023 04:07:11 -0700 (PDT) Received: by mail-yb1-xb49.google.com with SMTP id 3f1490d57ef6-babb51cb4d4so6170146276.1 for ; Tue, 23 May 2023 04:07:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1684840031; x=1687432031; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=2XgBvS7Dq5efKHkw7EY0MhJdVq0k/8wvd67gGiWjjGY=; b=I2NuidGBI/ZeU95AgQL5cjDLDKnFCRQhwK80Fgf6TjZTKTEC8DC+X9iSKW1+OGmbCQ tbEmvSculz37Vxh4nZ+cGSlHBgBO+BNMCsFePd5i1XJRDStdsKgK2UhycHnP+uIjq3W+ BGyXzdow/jD99f7ks6jbRs3YPyEn9XKtXB5BCAq7dsIV69FSVOllw9B/Z6WxozOHMNKv t1K98BdYWNjYgpKjmlUphUPoSDarlKaAZqPfv1Cr5pG2PTQYcqrpkj/yspAUFjppThcr dyxC630dpbZ2K0/yAlqfREb9rNAl58QGE6cRxvMiBJbtqW6UqM/Prd0ERjsPmpm5adrD Queg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1684840031; x=1687432031; 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=2XgBvS7Dq5efKHkw7EY0MhJdVq0k/8wvd67gGiWjjGY=; b=k0EfLX1WdXpCtVtXNdF26O+79Pjd8zYg38JCLky1B/yzWl2L5kpXJoexpTF2x/3YYl 7MhuCTdnAsD2hu4TE21lJX4skskrzXOEnZj85g2z/w0CL/j1cPeKYqAAqn+rkQ8uhujP OGyZLHF9IDhyHDAKHbfc0ELLbZm8XuQkmZG/nQPkPhXWq3U6tsivg3JXNPSm5TEIJVzj ey8Nx0RWQH1fqOrBVjjbztAFSBkKNkIeUQ0J8n8NDlDWV8P2vbZn7YMnxGI+1osmgfmz lm23nL7raxoY9Frc6uSULm88VsMvd9wpnq7n1Pt1Gt9qADdkuKuN92phmJJHOGNcqUku LkGQ== X-Gm-Message-State: AC+VfDwZNVB9LVI7fkM1VSTDmPRr19xiqYLsUUQKWq2VkI2W/OWCBBkR gVL1NcTgaaZuflqMrx+hNcrlgFm9jbxTUyQ= X-Received: from aliceryhl.c.googlers.com ([fda3:e722:ac3:cc00:31:98fb:c0a8:6c8]) (user=aliceryhl job=sendgmr) by 2002:a25:d48e:0:b0:ba8:9653:c948 with SMTP id m136-20020a25d48e000000b00ba89653c948mr5747400ybf.3.1684840031253; Tue, 23 May 2023 04:07:11 -0700 (PDT) Date: Tue, 23 May 2023 11:07:09 +0000 In-Reply-To: Mime-Version: 1.0 References: X-Mailer: git-send-email 2.40.1.698.g37aff9b760-goog Message-ID: <20230523110709.4077557-1-aliceryhl@google.com> Subject: Re: [PATCH v1 6/7] rust: workqueue: add safe API to workqueue From: Alice Ryhl To: yakoyoku@gmail.com Cc: alex.gaynor@gmail.com, aliceryhl@google.com, benno.lossin@proton.me, bjorn3_gh@protonmail.com, boqun.feng@gmail.com, gary@garyguo.net, jiangshanlai@gmail.com, linux-kernel@vger.kernel.org, ojeda@kernel.org, patches@lists.linux.dev, rust-for-linux@vger.kernel.org, tj@kernel.org, wedsonaf@gmail.com Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/18/23 21:17, Martin Rodriguez Reboredo wrote: > On 5/17/23 17:31, Alice Ryhl wrote: >> +unsafe impl WorkItem for Arc >> +where >> + T: ArcWorkItem + HasWork + ?Sized, >> +{ >> + type EnqueueOutput = Result<(), Self>; >> + >> + unsafe fn __enqueue(self, queue_work_on: F) -> Self::EnqueueOutput >> + where >> + F: FnOnce(*mut bindings::work_struct) -> bool, >> + { >> + let ptr = Arc::into_raw(self); >> + >> + // Using `get_work_offset` here for object-safety. >> + // >> + // SAFETY: The pointer is valid since we just got it from `into_raw`. >> + let off = unsafe { (&*ptr).get_work_offset() }; >> + >> + // SAFETY: The `HasWork` impl promises that this offset gives us a field of type >> + // `Work` in the same allocation. >> + let work_ptr = unsafe { (ptr as *const u8).add(off) as *const Work }; >> + // SAFETY: The pointer is not dangling. >> + let work_ptr = unsafe { Work::raw_get(work_ptr) }; >> + >> + match (queue_work_on)(work_ptr) { > > Match for boolean is not a good pattern in my eyes, if-else should be > used instead. I think this is a question of style. For a comparison: match (queue_work_on)(work_ptr) { true => Ok(()), // SAFETY: The work queue has not taken ownership of the pointer. false => Err(unsafe { Arc::from_raw(ptr) }), } vs if (queue_work_on)(work_ptr) { Ok(()) } else { // SAFETY: The work queue has not taken ownership of the pointer. Err(unsafe { Arc::from_raw(ptr) }), } I'm happy to change it if others disagree, but when the branches evaluate to a short expression like they do here, I quite like the first version. > Also aren't the parens around the closure unnecessary? Hmm, parenthesises are often required around closures, but it's possible that it is only required for stuff like `self.closure(args)` to disambiguate between a `closure` field (of pointer type) and a `closure` method. I can check and remove them if they are not necessary.