* [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export @ 2021-05-24 20:52 Jason Ekstrand 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) Jason Ekstrand ` (3 more replies) 0 siblings, 4 replies; 7+ messages in thread From: Jason Ekstrand @ 2021-05-24 20:52 UTC (permalink / raw) To: igt-dev This series adds tests for sync_file import/export as per this kernel series on dri-devel: https://patchwork.freedesktop.org/series/90380/ https://lists.freedesktop.org/archives/dri-devel/2021-May/307561.html The import stuff is labled RFC because that bit of the kernel patches aren't quite baked yet. Jason Ekstrand (2): tests/dmabuf: Add tests for sync_file export (v3) RFC: tests/dmabuf: Add tests for sync_file import (v3) tests/dmabuf_sync_file.c | 457 +++++++++++++++++++++++++++++++++++++++ tests/meson.build | 1 + 2 files changed, 458 insertions(+) create mode 100644 tests/dmabuf_sync_file.c -- 2.31.1 _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 7+ messages in thread
* [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) 2021-05-24 20:52 [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export Jason Ekstrand @ 2021-05-24 20:52 ` Jason Ekstrand 2021-06-03 12:37 ` Daniel Vetter 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) Jason Ekstrand ` (2 subsequent siblings) 3 siblings, 1 reply; 7+ messages in thread From: Jason Ekstrand @ 2021-05-24 20:52 UTC (permalink / raw) To: igt-dev v2 (Jason Ekstrand): - Rename subtests to have "export" in the name v3 (Jason Ekstrand): - Add an export-before-signal subtest Signed-off-by: Jason Ekstrand <jason@jlekstrand.net> --- tests/dmabuf_sync_file.c | 294 +++++++++++++++++++++++++++++++++++++++ tests/meson.build | 1 + 2 files changed, 295 insertions(+) create mode 100644 tests/dmabuf_sync_file.c diff --git a/tests/dmabuf_sync_file.c b/tests/dmabuf_sync_file.c new file mode 100644 index 00000000..afac5535 --- /dev/null +++ b/tests/dmabuf_sync_file.c @@ -0,0 +1,294 @@ +/* + * Copyright © 2021 Intel Corporation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + */ + +#include "igt.h" +#include "igt_vgem.h" + +#include <linux/dma-buf.h> +#include <sys/poll.h> + +IGT_TEST_DESCRIPTION("Tests for sync_file export from dma-buf"); + +struct igt_dma_buf_sync_file { + __u32 flags; + __s32 fd; +}; + +#define IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE _IOWR(DMA_BUF_BASE, 2, struct igt_dma_buf_sync_file) + +static bool has_dmabuf_export_sync_file(int fd) +{ + struct vgem_bo bo; + int dmabuf, ret; + struct igt_dma_buf_sync_file arg; + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + gem_close(fd, bo.handle); + + arg.flags = DMA_BUF_SYNC_WRITE; + arg.fd = -1; + + ret = igt_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE, &arg); + close(dmabuf); + igt_assert(ret == 0 || errno == ENOTTY); + + return ret == 0; +} + +static int dmabuf_export_sync_file(int dmabuf, uint32_t flags) +{ + struct igt_dma_buf_sync_file arg; + + arg.flags = flags; + arg.fd = -1; + do_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE, &arg); + + return arg.fd; +} + +static bool sync_file_busy(int sync_file) +{ + struct pollfd pfd = { .fd = sync_file, .events = POLLIN }; + return poll(&pfd, 1, 0) == 0; +} + +static bool dmabuf_sync_file_busy(int dmabuf, uint32_t flags) +{ + int sync_file; + bool busy; + + sync_file = dmabuf_export_sync_file(dmabuf, flags); + busy = sync_file_busy(sync_file); + close(sync_file); + + return busy; +} + +static void test_export_basic(int fd) +{ + struct vgem_bo bo; + int dmabuf; + uint32_t fence; + + igt_require(has_dmabuf_export_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + fence = vgem_fence_attach(fd, &bo, 0); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + vgem_fence_signal(fd, fence); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + vgem_fence_signal(fd, fence); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + close(dmabuf); + gem_close(fd, bo.handle); +} + +static void test_export_before_signal(int fd) +{ + struct vgem_bo bo; + int dmabuf, read_fd, write_fd; + uint32_t fence; + + igt_require(has_dmabuf_export_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + fence = vgem_fence_attach(fd, &bo, 0); + + read_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); + write_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); + + igt_assert(!sync_file_busy(read_fd)); + igt_assert(sync_file_busy(write_fd)); + + vgem_fence_signal(fd, fence); + + igt_assert(!sync_file_busy(read_fd)); + igt_assert(!sync_file_busy(write_fd)); + + close(read_fd); + close(write_fd); + + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); + + read_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); + write_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); + + igt_assert(sync_file_busy(read_fd)); + igt_assert(sync_file_busy(write_fd)); + + vgem_fence_signal(fd, fence); + + igt_assert(!sync_file_busy(read_fd)); + igt_assert(!sync_file_busy(write_fd)); + + close(read_fd); + close(write_fd); + + close(dmabuf); + gem_close(fd, bo.handle); +} + +static void test_export_multiwait(int fd) +{ + struct vgem_bo bo; + int dmabuf, sync_file; + uint32_t fence1, fence2, fence3; + + igt_require(has_dmabuf_export_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + fence1 = vgem_fence_attach(fd, &bo, 0); + fence2 = vgem_fence_attach(fd, &bo, 0); + + sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); + + fence3 = vgem_fence_attach(fd, &bo, 0); + + igt_assert(sync_file_busy(sync_file)); + + vgem_fence_signal(fd, fence1); + + igt_assert(sync_file_busy(sync_file)); + + vgem_fence_signal(fd, fence2); + + igt_assert(!sync_file_busy(sync_file)); + + vgem_fence_signal(fd, fence3); + + close(sync_file); + close(dmabuf); + gem_close(fd, bo.handle); +} + +static void test_export_wait_after_attach(int fd) +{ + struct vgem_bo bo; + int dmabuf, read_sync_file, write_sync_file; + uint32_t fence1, fence2; + + igt_require(has_dmabuf_export_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + read_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); + write_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); + + fence1 = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); + + igt_assert(!sync_file_busy(read_sync_file)); + igt_assert(!sync_file_busy(write_sync_file)); + close(read_sync_file); + close(write_sync_file); + + /* These wait on fence1 */ + read_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); + write_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); + + igt_assert(sync_file_busy(read_sync_file)); + igt_assert(sync_file_busy(write_sync_file)); + + vgem_fence_signal(fd, fence1); + fence2 = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); + + /* fence1 has signaled */ + igt_assert(!sync_file_busy(read_sync_file)); + igt_assert(!sync_file_busy(write_sync_file)); + + /* fence2 has not */ + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + vgem_fence_signal(fd, fence2); + close(read_sync_file); + close(write_sync_file); + + close(dmabuf); + gem_close(fd, bo.handle); +} + +igt_main +{ + int fd; + + igt_fixture { + fd = drm_open_driver(DRIVER_VGEM); + } + + igt_subtest_f("export-basic") + test_export_basic(fd); + + igt_subtest_f("export-before-signal") + test_export_before_signal(fd); + + igt_subtest_f("export-multiwait") + test_export_multiwait(fd); + + igt_subtest_f("export-wait-after-attach") + test_export_wait_after_attach(fd); + +} diff --git a/tests/meson.build b/tests/meson.build index 19cc4ebe..a0992989 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -7,6 +7,7 @@ test_progs = [ 'core_setmaster_vs_auth', 'debugfs_test', 'dmabuf', + 'dmabuf_sync_file', 'device_reset', 'drm_import_export', 'drm_mm', -- 2.31.1 _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) Jason Ekstrand @ 2021-06-03 12:37 ` Daniel Vetter 0 siblings, 0 replies; 7+ messages in thread From: Daniel Vetter @ 2021-06-03 12:37 UTC (permalink / raw) To: Jason Ekstrand; +Cc: igt-dev On Mon, May 24, 2021 at 03:52:24PM -0500, Jason Ekstrand wrote: > v2 (Jason Ekstrand): > - Rename subtests to have "export" in the name > > v3 (Jason Ekstrand): > - Add an export-before-signal subtest > > Signed-off-by: Jason Ekstrand <jason@jlekstrand.net> > --- > tests/dmabuf_sync_file.c | 294 +++++++++++++++++++++++++++++++++++++++ > tests/meson.build | 1 + > 2 files changed, 295 insertions(+) > create mode 100644 tests/dmabuf_sync_file.c > > diff --git a/tests/dmabuf_sync_file.c b/tests/dmabuf_sync_file.c > new file mode 100644 > index 00000000..afac5535 > --- /dev/null > +++ b/tests/dmabuf_sync_file.c > @@ -0,0 +1,294 @@ > +/* > + * Copyright © 2021 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + */ > + > +#include "igt.h" > +#include "igt_vgem.h" > + > +#include <linux/dma-buf.h> > +#include <sys/poll.h> > + > +IGT_TEST_DESCRIPTION("Tests for sync_file export from dma-buf"); > + > +struct igt_dma_buf_sync_file { > + __u32 flags; > + __s32 fd; > +}; > + > +#define IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE _IOWR(DMA_BUF_BASE, 2, struct igt_dma_buf_sync_file) > + > +static bool has_dmabuf_export_sync_file(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, ret; > + struct igt_dma_buf_sync_file arg; > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + gem_close(fd, bo.handle); > + > + arg.flags = DMA_BUF_SYNC_WRITE; > + arg.fd = -1; > + > + ret = igt_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE, &arg); > + close(dmabuf); > + igt_assert(ret == 0 || errno == ENOTTY); > + > + return ret == 0; > +} > + > +static int dmabuf_export_sync_file(int dmabuf, uint32_t flags) > +{ > + struct igt_dma_buf_sync_file arg; > + > + arg.flags = flags; > + arg.fd = -1; > + do_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE, &arg); > + > + return arg.fd; > +} > + > +static bool sync_file_busy(int sync_file) > +{ > + struct pollfd pfd = { .fd = sync_file, .events = POLLIN }; > + return poll(&pfd, 1, 0) == 0; > +} > + > +static bool dmabuf_sync_file_busy(int dmabuf, uint32_t flags) > +{ > + int sync_file; > + bool busy; > + > + sync_file = dmabuf_export_sync_file(dmabuf, flags); > + busy = sync_file_busy(sync_file); > + close(sync_file); I think for paranoia it would be good if this also cross-checks with poll status. Just to make absolutely sure we're consistent across all flavours of implicit sync. > + > + return busy; > +} > + > +static void test_export_basic(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf; > + uint32_t fence; > + > + igt_require(has_dmabuf_export_sync_file(fd)); Move this into the top-level fixture instead of in each test. > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); Comment here that for read fence we expect only read to be busy, but for write fence both. > + > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + fence = vgem_fence_attach(fd, &bo, 0); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + vgem_fence_signal(fd, fence); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); > + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + vgem_fence_signal(fd, fence); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > +static void test_export_before_signal(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, read_fd, write_fd; > + uint32_t fence; > + > + igt_require(has_dmabuf_export_sync_file(fd)); > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); For longer tests I like to sprinkle comments around about what's going on, since it tends to be hard to read among all the asserts. E.g. below > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + /* first test read case, write slot should never get busy */ > + fence = vgem_fence_attach(fd, &bo, 0); > + > + read_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); > + write_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); > + > + igt_assert(!sync_file_busy(read_fd)); > + igt_assert(sync_file_busy(write_fd)); > + > + vgem_fence_signal(fd, fence); > + > + igt_assert(!sync_file_busy(read_fd)); > + igt_assert(!sync_file_busy(write_fd)); > + > + close(read_fd); > + close(write_fd); > + /* test write slot, both read and write fences should become busy */ > + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); > + > + read_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); > + write_fd = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); > + > + igt_assert(sync_file_busy(read_fd)); > + igt_assert(sync_file_busy(write_fd)); > + > + vgem_fence_signal(fd, fence); > + > + igt_assert(!sync_file_busy(read_fd)); > + igt_assert(!sync_file_busy(write_fd)); > + > + close(read_fd); > + close(write_fd); > + > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > +static void test_export_multiwait(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, sync_file; > + uint32_t fence1, fence2, fence3; > + > + igt_require(has_dmabuf_export_sync_file(fd)); > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + /* attach two read fences */ > + fence1 = vgem_fence_attach(fd, &bo, 0); > + fence2 = vgem_fence_attach(fd, &bo, 0); > + > + sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); > + > + fence3 = vgem_fence_attach(fd, &bo, 0); > + > + igt_assert(sync_file_busy(sync_file)); > + > + vgem_fence_signal(fd, fence1); > + > + igt_assert(sync_file_busy(sync_file)); > + > + vgem_fence_signal(fd, fence2); > + > + igt_assert(!sync_file_busy(sync_file)); > + > + vgem_fence_signal(fd, fence3); I think you're missing an important case here: - attach write and then read fences - complete write fence, read slot should be still busy - complete read fence, both retired Ofc assuming vgem does this all correctly, I'm not sure :-) Also maybe the other way round of retiring the 2nd read fence before the write fence > + > + close(sync_file); > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > +static void test_export_wait_after_attach(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, read_sync_file, write_sync_file; > + uint32_t fence1, fence2; > + > + igt_require(has_dmabuf_export_sync_file(fd)); > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + > + read_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); > + write_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); > + > + fence1 = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); > + > + igt_assert(!sync_file_busy(read_sync_file)); > + igt_assert(!sync_file_busy(write_sync_file)); > + close(read_sync_file); > + close(write_sync_file); > + > + /* These wait on fence1 */ > + read_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_READ); > + write_sync_file = dmabuf_export_sync_file(dmabuf, DMA_BUF_SYNC_WRITE); > + > + igt_assert(sync_file_busy(read_sync_file)); > + igt_assert(sync_file_busy(write_sync_file)); > + > + vgem_fence_signal(fd, fence1); > + fence2 = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); > + > + /* fence1 has signaled */ > + igt_assert(!sync_file_busy(read_sync_file)); > + igt_assert(!sync_file_busy(write_sync_file)); > + > + /* fence2 has not */ > + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_sync_file_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + vgem_fence_signal(fd, fence2); I think that test duped with the read slot would be good for completeness. > + close(read_sync_file); > + close(write_sync_file); > + > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > +igt_main > +{ > + int fd; > + > + igt_fixture { > + fd = drm_open_driver(DRIVER_VGEM); > + } > + > + igt_subtest_f("export-basic") igt test descriptions missing. See IGT_TEST_DESCRIPTION for the top level and igt_describe for subtests. > + test_export_basic(fd); > + > + igt_subtest_f("export-before-signal") > + test_export_before_signal(fd); > + > + igt_subtest_f("export-multiwait") > + test_export_multiwait(fd); > + > + igt_subtest_f("export-wait-after-attach") > + test_export_wait_after_attach(fd); invalid ioctl parameters test missing. It's a bit annoying when you extend an ioctl, but then it's also very annoying when the checks are not there and you try to extend something. With the comments addressed: Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> > + > +} > diff --git a/tests/meson.build b/tests/meson.build > index 19cc4ebe..a0992989 100644 > --- a/tests/meson.build > +++ b/tests/meson.build > @@ -7,6 +7,7 @@ test_progs = [ > 'core_setmaster_vs_auth', > 'debugfs_test', > 'dmabuf', > + 'dmabuf_sync_file', > 'device_reset', > 'drm_import_export', > 'drm_mm', > -- > 2.31.1 > > _______________________________________________ > igt-dev mailing list > igt-dev@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/igt-dev -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 7+ messages in thread
* [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) 2021-05-24 20:52 [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export Jason Ekstrand 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) Jason Ekstrand @ 2021-05-24 20:52 ` Jason Ekstrand 2021-06-03 12:48 ` Daniel Vetter 2021-05-24 22:25 ` [igt-dev] ✓ Fi.CI.BAT: success for tests/dmabuf: Add tests for sync_file import/export Patchwork 2021-05-25 4:31 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork 3 siblings, 1 reply; 7+ messages in thread From: Jason Ekstrand @ 2021-05-24 20:52 UTC (permalink / raw) To: igt-dev v2 (Jason Ekstrand): - Put the skip for igt_rwquire_sw_sync() in the subtests v3 (Jason Ekstrand): - Use a separate igt_require(has_dmabuf_import_sync_file()) - Tag as RFC because the kernel patches are RFC Signed-off-by: Jason Ekstrand <jason@jlekstrand.net> --- tests/dmabuf_sync_file.c | 163 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 163 insertions(+) diff --git a/tests/dmabuf_sync_file.c b/tests/dmabuf_sync_file.c index afac5535..fe476885 100644 --- a/tests/dmabuf_sync_file.c +++ b/tests/dmabuf_sync_file.c @@ -23,6 +23,7 @@ #include "igt.h" #include "igt_vgem.h" +#include "sw_sync.h" #include <linux/dma-buf.h> #include <sys/poll.h> @@ -35,6 +36,7 @@ struct igt_dma_buf_sync_file { }; #define IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE _IOWR(DMA_BUF_BASE, 2, struct igt_dma_buf_sync_file) +#define IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE _IOW(DMA_BUF_BASE, 3, struct igt_dma_buf_sync_file) static bool has_dmabuf_export_sync_file(int fd) { @@ -71,6 +73,66 @@ static int dmabuf_export_sync_file(int dmabuf, uint32_t flags) return arg.fd; } +static bool has_dmabuf_import_sync_file(int fd) +{ + struct vgem_bo bo; + int dmabuf, timeline, fence, ret; + struct igt_dma_buf_sync_file arg; + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + gem_close(fd, bo.handle); + + timeline = sw_sync_timeline_create(); + fence = sw_sync_timeline_create_fence(timeline, 1); + sw_sync_timeline_inc(timeline, 1); + + arg.flags = DMA_BUF_SYNC_RW; + arg.fd = fence; + + ret = igt_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE, &arg); + close(dmabuf); + close(fence); + igt_assert(ret == 0 || errno == ENOTTY); + + return ret == 0; +} + +static void dmabuf_import_sync_file(int dmabuf, int sync_fd) +{ + struct igt_dma_buf_sync_file arg; + + arg.flags = DMA_BUF_SYNC_RW; + arg.fd = sync_fd; + do_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE, &arg); +} + +static void +dmabuf_import_timeline_fence(int dmabuf, int timeline, uint32_t seqno) +{ + int fence; + + fence = sw_sync_timeline_create_fence(timeline, seqno); + dmabuf_import_sync_file(dmabuf, fence); + close(fence); +} + +static bool dmabuf_busy(int dmabuf, uint32_t flags) +{ + struct pollfd pfd = { .fd = dmabuf }; + + if (flags & DMA_BUF_SYNC_READ) + pfd.events |= POLLIN; + if (flags & DMA_BUF_SYNC_WRITE) + pfd.events |= POLLOUT; + + return poll(&pfd, 1, 0) == 0; +} + static bool sync_file_busy(int sync_file) { struct pollfd pfd = { .fd = sync_file, .events = POLLIN }; @@ -271,6 +333,93 @@ static void test_export_wait_after_attach(int fd) gem_close(fd, bo.handle); } +static void test_import_existing_shared(int fd, int shared_count) +{ + struct vgem_bo bo; + int i, dmabuf, timeline; + uint32_t fences[32]; + + igt_require_sw_sync(); + igt_require(has_dmabuf_import_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + igt_assert(shared_count <= ARRAY_SIZE(fences)); + for (i = 0; i < shared_count; i++) + fences[i] = vgem_fence_attach(fd, &bo, 0); + + timeline = sw_sync_timeline_create(); + dmabuf_import_timeline_fence(dmabuf, timeline, 1); + + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + sw_sync_timeline_inc(timeline, 1); + + for (i = shared_count - 1; i >= 0; i--) { + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + vgem_fence_signal(fd, fences[i]); + } + + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + close(dmabuf); + gem_close(fd, bo.handle); +} + +static void test_import_existing_exclusive(int fd) +{ + struct vgem_bo bo; + int dmabuf, timeline; + uint32_t fence; + + igt_require_sw_sync(); + igt_require(has_dmabuf_import_sync_file(fd)); + + bo.width = 1; + bo.height = 1; + bo.bpp = 32; + vgem_create(fd, &bo); + + dmabuf = prime_handle_to_fd(fd, bo.handle); + + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); + + timeline = sw_sync_timeline_create(); + dmabuf_import_timeline_fence(dmabuf, timeline, 1); + + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + sw_sync_timeline_inc(timeline, 1); + + /* Still busy because we should have absorbed all the old fences */ + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + vgem_fence_signal(fd, fence); + + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); + + close(dmabuf); + gem_close(fd, bo.handle); +} + igt_main { int fd; @@ -291,4 +440,18 @@ igt_main igt_subtest_f("export-wait-after-attach") test_export_wait_after_attach(fd); + igt_subtest_f("import-basic") + test_import_existing_shared(fd, 0); + + igt_subtest_f("import-existing-shared-1") + test_import_existing_shared(fd, 1); + + igt_subtest_f("import-existing-shared-5") + test_import_existing_shared(fd, 5); + + igt_subtest_f("import-existing-shared-32") + test_import_existing_shared(fd, 32); + + igt_subtest_f("import-existing-exclusive") + test_import_existing_exclusive(fd); } -- 2.31.1 _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) Jason Ekstrand @ 2021-06-03 12:48 ` Daniel Vetter 0 siblings, 0 replies; 7+ messages in thread From: Daniel Vetter @ 2021-06-03 12:48 UTC (permalink / raw) To: Jason Ekstrand; +Cc: igt-dev On Mon, May 24, 2021 at 03:52:25PM -0500, Jason Ekstrand wrote: > v2 (Jason Ekstrand): > - Put the skip for igt_rwquire_sw_sync() in the subtests > > v3 (Jason Ekstrand): > - Use a separate igt_require(has_dmabuf_import_sync_file()) > - Tag as RFC because the kernel patches are RFC > > Signed-off-by: Jason Ekstrand <jason@jlekstrand.net> > --- > tests/dmabuf_sync_file.c | 163 +++++++++++++++++++++++++++++++++++++++ > 1 file changed, 163 insertions(+) > > diff --git a/tests/dmabuf_sync_file.c b/tests/dmabuf_sync_file.c > index afac5535..fe476885 100644 > --- a/tests/dmabuf_sync_file.c > +++ b/tests/dmabuf_sync_file.c > @@ -23,6 +23,7 @@ > > #include "igt.h" > #include "igt_vgem.h" > +#include "sw_sync.h" > > #include <linux/dma-buf.h> > #include <sys/poll.h> > @@ -35,6 +36,7 @@ struct igt_dma_buf_sync_file { > }; > > #define IGT_DMA_BUF_IOCTL_EXPORT_SYNC_FILE _IOWR(DMA_BUF_BASE, 2, struct igt_dma_buf_sync_file) > +#define IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE _IOW(DMA_BUF_BASE, 3, struct igt_dma_buf_sync_file) > > static bool has_dmabuf_export_sync_file(int fd) > { > @@ -71,6 +73,66 @@ static int dmabuf_export_sync_file(int dmabuf, uint32_t flags) > return arg.fd; > } > > +static bool has_dmabuf_import_sync_file(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, timeline, fence, ret; > + struct igt_dma_buf_sync_file arg; > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + gem_close(fd, bo.handle); > + > + timeline = sw_sync_timeline_create(); > + fence = sw_sync_timeline_create_fence(timeline, 1); > + sw_sync_timeline_inc(timeline, 1); > + > + arg.flags = DMA_BUF_SYNC_RW; > + arg.fd = fence; > + > + ret = igt_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE, &arg); > + close(dmabuf); > + close(fence); > + igt_assert(ret == 0 || errno == ENOTTY); > + > + return ret == 0; > +} > + > +static void dmabuf_import_sync_file(int dmabuf, int sync_fd) > +{ > + struct igt_dma_buf_sync_file arg; > + > + arg.flags = DMA_BUF_SYNC_RW; > + arg.fd = sync_fd; > + do_ioctl(dmabuf, IGT_DMA_BUF_IOCTL_IMPORT_SYNC_FILE, &arg); > +} > + > +static void > +dmabuf_import_timeline_fence(int dmabuf, int timeline, uint32_t seqno) > +{ > + int fence; > + > + fence = sw_sync_timeline_create_fence(timeline, seqno); > + dmabuf_import_sync_file(dmabuf, fence); > + close(fence); > +} > + > +static bool dmabuf_busy(int dmabuf, uint32_t flags) > +{ > + struct pollfd pfd = { .fd = dmabuf }; > + > + if (flags & DMA_BUF_SYNC_READ) > + pfd.events |= POLLIN; > + if (flags & DMA_BUF_SYNC_WRITE) > + pfd.events |= POLLOUT; > + > + return poll(&pfd, 1, 0) == 0; Ah here's the nice helper you can use in the previous patch to triple-check stuff :-) > +} > + > static bool sync_file_busy(int sync_file) > { > struct pollfd pfd = { .fd = sync_file, .events = POLLIN }; > @@ -271,6 +333,93 @@ static void test_export_wait_after_attach(int fd) > gem_close(fd, bo.handle); > } > > +static void test_import_existing_shared(int fd, int shared_count) > +{ > + struct vgem_bo bo; > + int i, dmabuf, timeline; > + uint32_t fences[32]; > + > + igt_require_sw_sync(); > + igt_require(has_dmabuf_import_sync_file(fd)); > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + Ok now I get somewhat what's going on here, some header scratching. Please add a comment here and in the next test func that we use vgem fences to pre-populate the implicit slots to our gusto, and then import an independent timeline sw_sync so we can validate the import ioctl. I had no idea at first what you're doing here. > + igt_assert(shared_count <= ARRAY_SIZE(fences)); > + for (i = 0; i < shared_count; i++) > + fences[i] = vgem_fence_attach(fd, &bo, 0); Maybe some asserts here that read is busy now, but write not yet. > + > + timeline = sw_sync_timeline_create(); > + dmabuf_import_timeline_fence(dmabuf, timeline, 1); > + > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + Comment here that importing merges into shared/reads slots too, and hence will keep both read and write busy until we've signalled all the read depedendencies too. > + sw_sync_timeline_inc(timeline, 1); > + > + for (i = shared_count - 1; i >= 0; i--) { > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + vgem_fence_signal(fd, fences[i]); > + } > + > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); I think we need another testcase where we signal the imported fence after all the previously attached ones. Just for completeness of testing (it should be entirely symmetric, but better to check). > + > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > +static void test_import_existing_exclusive(int fd) > +{ > + struct vgem_bo bo; > + int dmabuf, timeline; > + uint32_t fence; > + > + igt_require_sw_sync(); > + igt_require(has_dmabuf_import_sync_file(fd)); > + > + bo.width = 1; > + bo.height = 1; > + bo.bpp = 32; > + vgem_create(fd, &bo); > + > + dmabuf = prime_handle_to_fd(fd, bo.handle); > + > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + Again please comment about the roles of vgem fences and sw_sync fences for dummies like me. > + fence = vgem_fence_attach(fd, &bo, VGEM_FENCE_WRITE); > + > + timeline = sw_sync_timeline_create(); > + dmabuf_import_timeline_fence(dmabuf, timeline, 1); > + > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + sw_sync_timeline_inc(timeline, 1); > + > + /* Still busy because we should have absorbed all the old fences */ Same comment is needed in the previous test too. > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); > + > + vgem_fence_signal(fd, fence); > + > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_READ)); > + igt_assert(!dmabuf_busy(dmabuf, DMA_BUF_SYNC_WRITE)); Again I think the other testcase where we signal the vgem fences before the sw_sync imported one would be good to have for symmetry. > + > + close(dmabuf); > + gem_close(fd, bo.handle); > +} > + > igt_main > { > int fd; > @@ -291,4 +440,18 @@ igt_main > igt_subtest_f("export-wait-after-attach") > test_export_wait_after_attach(fd); Same thing about test descriptions. Also invalid flags test missing. > > + igt_subtest_f("import-basic") > + test_import_existing_shared(fd, 0); > + > + igt_subtest_f("import-existing-shared-1") > + test_import_existing_shared(fd, 1); > + > + igt_subtest_f("import-existing-shared-5") > + test_import_existing_shared(fd, 5); > + > + igt_subtest_f("import-existing-shared-32") > + test_import_existing_shared(fd, 32); > + > + igt_subtest_f("import-existing-exclusive") > + test_import_existing_exclusive(fd); With the comments addressed: Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> > } > -- > 2.31.1 > > _______________________________________________ > igt-dev mailing list > igt-dev@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/igt-dev -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 7+ messages in thread
* [igt-dev] ✓ Fi.CI.BAT: success for tests/dmabuf: Add tests for sync_file import/export 2021-05-24 20:52 [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export Jason Ekstrand 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) Jason Ekstrand 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) Jason Ekstrand @ 2021-05-24 22:25 ` Patchwork 2021-05-25 4:31 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork 3 siblings, 0 replies; 7+ messages in thread From: Patchwork @ 2021-05-24 22:25 UTC (permalink / raw) To: Jason Ekstrand; +Cc: igt-dev [-- Attachment #1.1: Type: text/plain, Size: 6612 bytes --] == Series Details == Series: tests/dmabuf: Add tests for sync_file import/export URL : https://patchwork.freedesktop.org/series/90490/ State : success == Summary == CI Bug Log - changes from CI_DRM_10128 -> IGTPW_5846 ==================================================== Summary ------- **SUCCESS** No regressions found. External URL: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/index.html Known issues ------------ Here are the changes found in IGTPW_5846 that come from known issues: ### IGT changes ### #### Issues hit #### * igt@amdgpu/amd_cs_nop@sync-fork-compute0: - fi-snb-2600: NOTRUN -> [SKIP][1] ([fdo#109271]) +17 similar issues [1]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-snb-2600/igt@amdgpu/amd_cs_nop@sync-fork-compute0.html #### Possible fixes #### * igt@i915_selftest@live@hangcheck: - fi-snb-2600: [INCOMPLETE][2] ([i915#2782]) -> [PASS][3] [2]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-snb-2600/igt@i915_selftest@live@hangcheck.html [3]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-snb-2600/igt@i915_selftest@live@hangcheck.html #### Warnings #### * igt@i915_selftest@live@execlists: - fi-icl-u2: [DMESG-FAIL][4] ([i915#3462]) -> [INCOMPLETE][5] ([i915#2782] / [i915#3462]) [4]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-icl-u2/igt@i915_selftest@live@execlists.html [5]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-icl-u2/igt@i915_selftest@live@execlists.html * igt@runner@aborted: - fi-cfl-8700k: [FAIL][6] ([i915#3363]) -> [FAIL][7] ([i915#2292] / [i915#2426] / [i915#3363] / [k.org#204565]) [6]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-cfl-8700k/igt@runner@aborted.html [7]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-cfl-8700k/igt@runner@aborted.html - fi-skl-6600u: [FAIL][8] ([i915#1436] / [i915#2426] / [i915#3363]) -> [FAIL][9] ([i915#1436] / [i915#3363]) [8]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-skl-6600u/igt@runner@aborted.html [9]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-skl-6600u/igt@runner@aborted.html - fi-icl-u2: [FAIL][10] ([i915#2426] / [i915#2782] / [i915#3363]) -> [FAIL][11] ([i915#2782] / [i915#3363]) [10]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-icl-u2/igt@runner@aborted.html [11]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-icl-u2/igt@runner@aborted.html - fi-glk-dsi: [FAIL][12] ([i915#2426] / [i915#3363] / [k.org#202321]) -> [FAIL][13] ([i915#3363] / [k.org#202321]) [12]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-glk-dsi/igt@runner@aborted.html [13]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-glk-dsi/igt@runner@aborted.html - fi-kbl-r: [FAIL][14] ([i915#1436] / [i915#2426] / [i915#3363]) -> [FAIL][15] ([i915#1436] / [i915#3363]) [14]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-kbl-r/igt@runner@aborted.html [15]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-kbl-r/igt@runner@aborted.html - fi-kbl-7567u: [FAIL][16] ([i915#1436] / [i915#2426] / [i915#3363]) -> [FAIL][17] ([i915#1436] / [i915#3363]) [16]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/fi-kbl-7567u/igt@runner@aborted.html [17]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/fi-kbl-7567u/igt@runner@aborted.html {name}: This element is suppressed. This means it is ignored when computing the status of the difference (SUCCESS, WARNING, or FAILURE). [fdo#109271]: https://bugs.freedesktop.org/show_bug.cgi?id=109271 [fdo#109285]: https://bugs.freedesktop.org/show_bug.cgi?id=109285 [fdo#109315]: https://bugs.freedesktop.org/show_bug.cgi?id=109315 [fdo#111827]: https://bugs.freedesktop.org/show_bug.cgi?id=111827 [i915#1072]: https://gitlab.freedesktop.org/drm/intel/issues/1072 [i915#1222]: https://gitlab.freedesktop.org/drm/intel/issues/1222 [i915#1436]: https://gitlab.freedesktop.org/drm/intel/issues/1436 [i915#2190]: https://gitlab.freedesktop.org/drm/intel/issues/2190 [i915#2283]: https://gitlab.freedesktop.org/drm/intel/issues/2283 [i915#2292]: https://gitlab.freedesktop.org/drm/intel/issues/2292 [i915#2426]: https://gitlab.freedesktop.org/drm/intel/issues/2426 [i915#2582]: https://gitlab.freedesktop.org/drm/intel/issues/2582 [i915#2782]: https://gitlab.freedesktop.org/drm/intel/issues/2782 [i915#2932]: https://gitlab.freedesktop.org/drm/intel/issues/2932 [i915#2966]: https://gitlab.freedesktop.org/drm/intel/issues/2966 [i915#3004]: https://gitlab.freedesktop.org/drm/intel/issues/3004 [i915#3005]: https://gitlab.freedesktop.org/drm/intel/issues/3005 [i915#3011]: https://gitlab.freedesktop.org/drm/intel/issues/3011 [i915#3012]: https://gitlab.freedesktop.org/drm/intel/issues/3012 [i915#3013]: https://gitlab.freedesktop.org/drm/intel/issues/3013 [i915#3014]: https://gitlab.freedesktop.org/drm/intel/issues/3014 [i915#3015]: https://gitlab.freedesktop.org/drm/intel/issues/3015 [i915#3301]: https://gitlab.freedesktop.org/drm/intel/issues/3301 [i915#3363]: https://gitlab.freedesktop.org/drm/intel/issues/3363 [i915#3462]: https://gitlab.freedesktop.org/drm/intel/issues/3462 [i915#533]: https://gitlab.freedesktop.org/drm/intel/issues/533 [k.org#202321]: https://bugzilla.kernel.org/show_bug.cgi?id=202321 [k.org#204565]: https://bugzilla.kernel.org/show_bug.cgi?id=204565 Participating hosts (34 -> 32) ------------------------------ Additional (2): fi-ehl-2 fi-hsw-gt1 Missing (4): fi-kbl-x1275 fi-dg1-1 fi-bsw-cyan fi-bdw-samus Build changes ------------- * CI: CI-20190529 -> None * IGT: IGT_6092 -> IGTPW_5846 CI-20190529: 20190529 CI_DRM_10128: a65996afe32761b9eef973bf230a566f38ac3340 @ git://anongit.freedesktop.org/gfx-ci/linux IGTPW_5846: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/index.html IGT_6092: d87087c321da07035d4f96d98c34e451b3ccb809 @ git://anongit.freedesktop.org/xorg/app/intel-gpu-tools == Testlist changes == +igt@dmabuf_sync_file@export-basic +igt@dmabuf_sync_file@export-before-signal +igt@dmabuf_sync_file@export-multiwait +igt@dmabuf_sync_file@export-wait-after-attach +igt@dmabuf_sync_file@import-basic +igt@dmabuf_sync_file@import-existing-exclusive +igt@dmabuf_sync_file@import-existing-shared-1 +igt@dmabuf_sync_file@import-existing-shared-5 +igt@dmabuf_sync_file@import-existing-shared-32 == Logs == For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/index.html [-- Attachment #1.2: Type: text/html, Size: 7813 bytes --] [-- Attachment #2: Type: text/plain, Size: 154 bytes --] _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 7+ messages in thread
* [igt-dev] ✗ Fi.CI.IGT: failure for tests/dmabuf: Add tests for sync_file import/export 2021-05-24 20:52 [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export Jason Ekstrand ` (2 preceding siblings ...) 2021-05-24 22:25 ` [igt-dev] ✓ Fi.CI.BAT: success for tests/dmabuf: Add tests for sync_file import/export Patchwork @ 2021-05-25 4:31 ` Patchwork 3 siblings, 0 replies; 7+ messages in thread From: Patchwork @ 2021-05-25 4:31 UTC (permalink / raw) To: Jason Ekstrand; +Cc: igt-dev [-- Attachment #1.1: Type: text/plain, Size: 30269 bytes --] == Series Details == Series: tests/dmabuf: Add tests for sync_file import/export URL : https://patchwork.freedesktop.org/series/90490/ State : failure == Summary == CI Bug Log - changes from CI_DRM_10128_full -> IGTPW_5846_full ==================================================== Summary ------- **FAILURE** Serious unknown changes coming with IGTPW_5846_full absolutely need to be verified manually. If you think the reported changes have nothing to do with the changes introduced in IGTPW_5846_full, please notify your bug team to allow them to document this new failure mode, which will reduce false positives in CI. External URL: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/index.html Possible new issues ------------------- Here are the unknown changes that may have been introduced in IGTPW_5846_full: ### IGT changes ### #### Possible regressions #### * {igt@dmabuf_sync_file@import-basic} (NEW): - shard-iclb: NOTRUN -> [SKIP][1] +8 similar issues [1]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@dmabuf_sync_file@import-basic.html * {igt@dmabuf_sync_file@import-existing-shared-5} (NEW): - shard-tglb: NOTRUN -> [SKIP][2] +8 similar issues [2]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb5/igt@dmabuf_sync_file@import-existing-shared-5.html * igt@kms_big_fb@yf-tiled-32bpp-rotate-180: - shard-glk: [PASS][3] -> [FAIL][4] [3]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-glk5/igt@kms_big_fb@yf-tiled-32bpp-rotate-180.html [4]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk5/igt@kms_big_fb@yf-tiled-32bpp-rotate-180.html New tests --------- New tests have been introduced between CI_DRM_10128_full and IGTPW_5846_full: ### New IGT tests (9) ### * igt@dmabuf_sync_file@export-basic: - Statuses : 4 skip(s) - Exec time: [0.0] s * igt@dmabuf_sync_file@export-before-signal: - Statuses : 6 skip(s) - Exec time: [0.0] s * igt@dmabuf_sync_file@export-multiwait: - Statuses : 5 skip(s) - Exec time: [0.0, 0.00] s * igt@dmabuf_sync_file@export-wait-after-attach: - Statuses : 3 skip(s) - Exec time: [0.0] s * igt@dmabuf_sync_file@import-basic: - Statuses : 5 skip(s) - Exec time: [0.00] s * igt@dmabuf_sync_file@import-existing-exclusive: - Statuses : 4 skip(s) - Exec time: [0.00] s * igt@dmabuf_sync_file@import-existing-shared-1: - Statuses : 6 skip(s) - Exec time: [0.00, 0.01] s * igt@dmabuf_sync_file@import-existing-shared-32: - Statuses : 6 skip(s) - Exec time: [0.01, 0.05] s * igt@dmabuf_sync_file@import-existing-shared-5: - Statuses : 4 skip(s) - Exec time: [0.00, 0.01] s Known issues ------------ Here are the changes found in IGTPW_5846_full that come from known issues: ### IGT changes ### #### Issues hit #### * igt@api_intel_bb@full-batch: - shard-glk: NOTRUN -> [DMESG-WARN][5] ([i915#118] / [i915#95]) [5]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk9/igt@api_intel_bb@full-batch.html * igt@core_hotunplug@unbind-rebind: - shard-kbl: [PASS][6] -> [DMESG-WARN][7] ([i915#2283]) [6]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-kbl2/igt@core_hotunplug@unbind-rebind.html [7]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@core_hotunplug@unbind-rebind.html * {igt@dmabuf_sync_file@import-existing-shared-5} (NEW): - shard-kbl: NOTRUN -> [SKIP][8] ([fdo#109271]) +203 similar issues [8]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@dmabuf_sync_file@import-existing-shared-5.html * igt@gem_ctx_persistence@idempotent: - shard-snb: NOTRUN -> [SKIP][9] ([fdo#109271] / [i915#1099]) +7 similar issues [9]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-snb6/igt@gem_ctx_persistence@idempotent.html * igt@gem_ctx_sseu@invalid-args: - shard-tglb: NOTRUN -> [SKIP][10] ([i915#280]) [10]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@gem_ctx_sseu@invalid-args.html * igt@gem_eio@unwedge-stress: - shard-tglb: [PASS][11] -> [TIMEOUT][12] ([i915#2369] / [i915#3063]) [11]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-tglb1/igt@gem_eio@unwedge-stress.html [12]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@gem_eio@unwedge-stress.html * igt@gem_exec_fair@basic-none-vip@rcs0: - shard-tglb: NOTRUN -> [FAIL][13] ([i915#2842]) +6 similar issues [13]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@gem_exec_fair@basic-none-vip@rcs0.html * igt@gem_exec_fair@basic-none@rcs0: - shard-kbl: NOTRUN -> [FAIL][14] ([i915#2842]) [14]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl4/igt@gem_exec_fair@basic-none@rcs0.html * igt@gem_exec_fair@basic-pace-solo@rcs0: - shard-iclb: NOTRUN -> [FAIL][15] ([i915#2842]) +5 similar issues [15]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gem_exec_fair@basic-pace-solo@rcs0.html - shard-glk: [PASS][16] -> [FAIL][17] ([i915#2842]) [16]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-glk7/igt@gem_exec_fair@basic-pace-solo@rcs0.html [17]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk6/igt@gem_exec_fair@basic-pace-solo@rcs0.html * igt@gem_exec_fair@basic-pace@vcs0: - shard-kbl: [PASS][18] -> [SKIP][19] ([fdo#109271]) [18]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-kbl7/igt@gem_exec_fair@basic-pace@vcs0.html [19]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@gem_exec_fair@basic-pace@vcs0.html * igt@gem_exec_fair@basic-throttle@rcs0: - shard-glk: NOTRUN -> [FAIL][20] ([i915#2842]) +2 similar issues [20]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk2/igt@gem_exec_fair@basic-throttle@rcs0.html - shard-iclb: NOTRUN -> [FAIL][21] ([i915#2849]) [21]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@gem_exec_fair@basic-throttle@rcs0.html * igt@gem_exec_flush@basic-batch-kernel-default-cmd: - shard-iclb: NOTRUN -> [SKIP][22] ([fdo#109313]) [22]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb4/igt@gem_exec_flush@basic-batch-kernel-default-cmd.html * igt@gem_exec_params@no-bsd: - shard-tglb: NOTRUN -> [SKIP][23] ([fdo#109283]) [23]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@gem_exec_params@no-bsd.html - shard-iclb: NOTRUN -> [SKIP][24] ([fdo#109283]) [24]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@gem_exec_params@no-bsd.html * igt@gem_exec_params@secure-non-master: - shard-tglb: NOTRUN -> [SKIP][25] ([fdo#112283]) [25]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb7/igt@gem_exec_params@secure-non-master.html - shard-iclb: NOTRUN -> [SKIP][26] ([fdo#112283]) [26]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gem_exec_params@secure-non-master.html * igt@gem_exec_reloc@basic-wide-active@vcs1: - shard-iclb: NOTRUN -> [FAIL][27] ([i915#2389]) [27]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gem_exec_reloc@basic-wide-active@vcs1.html * igt@gem_media_vme: - shard-tglb: NOTRUN -> [SKIP][28] ([i915#284]) [28]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb3/igt@gem_media_vme.html * igt@gem_mmap_gtt@cpuset-basic-small-copy: - shard-apl: NOTRUN -> [INCOMPLETE][29] ([i915#3468]) +1 similar issue [29]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl2/igt@gem_mmap_gtt@cpuset-basic-small-copy.html - shard-kbl: [PASS][30] -> [INCOMPLETE][31] ([i915#3468]) [30]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-kbl1/igt@gem_mmap_gtt@cpuset-basic-small-copy.html [31]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl2/igt@gem_mmap_gtt@cpuset-basic-small-copy.html * igt@gem_mmap_gtt@cpuset-basic-small-copy-xy: - shard-tglb: [PASS][32] -> [INCOMPLETE][33] ([i915#3468]) [32]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-tglb7/igt@gem_mmap_gtt@cpuset-basic-small-copy-xy.html [33]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb1/igt@gem_mmap_gtt@cpuset-basic-small-copy-xy.html * igt@gem_mmap_gtt@cpuset-medium-copy-xy: - shard-apl: [PASS][34] -> [INCOMPLETE][35] ([i915#3468]) +1 similar issue [34]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-apl7/igt@gem_mmap_gtt@cpuset-medium-copy-xy.html [35]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl3/igt@gem_mmap_gtt@cpuset-medium-copy-xy.html - shard-tglb: [PASS][36] -> [INCOMPLETE][37] ([i915#3468] / [i915#750]) [36]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-tglb2/igt@gem_mmap_gtt@cpuset-medium-copy-xy.html [37]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb2/igt@gem_mmap_gtt@cpuset-medium-copy-xy.html * igt@gem_mmap_gtt@medium-copy-xy: - shard-kbl: [PASS][38] -> [INCOMPLETE][39] ([i915#2502] / [i915#3468]) [38]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-kbl1/igt@gem_mmap_gtt@medium-copy-xy.html [39]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl1/igt@gem_mmap_gtt@medium-copy-xy.html * igt@gem_pread@exhaustion: - shard-tglb: NOTRUN -> [WARN][40] ([i915#2658]) +1 similar issue [40]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb7/igt@gem_pread@exhaustion.html * igt@gem_pwrite@basic-exhaustion: - shard-snb: NOTRUN -> [WARN][41] ([i915#2658]) +1 similar issue [41]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-snb6/igt@gem_pwrite@basic-exhaustion.html - shard-iclb: NOTRUN -> [WARN][42] ([i915#2658]) [42]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb1/igt@gem_pwrite@basic-exhaustion.html - shard-kbl: NOTRUN -> [WARN][43] ([i915#2658]) [43]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl1/igt@gem_pwrite@basic-exhaustion.html - shard-apl: NOTRUN -> [WARN][44] ([i915#2658]) [44]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl3/igt@gem_pwrite@basic-exhaustion.html - shard-glk: NOTRUN -> [WARN][45] ([i915#2658]) [45]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk6/igt@gem_pwrite@basic-exhaustion.html * igt@gem_render_copy@y-tiled-mc-ccs-to-vebox-y-tiled: - shard-iclb: NOTRUN -> [SKIP][46] ([i915#768]) +4 similar issues [46]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gem_render_copy@y-tiled-mc-ccs-to-vebox-y-tiled.html * igt@gem_softpin@evict-snoop-interruptible: - shard-tglb: NOTRUN -> [SKIP][47] ([fdo#109312]) [47]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb2/igt@gem_softpin@evict-snoop-interruptible.html - shard-iclb: NOTRUN -> [SKIP][48] ([fdo#109312]) [48]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@gem_softpin@evict-snoop-interruptible.html * igt@gem_userptr_blits@coherency-sync: - shard-iclb: NOTRUN -> [SKIP][49] ([fdo#109290]) [49]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gem_userptr_blits@coherency-sync.html * igt@gem_userptr_blits@dmabuf-sync: - shard-kbl: NOTRUN -> [SKIP][50] ([fdo#109271] / [i915#3323]) [50]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl3/igt@gem_userptr_blits@dmabuf-sync.html - shard-apl: NOTRUN -> [SKIP][51] ([fdo#109271] / [i915#3323]) [51]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl6/igt@gem_userptr_blits@dmabuf-sync.html * igt@gem_userptr_blits@input-checking: - shard-snb: NOTRUN -> [DMESG-WARN][52] ([i915#3002]) [52]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-snb7/igt@gem_userptr_blits@input-checking.html * igt@gem_userptr_blits@unsync-unmap-cycles: - shard-tglb: NOTRUN -> [SKIP][53] ([i915#3297]) [53]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb1/igt@gem_userptr_blits@unsync-unmap-cycles.html - shard-iclb: NOTRUN -> [SKIP][54] ([i915#3297]) [54]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb1/igt@gem_userptr_blits@unsync-unmap-cycles.html * igt@gem_workarounds@suspend-resume-fd: - shard-kbl: NOTRUN -> [DMESG-WARN][55] ([i915#180]) +4 similar issues [55]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@gem_workarounds@suspend-resume-fd.html * igt@gen7_exec_parse@bitmasks: - shard-iclb: NOTRUN -> [SKIP][56] ([fdo#109289]) +4 similar issues [56]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@gen7_exec_parse@bitmasks.html * igt@gen9_exec_parse@allowed-all: - shard-iclb: NOTRUN -> [SKIP][57] ([fdo#112306]) +5 similar issues [57]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@gen9_exec_parse@allowed-all.html * igt@gen9_exec_parse@bb-secure: - shard-tglb: NOTRUN -> [SKIP][58] ([fdo#112306]) +5 similar issues [58]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb3/igt@gen9_exec_parse@bb-secure.html * igt@i915_pm_dc@dc9-dpms: - shard-tglb: NOTRUN -> [SKIP][59] ([i915#3288]) [59]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb5/igt@i915_pm_dc@dc9-dpms.html - shard-iclb: NOTRUN -> [FAIL][60] ([i915#3343]) [60]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb6/igt@i915_pm_dc@dc9-dpms.html * igt@i915_pm_lpsp@kms-lpsp@kms-lpsp-dp: - shard-kbl: NOTRUN -> [SKIP][61] ([fdo#109271] / [i915#1937]) [61]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl4/igt@i915_pm_lpsp@kms-lpsp@kms-lpsp-dp.html * igt@i915_pm_rc6_residency@media-rc6-accuracy: - shard-tglb: NOTRUN -> [SKIP][62] ([fdo#109289] / [fdo#111719]) [62]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb1/igt@i915_pm_rc6_residency@media-rc6-accuracy.html * igt@i915_pm_rpm@gem-execbuf-stress-pc8: - shard-iclb: NOTRUN -> [SKIP][63] ([fdo#109293] / [fdo#109506]) [63]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@i915_pm_rpm@gem-execbuf-stress-pc8.html - shard-tglb: NOTRUN -> [SKIP][64] ([fdo#109506] / [i915#2411]) [64]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb7/igt@i915_pm_rpm@gem-execbuf-stress-pc8.html * igt@i915_query@query-topology-known-pci-ids: - shard-tglb: NOTRUN -> [SKIP][65] ([fdo#109303]) [65]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@i915_query@query-topology-known-pci-ids.html - shard-iclb: NOTRUN -> [SKIP][66] ([fdo#109303]) [66]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@i915_query@query-topology-known-pci-ids.html * igt@i915_selftest@live@execlists: - shard-glk: NOTRUN -> [DMESG-FAIL][67] ([i915#3462]) [67]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk6/igt@i915_selftest@live@execlists.html - shard-iclb: NOTRUN -> [INCOMPLETE][68] ([i915#2782] / [i915#3462]) [68]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@i915_selftest@live@execlists.html - shard-kbl: NOTRUN -> [INCOMPLETE][69] ([i915#2782] / [i915#3462] / [i915#794]) [69]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl3/igt@i915_selftest@live@execlists.html * igt@kms_addfb_basic@no-handle: - shard-glk: [PASS][70] -> [DMESG-WARN][71] ([i915#118] / [i915#95]) [70]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-glk5/igt@kms_addfb_basic@no-handle.html [71]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk8/igt@kms_addfb_basic@no-handle.html * igt@kms_atomic_transition@plane-all-modeset-transition-fencing: - shard-iclb: NOTRUN -> [SKIP][72] ([i915#1769]) +1 similar issue [72]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@kms_atomic_transition@plane-all-modeset-transition-fencing.html - shard-tglb: NOTRUN -> [SKIP][73] ([i915#1769]) +1 similar issue [73]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb3/igt@kms_atomic_transition@plane-all-modeset-transition-fencing.html * igt@kms_big_fb@x-tiled-16bpp-rotate-90: - shard-tglb: NOTRUN -> [SKIP][74] ([fdo#111614]) +3 similar issues [74]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb3/igt@kms_big_fb@x-tiled-16bpp-rotate-90.html * igt@kms_big_fb@x-tiled-32bpp-rotate-270: - shard-iclb: NOTRUN -> [SKIP][75] ([fdo#110725] / [fdo#111614]) +3 similar issues [75]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@kms_big_fb@x-tiled-32bpp-rotate-270.html * igt@kms_big_fb@yf-tiled-64bpp-rotate-270: - shard-iclb: NOTRUN -> [SKIP][76] ([fdo#110723]) [76]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_big_fb@yf-tiled-64bpp-rotate-270.html * igt@kms_big_joiner@basic: - shard-apl: NOTRUN -> [SKIP][77] ([fdo#109271] / [i915#2705]) +1 similar issue [77]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl2/igt@kms_big_joiner@basic.html * igt@kms_big_joiner@invalid-modeset: - shard-iclb: NOTRUN -> [SKIP][78] ([i915#2705]) [78]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_big_joiner@invalid-modeset.html - shard-kbl: NOTRUN -> [SKIP][79] ([fdo#109271] / [i915#2705]) [79]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl3/igt@kms_big_joiner@invalid-modeset.html - shard-glk: NOTRUN -> [SKIP][80] ([fdo#109271] / [i915#2705]) [80]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk9/igt@kms_big_joiner@invalid-modeset.html - shard-tglb: NOTRUN -> [SKIP][81] ([i915#2705]) [81]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_big_joiner@invalid-modeset.html * igt@kms_chamelium@dp-hpd-for-each-pipe: - shard-kbl: NOTRUN -> [SKIP][82] ([fdo#109271] / [fdo#111827]) +17 similar issues [82]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@kms_chamelium@dp-hpd-for-each-pipe.html * igt@kms_chamelium@dp-hpd-storm: - shard-iclb: NOTRUN -> [SKIP][83] ([fdo#109284] / [fdo#111827]) +14 similar issues [83]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_chamelium@dp-hpd-storm.html * igt@kms_chamelium@dp-mode-timings: - shard-apl: NOTRUN -> [SKIP][84] ([fdo#109271] / [fdo#111827]) +24 similar issues [84]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl2/igt@kms_chamelium@dp-mode-timings.html * igt@kms_chamelium@hdmi-aspect-ratio: - shard-glk: NOTRUN -> [SKIP][85] ([fdo#109271] / [fdo#111827]) +15 similar issues [85]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk5/igt@kms_chamelium@hdmi-aspect-ratio.html * igt@kms_chamelium@vga-hpd-after-suspend: - shard-tglb: NOTRUN -> [SKIP][86] ([fdo#109284] / [fdo#111827]) +14 similar issues [86]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_chamelium@vga-hpd-after-suspend.html * igt@kms_color@pipe-c-degamma: - shard-iclb: NOTRUN -> [FAIL][87] ([i915#1149]) [87]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb1/igt@kms_color@pipe-c-degamma.html - shard-tglb: NOTRUN -> [FAIL][88] ([i915#1149]) [88]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb1/igt@kms_color@pipe-c-degamma.html * igt@kms_color_chamelium@pipe-a-ctm-0-25: - shard-snb: NOTRUN -> [SKIP][89] ([fdo#109271] / [fdo#111827]) +25 similar issues [89]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-snb5/igt@kms_color_chamelium@pipe-a-ctm-0-25.html * igt@kms_content_protection@atomic: - shard-kbl: NOTRUN -> [TIMEOUT][90] ([i915#1319]) [90]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@kms_content_protection@atomic.html * igt@kms_content_protection@content_type_change: - shard-iclb: NOTRUN -> [SKIP][91] ([fdo#109300] / [fdo#111066]) +1 similar issue [91]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_content_protection@content_type_change.html * igt@kms_content_protection@dp-mst-lic-type-0: - shard-iclb: NOTRUN -> [SKIP][92] ([i915#3116]) [92]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_content_protection@dp-mst-lic-type-0.html - shard-tglb: NOTRUN -> [SKIP][93] ([i915#3116]) [93]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_content_protection@dp-mst-lic-type-0.html * igt@kms_content_protection@lic: - shard-apl: NOTRUN -> [TIMEOUT][94] ([i915#1319]) [94]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl6/igt@kms_content_protection@lic.html * igt@kms_content_protection@uevent: - shard-kbl: NOTRUN -> [FAIL][95] ([i915#2105]) [95]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl2/igt@kms_content_protection@uevent.html - shard-tglb: NOTRUN -> [SKIP][96] ([fdo#111828]) +1 similar issue [96]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb1/igt@kms_content_protection@uevent.html * igt@kms_cursor_crc@pipe-b-cursor-512x512-rapid-movement: - shard-iclb: NOTRUN -> [SKIP][97] ([fdo#109278] / [fdo#109279]) +6 similar issues [97]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@kms_cursor_crc@pipe-b-cursor-512x512-rapid-movement.html * igt@kms_cursor_crc@pipe-c-cursor-max-size-offscreen: - shard-tglb: NOTRUN -> [SKIP][98] ([i915#3359]) +8 similar issues [98]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_cursor_crc@pipe-c-cursor-max-size-offscreen.html * igt@kms_cursor_crc@pipe-d-cursor-32x32-rapid-movement: - shard-iclb: NOTRUN -> [SKIP][99] ([fdo#109278]) +42 similar issues [99]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_cursor_crc@pipe-d-cursor-32x32-rapid-movement.html - shard-tglb: NOTRUN -> [SKIP][100] ([i915#3319]) +2 similar issues [100]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb7/igt@kms_cursor_crc@pipe-d-cursor-32x32-rapid-movement.html * igt@kms_cursor_crc@pipe-d-cursor-512x512-offscreen: - shard-tglb: NOTRUN -> [SKIP][101] ([fdo#109279] / [i915#3359]) +6 similar issues [101]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@kms_cursor_crc@pipe-d-cursor-512x512-offscreen.html * igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size: - shard-iclb: NOTRUN -> [SKIP][102] ([fdo#109274] / [fdo#109278]) +5 similar issues [102]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size.html * igt@kms_cursor_legacy@pipe-d-single-bo: - shard-apl: NOTRUN -> [SKIP][103] ([fdo#109271] / [i915#533]) [103]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl3/igt@kms_cursor_legacy@pipe-d-single-bo.html * igt@kms_dp_tiled_display@basic-test-pattern: - shard-iclb: NOTRUN -> [SKIP][104] ([i915#426]) [104]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@kms_dp_tiled_display@basic-test-pattern.html - shard-tglb: NOTRUN -> [SKIP][105] ([i915#426]) [105]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@kms_dp_tiled_display@basic-test-pattern.html * igt@kms_flip@2x-flip-vs-panning-vs-hang: - shard-iclb: NOTRUN -> [SKIP][106] ([fdo#109274]) +6 similar issues [106]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@kms_flip@2x-flip-vs-panning-vs-hang.html * igt@kms_flip@flip-vs-suspend-interruptible@a-dp1: - shard-kbl: [PASS][107] -> [DMESG-WARN][108] ([i915#180]) +2 similar issues [107]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_10128/shard-kbl2/igt@kms_flip@flip-vs-suspend-interruptible@a-dp1.html [108]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl4/igt@kms_flip@flip-vs-suspend-interruptible@a-dp1.html * igt@kms_flip_scaled_crc@flip-32bpp-ytile-to-32bpp-ytilegen12rcccs: - shard-iclb: NOTRUN -> [SKIP][109] ([i915#2587]) [109]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@kms_flip_scaled_crc@flip-32bpp-ytile-to-32bpp-ytilegen12rcccs.html * igt@kms_flip_scaled_crc@flip-32bpp-ytile-to-64bpp-ytile: - shard-glk: NOTRUN -> [SKIP][110] ([fdo#109271] / [i915#2642]) [110]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk6/igt@kms_flip_scaled_crc@flip-32bpp-ytile-to-64bpp-ytile.html * igt@kms_flip_scaled_crc@flip-32bpp-ytileccs-to-64bpp-ytile: - shard-kbl: NOTRUN -> [SKIP][111] ([fdo#109271] / [i915#2642]) +1 similar issue [111]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl3/igt@kms_flip_scaled_crc@flip-32bpp-ytileccs-to-64bpp-ytile.html * igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-shrfb-pgflip-blt: - shard-iclb: NOTRUN -> [SKIP][112] ([fdo#109280]) +35 similar issues [112]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb8/igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-shrfb-pgflip-blt.html * igt@kms_frontbuffer_tracking@psr-1p-primscrn-cur-indfb-onoff: - shard-snb: NOTRUN -> [SKIP][113] ([fdo#109271]) +468 similar issues [113]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-snb7/igt@kms_frontbuffer_tracking@psr-1p-primscrn-cur-indfb-onoff.html * igt@kms_frontbuffer_tracking@psr-2p-primscrn-cur-indfb-draw-mmap-cpu: - shard-tglb: NOTRUN -> [SKIP][114] ([fdo#111825]) +39 similar issues [114]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_frontbuffer_tracking@psr-2p-primscrn-cur-indfb-draw-mmap-cpu.html * igt@kms_frontbuffer_tracking@psr-rgb565-draw-mmap-cpu: - shard-glk: NOTRUN -> [SKIP][115] ([fdo#109271]) +162 similar issues [115]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk8/igt@kms_frontbuffer_tracking@psr-rgb565-draw-mmap-cpu.html * igt@kms_hdr@static-toggle: - shard-iclb: NOTRUN -> [SKIP][116] ([i915#1187]) +1 similar issue [116]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_hdr@static-toggle.html * igt@kms_hdr@static-toggle-dpms: - shard-tglb: NOTRUN -> [SKIP][117] ([i915#1187]) +1 similar issue [117]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb8/igt@kms_hdr@static-toggle-dpms.html * igt@kms_invalid_dotclock: - shard-iclb: NOTRUN -> [SKIP][118] ([fdo#109310]) [118]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb3/igt@kms_invalid_dotclock.html * igt@kms_multipipe_modeset@basic-max-pipe-crc-check: - shard-tglb: NOTRUN -> [SKIP][119] ([i915#1839]) [119]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb7/igt@kms_multipipe_modeset@basic-max-pipe-crc-check.html - shard-iclb: NOTRUN -> [SKIP][120] ([i915#1839]) [120]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-iclb2/igt@kms_multipipe_modeset@basic-max-pipe-crc-check.html * igt@kms_pipe_crc_basic@nonblocking-crc-pipe-d-frame-sequence: - shard-kbl: NOTRUN -> [SKIP][121] ([fdo#109271] / [i915#533]) +2 similar issues [121]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl7/igt@kms_pipe_crc_basic@nonblocking-crc-pipe-d-frame-sequence.html - shard-glk: NOTRUN -> [SKIP][122] ([fdo#109271] / [i915#533]) [122]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk9/igt@kms_pipe_crc_basic@nonblocking-crc-pipe-d-frame-sequence.html * igt@kms_pipe_crc_basic@suspend-read-crc-pipe-b: - shard-apl: NOTRUN -> [DMESG-WARN][123] ([i915#180]) [123]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl6/igt@kms_pipe_crc_basic@suspend-read-crc-pipe-b.html * igt@kms_plane_alpha_blend@pipe-a-alpha-opaque-fb: - shard-apl: NOTRUN -> [FAIL][124] ([fdo#108145] / [i915#265]) +2 similar issues [124]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-apl3/igt@kms_plane_alpha_blend@pipe-a-alpha-opaque-fb.html * igt@kms_plane_alpha_blend@pipe-a-constant-alpha-max: - shard-glk: NOTRUN -> [FAIL][125] ([fdo#108145] / [i915#265]) [125]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-glk5/igt@kms_plane_alpha_blend@pipe-a-constant-alpha-max.html * igt@kms_plane_alpha_blend@pipe-b-alpha-transparent-fb: - shard-kbl: NOTRUN -> [FAIL][126] ([i915#265]) [126]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl2/igt@kms_plane_alpha_blend@pipe-b-alpha-transparent-fb.html * igt@kms_plane_alpha_blend@pipe-c-alpha-basic: - shard-kbl: NOTRUN -> [FAIL][127] ([fdo#108145] / [i915#265]) +2 similar issues [127]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-kbl4/igt@kms_plane_alpha_blend@pipe-c-alpha-basic.html * igt@kms_plane_lowres@pipe-d-tiling-yf: - shard-tglb: NOTRUN -> [SKIP][128] ([fdo#112054]) [128]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@kms_plane_lowres@pipe-d-tiling-yf.html * igt@kms_plane_multiple@atomic-pipe-b-tiling-yf: - shard-tglb: NOTRUN -> [SKIP][129] ([fdo#111615]) +4 similar issues [129]: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/shard-tglb6/igt@kms == Logs == For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/IGTPW_5846/index.html [-- Attachment #1.2: Type: text/html, Size: 34221 bytes --] [-- Attachment #2: Type: text/plain, Size: 154 bytes --] _______________________________________________ igt-dev mailing list igt-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/igt-dev ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2021-06-03 12:48 UTC | newest] Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2021-05-24 20:52 [igt-dev] [PATCH i-g-t 0/2] tests/dmabuf: Add tests for sync_file import/export Jason Ekstrand 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 1/2] tests/dmabuf: Add tests for sync_file export (v3) Jason Ekstrand 2021-06-03 12:37 ` Daniel Vetter 2021-05-24 20:52 ` [igt-dev] [PATCH i-g-t 2/2] RFC: tests/dmabuf: Add tests for sync_file import (v3) Jason Ekstrand 2021-06-03 12:48 ` Daniel Vetter 2021-05-24 22:25 ` [igt-dev] ✓ Fi.CI.BAT: success for tests/dmabuf: Add tests for sync_file import/export Patchwork 2021-05-25 4:31 ` [igt-dev] ✗ Fi.CI.IGT: failure " Patchwork
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.