From nobody Sun Apr 5 18:18:41 2026 Received: from mail-dl1-f51.google.com (mail-dl1-f51.google.com [74.125.82.51]) (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 5D75835F19B for ; Tue, 24 Mar 2026 00:40:02 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=74.125.82.51 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774312804; cv=none; b=gDkpZEYRNp5ZvxHhKlxsa4X5abawOeu13Y0+V4ZstiO+Q6gZ9fqjZwrP8Heqrn00RBHyRJPKuig7TTZizQq2E9bNmiadumIro7px5Ai+BApA5N9xAoPHpXJ0shtJy0ySWWT7zQxdrUU505FmhZodSmcy59MpAQIX8suapp60F80= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774312804; c=relaxed/simple; bh=WAA48TAgXPKh6OTsM9jfu2LAkNr3B0EfohpnQi0pV2k=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=gSnfFzcxFpNCAqe6RRtoK1bXRJ8qd0Vt0P3OC82dNwITqALzUGAdX1CY4YJkvNqerTB/aAOZ5lOC11GSt/1l/myxTOte3sXzE77Zn3W7DRH0A3hGkYBaneGyVWcObM//78d1FLejB6LdqcywIrlcdwasu8CmbofPMKDK4ef9iyo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=Yi4NVPgf; arc=none smtp.client-ip=74.125.82.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Yi4NVPgf" Received: by mail-dl1-f51.google.com with SMTP id a92af1059eb24-12a74039dc6so627349c88.0 for ; Mon, 23 Mar 2026 17:40:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1774312801; x=1774917601; darn=vger.kernel.org; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=VMnha1VqvY6bmQXtBiFyEl6o1L0XqC/h5XlUXxbZCb0=; b=Yi4NVPgf81cfAe9ZHhZ0tGlyXftHJfw5ujoOfJwhDUEl3VenPFTq2nLQMneYek/Ayk 1UVKtvsIq/+o9U9smEMxSaO9agj1zcNNlXCXBKl4t4WR9DRvZg2JWIYcds2B+OFggHcU D1KOi+3k4HdQbRxKamV3uWoKgqSQa/oavm9ptnPXj2WAubnS9wGOu27KKFQKK/sjNFMb zb0FKJm+7rYcg98MNpW6MHhB9jAfUPCJJxAPmZLoTNRLlQ2a4ZKDlB8aILCkITQ2fmc+ 6a+a5//nhgNYc/Kx3zfjtIrRBfPVH2Dzu1Q0+OXZhNI+VcVkhaG1i5hySlb39egO//Vn oDoQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1774312801; x=1774917601; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=VMnha1VqvY6bmQXtBiFyEl6o1L0XqC/h5XlUXxbZCb0=; b=XkrHRIoIpdNbo8qPLgRwu5JcmrMsd6dPCvwoOP9opzcOtQvg72FZjCSvCnjUakbhLX Xr9zQJaMCKlrO1996D8kzzA7T2IAIYgbW3mk3ZrId95Cc2LAg8d4mILIwCM0l4B0dMzs mK7PaGqJ0fYW2OuVhEJU+zMztoxNlmf2J4NeCgtWvbPpKj9se2rPqvjKRFhvLpNgxrlO ryj3KLoMZvtXwrEmj3lhYWFlgBKuLyJjjx23LQpYZIDRldxtop8HpkxggFXleV2Ydtgg DWencsoBaYgOwRm67O05cW3nv+tL56Fwjrh5dY0tYGY97I9k1didSfwVu53uZzc1sgUF 5w5Q== X-Gm-Message-State: AOJu0YyKUoShmLUhp+YNACO74xT8Giz/5F4OmUPalNeJaukqByFbtnY6 DBwgpyHQ2Vf3HQ+8GT0gPNOpY9aAJwkjOfme799Cxwh6NfYQHfmwLDUD X-Gm-Gg: ATEYQzzI38rynoksZ5XVL8BLuIS2+ox2sCjkWR6+Sn7PCbIG7mHMpHRVlztzOrCEceL DJ9sc/GS+mUTJasm8l+HHJWzznNysX/WI8k1zrOO2xin85RnU1bv0xdOu0kS7xDVF47mahup3CH 8H9dtj88yMKW7K8ApL7VYfkvKB7Lmq6ExZ4C/ka8TrpmT5IRt53uxMjsKBvP14U6RaRefltDpv+ 4nNHS2zUE7ocSIxEuYujegneV7itXS7OEgqtR5IsGg5CMnNQCxZiV+ubeo/y8Ei5W49/tf3hzwD aaxl5+/yaSFMIXOHS1Wfi+a+21X8Yq5AlCRn2JoZ0YIU5W8kojsrKTwO77M4XonAH3BB2J0EmL+ 5KMr7f/ygynJaRYqqFU0HoAxeB6K4rSFWKtK2VDMSMvKlzjW0igCedLgofei6jiiZP16EHziMaY liciq2TbKwnMN1QSj81lKkBFpWEiP5KttptYFzs00AO8XaBwnqWozK8r6I/vQ05SbdMDbPQyxrn Q5btI5ZAwrtJxI= X-Received: by 2002:a05:7300:572a:b0:2c1:564:7127 with SMTP id 5a478bee46e88-2c1095a5b97mr5955288eec.4.1774312801221; Mon, 23 Mar 2026 17:40:01 -0700 (PDT) Received: from dtor-ws.sjc.corp.google.com ([2a00:79e0:2ebe:8:a296:1211:5ab0:bc95]) by smtp.gmail.com with ESMTPSA id 5a478bee46e88-2c10b17b90dsm17543148eec.10.2026.03.23.17.39.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 23 Mar 2026 17:40:00 -0700 (PDT) From: Dmitry Torokhov Date: Mon, 23 Mar 2026 17:39:38 -0700 Subject: [PATCH 2/4] software node: allow passing reference args to PROPERTY_ENTRY_REF Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260323-property-gpio-fix-v1-2-9cb46e5fe7df@gmail.com> References: <20260323-property-gpio-fix-v1-0-9cb46e5fe7df@gmail.com> In-Reply-To: <20260323-property-gpio-fix-v1-0-9cb46e5fe7df@gmail.com> To: Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , x86@kernel.org, Hans de Goede , Greg Kroah-Hartman , "Rafael J. Wysocki" , Danilo Krummrich , Andy Shevchenko , Daniel Scally , Heikki Krogerus , Sakari Ailus Cc: linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, driver-core@lists.linux.dev X-Mailer: b4 0.15-dev-a6826 When dynamically creating software nodes and properties for subsequent use with software_node_register() current implementation of PROPERTY_ENTRY_REF is not suitable because it creates a temporary instance of struct software_node_ref_args on stack which will later disappear, and software_node_register() only does shallow copy of properties. Fix this by allowing to pass address of reference arguments structure directly into PROPERTY_ENTRY_REF(), so that caller can manage lifetime of the object properly. Signed-off-by: Dmitry Torokhov --- include/linux/property.h | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/include/linux/property.h b/include/linux/property.h index e30ef23a9af3..942657e76993 100644 --- a/include/linux/property.h +++ b/include/linux/property.h @@ -471,12 +471,19 @@ struct property_entry { #define PROPERTY_ENTRY_STRING(_name_, _val_) \ __PROPERTY_ENTRY_ELEMENT(_name_, str, STRING, _val_) =20 +#define __PROPERTY_ENTRY_REF_ARGS(_ref_, ...) \ + _Generic(_ref_, \ + const struct software_node_ref_args *: _ref_, \ + struct software_node_ref_args *: _ref_, \ + default: &SOFTWARE_NODE_REFERENCE(_ref_, \ + ##__VA_ARGS__)) + #define PROPERTY_ENTRY_REF(_name_, _ref_, ...) \ (struct property_entry) { \ .name =3D _name_, \ .length =3D sizeof(struct software_node_ref_args), \ .type =3D DEV_PROP_REF, \ - { .pointer =3D &SOFTWARE_NODE_REFERENCE(_ref_, ##__VA_ARGS__), }, \ + { .pointer =3D __PROPERTY_ENTRY_REF_ARGS(_ref_, ##__VA_ARGS__) }, \ } =20 #define PROPERTY_ENTRY_BOOL(_name_) \ --=20 2.53.0.1018.g2bb0e51243-goog