Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp2790002rdb; Fri, 22 Sep 2023 08:26:42 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHNF0uYscgzRzT+S8BxWAWPimTeR3ae2KavywthqcN1ARQa8rrrbvIjR3uq3V1DohzCWiVI X-Received: by 2002:a05:6a00:1ace:b0:692:b8b9:f728 with SMTP id f14-20020a056a001ace00b00692b8b9f728mr892656pfv.30.1695396401975; Fri, 22 Sep 2023 08:26:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695396401; cv=none; d=google.com; s=arc-20160816; b=j05SOpPpRerG3dpRmTl41TfJxiQAaK2+btCoczTKmQPhgJSpCq8qRK3Tmwpondwd3Y mhAFbsTlxbu3fyDH1NrHJnEXUzlFtM5sV4TODaFuvz2lxtnAlBkgCovbGRFrcSZOqPbq 0qLsX2xzEqwe8QFMmBR5TkPxGHECY2t4BQVrqmf+EQf8J874WNqI672MCc3uLUcCihD5 XDM5suRSr26ORt3BPZqUaFx4+gu/xVB314C9/7GesYuagIBLlfzbhu1I+VB4wZUfRTiz n0MFwJlQm3snNBZo+7gBrQENv01Lm+dYM8u6LhZRqUCUqgQUAfR2U0PI/NU/YpxS9xVl 5kWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=+UjjrLZjWkpNjZJQ1IoOHoJ/1t1H4lLZHSoX3tWgt70=; fh=3oKCKs2MZu0FBkEAUFHkAZ5eHcp+8NaASFGQwgFhLt0=; b=R1SqW3cA0EjoT6wy9vqkcehlznAYkmGRDe48/j5vzypODo56gCm86hb9et48ld74XV ifDHHRIkZkX5+dXrGm5gkU4H+bAun4snwzHxLv1g2NARoR+HroP2sBkFrIOoqUvcFhjv BryP/HnqBXaiuVsm0GPbmih3boPSq0htyzO0jUWzaza2RZdX4hgfFQoznXgNrDgEnP4N MPw+7Jb5f/ozv1JMPYBltt/a1etxsvb9nevNyS5aJU1hF6pN6XVGvRcoFgTdthn+RsZB OnsqHeA3YWwvdylJ+bZlljc/QqOYxHyn/PEEoBOnmwF6qV9JfNf9bEGjvLTYe5ur2OdF THaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b="W/QqtKII"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 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 agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id u69-20020a627948000000b0068740bcd8d7si3842832pfc.362.2023.09.22.08.26.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Sep 2023 08:26:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b="W/QqtKII"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 4149C822F05A; Fri, 22 Sep 2023 01:02:21 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232266AbjIVICO (ORCPT + 99 others); Fri, 22 Sep 2023 04:02:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32964 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232327AbjIVIBi (ORCPT ); Fri, 22 Sep 2023 04:01:38 -0400 Received: from mail-wm1-x333.google.com (mail-wm1-x333.google.com [IPv6:2a00:1450:4864:20::333]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 38FDB1700 for ; Fri, 22 Sep 2023 01:00:35 -0700 (PDT) Received: by mail-wm1-x333.google.com with SMTP id 5b1f17b1804b1-405290ab4b6so86355e9.0 for ; Fri, 22 Sep 2023 01:00:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1695369633; x=1695974433; darn=vger.kernel.org; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=+UjjrLZjWkpNjZJQ1IoOHoJ/1t1H4lLZHSoX3tWgt70=; b=W/QqtKIIzvFTdtAKQJQL5SEw9O/gIM2nfM+dTUSSV5rWcVZ9D+kuY6nfp6G7DyHIZI ZNaO0qlbYADS9SviVif4b7pOiW5tf1I0qVMTupEX5L89bAnBTVOQGwifGO4L1LdEsFp9 8UocGtx2x1IN+c6vXsa9Z/+4Nqt3qGT1vcIXy8pj47Cuu2zjxs4twKTJvwXkjASzp+74 /Ai7CEhBkkTpLASGE5gxEEVdLHV+hxPWGKUXlP2jFl2Rb//+cWfpgHA6Q22hu93hmaS2 Et2KawUfM3/7Jkc94cuUnI6ztdnVqFcxydddxpAPk2eBVHw/Ebx7kZftg2rRcerWQPkX x8CQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695369633; x=1695974433; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=+UjjrLZjWkpNjZJQ1IoOHoJ/1t1H4lLZHSoX3tWgt70=; b=h6FTxu1JPkMTy51yaJUt7DJzS7oQ8htnnHpS6yV3Orx4+bN5dWALgYyiIGnSm5e5E1 SIygiL4IKNqapGoG2cLwnKDxu+t6F4bM/dRYoUqZYbxwte+sCwVaMgJt4eupYrXlLRmv QKX7eozEwTv3w3R39UwkQxt2W7RGjaZ1bLZw4D5sb+8FDb4xOMoGa5vTOC9+uhlnrQLt nrDPZbW59jwz+w8cbdW88Ih1zOaHXdfY170Zw23vyB01Y2lh610ZAdZvc336DRJQFjo3 l9MA7eVEbuYYzpIDji60pmgBUhdsltMn4YGBL/iHZMMVte0krtU6PQSIKyBFRKLowBNp KJdw== X-Gm-Message-State: AOJu0YxCEXJL0NeOrfnJIipfQj4EebWTIGtuOuzfWPYwh1wFGPlUOHw3 4iIJLc2Cs9zJv7rPmT/raXEJjaGPBfcn5YLwl7IemQ== X-Received: by 2002:a7b:cd07:0:b0:3fe:f32f:c57f with SMTP id f7-20020a7bcd07000000b003fef32fc57fmr50536wmj.0.1695369633354; Fri, 22 Sep 2023 01:00:33 -0700 (PDT) MIME-Version: 1.0 References: <20230920-kunit-kasan-fixes-v1-0-1a0fc261832d@riseup.net> <20230920-kunit-kasan-fixes-v1-2-1a0fc261832d@riseup.net> In-Reply-To: <20230920-kunit-kasan-fixes-v1-2-1a0fc261832d@riseup.net> From: David Gow Date: Fri, 22 Sep 2023 16:00:21 +0800 Message-ID: Subject: Re: [PATCH 2/3] kunit: Add kunit_move_action_to_top_or_reset() to reorder actions To: Arthur Grillo Cc: David Airlie , Daniel Vetter , Maxime Ripard , Javier Martinez Canillas , Brendan Higgins , tales.aparecida@gmail.com, andrealmeid@riseup.net, mairacanal@riseup.net, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, kunit-dev@googlegroups.com Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="000000000000ca098d0605ee003a" X-Spam-Status: No, score=-8.4 required=5.0 tests=DKIMWL_WL_MED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_IN_DEF_DKIM_WL autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.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 (agentk.vger.email [0.0.0.0]); Fri, 22 Sep 2023 01:02:21 -0700 (PDT) --000000000000ca098d0605ee003a Content-Type: text/plain; charset="UTF-8" On Wed, 20 Sept 2023 at 14:12, Arthur Grillo wrote: > > On Kunit, if we allocate a resource A and B on this order, with its > deferred actions to free them. The resource stack would be something > like this: > > +---------+ > | free(B) | > +---------+ > | ... | > +---------+ > | free(A) | > +---------+ > > If the deferred action of A accesses B, this would cause a > use-after-free bug. To solve that, we need a way to change the order > of actions. > > Create a function to move an action to the top of the resource stack, > as shown in the diagram below. > > +---------+ +---------+ > | free(B) | | free(A) | > +---------+ +---------+ > | ... | -> | free(B) | > +---------+ +---------+ > | free(A) | | ... | > +---------+ +---------+ > > Signed-off-by: Arthur Grillo > --- Thanks. This is a really interesting patch: my hope was that something like this wouldn't be necessary, as in most cases freeing things in the reverse order to which they were created is the right thing to do. It looks like, from the comments on patch 3, this may no longer be necessary? Is that so? Otherwise, if you have a real use case for it, I've no objection to KUnit adding this as a feature (though I'd probably add some documentation suggesting that it's best avoided if you can order your allocations / calls better). Cheers, -- David > include/kunit/resource.h | 17 +++++++++++++++++ > lib/kunit/resource.c | 19 +++++++++++++++++++ > 2 files changed, 36 insertions(+) > > diff --git a/include/kunit/resource.h b/include/kunit/resource.h > index c7383e90f5c9..c598b23680e3 100644 > --- a/include/kunit/resource.h > +++ b/include/kunit/resource.h > @@ -479,4 +479,21 @@ void kunit_remove_action(struct kunit *test, > void kunit_release_action(struct kunit *test, > kunit_action_t *action, > void *ctx); > + > +/** > + * kunit_move_action_to_top_or_reset - Move a previously added action to the top > + * of the order of actions calls. > + * @test: Test case to associate the action with. > + * @action: The function to run on test exit > + * @ctx: Data passed into @func > + * > + * Reorder the action stack, by moving the desired action to the top. > + * > + * Returns: > + * 0 on success, an error if the action could not be inserted on the top. > + */ > +int kunit_move_action_to_top_or_reset(struct kunit *test, > + kunit_action_t *action, > + void *ctx); > + > #endif /* _KUNIT_RESOURCE_H */ > diff --git a/lib/kunit/resource.c b/lib/kunit/resource.c > index f0209252b179..fe40a34b62a6 100644 > --- a/lib/kunit/resource.c > +++ b/lib/kunit/resource.c > @@ -176,3 +176,22 @@ void kunit_release_action(struct kunit *test, > } > } > EXPORT_SYMBOL_GPL(kunit_release_action); > + > +int kunit_move_action_to_top_or_reset(struct kunit *test, > + kunit_action_t *action, > + void *ctx) > +{ > + struct kunit_action_ctx match_ctx; > + struct kunit_resource *res; > + > + match_ctx.func = action; > + match_ctx.ctx = ctx; > + res = kunit_find_resource(test, __kunit_action_match, &match_ctx); > + if (res) { > + kunit_remove_action(test, action, ctx); > + return kunit_add_action_or_reset(test, action, ctx); > + } > + if (!res), this doesn't call the action, so the _or_reset() part of this doesn't quite make sense. As I understand it, there are three cases handled here: 1. The action already existed, and we were able to recreate it at the top. 2. The action already existed, but we were unable to recreate it. 3. The action did not previously exist. In this case, for (1), the action is successfully moved to the top. This is the "good case". For (2), we run the action immediately (the idea being that it's better to not leak memory). For (3), we do nothing, the action is never run. My guess, from the name ending in _or_reset, (3) should: - Try to defer the action. If deferring it fails, run the action immediately. Or possibly, always run the action immediately in case (3). Whatever we want, we need to decide on what happens here and document them. And of course, we can get some of those behaviours without needing to call kunit_find_resource() at all, just by calling kunit_remove_action(...) kunit_add_action_or_reset() unconditionally. > + return 0; > +} > +EXPORT_SYMBOL_GPL(kunit_move_action_to_top_or_reset); > > -- > 2.41.0 > --000000000000ca098d0605ee003a Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature MIIPnwYJKoZIhvcNAQcCoIIPkDCCD4wCAQExDzANBglghkgBZQMEAgEFADALBgkqhkiG9w0BBwGg ggz5MIIEtjCCA56gAwIBAgIQeAMYYHb81ngUVR0WyMTzqzANBgkqhkiG9w0BAQsFADBMMSAwHgYD VQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UE AxMKR2xvYmFsU2lnbjAeFw0yMDA3MjgwMDAwMDBaFw0yOTAzMTgwMDAwMDBaMFQxCzAJBgNVBAYT AkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMSowKAYDVQQDEyFHbG9iYWxTaWduIEF0bGFz IFIzIFNNSU1FIENBIDIwMjAwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvLe9xPU9W dpiHLAvX7kFnaFZPuJLey7LYaMO8P/xSngB9IN73mVc7YiLov12Fekdtn5kL8PjmDBEvTYmWsuQS 6VBo3vdlqqXZ0M9eMkjcKqijrmDRleudEoPDzTumwQ18VB/3I+vbN039HIaRQ5x+NHGiPHVfk6Rx c6KAbYceyeqqfuJEcq23vhTdium/Bf5hHqYUhuJwnBQ+dAUcFndUKMJrth6lHeoifkbw2bv81zxJ I9cvIy516+oUekqiSFGfzAqByv41OrgLV4fLGCDH3yRh1tj7EtV3l2TngqtrDLUs5R+sWIItPa/4 AJXB1Q3nGNl2tNjVpcSn0uJ7aFPbAgMBAAGjggGKMIIBhjAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0l BBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMEMBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFHzM CmjXouseLHIb0c1dlW+N+/JjMB8GA1UdIwQYMBaAFI/wS3+oLkUkrk1Q+mOai97i3Ru8MHsGCCsG AQUFBwEBBG8wbTAuBggrBgEFBQcwAYYiaHR0cDovL29jc3AyLmdsb2JhbHNpZ24uY29tL3Jvb3Ry MzA7BggrBgEFBQcwAoYvaHR0cDovL3NlY3VyZS5nbG9iYWxzaWduLmNvbS9jYWNlcnQvcm9vdC1y My5jcnQwNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5nbG9iYWxzaWduLmNvbS9yb290LXIz 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 ddIn9n5Jt6Z1o79zxraLMEwGA1UdIARFMEMwQQYJKwYBBAGgMgEoMDQwMgYIKwYBBQUHAgEWJmh0 dHBzOi8vd3d3Lmdsb2JhbHNpZ24uY29tL3JlcG9zaXRvcnkvMAwGA1UdEwEB/wQCMAAwgZoGCCsG AQUFBwEBBIGNMIGKMD4GCCsGAQUFBzABhjJodHRwOi8vb2NzcC5nbG9iYWxzaWduLmNvbS9jYS9n c2F0bGFzcjNzbWltZWNhMjAyMDBIBggrBgEFBQcwAoY8aHR0cDovL3NlY3VyZS5nbG9iYWxzaWdu LmNvbS9jYWNlcnQvZ3NhdGxhc3Izc21pbWVjYTIwMjAuY3J0MB8GA1UdIwQYMBaAFHzMCmjXouse LHIb0c1dlW+N+/JjMEYGA1UdHwQ/MD0wO6A5oDeGNWh0dHA6Ly9jcmwuZ2xvYmFsc2lnbi5jb20v Y2EvZ3NhdGxhc3Izc21pbWVjYTIwMjAuY3JsMA0GCSqGSIb3DQEBCwUAA4IBAQBtHFwIgQZjer5K H+4Q+wns10k7qN+4wN2Uf+JsyOYjukaMEgdLErfA1wwtQ9uHkoYQZcWBuVVkQFa5hI+sqI2m1Weq riMCFSiU38s1tADdMX12IMfJRN60Nznhrw+nPyDRZqRhUTW24TwnHorkDnFPW8PHo7fAw4FrpI0n impZAng7ccvvK09K3ZuhwTIxJMsPXCZYsrXWORTw5sczRAP6XvKbPBJnsJoSTe5dFBPBHOQJOGhU qWfEfWnWMJPF3LxSGLpLFQXO3RwQqmxv08avwXfVPouh1xuB3FX7rpDabT8YDhu9JgIZkLEKko7L yQt6zWwng7k8YF/jGbiAta6VMYICajCCAmYCAQEwaDBUMQswCQYDVQQGEwJCRTEZMBcGA1UEChMQ R2xvYmFsU2lnbiBudi1zYTEqMCgGA1UEAxMhR2xvYmFsU2lnbiBBdGxhcyBSMyBTTUlNRSBDQSAy MDIwAhABzgV+4+mJnUzG7XDy6d2uMA0GCWCGSAFlAwQCAQUAoIHUMC8GCSqGSIb3DQEJBDEiBCD+ HMlWgOatsOgN/fPJzVXnAZ6AjyVEpXFSTvrioFxPEzAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcB MBwGCSqGSIb3DQEJBTEPFw0yMzA5MjIwODAwMzNaMGkGCSqGSIb3DQEJDzFcMFowCwYJYIZIAWUD BAEqMAsGCWCGSAFlAwQBFjALBglghkgBZQMEAQIwCgYIKoZIhvcNAwcwCwYJKoZIhvcNAQEKMAsG CSqGSIb3DQEBBzALBglghkgBZQMEAgEwDQYJKoZIhvcNAQEBBQAEggEACQ8DSLVA86tGJWUweagD 6StfrKRZR+FPBWvOEE1Ko1pMMkLD8PN4eshle9TpruGolw3j66c8k5ATj2YjhObhycqrZWzs3Cbl wTIjaE4XioXindwn3ksR216BBFpTLRKAV7DjJ21o9KUzgxVgtGrXcb9uAMQakSoTtQFJrvzwNMUR o7CxfdX90cppIQ+5hiiwrXj36fh9CW5W8ijpLEcqAFN30zXF1IdKl/F3LUrGdUoYRQYLpAEw3q9o FDaZmidwyDdAW2jgiJg2JzBl6+ZI0KdNNSkc6UFT/nZF8GzrmHZKWb10cYRDXhLqRdI1kGuFGPTw U7SGJSRJmOnQuTKjoA== --000000000000ca098d0605ee003a--