From nobody Thu Jun 18 19:22:44 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 D2B4A403EB0 for ; Fri, 22 May 2026 13:42:29 +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=1779457351; cv=none; b=jpRl9VRScMjg5HLxMVnWT9LLXBewLErokwZvGCY1xPkN6O2f0cLqK+A1wpz01RvlntOJl+q10h0at8jzZ6Hyf7VJzJVLKBr5pcnil/Sb5vsgSRHCllIuURBM8Tq7E3KJ1s1kQaGykkKRVzsbTcjZevEAJT+yvUslU/N+uTDSys0= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779457351; c=relaxed/simple; bh=t3GMhU5BiDcAMpoxPcbsowAatqnK8Fer8zJ7S43It88=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=T+gTF9s8CrUCUGUmEVPU6+zCtC50ClDODdcE/d5UpVLano6B6DBeh+jmn0ieK84xBD4Mj6/J+DeDFN3isG48Y/7FRkGoUhLFifN8CMR2l1AnLCdlfp/GnH0RE8cWsDk12IiNDUlPZTbRNmE/2fDMYSLUGzs7Kv/V5Xgv9FHocAw= 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=LtGe0tmg; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=cFonWNAu; 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="LtGe0tmg"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="cFonWNAu" Received: from pps.filterd (m0279867.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64M8W0fn399163 for ; Fri, 22 May 2026 13:42:29 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=LtGe0tmglXAtzxpE WNmZPVo9zftc6/rHgKnQZ4jjt7x/ny7UXujoId57UrATIMyskSurmjOf2QEuvOf0 mmsSZCotYwvq0brIyeHN7hPudUIyYev+Awu+1+N/bPAmdit1sC81UzzyH/TQf4J5 jFGaPdwcsU/00gIydghxTrpCLFGPcnNADVN5Rdiv1rkgBciFuY7QDmDRyb5dqWZP /AfhC92ItACVk9H0Y2Kv4UJ86yAlcu6SV8YcExz+ZMEYIHG9Lki+XCSqk+SvChUE nIZDq6E9gZpnbBenTDcH1Sw12o5hW8UsK3VpxHWn2b5w0H061fT4O8TcJkG3RQDJ wEyyew== Received: from mail-qt1-f199.google.com (mail-qt1-f199.google.com [209.85.160.199]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4ea5p9vh5d-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Fri, 22 May 2026 13:42:28 +0000 (GMT) Received: by mail-qt1-f199.google.com with SMTP id d75a77b69052e-50faf575af4so197026781cf.0 for ; Fri, 22 May 2026 06:42:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1779457348; x=1780062148; 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=cFonWNAuyFUsu01VHvolCk3bG4v9b38BS/4iNjIechk7LX2CmMnmSw3ED4l7kQBmQ+ Lva8X4YiTIZZCaPZez/DPqiRE31W9+OyfPQLFcYQhSnuzb4r0IKhBL+uH/Wib/+Dud8m g3u75M/5CN8ef+bQ72E/r40HDVf8obfRm4mQtsnK+NTrWnQVPDDmeUuzSGQYTE2+WRu+ 7GQluco3jx0dPiQgxvO/4Sl7AI9upFHdIOY7OKd+jZR4Enwsfk0CWz6DRnC6lvSVubWC c7hz46UjXWgpJkMcVVpuHUfXhIPpNbEjA8qgVoM2u4NC/rRNXdFVz9lg/eHC7gH0QEQH fgAQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1779457348; x=1780062148; 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=UUJg5j4RwjNQy9RUNi5VXmhyEaNRyHlzzrbu3P40WSWnsIHWHz6irE+wjWg2rTLIv1 qk5zL/TojqKjjPoWdp8H7Z6nKRirMqmCBxbGucuwOatws7ijP0j420e7f0rZgEmB9VGF 6OT31vK56HMoG2JgectYtAz81eOuWwKgQDDACo3D83YhSYhDXV8n6Yol5khaJosmkSXE 6aWjF6pE1Qg2TJ9XVOCYrAdNOQbn812stIZIXyKuwbrQ54b3yLRMjmwmk89PiI4Kg5F3 rTFkiHmccTJQbTYo0gwaHfD2YPmEdthJAytkPPCbV9LOQggI3dTFWPTMCkvN0JdIbmVA F+pA== X-Forwarded-Encrypted: i=1; AFNElJ9Sfn7GGDxhkk5ENDZpAT2H4slbG6SWAIto29hEXH2fIl3JZuoqPfzQeABvCkFsOPmmIGHJiecOSSqxXn4=@vger.kernel.org X-Gm-Message-State: AOJu0Yw2NqvxdsmSmuFdM8o9gc1g7Lrti67mRP4YHEc+DLTNGyPIQu57 tEiCGsqaxgkG6oy3IVbwYDIu57IMHntAoq7QhC/K2A1TM53/LDK5pZFaAhAqdqMuK7GX/FFqKQk 6gXCQc47jJrEva6Lxz+hEH0PHPOwqupPE6nNjidwcZmiPShFxWEPsOHEtHAHtILSVI6b63zb8y4 4= X-Gm-Gg: Acq92OF0h21ydngpc/UBmI3ms39zac+GlyKmcoFKuRPL8H9oWn1aUTkSsG8ejqGRaxX qPRVyyUNwzTMv0WUzOUUqeFqVtMn1CwPQCLfyq+vaj48Xae1lscGsCFzutWtfEtSqzHsi6fZqOV TvYXIIK0SS9hDcPZpivO14Gtan3sNLYofN3P3RBop0VtT5dA7IZ64tMTbnel92NG9PXrHz08DcJ Y7/2tMd1zn4MW6vRYqwVwhEr4QlbUel6dsPsDs2oKQEnpXv6BhCARxT9O6bya0JjOKCKExUkHp2 NMOTz5+a4lau52jKga99SkMYmO0Bmpt8VlxC87pYkbOVoh2FUS0o9k8HiTHHT2dCv5T0ODxKd+b LUVNpAhFKQEYRlU9HCI/9K8wXSoJnXT+FLoMk9RLuT8tpFWWDmw== X-Received: by 2002:a05:622a:4019:b0:516:d612:d1d0 with SMTP id d75a77b69052e-516d612e01dmr38083021cf.44.1779457347859; Fri, 22 May 2026 06:42:27 -0700 (PDT) X-Received: by 2002:a05:622a:4019:b0:516:d612:d1d0 with SMTP id d75a77b69052e-516d612e01dmr38082551cf.44.1779457347398; Fri, 22 May 2026 06:42:27 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:2fa:6280:a48f:fb37]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-45eb6c9f548sm4886546f8f.2.2026.05.22.06.42.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 May 2026 06:42:26 -0700 (PDT) From: Bartosz Golaszewski Date: Fri, 22 May 2026 15:42:16 +0200 Subject: [PATCH v3 1/3] 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: <20260522-gpiolib-kunit-v3-1-b15fe6987430@oss.qualcomm.com> References: <20260522-gpiolib-kunit-v3-0-b15fe6987430@oss.qualcomm.com> In-Reply-To: <20260522-gpiolib-kunit-v3-0-b15fe6987430@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/NoTDAcsmYgBqEF09akdtuWuz0HDpea3//v+tQj9e8KPiyPgit jZnToGq6rSJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCahBdPQAKCRAFnS7L/zaE w9CIEAC1OPkgYBY0TsdaGT+nsD1K+xnFnem9v0LXfFvtLmw2LGuPBgWxOAzFCRdP7qisriHzqtp uzxJfD4ubqQ4Co2LatgTuhcJ72nuDmASloYepiA0NEnXdwf7e9DvQ247FhEL75qIV6pYzjbfHbB c7mPRtuR3gtW+KAPiUeRDA3c6XNPV6jhvs0ORr+2+CM6I6xQjggFpJcS/loto3Pth41UZOKCgGe 9Bs/lfcu5lShmGitUE+YU37KgP5uubyPpp8cDpmjY7QgXBGJn5F+HdtVZpUXDQld1HK85q/wdiY DxrffqyuLy8zEeP/O0pfqUkWe5dofcZV4P+UVa52BYiWhlma98a74q1PsJzqj6f5mNz5ZHlCeNf x1RL06JZQ3QNyjfRgIgM1aTgHHgwGW82rtRPhMCvMn+jilCPiwd7oRzRfQVi8rDqSg8dJNLfakf 4GOJgFGRZwNcFlfmwzlcBzW6Q1ArERU6lue8HVzbPNgycm7ImIaQFtLhOUaGXq5z3nHbthOxlZS joOzKtgQgfbltgcU0lJxbf9GOKc+h8034aZkqTXsq9mH71ChD8vU5NoCnmDHfG7kx2FfCNFUVDM 5CNFeZNdG7Wc8vkSbEKP+W2eeahd5XBNtKmqcVYx0L1TRGViXNgfk0jwQvrCeAU82kVeYN6kge4 sx4AMRjlULgCRaw== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Authority-Analysis: v=2.4 cv=DKm/JSNb c=1 sm=1 tr=0 ts=6a105d44 cx=c_pps a=WeENfcodrlLV9YRTxbY/uA==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=eoimf2acIAo5FJnRuUoq:22 a=EUspDBNiAAAA:8 a=3Mdbh2SI1NvihuWZMnwA:9 a=QEXdDO2ut3YA:10 a=kacYvNCVWA4VmyqE58fU:22 X-Proofpoint-GUID: nlUx4W8FK0Tnkopi2V7OKkEtLhUlXIOy X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTIyMDEzNiBTYWx0ZWRfX/gu15ush1004 OqFm/5olTM2GxhwOQV2BiNrCvV0OFnSEeQ9zAMJgGhAKN7DySjsGfFdLwxRgQ+BEreLeM0BJFho 98CHfNT65Xn+f/OlCHyAT2tRlQDgYNj/nAs0cMGtQBcst5Tp5QYUy+Yx4ZmaTL4Iz0S11X3a+Fm hlM7jnuaQlBDptDIkhrmA1piMa6DSvTaUQzl5arsTBMw2Q783+qHGuIQTmwe49EQ4TQhEvFLO1a 1G8SAayiZyFdq2wS6ZOAJwQTgHlLWxSBjSIDZ7tyA6lWP7PEOB+L0Melp26E3Yq0D6eW1mERRBV xU8zAkgTqV8BDKEUrAbWR5maQCDNxQUIfofidNLBxuCIgt6yeQBST2Za3FgIIiJjoOM6LO8zwwT 8/qCxvRJOCkRI0OvlVGHnSYMOOUvCYhS8O4b2Fs9nQjlKhRG4/+NfzBUkiihz6xqLgvCVHJvshi BvdFS1ioRgxx9zc/rCw== X-Proofpoint-ORIG-GUID: nlUx4W8FK0Tnkopi2V7OKkEtLhUlXIOy 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-22_03,2026-05-18_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 bulkscore=0 malwarescore=0 spamscore=0 phishscore=0 suspectscore=0 priorityscore=1501 clxscore=1015 impostorscore=0 adultscore=0 lowpriorityscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605220136 Provide a kunit-managed variant of platform_device_register_full(). Signed-off-by: Bartosz Golaszewski Reviewed-by: Linus Walleij --- 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 Thu Jun 18 19:22:44 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 50538407CF7 for ; Fri, 22 May 2026 13:42:31 +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=1779457353; cv=none; b=Q1K6Q17GS/71+wsoVFLbjgW90dbyE99Li2TgV4Kqy06/jioZQjCDY1+foRZ/56maJLHRNr7TLZtszWvo2wfeJEuDZWpeLRHjbKP71GYb/mJg8Mm7G4tQUiA9EAqsk1BQezWF4mDYgOlmkcdXfEAaEhSHHIzTcDSuiTgcUiDsOck= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779457353; c=relaxed/simple; bh=3QhdbY+CCYZtYCHfS+wbbbRFki/DhpgeGMwKpTuQGcQ=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=RN9/yk7N9g6bGgyx/TdduSvS5bhh43CDSbe5gYDmebulttjN2eT5OrW44G3knUAzI4hRRjnrVpHnvsg6Yq0nqasPC+9KUVFtA1dyXiGBf619kqqa8NZ+geqT1OsgUCkVvCbOwFvbocx1gP4gJvpubYz7TuW+tfAfsiNBcC1dvNE= 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=TKXcVIyq; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=e+0ohit4; 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="TKXcVIyq"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="e+0ohit4" Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64M8WwBf3532229 for ; Fri, 22 May 2026 13:42:30 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= oZTO0NLY/beCR07aLpL/t7D4AdbPlbOmoaxCvBeaC9Y=; b=TKXcVIyqojxyi7DU m3oRW6xbVxGvKzxSjnki7jpNDDy2uY03xTPOYfUrV6eVl79HdTFBM3P19044jnmo tvTirrbwaEkjZucysgl1CDu+G6h6WBm7WF4jAR12vKqs+/cTXfKZahAje8WSpWmJ Xifslaf4xYUQdmrZ8j+Hje7iPJNK9dV+9ILhmSdhN4d8zh3t3vvKApZzTPBtlU7S gFB6enDtTR6l09Zii88lryLnYc7mY5+jzhEWCBlV8CmGUeV5yFhJt1g+BVsqJo62 ra5cJNLbwLlyYp5TylHmHrxd6UZjrgvrezf4gOIcHOaPwi9t4Y2DoAjnxSCJKxBj oHgUVQ== Received: from mail-qt1-f198.google.com (mail-qt1-f198.google.com [209.85.160.198]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4ea39gw95m-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Fri, 22 May 2026 13:42:30 +0000 (GMT) Received: by mail-qt1-f198.google.com with SMTP id d75a77b69052e-516d58f74b0so11674291cf.0 for ; Fri, 22 May 2026 06:42:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1779457349; x=1780062149; 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=oZTO0NLY/beCR07aLpL/t7D4AdbPlbOmoaxCvBeaC9Y=; b=e+0ohit4pGfR4MG3fOaMTnqc03D6Cf0XQ48AFFJRkcNFuvJzYKCkaFBnFOiShLExks J8BWNj/Ug1E7nx4cx9rn69ii8ngTPK7edWHXMygm7hOQpoZi/i+kkopAvq4ynzlB3OlV SZj9JNmHmw0UNfW6A+5ADL1XX64sjkAuTbVRdk/GjvaYCWVbL1q2vm6WWdcMKXIcrVUI h40EYRtfbIJUS+zOmq4Q1yCe9tJ3ubLwYk+JQHV5+XX8GvilhsfvVuEcfU2/S8CgZ+/k 9kebFBXzr0N8EVZ6HC8r1WkoAT1kxvuzXWmlOAijg5aMiaxLbL2UI6hrCsk4PO75uFdZ /nOw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1779457349; x=1780062149; 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=oZTO0NLY/beCR07aLpL/t7D4AdbPlbOmoaxCvBeaC9Y=; b=LhZ4InCwzC2l/6AJTw3XC0+GcZHj/HsZ+uB68dBNdx67dMm/sGAmpfbwWn5GGvvVAz fzsmZOx0hs2mi5jPd76f4GVAuE8XbM/3mPtLsLtz/J/G/6h/k2jQqP54SZ5MQovBmJkH utS0RwGx3DnDnJj0Dewjk4FE+iUjV1wj6CU7Sdb3MQDSW3c2gecCLmWw9kyOG2p1ziMT pzxHyFpreob53K2Em9nsnLWaMBe/Gcu9j0mT5t+MX0Uw9BVDlPXHcyL5S8+jKqssDAuI CKgMy0ep0LCWMzX6bVbv35LGFPblBE9lLqFeZa+KbZ9xkZMx4VeXyGUzMU6ahwMmHVFR qk8A== X-Forwarded-Encrypted: i=1; AFNElJ92+jEs3nEBuDqZ6GZLQae40yhzztGRH66g9GDTUAUzbMU5cFkG18UP+7wt3rJP3CWxmaCc0ebOIp8AMgI=@vger.kernel.org X-Gm-Message-State: AOJu0YxXmZgxz+YgVFHT5teo/MUdTx/cMQ4+59k0pKemdHsz/bZUCxXX qOnzVy45bsA/WhgBdl3mbdsBg+i3RqKy5aA4hnV4d9RNKMAW2XNHPFkLFDKYrexyNx0OkzpXtQr +aYAsJlSn1zzncdW7rpibXk+hV0tgZ7typK80prduauTxMPwnQpnc9UZhSF+uw9Ka6z8= X-Gm-Gg: Acq92OGHlEhdv9glSwEoqrHRsk4ORCxLCtWDW/2UET1CBnqDZB2bXMxQayLknR3byFy In8DnhorfjzOSUHunqf1cb9ddZaUsUvhWJxyXC2HiwtMVZTAO0Kba+22LkYKWh8jlH9254JQ2Sf oGhkS5okCPRFuJk0ymSzdSXQAJ8QKFH8BwQNMvFL/gY5Ze+7VELT/DZYkyuejELNwwD34HX7yz4 fre5f38kqBDh2eOVlP+K1hTTgI/MPY5wLQ+pXkMqwA+lz57QD35zJsSnWsPRdEqdhqONouNVbih lo/2ihtKbPLqY+QfdgrcvON+GzgU81LPj3rESGXE6gFf4c2yy0+rRAdHbe0oF6AR9A83WPCaTDW 3t2K47kYd+vD/SskJXRSSqiUS5vKoNUs8Dgi+ZH0iUAsDdrY8Jg== X-Received: by 2002:a05:622a:5811:b0:50d:863d:b50e with SMTP id d75a77b69052e-516d429352amr56069661cf.3.1779457349555; Fri, 22 May 2026 06:42:29 -0700 (PDT) X-Received: by 2002:a05:622a:5811:b0:50d:863d:b50e with SMTP id d75a77b69052e-516d429352amr56069251cf.3.1779457348978; Fri, 22 May 2026 06:42:28 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:2fa:6280:a48f:fb37]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-45eb6c9f548sm4886546f8f.2.2026.05.22.06.42.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 May 2026 06:42:28 -0700 (PDT) From: Bartosz Golaszewski Date: Fri, 22 May 2026 15:42:17 +0200 Subject: [PATCH v3 2/3] kunit: provide kunit_platform_device_unregister() 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: <20260522-gpiolib-kunit-v3-2-b15fe6987430@oss.qualcomm.com> References: <20260522-gpiolib-kunit-v3-0-b15fe6987430@oss.qualcomm.com> In-Reply-To: <20260522-gpiolib-kunit-v3-0-b15fe6987430@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=2738; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=3QhdbY+CCYZtYCHfS+wbbbRFki/DhpgeGMwKpTuQGcQ=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBqEF0+V3akSytsAqDiyBviKoNYvmGAXEDMYftgB jWSaXszSdyJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCahBdPgAKCRAFnS7L/zaE wyXWD/9lW6c8aNvbsPH3hxd+JqTM2UAC9fH8BVhbM/z/Gl2SrM0OJlO/ZyUE9542ABu/EYvHlRx HEpwVaCLMCEaNiD2ipPTYigMMouaMPBIVd5r3sPer/jIaAX1adFA7bnagHitgAxfx7AogZ5SJW/ DBgsCtDLXI03hG/77TXhrVg0p8Py6wphtw/TO6sXuWNdpOpBz8Dt9EAHMb2W0OUCcGHteaoPJ4j NbJOvHFjP9ABt8dwXYY/MM2fDjffwL2+MduK62GMrzBycG6eFbLSKgIJznjSzqdnJhiXGGwFc0f Oh6RGPSCELIU/PUO/iWVEt/8c/RZnbZiIaFMbktTjZb/6dfCoGV8oQoo5rmUrFCoRYYWaECZtbK bRqAGf/FZWiU4/wtlvMRApxPaKjNp2G0vdkFqmSmDEHDQDvL4L/wDnkWZQb7dKBODcdvkdPgVeX T0ulkxK+RALChD+1i/cYKli7u5Y4tjxajAR2gf7DzDYoeqDBKYL2bz1M95B81W1rY4AeNbHnY+i WTto+oL2nQIh0nZaMq1Y0NntAMbM/O6hTfGIfbOJctTRg32RhsncSyJtosayUjYvkCUa22x6K9k FPeJsdxFRRu4SHtieD8tym9XmzpS+T4x1Qcpsv+P4Uuh/PfjM8JZIImFadBtyh78U6sJ/sXiraQ f0frZipWwDDt+iA== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Authority-Analysis: v=2.4 cv=Yr8/gYYX c=1 sm=1 tr=0 ts=6a105d46 cx=c_pps a=mPf7EqFMSY9/WdsSgAYMbA==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=YMgV9FUhrdKAYTUUvYB2:22 a=EUspDBNiAAAA:8 a=kmOvhMkJ8j3s7cJ8cD8A:9 a=QEXdDO2ut3YA:10 a=dawVfQjAaf238kedN5IG:22 X-Proofpoint-ORIG-GUID: QsBdleqI1XTiOQHeo8bJHQW3fCiyiJ7R X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTIyMDEzNiBTYWx0ZWRfXxVzoKBoVpD+v z/84+Hlbj9uTL3D5B4cv86dqzHP3BRvmf1Xtu1ejv5OWeRwlxVjOj6P9H8n7TRfxMDuUAHudpJ5 DUa67gMMy+G8YPWwWyoH88CPfZ8f6oQfIu/FI49t7ZhN+G0rwQHjODpK++pICN6wzP41JOk2vnu 6ABZOseAdfAa6ItZi2nPaHyof4oB4o28ASACjLspnarWemM6hp/r9YrP8KVeIjgyKqueq0GsPH3 D1ThS6MHkT5p5nui45vEuUi0XtK/Plj9gzCKIpBS1RnfpHPBBiL6O08TWL7kufPdy767csCvnsM go5svUmlRjvj4i6fB8azmZRbWneGjZI86X4RzEofNyiG6GpLlwDxZgqV5bh3qgI2qrD8hlDLUze 17HolFMeKv+QXrIpW41hWKl0KpA5HIteClVsf3w9fq6mFEBB9fAAuz8W1fPuKzEr8bAANLeRB+r ulLpS5VZV6jZISxtv6Q== X-Proofpoint-GUID: QsBdleqI1XTiOQHeo8bJHQW3fCiyiJ7R 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-22_03,2026-05-18_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 adultscore=0 priorityscore=1501 lowpriorityscore=0 clxscore=1015 suspectscore=0 bulkscore=0 impostorscore=0 phishscore=0 spamscore=0 malwarescore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605220136 Tests may want to unregister a platform device as part of the test case logic. Using the regular platform_device_register() with kunit assertions may result in a platform device leak or otherwise requires cumbersome error handling. Provide a function that unregisters a kunit-managed platform device and drops the release action from the test's list. Signed-off-by: Bartosz Golaszewski Reviewed-by: Linus Walleij --- include/kunit/platform_device.h | 2 ++ lib/kunit/platform.c | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) diff --git a/include/kunit/platform_device.h b/include/kunit/platform_devic= e.h index 8cad6e1c3e7efba862862b579089f2f317784a73..eee565d5d1d35c1d1bc82b45eb9= 1d21d00c68428 100644 --- a/include/kunit/platform_device.h +++ b/include/kunit/platform_device.h @@ -14,6 +14,8 @@ 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); +void kunit_platform_device_unregister(struct kunit *test, + struct platform_device *pdev); =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 583b50b538c79599ebbf33e261fe2e9ced35efa9..737758d710b2839fab29c5cbcf3= bc5ba00e20094 100644 --- a/lib/kunit/platform.c +++ b/lib/kunit/platform.c @@ -161,6 +161,39 @@ kunit_platform_device_register_full(struct kunit *test, } EXPORT_SYMBOL_GPL(kunit_platform_device_register_full); =20 +static bool +kunit_platform_device_add_match(struct kunit *test, struct kunit_resource = *res, + void *match_data) +{ + struct platform_device *pdev =3D match_data; + + return res->data =3D=3D pdev && res->free =3D=3D kunit_platform_device_ad= d_exit; +} + +/** + * kunit_platform_device_unregister() - Unregister a KUnit-managed platfor= m device + * @test: test context + * @pdev: platform device to unregister + * + * Unregister a test-managed platform device and cancel its release action. + */ +void kunit_platform_device_unregister(struct kunit *test, + struct platform_device *pdev) +{ + struct kunit_resource *res; + + res =3D kunit_find_resource(test, kunit_platform_device_add_match, pdev); + if (res) { + res->free =3D NULL; + kunit_put_resource(res); + } else { + kunit_remove_action(test, platform_device_unregister_wrapper, pdev); + } + + platform_device_unregister(pdev); +} +EXPORT_SYMBOL_GPL(kunit_platform_device_unregister); + struct kunit_platform_device_probe_nb { struct completion *x; struct device *dev; --=20 2.47.3 From nobody Thu Jun 18 19:22:44 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 88DFD409625 for ; Fri, 22 May 2026 13:42:32 +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=1779457355; cv=none; b=gnga/jxs/mQ/UzoFsbEeuLPK6N5PRbLJXjcwzoemADxBLjOhYG85PCXs/EIOCcRHhJlGZXnAaQR6ju4mXwhuhf71bu3jpW5hFVIX2WFCXQ76Wxom3z1KM/MflYIUtv1P9+/wFJla5aCLJXFRretDRgnZqNS/l1UFL/hamz09Rsk= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779457355; c=relaxed/simple; bh=7YnHenPV9LU9HH0oXXRrIPZLMPovAnvfYPI2d8UeBlQ=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=FYRotVE6AHGNoOB6305gui2cGkFKQpc8EmVeYD7gzRMstZmv0daxOFIRRXdKbzz8we7/m95P05vJmbqLxUqaYaihEoWGvnKcycrTBF0iNIvVWta+E6hgq82nColsu5Hmuioq7TErx39OdYZNj9+pijEAJbuXEqmoo/VMNcbcaPI= 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=nA1008es; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=FI+GtCPd; 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="nA1008es"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="FI+GtCPd" Received: from pps.filterd (m0279867.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 64M8ml0R399407 for ; Fri, 22 May 2026 13:42:32 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= gpOoi3K+3WVMMUDmiIwOSuu1JgGomDZPzYqit1n/jaQ=; b=nA1008esADISWpvt Fm9V+hDJyd6gdf6/NXGwEu9WXoDfqDHGn8eZ/NfBkNqJKtzvAwUXyfU7qezLgZjy 1fFkljCIjJL+fnkBCylbEne3QTmA7blWrgYckzj44jxZlnBR+34l+Gts37gj061g NLWUuVQSGnqGHSHpOOHpsuG09sGklI4tHZA3kEvpJfaN2wh8drGkzrtM4x137WiP iNdAK2GdXINSMDIaIOoPbC34n0KN6GZpyWYkcsfdZXWoM7/EEv2Ufzg9KgPgrrWl bXy7un3eTe3Te3jXC+uxb7Hh0hALi3rppBjYJ7FOv7l0jFrTGN5M8UQeil4bKMnn v3jE/A== Received: from mail-qt1-f198.google.com (mail-qt1-f198.google.com [209.85.160.198]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4ea5p9vh5q-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Fri, 22 May 2026 13:42:31 +0000 (GMT) Received: by mail-qt1-f198.google.com with SMTP id d75a77b69052e-51650041428so2918231cf.3 for ; Fri, 22 May 2026 06:42:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1779457351; x=1780062151; 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=gpOoi3K+3WVMMUDmiIwOSuu1JgGomDZPzYqit1n/jaQ=; b=FI+GtCPdUuVq4mugQ22ogYD8Tf6usZOtpfaRxeKc3hBRESYb4rEXhHX/Nas9a2vTjG si3ibtcUahmWN8chdRQZlOt0tsRgqtSnFOQyHFRod8U0YSbmM78I/wIAOpzlv9u45JiC PlCplr6BnljuJ0wmH6JXZOIULNsbZXJjILIlB3aFb/EOf9Pu7GcxpGogM6VeaIp18qXT xkNwTVLSuCuRl51up4RpitXm4WdgRntsp88Zxm9fnIO1iuWk7I65epAINQv10z1NVjyM /58JDiCemvif8JRhxenYf13KpWLkiPmmdb2JqH/6tkonzajWAtQ3rfuFKeIxmdNVuhip ppYQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1779457351; x=1780062151; 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=gpOoi3K+3WVMMUDmiIwOSuu1JgGomDZPzYqit1n/jaQ=; b=i4lZ6Gfvn8AwVX3AdNL7SA/Y7VZRNVgIYDgPajCyS1GwzBC98Bu0vBsZvvHLy/Gx7r 5jt5/Tgo5gBJpwWOX18SMU7DKl/kA9tLNoPjZjFGudRRYl9gB0jCAlSPtqDeUAgIdNug aaANE35r3ZL3XGFtigUKPFcgkNuAAqY0wYIun2c+8fvJhsnVz1jiCuzoSyO3NENfce8k mi5BNdMZ09xrRGn6aZCUffXJRqOsNFGZCCfxMc3AmZK948Vq8P0xNZy/kxQcUrBCawEs UrC6ESsiuX6ICtVYgBhLCl04NCflb5huVEpJjD+Z9EmfzkXJvsVG/p2g1jpB4PhknWXw Oo2w== X-Forwarded-Encrypted: i=1; AFNElJ+JratSeP8arORDsrohlxxzeXYPdmizXnDnLvkN3bVSopisTfkCtV7sou/6H+zluamm22GLAqUopOLWqv8=@vger.kernel.org X-Gm-Message-State: AOJu0Yz5hSOuRzMpNe1q8d2xsR0oQMVPdoQlIAd+AFck+GyfHbWYDw2v /5ERp6PEyw7vxoj5n/6uI8+o/y96G0VA5Eg8IAWglc983KpKhaaDjUJZrkGAtKCUr8YtA46fDC2 QyhIyN2K9bxgf/kkGJ5PNZrd68YXp1GwwE13O/kOH3bXDq9oynP19ZmyvCkiO4qgXD7g= X-Gm-Gg: Acq92OHQhwQsAOQS2CKA1ee1K81RqBGjCwB3benzboOptVBzDvndy1ii6JrJUE5FQ/v hSPBUH17zHRUNw+KMk3ZwUOP2lp/sSiYwlaxUSMToDNqIP2PA8WPOStH4k5a9IjThFwkskD24LG f7vmHBkvkAP7xvpJdjaH3omIkxF/kKOrneDquJjSrq0S1gQ4sMxKBeVhoisQZKVWX2nNgs29sBk 5grN4SxudDW6NSiswTnAK7YoO9QXJh0HfKfvOwEL8V2CKMKyE7q8YWMvJLyak3lr6r2WMT+w/WT /ozsTjdofLrwDnCiLPs8RaPIWpkPX5oMHW1+9WZxvYs0rqHiMtQ2LzZPeu+Y4fK6//uiId1bam3 0DkPzrSYPI3YagsX43KjeSl4Va7X8a8E5ttu/2TRUNxWRc7Fs/A== X-Received: by 2002:ac8:5e0f:0:b0:516:41f1:9203 with SMTP id d75a77b69052e-516d4645f53mr51222941cf.38.1779457350881; Fri, 22 May 2026 06:42:30 -0700 (PDT) X-Received: by 2002:ac8:5e0f:0:b0:516:41f1:9203 with SMTP id d75a77b69052e-516d4645f53mr51222331cf.38.1779457350359; Fri, 22 May 2026 06:42:30 -0700 (PDT) Received: from brgl-qcom.local ([2a01:cb1d:dc:7e00:2fa:6280:a48f:fb37]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-45eb6c9f548sm4886546f8f.2.2026.05.22.06.42.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 May 2026 06:42:29 -0700 (PDT) From: Bartosz Golaszewski Date: Fri, 22 May 2026 15:42:18 +0200 Subject: [PATCH v3 3/3] 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: <20260522-gpiolib-kunit-v3-3-b15fe6987430@oss.qualcomm.com> References: <20260522-gpiolib-kunit-v3-0-b15fe6987430@oss.qualcomm.com> In-Reply-To: <20260522-gpiolib-kunit-v3-0-b15fe6987430@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=12281; i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id; bh=7YnHenPV9LU9HH0oXXRrIPZLMPovAnvfYPI2d8UeBlQ=; b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBqEF0/d6dc86rvhkptlS2ysBrl3Fx3w9H7T4UiV mrxNR4Iw72JAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCahBdPwAKCRAFnS7L/zaE wwSED/9WDi6ixUviG4At3jGPIVH66nIjISTqQ1fqWtkf+PfLdqiuNK7An7drg20Aj3GfFVImmng sHxxojcLIADuu9Y2qdf3rvx6aGFO7PPmPrQ4EScJ7SATRfwtiCuGo2+wq6RCDBuAsVekLazQi6K ln+74qA7+z7yWYr9oVdX17mae9LkEZwmhv7I+BJBuDs+z62FIGenns+pVVnVH48jKy1e/lLgg5w mWextdgniq3LPPMPH1Y4czTkonnPR5JBM4MHdWgud/3fESDW64saVDxiU4FcaX3j4ObzhEFZ9JZ eBk4Q+VjMIyeMyNjyiNG3yMkF5m1DFjW+e9pggaeOAUW9sLkFO9ZJwaaen6cwibGZAleW4ktBaW p9E5QCaYPbBXdEFC3ZJPeqTCpl/blJYPLZgSKHb75r8McpI0Vrm722RBYzVuBEC0hVdCzwpHaQ1 7qcMrEeHk7SQvjLf95eQMCvG+Ml/Vq8JV6Pb0li8sLyzniu759hroTTlXSm870GyDHrs4SC0pHS aDZDamgLhNogV2fo8MPEPGZNmIAoLz145jVlqlAELZKcQA3D9rWCyE9HH/qAsGcbMCZIbpoT4Jm U26ClM6GwaT6YV3X7MBN0dG1nZZw7KZBOZiWByK21+U1g/A4jMmv+/A7Je3ZrR2HcbzvrVMq2gI VvJyy+3bVVXfP9g== X-Developer-Key: i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp; fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772 X-Authority-Analysis: v=2.4 cv=DKm/JSNb c=1 sm=1 tr=0 ts=6a105d47 cx=c_pps a=mPf7EqFMSY9/WdsSgAYMbA==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10 a=NGcC8JguVDcA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=eoimf2acIAo5FJnRuUoq:22 a=EUspDBNiAAAA:8 a=kd_SSO-Pc4bEN0uSuqsA:9 a=QEXdDO2ut3YA:10 a=dawVfQjAaf238kedN5IG:22 X-Proofpoint-GUID: 9BGy1NnQfXdFbrJYz4SOS0sSGsxzwdXS X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwNTIyMDEzNiBTYWx0ZWRfXzpkSvqpqepQb xdKXjZw4stnZ60paHyKu4twGEc88nNAYlmbwQVPmOHb1Pf9XsYSUR+tquHaxUS+kmHqoVGdn9L/ 2PioPnhWNwlCRp9nHdRoA9w4DsWxm2SQora4Cp7jvBBp5VD6QqkykX32QqXlXwXOtgBuHk3Q78S XIYFMsOO9cwGFqfCHcdsNj++wNi35yO3QClJjuygAQcNq/hWpnAz0wUBYrIsm5rkUQtU5d5j77F odKPg0k83yJFGD+LOR8QD9gOAVY2/BlTjliEtRvC6wxjKVRA8qN1eO2mtCdmlbnPWYXSUYGEVzK UpRxhuVcNPfSLyPGOf0Nz0cKAbB6WDKaqjvq+ZO1srWyS5pLoh37uq9J+yc2lzjcPVI0C1K//uT QeASUvmvRe7FzbPV0KxdDjvQr5D6qsXeFJZ4UOQj1pdabzppqlcl/JOoEgK23/1oKhDL5JHGGEY U28IjK8jbzWXN20Ul2g== X-Proofpoint-ORIG-GUID: 9BGy1NnQfXdFbrJYz4SOS0sSGsxzwdXS 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-22_03,2026-05-18_01,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 bulkscore=0 malwarescore=0 spamscore=0 phishscore=0 suspectscore=0 priorityscore=1501 clxscore=1015 impostorscore=0 adultscore=0 lowpriorityscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2605130000 definitions=main-2605220136 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 Reviewed-by: Linus Walleij --- drivers/gpio/Kconfig | 8 + drivers/gpio/Makefile | 1 + drivers/gpio/gpiolib-kunit.c | 358 +++++++++++++++++++++++++++++++++++++++= ++++ 3 files changed, 367 insertions(+) diff --git a/drivers/gpio/Kconfig b/drivers/gpio/Kconfig index 00fcab5d09a4294ed778cea78af5867a0f6e481b..0306005fb7d65ae85905e967b90= 65fd74db753db 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 2ea47d9d3dca948e1cdc46965e83b0e1b6de5f70..c66b6dd659b16b80b6bb6b15fac= 3e3f462dec596 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..380b68f879e55433668353bb880= 67d561142a5bc --- /dev/null +++ b/drivers/gpio/gpiolib-kunit.c @@ -0,0 +1,358 @@ +// 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; + bool bound =3D false; + 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) + bound =3D device_is_bound(&pdev->dev); + + KUNIT_ASSERT_TRUE(test, bound); + + 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; + bool bound =3D false; + 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) + bound =3D device_is_bound(&pdev->dev); + + KUNIT_ASSERT_TRUE(test, bound); + + 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; + bool bound =3D false; + 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 kunit_platform_device_register_full(test, &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) + bound =3D device_is_bound(&cons->dev); + + KUNIT_ASSERT_TRUE(test, bound); + + kunit_platform_device_unregister(test, 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); + ret =3D cons_data->set_retval; + } + + KUNIT_ASSERT_EQ(test, ret, -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