Skip to content

Commit

Permalink
Skip usbfs_ioctl_pcap on sparc64
Browse files Browse the repository at this point in the history
Calling Ioctl.USBDEVFS_REAPURB in the test causes a SIGBUS error on
sparc64. It's actually surprising that this test passes on a lot of
architectures -- the pcap file was recorded on x86_64, and there may be
some unaligned access there.

I don't know enough about compilers, alignment, and pcap files to
actually fix this. But the more pressing issue is to fix the package
build on sparc64.

Fixes #218
  • Loading branch information
martinpitt committed Mar 3, 2024
1 parent 15b4fed commit 570b58e
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 1 deletion.
3 changes: 2 additions & 1 deletion meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ python = find_program('python3', 'python', required: false)
vapi_posix = valac.find_library('posix')
vapi_linux = valac.find_library('linux')
vapi_linux_fixes = valac.find_library('linux_fixes', dirs: srcdir)
vapi_glibc = valac.find_library('glibc', dirs: srcdir)
vala_libudev = cc.find_library('udev')
vala_libutil = cc.find_library('util')

Expand Down Expand Up @@ -278,7 +279,7 @@ if gudev.found()

test('umockdev-vala', executable('test-umockdev-vala',
'tests/test-umockdev-vala.vala',
dependencies: [glib, gobject, gio, gudev, vapi_posix, vapi_assertions, vapi_ioctl, vapi_selinux, selinux],
dependencies: [glib, gobject, gio, gudev, vapi_posix, vapi_assertions, vapi_ioctl, vapi_glibc, vapi_selinux, selinux],
link_with: [umockdev_lib, umockdev_utils_lib],
vala_args: optional_defines),
depends: [preload_lib],
Expand Down
14 changes: 14 additions & 0 deletions src/glibc.vapi
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
[CCode (cheader_filename = "sys/utsname.h")]
namespace GLibc {
[CCode (cname = "struct utsname", destroy_function="")]
public struct Utsname {
unowned string sysname;
unowned string nodename;
unowned string release;
unowned string version;
unowned string machine;
}

[CCode (cname = "uname")]
public void uname (out Utsname buf);
}
8 changes: 8 additions & 0 deletions tests/test-umockdev-vala.vala
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

using UMockdevUtils;
using Assertions;
using GLibc;

#if HAVE_SELINUX
using Selinux;
Expand Down Expand Up @@ -549,6 +550,13 @@ t_usbfs_ioctl_pcap ()
string device;
Ioctl.usbdevfs_urb* urb_reap = null;

GLibc.Utsname utsbuf;
GLibc.uname (out utsbuf);
if (utsbuf.machine == "sparc64") {
stdout.printf ("[SKIP pre-recorded pcap does not work on sparc64]\n");
return;
}

/* NOTE: This test is a bit ugly. It wasn't the best idea to use a USB keyboard. */

checked_file_get_contents (Path.build_filename(rootdir + "/devices/input/usbkbd.pcap.umockdev"), out device);
Expand Down

0 comments on commit 570b58e

Please sign in to comment.