From nobody Mon May 25 05:13:50 2026 Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 56B1C48AE2C for ; Mon, 18 May 2026 14:16:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.180.131 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779113809; cv=none; b=oj9PkkJ6khQLyOCIpAYMDU3fjgK6l8RGtn2XVKL2agxVNy0YPwXZ0uhnHt3Yk019gfLxufC/WLmclLQx/nPONkpJdPNfOwAzSRKnBIbaDyWHkt5J951VoWduLd1IRmutu3l9Amk1vr2UG/5q8ZSLvat0/dpoL4sl87yaCCE5HsU= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779113809; c=relaxed/simple; bh=t3GMhU5BiDcAMpoxPcbsowAatqnK8Fer8zJ7S43It88=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=LIx0MHonnnF5GHLPQ1Ce60b91ApiKwWIOpIWPl+Qn9BOaR2SZ/82hOXX+akh8nnQtpB6FmYTfZfK3zJJme9+VohIkr8ovo2gXmiVXuoCTE6zUXPed1tf0cBwbbOx5yR+MIwcDVfIgTi2k9MECTd1lJyUI/ZRNzxeJTdysQca8Bo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=Da+yG5NC; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=PUPL3/zK; arc=none smtp.client-ip=205.220.180.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="Da+yG5NC"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="PUPL3/zK" Received: from pps.filterd (m0279871.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64ICG13o2701134 for ; Mon, 18 May 2026 14:16:47 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= AeQ6mMjem3Bq4Th8eTbkEqzyisijnZHO8faMrAT7mEA=; b=Da+yG5NCap8TB4JT 2bnORosKIegi+I0AUEo3iYC8rj19cnVvV3OQ9XM/jbmRt+KbicsWnojSfn+YGA1L N9DgnjeuZN008Zz7+4FAN6XapEGZ9sBlFAKsyxmZJA6VmehaeEBETLtZUILJPBkE uffATMLa+pbUBBo8tqLTLrNN0KuacdUgglEu/I415gQEvCHq5fA2tpJY8VXOM/aH y1UMAcXdNbKKARMitx3nR3N6MJRZgJdYJXhJlspbUSRVoPMSA8TuySfRitUGTH41 3lwyjCQIioR/q0aYwyLybdMg4T8vS9MmIIV8blD539Z9hJtUunqpVdfkfl7LqL93 +csZVg== Received: from mail-oi1-f199.google.com (mail-oi1-f199.google.com [209.85.167.199]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4e82megen2-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Mon, 18 May 2026 14:16:47 +0000 (GMT) Received: by mail-oi1-f199.google.com with SMTP id 5614622812f47-479d900bee9so4370761b6e.1 for ; Mon, 18 May 2026 07:16:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1779113807; x=1779718607; 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=AeQ6mMjem3Bq4Th8eTbkEqzyisijnZHO8faMrAT7mEA=; b=PUPL3/zKdcnfCJs4tkMOSGd4hweMz5xhAJyS9hj0uXOYAs2rGuYzagPGUiYdhOvptV OJcG20EjitIara5f420WtDHWQizbPNXY3AXQ6jOnzK6FdnFTtApRxKy//dFSzVRC175v xJmg0p5KfH+a6XK+JnLmLTXMT3U2Fs5g32amwhyV6PIGUx9zLUa+UuQ980y62nPNT8aO dYrY6RbqOXvJ5hg4IurLmRoL/nVGN/7S29xG0g87q3YfeEB7twu1djYhYxgp0dZKqKMa Qb/r+Q0rXdtJiSLk04IHgwPg5TiGWh2f+VuMDo+u24JOLvZ4UCU5MQMlycRadC0TtGER Ws/A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1779113807; x=1779718607; 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=AeQ6mMjem3Bq4Th8eTbkEqzyisijnZHO8faMrAT7mEA=; b=U0s2ML1Q/wbr6V0SbBHf3MH0Iln/lTNBScPH+vXlHCnfYY2DFcWmyY8SHbyWuzqLIc OtF4xx70j3T7LVgB4Zi7gZOWMJZw5iXdBywRuLRySW2G7Tt8cAb7K4K3LiI7b7IT1nIl n5oKVTW2DKqAFTCYSmeCvhw6JeYOg7qMqdOqRysFpEFcOEd/LwSQzu9HSY46UzK6FJxZ O/b1GP+36P1a/oUZs1b7pMD5SeHWO8/W640MR80/KkpafzdmvBp2duDwS3dl52KH5DQy a9avJmcpMwiqBWOtdBu/7kJrF0wfIbCW7DIFxG3FItP37MG2wgGsu+yC+xcNhE6lnApD pCCA== X-Forwarded-Encrypted: i=1; AFNElJ/tffzR+hC90JAyyLu2d7Wspc0tRhvQQw3w4BpqmJa9lCWQJLbqGarBXkroigPTle/p7MAY1Y5b12RY9x0=@vger.kernel.org X-Gm-Message-State: AOJu0Ywxqb4U8Lbnypjh9i6TtQWNlj1+ZCpHHW/7O8FjlWT1K2eQP4Mm awJQVTFpAn3akJbNIOcmvAQdU0hGsZ19b0J6y74ixwWDh+g68Jq3rvg3PUGeVVUOxquPU+xY71C tvo3WD0atDrTlBBYUdKOxYIPdx45DR6FE2vYnTq5YcvkrlUImC+w97wl+MBjSSmQfhxE= X-Gm-Gg: Acq92OFVJ0RZVpwLc0Ko/IvJu5FAt14W7NiOEFLR0FAA+q7s5x8P0GzENM6jfr0TmhE 6dq0nd6/ktg5pBbQFw0FxO6YwoOeRQUkRQ6vN4+aSxMwEM0cBRoATaNFzXhDALo05hBWNMSyvht Z5ezKPIqYwQYE/dYniQxCUcp6NDTohtTCxol7STvh7oRROdaGe4yJDZKNup0eZwRwDD1yaIEjVn WF3/2LJhSX0fkAje/ASXFrPD0OvWkDV0lpLac07GstoUMoZA9z27UHFjjJqcRNJWfvAN6aguEfb /n6iOLg38Vkd5NCapVF6SFvZXFszJDFE3KmJPRiQDaWzJrw7Ei2lAIRjTBR1QilO9Cb6vZRinM/ /bUXakRa7PsUXlmm/JYoXBpCwSri/G2utDq/QwlUSfTG5BIbpOw== X-Received: by 2002:a05:6808:1482:b0:479:d467:1a26 with SMTP id 5614622812f47-482e5bb9669mr9786608b6e.43.1779113806655; Mon, 18 May 2026 07:16:46 -0700 (PDT) X-Received: by 2002:a05:6808:1482:b0:479:d467:1a26 with SMTP id 5614622812f47-482e5bb9669mr9786550b6e.43.1779113806228; Mon, 18 May 2026 07:16:46 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:1337:b6d0:456:372c]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-48feaa2949asm119371225e9.1.2026.05.18.07.16.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 May 2026 07:16:45 -0700 (PDT) From: Bartosz Golaszewski Date: Mon, 18 May 2026 16:16:29 +0200 Subject: [PATCH 1/2] kunit: provide kunit_platform_device_register_full() 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: <20260518-gpiolib-kunit-v1-1-131ec646c4df@oss.qualcomm.com> References: <20260518-gpiolib-kunit-v1-0-131ec646c4df@oss.qualcomm.com> In-Reply-To: <20260518-gpiolib-kunit-v1-0-131ec646c4df@oss.qualcomm.com> To: Brendan Higgins , David Gow , Rae Moar , Linus Walleij , Bartosz Golaszewski Cc: linux-kselftest@vger.kernel.org, kunit-dev@googlegroups.com, linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, Bartosz Golaszewski X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=2774; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=t3GMhU5BiDcAMpoxPcbsowAatqnK8Fer8zJ7S43It88=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBqCx9IXqDK7+Xm8oAjrxbh18dmFPVeLVFeNZ+6i QWHES+2ImGJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCagsfSAAKCRAFnS7L/zaE w+QcEACUh7huTT6cP21wKtuQX/BpfJTQVM+DQerd+zTEzwF3+SaqgRHd6WyIPFtF6iBsbxkORiu cPQpfRdVWHuiicmE8h1ZrDKf8+zZF1jyzuUWnCbawdAxtBicaSLfv3u2LR2Tfa9zgltKU4rBxby EcoROfoH3oV+5VQjU9miAx/u8XRRgjguWZ6fJV4Wo/q+W6Oxih896GB7rulrOnH5r3Fg69wPvdl jOZ6YjC7R6ae2KOBAPjHHaLvlTLJCRURsc7Uv6AfDIb7oVrAzz75qKVPibxGycp2jDV47GbJVKj oOOf8iEpzzuTEUMFxKeS1+C96MeyqiAWGZPku/QWlledPKSl5dLQMekJVBrL8BWMp4zJ7ZpXvAR vuUqn5mGGQ+o1EuMWmzd7Iq+YLWhkFkbOhEatGVLNNyJ8BrVr3pcVVk0YBaZL2KsZ9TUjh4Meoo zQdWwz/XvRfdjvJ94eWWnBkW7aD6IfEo0Z0Q0GyQ/MgPm0j5cmkZE94b8OhrBIXXsnqoCET3eJr i7zIt6NYIl4sqpBTboSp7TdBopT44oPYC1Cfv13CpfOP3dFBEnFzVxUeOes0KT0iBS0VF/kmy+t /lly47e75lH5qrujZrNP8M3Egl12HvHrCiZEhMyA9HH2XoiSD8hCzxxS+91aaf2h8WWu9M+1BN7 asIHj8bAjtU+Z5Q== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Authority-Analysis: v=2.4 cv=Tr7WQjXh c=1 sm=1 tr=0 ts=6a0b1f4f cx=c_pps a=yymyAM/LQ7lj/HqAiIiKTw==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=3WHJM1ZQz_JShphwDgj5:22 a=EUspDBNiAAAA:8 a=3Mdbh2SI1NvihuWZMnwA:9 a=QEXdDO2ut3YA:10 a=efpaJB4zofY2dbm2aIRb:22 X-Proofpoint-GUID: RRUeeWpAIJCo4tUtGFigy_9VjWvpVB5M X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTE4MDEzOSBTYWx0ZWRfXzzKwGom8mBv7 QjLdmT+qxu2ilCzKfBAroP+sgYn5KrZE+JmsytQFQ/BCs/5H3s4Llyl9Yw8Kq57+ihUUG6efdja nYNgBnTQ9SM+6giLYBQdD+5WVc9KtWb4iWSr79DLErfNpaGgwAYJ6Uu/75o9m3xChtUUziCNdWd vl17AJLF3cHl4M2A30Z3B5jAXdFIUX6cBCN2YsbhmfewxQO+eaqE0/uJqvRfhKL2FWbzV6nvn8P Q8GjXhUQT923EXKn1c7KQj4r5hk1u/empnq7KfdMq8IBcdFHm1xizgtJJxDAUQNXMNSkgcPsRiN nH58IwsftKiA4yvApellUD+PRhOqopAFNtCeWXvx3NEk6hrAEEKZdJOQ4JmKUNubJb7PrEIlATE VVKwirmv8aKOAbtDQuYLXoeZiniOp+LTRAlfBwJAvdezBXsfyBoJC1LpAtg2J42L2mSEIrD+syO 62ulUx+6DNbZKe03f1g== X-Proofpoint-ORIG-GUID: RRUeeWpAIJCo4tUtGFigy_9VjWvpVB5M X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-05-18_03,2026-05-15_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 impostorscore=0 phishscore=0 bulkscore=0 malwarescore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 priorityscore=1501 suspectscore=0 adultscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605180139 Provide a kunit-managed variant of platform_device_register_full(). Signed-off-by: Bartosz Golaszewski --- include/kunit/platform_device.h | 4 ++++ lib/kunit/platform.c | 31 +++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) diff --git a/include/kunit/platform_device.h b/include/kunit/platform_devic= e.h index f8236a8536f7ebcee6b0e00a7bd799a14b345c1b..8cad6e1c3e7efba862862b57908= 9f2f317784a73 100644 --- a/include/kunit/platform_device.h +++ b/include/kunit/platform_device.h @@ -6,10 +6,14 @@ struct completion; struct kunit; struct platform_device; struct platform_driver; +struct platform_device_info; =20 struct platform_device * kunit_platform_device_alloc(struct kunit *test, const char *name, int id); int kunit_platform_device_add(struct kunit *test, struct platform_device *= pdev); +struct platform_device * +kunit_platform_device_register_full(struct kunit *test, + const struct platform_device_info *pdevinfo); =20 int kunit_platform_device_prepare_wait_for_probe(struct kunit *test, struct platform_device *pdev, diff --git a/lib/kunit/platform.c b/lib/kunit/platform.c index 0b518de26065d65dac3bd49dd94a4b3e7ea0634b..583b50b538c79599ebbf33e261f= e2e9ced35efa9 100644 --- a/lib/kunit/platform.c +++ b/lib/kunit/platform.c @@ -6,6 +6,7 @@ #include #include #include +#include #include =20 #include @@ -130,6 +131,36 @@ int kunit_platform_device_add(struct kunit *test, stru= ct platform_device *pdev) } EXPORT_SYMBOL_GPL(kunit_platform_device_add); =20 +/** + * kunit_platform_device_register_full() - Register a KUnit test-managed p= latform + * device described by platform de= vice info + * @test: test context + * @pdevinfo: platform device information describing the new device + * + * Register a test-managed platform device. The device is unregistered whe= n the + * test completes. + * + * Return: New platform device on success, IS_ERR() on error. + */ +struct platform_device * +kunit_platform_device_register_full(struct kunit *test, + const struct platform_device_info *pdevinfo) +{ + struct platform_device *pdev; + int ret; + + pdev =3D platform_device_register_full(pdevinfo); + if (IS_ERR(pdev)) + return pdev; + + ret =3D kunit_add_action_or_reset(test, platform_device_unregister_wrappe= r, pdev); + if (ret) + return ERR_PTR(ret); + + return pdev; +} +EXPORT_SYMBOL_GPL(kunit_platform_device_register_full); + struct kunit_platform_device_probe_nb { struct completion *x; struct device *dev; --=20 2.47.3 From nobody Mon May 25 05:13:50 2026 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id CD43148AE06 for ; Mon, 18 May 2026 14:16:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779113811; cv=none; b=hjnIaZPIY6M8UqljrjHlrdXZ5erwBJrlglt4faDxV5uP8M8zECSRm9qbsf7uRXsGEP50uOfT0BvUR8pvXw+tFYeLyjCyOnOxLimfCc3BMsQFvYWW7QAYshEI9VgkaBP4ObQVrWNbCq7+r6j4aNQy10r3HQi/W3AQdbIBNBxuHBw= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779113811; c=relaxed/simple; bh=BmKFZ16woToo8VTwA3cT9gFAnZXIwnot36eGFq+4CeE=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=QoTjGLyvKqTodeYK7EMjYgfz7oYSE6+VekQ69fMNQ4saMPJKQfrLsluG2Wvn8mw5eKhYrntRTIfBRpbfbHqhetglDHhk5mza7lzmNdrueP8j0DgGJorh/mdcNhSZGZoUK2Wq/1oi4Dld3XGuw6a9hMzhcRb+qFN02CJRnESNeKo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=Kv5Ok+S6; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=ES67cN6R; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="Kv5Ok+S6"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="ES67cN6R" Received: from pps.filterd (m0279863.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64ICLGoL1890501 for ; Mon, 18 May 2026 14:16:49 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= pd8ZAERHCpbOlJVrvmsk3jHZZ7KVbOqxjjh2kOkwDyU=; b=Kv5Ok+S6yIA0rERr 2I6FxbSwH6gZ684PrpYWS1whxz9nmSuE/3p4wLSoD/X8jkBXM+RvgIAMNV3dTdKS DJpP1FNPrvUzTrTVJlqYxuKRvdn/vkhc2iFKSCMswbx/zd4xTGzOIDZhE+pFFyLp gziqSb4i5VFqgp+54vwNlDsJ0BHwRDxYYemSx26xEz4Z7SKaRh5oUg0R69e1xtZP WJYiBx4KlHknntF9eD7+o/3I2eXiWiMVZef/FuvE4BLOfKTiS08zCi/EHy4cxjTh AlcfQKTfFtWXo1ZSIoVZx4x58w7R3hO/FPDjY21EOMzz7ZNumRSR8MX4/7XBfvcj pMyq5w== Received: from mail-ot1-f71.google.com (mail-ot1-f71.google.com [209.85.210.71]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4e82pw0ed5-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Mon, 18 May 2026 14:16:49 +0000 (GMT) Received: by mail-ot1-f71.google.com with SMTP id 46e09a7af769-7dccdbdf5c2so2909378a34.3 for ; Mon, 18 May 2026 07:16:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1779113808; x=1779718608; 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=pd8ZAERHCpbOlJVrvmsk3jHZZ7KVbOqxjjh2kOkwDyU=; b=ES67cN6REmhFwrJLDAFJfjSm8OZZNdeDsQJpw+upw5NDavgiAT4PbbFbDLIm2glEWG Tokr+uj0tb07wKSNoCPal8274kD53mGelnaj4zOcO1pMQtF40dWCHaUrlEkBrzRYXuZ7 fONZ6wQ4NZbLfuhlSzvYANk5HcYbPI5Hkw7KJp2QkavSlksy1EF16KwDirR94Bgce0Mc eO9wnyh3BopFrwo5eZOcO01Vp+d7o4AuzRr6f0ymgaLwWwlPcMNJw1DTx2X1iwwKBU91 zrbg0SCyBuJKweGAhTR94nazdQUUdsvqnp8j9beu/L3wiJmd68M4DOEd+VhDbe26UvMK 7i8Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1779113808; x=1779718608; 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=pd8ZAERHCpbOlJVrvmsk3jHZZ7KVbOqxjjh2kOkwDyU=; b=DVcx0bzCSU2nrOeqFbTqySYk1TjvCuz5qGRzrE8OkJMZmaMhqlhGzEk42YcQ+goDU/ ogWGElKWWL/P9/lZo7KpXzNvo+LeUH4LNmWOPmoxDUb9eVBnPHndSrTX0v1XJxbzehQa lS3yyb7/b5mo8Ep6ZGT0UWwtisP0/DNSTbbUGE5lXaFbqKEVwLGjftDAXL9zN5gA/vwm wZC7AU4aD7GBtNKsqcNO5ARybXziYNPwc3gq4Ivp92s4iBPD23Y4A0aN59332tZnu2Sf T87Y3QHMf0WtkLE/2aPMKYokPb8j7rei/Od0Zfg01IGBTcD7dcHW1lzbUb/5FmpJCvXS Llww== X-Forwarded-Encrypted: i=1; AFNElJ8FRtvyY/LjiU9CPHJjzGn+Efsq2R8jLjYNSLRWoMpdvaKF1FeaVdRCKvKnyLSa7Z6f1P9VSsk6/maCLrc=@vger.kernel.org X-Gm-Message-State: AOJu0YwRd2/zNuqv+04XeC37tcja745AdnaLfvQXJeFEZq/kHe+KZ7/7 gqsBL++m64g/i+TwkpkmITx2b2vZiD+Bi1VvrOBJ7hMg/J3izRgRiRjMml2hPTDygwks+m9qkO+ ByfuBV+GkeEP8cGBI4Dadtz2qy6yoV3nAWsf3s7zMHn0AuN4swrLeAQa93zP6xtppcDQ= X-Gm-Gg: Acq92OEQL1Dk91dJBNCGcspGXHwv1jGzSiimcSJlqMx/V7Cj4rF+sLZeH/qFl6OYYyu 9d1c3jUbwGVZg84zBCJPVKrWn5RS4hRrXs6nPOv9sItEaK3lkE71Q26ZKmfur9ZvKdDTbHtQGFk sL+HwdSx6+qw35+fN3fF09CKs+JXWmJdP4LUdMK+bXkqu+Ny92sIwwodI+9PROG3o2zlzfeS2xx WwPXIn66KYJg29LJgzUNW3f3Btp9RyK8C0I8jnCPhdgr2baLMuhqEKPdQkR6ncHGstvRLDSTHAO VxCYZXTPUG/xlRN5YCn4AdiEbVutwRedzHPOuaNH5/9G4YrToOmdASm9Mi18UgxexmA+sEh2/p9 fYu/bgrPEosHJiMCP1X5K5gaThXTpGA7uV9Hzkx7iECY1NHBHXA== X-Received: by 2002:a05:6830:6688:b0:7dc:c4ae:a689 with SMTP id 46e09a7af769-7e4ea081258mr9858881a34.2.1779113808130; Mon, 18 May 2026 07:16:48 -0700 (PDT) X-Received: by 2002:a05:6830:6688:b0:7dc:c4ae:a689 with SMTP id 46e09a7af769-7e4ea081258mr9858812a34.2.1779113807579; Mon, 18 May 2026 07:16:47 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:1337:b6d0:456:372c]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-48feaa2949asm119371225e9.1.2026.05.18.07.16.46 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 May 2026 07:16:46 -0700 (PDT) From: Bartosz Golaszewski Date: Mon, 18 May 2026 16:16:30 +0200 Subject: [PATCH 2/2] gpio: add kunit test cases for the GPIO subsystem 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: <20260518-gpiolib-kunit-v1-2-131ec646c4df@oss.qualcomm.com> References: <20260518-gpiolib-kunit-v1-0-131ec646c4df@oss.qualcomm.com> In-Reply-To: <20260518-gpiolib-kunit-v1-0-131ec646c4df@oss.qualcomm.com> To: Brendan Higgins , David Gow , Rae Moar , Linus Walleij , Bartosz Golaszewski Cc: linux-kselftest@vger.kernel.org, kunit-dev@googlegroups.com, linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, Bartosz Golaszewski X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=12340; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=BmKFZ16woToo8VTwA3cT9gFAnZXIwnot36eGFq+4CeE=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBqCx9J730mYv54PYpt7ImWUfS4BmcvQFe7aqfQG Ox3enF+2MOJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCagsfSQAKCRAFnS7L/zaE w3ozD/9I47UCpa4J7TaSEJOPXRqRTxIQZVKVmTNugs7E66r5nPQyLflg0TMbZ8VfoCMFk6HTV+K bTvuBmVf7cZCI7weaYIz73SRhULCwy7h3/FsuorniPcwBHxJ+NvdZ+ctZsavMC/Nat1vQZHPCt0 R7ixP5WmILwnbZnxCuxVkn//XITrPQ9QF7eZXrSZtcLdr2Rfj9kH3/kKlfXNEK002P2UsJaBrxa HZmN3SeuZzC5C5UaUWN/6FSqPKKbzz/NWyQf10oIIutwesZktrsLEEChOiCkq8AMHLbyV5PzjwP To+3UlqALvk7sdQsgVn4nJ2EjKETuzQCYvKe1jA+hCL09tSzxekCVWuqYJm4Kfa26V7Nx7Ne3E4 FqmGqdNZVMq5uOtFySlJoKyNeagM6jij+xJ1hCGPlPy0eKl7jU2yxva7CK1PYHWyxFxuldHRt/z RV1r6v2iVcO3rS1axyt94qNUIhDTQo9h3qaWyBDY48bhBMA2bStKAEW7Sfvelf902LZpccg4dsB /nhMKcj6Mo1RQH6QZ88w7Lgv+EUOeJnNz/acm/5YMRlfpBBHQ0qA89lyKvI2a1Opgez+77r8Uli ZmaDJn0ZzpRTVMR/9n+yVb3SHrox/LpKJo56EP/4+35uNgfIxXaSThHTOa/3bKrOYusoLeTvi1K e0r6Y3TeG0qdOkQ== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Authority-Analysis: v=2.4 cv=a6AAM0SF c=1 sm=1 tr=0 ts=6a0b1f51 cx=c_pps a=OI0sxtj7PyCX9F1bxD/puw==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=yOCtJkima9RkubShWh1s:22 a=EUspDBNiAAAA:8 a=kd_SSO-Pc4bEN0uSuqsA:9 a=QEXdDO2ut3YA:10 a=Z1Yy7GAxqfX1iEi80vsk:22 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTE4MDEzOSBTYWx0ZWRfX7KET4hZeX5Ls e5rS9u0vErWYDTZPkdaFxRKMMYNkEhE5vCYsei5C2ac3svGElZYRV2M990fuzsWqLqJuVtIiGJd 4IN5wCxFV5k+tveOpmR894e5EEkWAks97puZBlnYIU7Ig7DCvQLE0tZWVpSF+IaGbHEu6nDLvpn nBaLulyKnW7fjnV3lHr50XyA65z8ieQUxiNm0uog+cHlBWgZ5qB9mP63fwdfTK52ob7J2DeEaSM Ewh7aNCWIaj4ONd6/fo0OwT8tdU+/TbnbNA/lhZksj52vht5QEOG2weOSls9K2vZUFwe9FF50EB O0BIchJ+qH7+ukVqp1AD6i1OkL1r6M/A16vP+DMc923TjhhknlyB9k2v5nnUeCZzunFzt65iujj JcOlrs2se+C4T7IGn8m85cg8P50fW+wsyVDa+4mIYaur65hPpfaZxEArfzqUy9UurpJ6MnJTHDk /4Tvcl96FfyXuy1iBTg== X-Proofpoint-GUID: 65kTmP8Acb6SoQh1pPAflI9QX-ibs65y X-Proofpoint-ORIG-GUID: 65kTmP8Acb6SoQh1pPAflI9QX-ibs65y X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-05-18_03,2026-05-15_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=0 phishscore=0 priorityscore=1501 lowpriorityscore=0 malwarescore=0 bulkscore=0 impostorscore=0 adultscore=0 clxscore=1015 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605180139 Add a module containing kunit test cases for GPIO core. The idea is to use it to test functionalities that can't easily be tested from user-space with kernel selftests or GPIO character device test suites provided by the libgpiod package. For now add test cases that verify software node based lookup and ensure that a GPIO provider unbinding with active consumers does not cause a crash. Signed-off-by: Bartosz Golaszewski --- drivers/gpio/Kconfig | 8 + drivers/gpio/Makefile | 1 + drivers/gpio/gpiolib-kunit.c | 354 +++++++++++++++++++++++++++++++++++++++= ++++ 3 files changed, 363 insertions(+) diff --git a/drivers/gpio/Kconfig b/drivers/gpio/Kconfig index 020e51e30317a8574638bbe31365a3cf49591641..2ed9ba8d9c12b0fec9f6fa3fe60= 77f5588bf719c 100644 --- a/drivers/gpio/Kconfig +++ b/drivers/gpio/Kconfig @@ -102,6 +102,14 @@ config GPIO_CDEV_V1 This ABI version is deprecated. Please use the latest ABI for new developments. =20 +config GPIO_KUNIT + tristate "Build GPIO Kunit test cases" + depends on KUNIT + default KUNIT_ALL_TESTS + help + Say Y here to build the module containing Kunit test cases verifying + the functionality of the GPIO subsystem. + config GPIO_GENERIC depends on HAS_IOMEM # Only for IOMEM drivers tristate diff --git a/drivers/gpio/Makefile b/drivers/gpio/Makefile index b267598b517de089cf6339d837264f1d09e275c0..b01163c6a94db1aa21d895fb897= e87be62b816e4 100644 --- a/drivers/gpio/Makefile +++ b/drivers/gpio/Makefile @@ -13,6 +13,7 @@ obj-$(CONFIG_GPIO_ACPI) +=3D gpiolib-acpi.o gpiolib-acpi-y :=3D gpiolib-acpi-core.o gpiolib-acpi-quirks.o obj-$(CONFIG_GPIOLIB) +=3D gpiolib-swnode.o obj-$(CONFIG_GPIO_SHARED) +=3D gpiolib-shared.o +obj-$(CONFIG_GPIO_KUNIT) +=3D gpiolib-kunit.o =20 # Device drivers. Generally keep list sorted alphabetically obj-$(CONFIG_GPIO_REGMAP) +=3D gpio-regmap.o diff --git a/drivers/gpio/gpiolib-kunit.c b/drivers/gpio/gpiolib-kunit.c new file mode 100644 index 0000000000000000000000000000000000000000..f45ba72362f82387d7e345fe57c= 6ae976265ff9c --- /dev/null +++ b/drivers/gpio/gpiolib-kunit.c @@ -0,0 +1,354 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +/* + * Copyright (C) Qualcomm Technologies, Inc. and/or its subsidiaries + */ + +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include + +#define GPIO_TEST_PROVIDER "gpio-test-provider" +#define GPIO_SWNODE_TEST_CONSUMER "gpio-swnode-test-consumer" +#define GPIO_UNBIND_TEST_CONSUMER "gpio-unbind-test-consumer" + +static int gpio_test_provider_get_direction(struct gpio_chip *gc, unsigned= int offset) +{ + return GPIO_LINE_DIRECTION_OUT; +} + +static int gpio_test_provider_set(struct gpio_chip *gc, unsigned int offse= t, int value) +{ + return 0; +} + +static int gpio_test_provider_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct gpio_chip *gc; + + gc =3D devm_kzalloc(dev, sizeof(*gc), GFP_KERNEL); + if (!gc) + return -ENOMEM; + + gc->base =3D -1; + gc->ngpio =3D 4; + gc->label =3D "gpio-swnode-consumer-test-device"; + gc->parent =3D dev; + gc->owner =3D THIS_MODULE; + + gc->get_direction =3D gpio_test_provider_get_direction; + gc->set =3D gpio_test_provider_set; + + return devm_gpiochip_add_data(dev, gc, NULL); +} + +static struct platform_driver gpio_test_provider_driver =3D { + .probe =3D gpio_test_provider_probe, + .driver =3D { + .name =3D GPIO_TEST_PROVIDER, + }, +}; + +static const struct software_node gpio_test_provider_swnode =3D { + .name =3D "gpio-test-provider-primary", +}; + +struct gpio_swnode_consumer_pdata { + bool gpio_ok; +}; + +static const struct gpio_swnode_consumer_pdata gpio_swnode_pdata_template = =3D { + .gpio_ok =3D false, +}; + +static int gpio_swnode_consumer_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct gpio_swnode_consumer_pdata *pdata =3D dev_get_platdata(dev); + struct gpio_desc *desc; + + desc =3D devm_gpiod_get(dev, "foo", GPIOD_OUT_HIGH); + if (IS_ERR(desc)) + return PTR_ERR(desc); + + pdata->gpio_ok =3D true; + + return 0; +} + +static struct platform_driver gpio_swnode_consumer_driver =3D { + .probe =3D gpio_swnode_consumer_probe, + .driver =3D { + .name =3D GPIO_SWNODE_TEST_CONSUMER, + }, +}; + +static void gpio_swnode_lookup_by_primary(struct kunit *test) +{ + struct gpio_swnode_consumer_pdata *pdata; + struct platform_device_info pdevinfo; + struct property_entry properties[2]; + struct platform_device *pdev; + int ret; + + ret =3D kunit_platform_driver_register(test, &gpio_test_provider_driver); + KUNIT_ASSERT_EQ(test, ret, 0); + + ret =3D kunit_platform_driver_register(test, &gpio_swnode_consumer_driver= ); + KUNIT_ASSERT_EQ(test, ret, 0); + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_TEST_PROVIDER, + .id =3D PLATFORM_DEVID_NONE, + .swnode =3D &gpio_test_provider_swnode, + }; + + pdev =3D kunit_platform_device_register_full(test, &pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, pdev); + + properties[0] =3D PROPERTY_ENTRY_GPIO("foo-gpios", + &gpio_test_provider_swnode, + 0, GPIO_ACTIVE_HIGH); + properties[1] =3D (struct property_entry){ }; + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_SWNODE_TEST_CONSUMER, + .id =3D PLATFORM_DEVID_NONE, + .data =3D &gpio_swnode_pdata_template, + .size_data =3D sizeof(gpio_swnode_pdata_template), + .properties =3D properties, + }; + + pdev =3D kunit_platform_device_register_full(test, &pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, pdev); + + wait_for_device_probe(); + scoped_guard(device, &pdev->dev) + KUNIT_ASSERT_TRUE(test, device_is_bound(&pdev->dev)); + + pdata =3D dev_get_platdata(&pdev->dev); + KUNIT_ASSERT_TRUE(test, pdata->gpio_ok); +} + +static void gpio_swnode_lookup_by_secondary(struct kunit *test) +{ + struct gpio_swnode_consumer_pdata *pdata; + struct platform_device_info pdevinfo; + struct property_entry properties[2]; + struct fwnode_handle *primary; + struct platform_device *pdev; + int ret; + + /* + * Can't live on the stack as it will still get referenced in cleanup + * path after this function returns. + */ + primary =3D kunit_kzalloc(test, sizeof(*primary), GFP_KERNEL); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, primary); + + ret =3D kunit_platform_driver_register(test, &gpio_test_provider_driver); + KUNIT_ASSERT_EQ(test, ret, 0); + + ret =3D kunit_platform_driver_register(test, &gpio_swnode_consumer_driver= ); + KUNIT_ASSERT_EQ(test, ret, 0); + + fwnode_init(primary, NULL); + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_TEST_PROVIDER, + .id =3D PLATFORM_DEVID_NONE, + .fwnode =3D primary, + .swnode =3D &gpio_test_provider_swnode, + }; + + pdev =3D kunit_platform_device_register_full(test, &pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, pdev); + + properties[0] =3D PROPERTY_ENTRY_GPIO("foo-gpios", + &gpio_test_provider_swnode, + 0, GPIO_ACTIVE_HIGH); + properties[1] =3D (struct property_entry){ }; + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_SWNODE_TEST_CONSUMER, + .id =3D PLATFORM_DEVID_NONE, + .data =3D &gpio_swnode_pdata_template, + .size_data =3D sizeof(gpio_swnode_pdata_template), + .properties =3D properties, + }; + + pdev =3D kunit_platform_device_register_full(test, &pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, pdev); + + wait_for_device_probe(); + scoped_guard(device, &pdev->dev) + KUNIT_ASSERT_TRUE(test, device_is_bound(&pdev->dev)); + + pdata =3D dev_get_platdata(&pdev->dev); + KUNIT_ASSERT_TRUE(test, pdata->gpio_ok); +} + +static struct kunit_case gpio_swnode_lookup_tests[] =3D { + KUNIT_CASE(gpio_swnode_lookup_by_primary), + KUNIT_CASE(gpio_swnode_lookup_by_secondary), + { } +}; + +static struct kunit_suite gpio_swnode_lookup_test_suite =3D { + .name =3D "gpio-swnode-lookup", + .test_cases =3D gpio_swnode_lookup_tests, +}; + +static BLOCKING_NOTIFIER_HEAD(gpio_unbind_notifier); + +struct gpio_unbind_consumer_drvdata { + struct device *dev; + struct gpio_desc *desc; + struct notifier_block nb; + int set_retval; +}; + +static int gpio_unbind_notify(struct notifier_block *nb, unsigned long act= ion, + void *data) +{ + struct gpio_unbind_consumer_drvdata *drvdata =3D + container_of(nb, struct gpio_unbind_consumer_drvdata, nb); + struct device *dev =3D data; + + if (dev !=3D drvdata->dev) + return NOTIFY_DONE; + + drvdata->set_retval =3D gpiod_set_value_cansleep(drvdata->desc, 0); + + return NOTIFY_OK; +} + +static void gpio_unbind_unregister_notifier(void *data) +{ + struct notifier_block *nb =3D data; + + blocking_notifier_chain_unregister(&gpio_unbind_notifier, nb); +} + +static int gpio_unbind_consumer_probe(struct platform_device *pdev) +{ + struct gpio_unbind_consumer_drvdata *data; + struct device *dev =3D &pdev->dev; + int ret; + + data =3D devm_kzalloc(dev, sizeof(*data), GFP_KERNEL); + if (!data) + return -ENOMEM; + + data->dev =3D dev; + + data->desc =3D devm_gpiod_get(dev, "foo", GPIOD_OUT_HIGH); + if (IS_ERR(data->desc)) + return PTR_ERR(data->desc); + + data->nb.notifier_call =3D gpio_unbind_notify; + ret =3D blocking_notifier_chain_register(&gpio_unbind_notifier, &data->nb= ); + if (ret) + return ret; + + ret =3D devm_add_action_or_reset(dev, gpio_unbind_unregister_notifier, &d= ata->nb); + if (ret) + return ret; + + platform_set_drvdata(pdev, data); + + return 0; +} + +static struct platform_driver gpio_unbind_consumer_driver =3D { + .probe =3D gpio_unbind_consumer_probe, + .driver =3D { + .name =3D GPIO_UNBIND_TEST_CONSUMER, + }, +}; + +static void gpio_unbind_with_consumers(struct kunit *test) +{ + struct gpio_unbind_consumer_drvdata *cons_data; + struct platform_device_info pdevinfo; + struct property_entry properties[2]; + struct platform_device *prvd, *cons; + int ret; + + ret =3D kunit_platform_driver_register(test, &gpio_test_provider_driver); + KUNIT_ASSERT_EQ(test, ret, 0); + + ret =3D kunit_platform_driver_register(test, &gpio_unbind_consumer_driver= ); + KUNIT_ASSERT_EQ(test, ret, 0); + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_TEST_PROVIDER, + .id =3D PLATFORM_DEVID_NONE, + .swnode =3D &gpio_test_provider_swnode, + }; + + prvd =3D platform_device_register_full(&pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, prvd); + + properties[0] =3D PROPERTY_ENTRY_GPIO("foo-gpios", + &gpio_test_provider_swnode, + 0, GPIO_ACTIVE_HIGH); + properties[1] =3D (struct property_entry){ }; + + pdevinfo =3D (struct platform_device_info){ + .name =3D GPIO_UNBIND_TEST_CONSUMER, + .id =3D PLATFORM_DEVID_NONE, + .properties =3D properties, + }; + + cons =3D kunit_platform_device_register_full(test, &pdevinfo); + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, cons); + + wait_for_device_probe(); + scoped_guard(device, &cons->dev) + KUNIT_ASSERT_TRUE(test, device_is_bound(&cons->dev)); + + platform_device_unregister(prvd); + + ret =3D blocking_notifier_call_chain(&gpio_unbind_notifier, 0, &cons->dev= ); + KUNIT_ASSERT_EQ(test, ret, NOTIFY_OK); + + scoped_guard(device, &cons->dev) { + cons_data =3D platform_get_drvdata(cons); + /* + * We can't have KUNIT_ASSERT_EQ() under the guard. Despite + * the lock being released automatically, it will complain that + * a lock is still taken during a test abort. + */ + ret =3D cons_data->set_retval; + } + + KUNIT_ASSERT_EQ(test, cons_data->set_retval, -ENODEV); +} + +static struct kunit_case gpio_unbind_with_consumers_tests[] =3D { + KUNIT_CASE(gpio_unbind_with_consumers), + { } +}; + +static struct kunit_suite gpio_unbind_with_consumers_test_suite =3D { + .name =3D "gpio-unbind-with-consumers", + .test_cases =3D gpio_unbind_with_consumers_tests, +}; + +kunit_test_suites( + &gpio_swnode_lookup_test_suite, + &gpio_unbind_with_consumers_test_suite, +); + +MODULE_DESCRIPTION("Test module for the GPIO subsystem"); +MODULE_AUTHOR("Bartosz Golaszewski "= ); +MODULE_LICENSE("GPL"); --=20 2.47.3