From: "Günther Noack" <gnoack@google.com>
To: Mikhail Ivanov <ivanov.mikhail1@huawei-partners.com>
Cc: mic@digikod.net, willemdebruijn.kernel@gmail.com,
gnoack3000@gmail.com, linux-security-module@vger.kernel.org,
netdev@vger.kernel.org, netfilter-devel@vger.kernel.org,
yusongping@huawei.com, artem.kuzin@huawei.com,
konstantin.meskhidze@huawei.com
Subject: Re: [RFC PATCH v2 6/9] selftests/landlock: Test listening without explicit bind restriction
Date: Tue, 20 Aug 2024 15:02:32 +0200 [thread overview]
Message-ID: <ZsST6Nk3Bf8F5lmJ@google.com> (raw)
In-Reply-To: <20240814030151.2380280-7-ivanov.mikhail1@huawei-partners.com>
On Wed, Aug 14, 2024 at 11:01:48AM +0800, Mikhail Ivanov wrote:
> Test scenarios where listen(2) call without explicit bind(2) is allowed
> and forbidden.
>
> Signed-off-by: Mikhail Ivanov <ivanov.mikhail1@huawei-partners.com>
> ---
> tools/testing/selftests/landlock/net_test.c | 83 +++++++++++++++++++++
> 1 file changed, 83 insertions(+)
>
> diff --git a/tools/testing/selftests/landlock/net_test.c b/tools/testing/selftests/landlock/net_test.c
> index 551891b18b7a..92c042349596 100644
> --- a/tools/testing/selftests/landlock/net_test.c
> +++ b/tools/testing/selftests/landlock/net_test.c
> @@ -1851,6 +1851,89 @@ TEST_F(port_specific, bind_connect_zero)
> EXPECT_EQ(0, close(bind_fd));
> }
>
> +TEST_F(port_specific, listen_without_bind_allowed)
> +{
> + if (variant->sandbox == TCP_SANDBOX) {
> + const struct landlock_ruleset_attr ruleset_attr = {
> + .handled_access_net = LANDLOCK_ACCESS_NET_BIND_TCP |
> + LANDLOCK_ACCESS_NET_LISTEN_TCP
> + };
> + const struct landlock_net_port_attr tcp_listen_zero = {
> + .allowed_access = LANDLOCK_ACCESS_NET_LISTEN_TCP,
> + .port = 0,
> + };
> + int ruleset_fd;
> +
> + ruleset_fd = landlock_create_ruleset(&ruleset_attr,
> + sizeof(ruleset_attr), 0);
> + ASSERT_LE(0, ruleset_fd);
> +
> + /*
> + * Allow listening without explicit bind
> + * (cf. landlock_net_port_attr).
> + */
> + EXPECT_EQ(0,
> + landlock_add_rule(ruleset_fd, LANDLOCK_RULE_NET_PORT,
> + &tcp_listen_zero, 0));
> +
> + enforce_ruleset(_metadata, ruleset_fd);
> + EXPECT_EQ(0, close(ruleset_fd));
> + }
> + int listen_fd, connect_fd;
> + __u64 port;
> +
> + listen_fd = socket_variant(&self->srv0);
> + ASSERT_LE(0, listen_fd);
> +
> + connect_fd = socket_variant(&self->srv0);
> + ASSERT_LE(0, connect_fd);
> + /*
> + * Allow listen(2) to select a random port for the socket,
> + * since bind(2) wasn't called.
> + */
> + EXPECT_EQ(0, listen_variant(listen_fd, backlog));
> +
> + /* Connects on the binded port. */
> + port = get_binded_port(listen_fd, &variant->prot);
Please rename "binded" to "bound" when you come across it.
> + EXPECT_NE(0, port);
> + set_port(&self->srv0, port);
> + EXPECT_EQ(0, connect_variant(connect_fd, &self->srv0));
> +
> + EXPECT_EQ(0, close(connect_fd));
> + EXPECT_EQ(0, close(listen_fd));
> +}
> +
> +TEST_F(port_specific, listen_without_bind_denied)
> +{
> + if (variant->sandbox == TCP_SANDBOX) {
> + const struct landlock_ruleset_attr ruleset_attr = {
> + .handled_access_net = LANDLOCK_ACCESS_NET_LISTEN_TCP
> + };
> + int ruleset_fd;
> +
> + ruleset_fd = landlock_create_ruleset(&ruleset_attr,
> + sizeof(ruleset_attr), 0);
> + ASSERT_LE(0, ruleset_fd);
> +
> + /* Deny listening. */
> + enforce_ruleset(_metadata, ruleset_fd);
> + EXPECT_EQ(0, close(ruleset_fd));
> + }
> + int listen_fd, ret;
> +
> + listen_fd = socket_variant(&self->srv0);
> + ASSERT_LE(0, listen_fd);
> +
> + /* Checks that listening without explicit binding is prohibited. */
> + ret = listen_variant(listen_fd, backlog);
> + if (is_restricted(&variant->prot, variant->sandbox)) {
> + /* Denied by Landlock. */
> + EXPECT_EQ(-EACCES, ret);
> + } else {
> + EXPECT_EQ(0, ret);
> + }
> +}
> +
> TEST_F(port_specific, port_1023)
> {
> int bind_fd, connect_fd, ret;
> --
> 2.34.1
>
next prev parent reply other threads:[~2024-08-20 13:02 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-14 3:01 [RFC PATCH v2 0/9] Support TCP listen access-control Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 1/9] landlock: Refactor current_check_access_socket() access right check Mikhail Ivanov
2024-08-19 21:37 ` Günther Noack
2024-08-20 11:20 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 2/9] landlock: Support TCP listen access-control Mikhail Ivanov
2024-10-05 16:56 ` Günther Noack
2024-10-05 17:53 ` Mikhail Ivanov
2024-10-05 18:22 ` Günther Noack
2024-10-05 18:32 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 3/9] selftests/landlock: Support LANDLOCK_ACCESS_NET_LISTEN_TCP Mikhail Ivanov
2024-08-19 21:52 ` Günther Noack
2024-08-20 12:32 ` Mikhail Ivanov
2024-08-20 13:14 ` Günther Noack
2024-08-20 18:27 ` Mikhail Ivanov
2024-09-25 18:31 ` Mickaël Salaün
2024-09-26 11:59 ` Mikhail Ivanov
2024-08-19 21:53 ` Günther Noack
2024-08-20 12:35 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 4/9] selftests/landlock: Test listening restriction Mikhail Ivanov
2024-08-20 12:31 ` Günther Noack
2024-08-20 18:46 ` Mikhail Ivanov
2024-09-25 18:31 ` Mickaël Salaün
2024-09-26 13:51 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 5/9] selftests/landlock: Test listen on connected socket Mikhail Ivanov
2024-08-20 13:01 ` Günther Noack
2024-08-20 13:42 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 6/9] selftests/landlock: Test listening without explicit bind restriction Mikhail Ivanov
2024-08-20 13:02 ` Günther Noack [this message]
2024-08-20 13:46 ` Mikhail Ivanov
2024-08-21 11:52 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 7/9] selftests/landlock: Test listen on ULP socket without clone method Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 8/9] selftests/landlock: Test changing socket backlog with listen(2) Mikhail Ivanov
2024-10-05 16:57 ` Günther Noack
2024-10-05 17:29 ` Mikhail Ivanov
2024-08-14 3:01 ` [RFC PATCH v2 9/9] samples/landlock: Support LANDLOCK_ACCESS_NET_LISTEN Mikhail Ivanov
2024-10-05 16:57 ` Günther Noack
2024-10-05 17:30 ` Mikhail Ivanov
2024-08-20 13:11 ` [RFC PATCH v2 0/9] Support TCP listen access-control Günther Noack
2024-08-20 13:23 ` Günther Noack
2024-08-20 13:53 ` Mikhail Ivanov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ZsST6Nk3Bf8F5lmJ@google.com \
--to=gnoack@google.com \
--cc=artem.kuzin@huawei.com \
--cc=gnoack3000@gmail.com \
--cc=ivanov.mikhail1@huawei-partners.com \
--cc=konstantin.meskhidze@huawei.com \
--cc=linux-security-module@vger.kernel.org \
--cc=mic@digikod.net \
--cc=netdev@vger.kernel.org \
--cc=netfilter-devel@vger.kernel.org \
--cc=willemdebruijn.kernel@gmail.com \
--cc=yusongping@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.