From nobody Tue Jan 27 00:10:03 2026 Received: from mail-pg1-f171.google.com (mail-pg1-f171.google.com [209.85.215.171]) (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 1546933F364 for ; Mon, 26 Jan 2026 15:42:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.215.171 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769442141; cv=none; b=pmZovcH6HFrJCSCxeUGwXTwWri7C3SfIC29opC3h/nbJag4KLptzs9DhAIPqBZ8SBBER1BSsQOBO0PPih1i1MHisVBQGKr55y960t5ku2W5ql/jtkjln0+TB0tDN4iR3/CrxSQefbyvuVOY5EjgBQDA1rJt7VjQLQxQsi7PMyDY= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769442141; c=relaxed/simple; bh=tqewIhbRqq1adswiVbpduoDW8JX3z3VKvL2i1Kqr57I=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=ED5xnk2DcKMpfXWI+Kfa/WwBbfwZZ45O84QRrW9zTnbU1wRtr/FqgcDjLioEtl6b7PFBz/UOQ05wJcXSzX5Fez4G0Xkglt9WL+sw3U7iF+MVC4+6SR4+WXh5Dh/YrYINBkctCD125HnHMv2vu+XyJ3SYB/paZ2mPsq40XHS3Ggw= 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=bePWme8q; arc=none smtp.client-ip=209.85.215.171 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="bePWme8q" Received: by mail-pg1-f171.google.com with SMTP id 41be03b00d2f7-bd1ce1b35e7so3011057a12.0 for ; Mon, 26 Jan 2026 07:42:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1769442139; x=1770046939; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=EFHTE7+4vut1ZBbXi2BaQWFLCQQCwb8j1cvQskcZkjo=; b=bePWme8qPU39g65mrF5KWvwERR0PvniLQwnyJWyokZP3mWNwFl32zxMcwVwZKlrBUu Ft1QUwKr2Jk1goOBfpENojDRUjlvKaMq2YBPZEdvK2ztrytV8l/XLlxI9Yca/dr/o7XV 2bt1f9xijzV/HJvBp3AuivgNJd1AA3s2t7XY9KqpWaEwWfvMwYmTEtgD9/v7YuKAUNDT u1GarTfANyacMt1rLF2GO3wWYFdtgwbhqCKfzo1g0AOrilxhnuLP/aNr8NUWGOOzrRwJ +hwJeB0P2OmtAmvBsUUKq7zd6HrlVt1zwONAWf0RADCAZHD8kDGwRYITTrGBc2Ivd2yv 3xZA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1769442139; x=1770046939; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=EFHTE7+4vut1ZBbXi2BaQWFLCQQCwb8j1cvQskcZkjo=; b=u03TV+mqxA9wVR3MiB/q+VkPI8OTulg7kmw99CZPPaFcKycsbrAINye0J5w4fp/d45 ID6H7FPpMMkBTwP1KhLuf3ntOUQst03Vx03G4EwumCmd/c7ephPjHob3HyZBw9Lsfn/O NVp8HovTZzVUcyXeRWRUbO6cHO51teYkAeA9WF1u5xUBb1qq8u+h4pxbXsKI55XBWwJD 1V1juuVO2wMct5YFtPPv25wWNh7e/fRF74ki+U+6moElTwrE4I6x+hG5JjbSTcT+cJtV CAUdbUPQatSsx9l5T0ZvIG41fWg4ii+btIJzxRwubWPaScF+HCcgnva5U5/8DaDSvCRb YeSw== X-Gm-Message-State: AOJu0Yxmk8VqINQdebyAtGjHGIEy+rnBVujFsjt0kdNAq0HeJN/QRJCG Z1lNevAfbiOhF32UyQV3OU8UtoItTt5yZj1grhPuv+qAnbxe/3JkrQfk X-Gm-Gg: AZuq6aI68HJIRcXQvH8A+EkulxkKRHhvZC/qskNrj7YAA/dju5Cga+hwTWA1PcBb358 Njs8TN3TPZeOR0fjqgSaFJ8TqS0ll2rJx3IYMF9PSyqpEM1t6Vvd+ffq1TFyVEo2Pqv7Dp2rOo1 gROmEpuS75m++frkv4u4+4ACdlxQL3EtzHxpfPicmQGhp+5tSg/elzPpfKjc5Ob9+5LL26j0ALx IkJN9FyUO5vC6nGMt5y/8+VkIgCEpR87MJwoONGRtdfaRekj/PUfL6utrYdsLIObIGRp7cd3i83 DAKAzxA7w4cDuI4Ea5CZwH5Jq+OzuNKX27aDrK9nZrH1F1MacbNwagbRsZFTRorZYFr95CGzn// h9llLz+Vab0BI8oZHOvBWr2RxkXdVIoeqsORrteNl6ED7yA72HrIQmdrnXz1jfD/rOvKjinm8kN jPT7YaoXq13o5nu5OxG+a20MY6MGcxCGS3agKn/Lnekay45QnGQ9gC/Q== X-Received: by 2002:a17:90b:3a4d:b0:32e:38b0:15f4 with SMTP id 98e67ed59e1d1-353c40b88f3mr4065706a91.7.1769442139114; Mon, 26 Jan 2026 07:42:19 -0800 (PST) Received: from toolbx ([103.230.182.3]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-3536d88b098sm8649100a91.3.2026.01.26.07.42.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 26 Jan 2026 07:42:18 -0800 (PST) From: Dorjoy Chowdhury To: linux-fsdevel@vger.kernel.org Cc: linux-kernel@vger.kernel.org, viro@zeniv.linux.org.uk, brauner@kernel.org, jack@suse.cz, jlayton@kernel.org, chuck.lever@oracle.com, alex.aring@gmail.com, arnd@arndb.de Subject: [PATCH v2 2/2] kselftest/openat2: test for O_REGULAR flag Date: Mon, 26 Jan 2026 21:39:22 +0600 Message-ID: <20260126154156.55723-3-dorjoychy111@gmail.com> X-Mailer: git-send-email 2.52.0 In-Reply-To: <20260126154156.55723-1-dorjoychy111@gmail.com> References: <20260126154156.55723-1-dorjoychy111@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Just a happy path test. Signed-off-by: Dorjoy Chowdhury --- .../testing/selftests/openat2/openat2_test.c | 37 ++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/tools/testing/selftests/openat2/openat2_test.c b/tools/testing= /selftests/openat2/openat2_test.c index 0e161ef9e9e4..011ebc9af4e5 100644 --- a/tools/testing/selftests/openat2/openat2_test.c +++ b/tools/testing/selftests/openat2/openat2_test.c @@ -320,8 +320,42 @@ void test_openat2_flags(void) } } =20 +#ifndef O_REGULAR +#define O_REGULAR 040000000 +#endif + +#ifndef ENOTREG +#define ENOTREG 134 +#endif + +void test_openat2_o_regular_flag(void) +{ + if (!openat2_supported) { + ksft_test_result_skip("Skipping %s as openat2 is not supported\n", __fun= c__); + return; + } + + struct open_how how =3D { + .flags =3D O_REGULAR | O_RDONLY + }; + + int fd =3D sys_openat2(AT_FDCWD, "/dev/null", &how); + + if (fd =3D=3D ENOENT) { + ksft_test_result_skip("Skipping %s as there is no /dev/null\n", __func__= ); + return; + } + + if (fd !=3D -ENOTREG) { + ksft_test_result_fail("openat2 should return ENOTREG\n"); + return; + } + + ksft_test_result_pass("%s succeeded\n", __func__); +} + #define NUM_TESTS (NUM_OPENAT2_STRUCT_VARIATIONS * NUM_OPENAT2_STRUCT_TEST= S + \ - NUM_OPENAT2_FLAG_TESTS) + NUM_OPENAT2_FLAG_TESTS + 1) =20 int main(int argc, char **argv) { @@ -330,6 +364,7 @@ int main(int argc, char **argv) =20 test_openat2_struct(); test_openat2_flags(); + test_openat2_o_regular_flag(); =20 if (ksft_get_fail_cnt() + ksft_get_error_cnt() > 0) ksft_exit_fail(); --=20 2.52.0