From: Hariharan Mari <hari55@linux.ibm.com>
To: Christoph Schlameuss <schlameuss@linux.ibm.com>
Cc: kvm@vger.kernel.org,
Christian Borntraeger <borntraeger@linux.ibm.com>,
Janosch Frank <frankja@linux.ibm.com>,
Claudio Imbrenda <imbrenda@linux.ibm.com>,
David Hildenbrand <david@redhat.com>,
Paolo Bonzini <pbonzini@redhat.com>,
Shuah Khan <shuah@kernel.org>,
linux-s390@vger.kernel.org, linux-kselftest@vger.kernel.org,
Ulrich Weigand <ulrich.weigand@de.ibm.com>,
Dominik Dingel <dingel@linux.vnet.ibm.com>,
Cornelia Huck <cohuck@redhat.com>
Subject: Re: [PATCH v2 2/6] selftests: kvm: s390: Add ucontrol flic attr selftests
Date: Thu, 19 Dec 2024 16:52:37 +0100 [thread overview]
Message-ID: <0cc5df8fb51600c1c9d843ba36becf95@linux.ibm.com> (raw)
In-Reply-To: <20241216092140.329196-3-schlameuss@linux.ibm.com>
On 2024-12-16 10:21, Christoph Schlameuss wrote:
> Add some superficial selftests for the floating interrupt controller
> when using ucontrol VMs. These tests are intended to cover very basic
> calls only.
>
> Some of the calls may trigger null pointer dereferences on kernels not
> containing the fixes in this patch series.
>
> Signed-off-by: Christoph Schlameuss <schlameuss@linux.ibm.com>
Reviewed-by: Hariharan Mari <hari55@linux.ibm.com>
> ---
> .../selftests/kvm/s390x/ucontrol_test.c | 148 ++++++++++++++++++
> 1 file changed, 148 insertions(+)
>
> diff --git a/tools/testing/selftests/kvm/s390x/ucontrol_test.c
> b/tools/testing/selftests/kvm/s390x/ucontrol_test.c
> index 0c112319dab1..b003abda8495 100644
> --- a/tools/testing/selftests/kvm/s390x/ucontrol_test.c
> +++ b/tools/testing/selftests/kvm/s390x/ucontrol_test.c
> @@ -635,4 +635,152 @@ TEST_F(uc_kvm, uc_skey)
> uc_assert_diag44(self);
> }
>
> +static char uc_flic_b[PAGE_SIZE];
> +static struct kvm_s390_io_adapter uc_flic_ioa = { .id = 0 };
> +static struct kvm_s390_io_adapter_req uc_flic_ioam = { .id = 0 };
> +static struct kvm_s390_ais_req uc_flic_asim = { .isc = 0 };
> +static struct kvm_s390_ais_all uc_flic_asima = { .simm = 0 };
> +static struct uc_flic_attr_test {
> + char *name;
> + struct kvm_device_attr a;
> + int hasrc;
> + int geterrno;
> + int seterrno;
> +} uc_flic_attr_tests[] = {
> + {
> + .name = "KVM_DEV_FLIC_GET_ALL_IRQS",
> + .seterrno = EINVAL,
> + .a = {
> + .group = KVM_DEV_FLIC_GET_ALL_IRQS,
> + .addr = (u64)&uc_flic_b,
> + .attr = PAGE_SIZE,
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_ENQUEUE",
> + .geterrno = EINVAL,
> + .a = { .group = KVM_DEV_FLIC_ENQUEUE, },
> + },
> + {
> + .name = "KVM_DEV_FLIC_CLEAR_IRQS",
> + .geterrno = EINVAL,
> + .a = { .group = KVM_DEV_FLIC_CLEAR_IRQS, },
> + },
> + {
> + .name = "KVM_DEV_FLIC_ADAPTER_REGISTER",
> + .geterrno = EINVAL,
> + .a = {
> + .group = KVM_DEV_FLIC_ADAPTER_REGISTER,
> + .addr = (u64)&uc_flic_ioa,
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_ADAPTER_MODIFY",
> + .geterrno = EINVAL,
> + .seterrno = EINVAL,
> + .a = {
> + .group = KVM_DEV_FLIC_ADAPTER_MODIFY,
> + .addr = (u64)&uc_flic_ioam,
> + .attr = sizeof(uc_flic_ioam),
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_CLEAR_IO_IRQ",
> + .geterrno = EINVAL,
> + .seterrno = EINVAL,
> + .a = {
> + .group = KVM_DEV_FLIC_CLEAR_IO_IRQ,
> + .attr = 32,
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_AISM",
> + .geterrno = EINVAL,
> + .seterrno = ENOTSUP,
> + .a = {
> + .group = KVM_DEV_FLIC_AISM,
> + .addr = (u64)&uc_flic_asim,
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_AIRQ_INJECT",
> + .geterrno = EINVAL,
> + .a = { .group = KVM_DEV_FLIC_AIRQ_INJECT, },
> + },
> + {
> + .name = "KVM_DEV_FLIC_AISM_ALL",
> + .geterrno = ENOTSUP,
> + .seterrno = ENOTSUP,
> + .a = {
> + .group = KVM_DEV_FLIC_AISM_ALL,
> + .addr = (u64)&uc_flic_asima,
> + .attr = sizeof(uc_flic_asima),
> + },
> + },
> + {
> + .name = "KVM_DEV_FLIC_APF_ENABLE",
> + .geterrno = EINVAL,
> + .seterrno = EINVAL,
> + .a = { .group = KVM_DEV_FLIC_APF_ENABLE, },
> + },
> + {
> + .name = "KVM_DEV_FLIC_APF_DISABLE_WAIT",
> + .geterrno = EINVAL,
> + .seterrno = EINVAL,
> + .a = { .group = KVM_DEV_FLIC_APF_DISABLE_WAIT, },
> + },
> +};
> +
> +TEST_F(uc_kvm, uc_flic_attrs)
> +{
> + struct kvm_create_device cd = { .type = KVM_DEV_TYPE_FLIC };
> + struct kvm_device_attr attr;
> + u64 value;
> + int rc, i;
> +
> + rc = ioctl(self->vm_fd, KVM_CREATE_DEVICE, &cd);
> + ASSERT_EQ(0, rc) TH_LOG("create device failed with err %s (%i)",
> + strerror(errno), errno);
> +
> + for (i = 0; i < ARRAY_SIZE(uc_flic_attr_tests); i++) {
> + TH_LOG("test %s", uc_flic_attr_tests[i].name);
> + attr = (struct kvm_device_attr) {
> + .group = uc_flic_attr_tests[i].a.group,
> + .attr = uc_flic_attr_tests[i].a.attr,
> + .addr = uc_flic_attr_tests[i].a.addr,
> + };
> + if (attr.addr == 0)
> + attr.addr = (u64)&value;
> +
> + rc = ioctl(cd.fd, KVM_HAS_DEVICE_ATTR, &attr);
> + EXPECT_EQ(uc_flic_attr_tests[i].hasrc, !!rc)
> + TH_LOG("expected dev attr missing %s",
> + uc_flic_attr_tests[i].name);
> +
> + rc = ioctl(cd.fd, KVM_GET_DEVICE_ATTR, &attr);
> + EXPECT_EQ(!!uc_flic_attr_tests[i].geterrno, !!rc)
> + TH_LOG("get dev attr rc not expected on %s %s (%i)",
> + uc_flic_attr_tests[i].name,
> + strerror(errno), errno);
> + if (uc_flic_attr_tests[i].geterrno)
> + EXPECT_EQ(uc_flic_attr_tests[i].geterrno, errno)
> + TH_LOG("get dev attr errno not expected on %s %s (%i)",
> + uc_flic_attr_tests[i].name,
> + strerror(errno), errno);
> +
> + rc = ioctl(cd.fd, KVM_SET_DEVICE_ATTR, &attr);
> + EXPECT_EQ(!!uc_flic_attr_tests[i].seterrno, !!rc)
> + TH_LOG("set sev attr rc not expected on %s %s (%i)",
> + uc_flic_attr_tests[i].name,
> + strerror(errno), errno);
> + if (uc_flic_attr_tests[i].seterrno)
> + EXPECT_EQ(uc_flic_attr_tests[i].seterrno, errno)
> + TH_LOG("set dev attr errno not expected on %s %s (%i)",
> + uc_flic_attr_tests[i].name,
> + strerror(errno), errno);
> + }
> +
> + close(cd.fd);
> +}
> +
> TEST_HARNESS_MAIN
next prev parent reply other threads:[~2024-12-19 15:52 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-16 9:21 [PATCH v2 0/6] selftests: kvm: s390: Reject invalid ioctls on ucontrol VMs Christoph Schlameuss
2024-12-16 9:21 ` [PATCH v2 1/6] kvm: s390: Reject setting flic pfault attributes " Christoph Schlameuss
2024-12-19 10:03 ` Hariharan Mari
2024-12-16 9:21 ` [PATCH v2 2/6] selftests: kvm: s390: Add ucontrol flic attr selftests Christoph Schlameuss
2024-12-18 15:07 ` Hariharan Mari
2024-12-19 15:52 ` Hariharan Mari [this message]
2024-12-16 9:21 ` [PATCH v2 3/6] kvm: s390: Reject KVM_SET_GSI_ROUTING on ucontrol VMs Christoph Schlameuss
2024-12-18 15:08 ` Hariharan Mari
2024-12-19 15:53 ` Hariharan Mari
2024-12-16 9:21 ` [PATCH v2 4/6] selftests: kvm: s390: Add ucontrol gis routing test Christoph Schlameuss
2024-12-18 15:08 ` Hariharan Mari
2024-12-19 15:54 ` Hariharan Mari
2024-12-16 9:21 ` [PATCH v2 5/6] selftests: kvm: s390: Streamline uc_skey test to issue iske after sske Christoph Schlameuss
2024-12-18 15:09 ` Hariharan Mari
2024-12-16 9:21 ` [PATCH v2 6/6] selftests: kvm: s390: Add has device attr check to uc_attr_mem_limit selftest Christoph Schlameuss
2024-12-18 15:09 ` Hariharan Mari
2024-12-16 13:01 ` [PATCH v2 0/6] selftests: kvm: s390: Reject invalid ioctls on ucontrol VMs Claudio Imbrenda
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=0cc5df8fb51600c1c9d843ba36becf95@linux.ibm.com \
--to=hari55@linux.ibm.com \
--cc=borntraeger@linux.ibm.com \
--cc=cohuck@redhat.com \
--cc=david@redhat.com \
--cc=dingel@linux.vnet.ibm.com \
--cc=frankja@linux.ibm.com \
--cc=imbrenda@linux.ibm.com \
--cc=kvm@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-s390@vger.kernel.org \
--cc=pbonzini@redhat.com \
--cc=schlameuss@linux.ibm.com \
--cc=shuah@kernel.org \
--cc=ulrich.weigand@de.ibm.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.