pkgsrc-Bugs archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

Re: pkg/59163: emulators/qemu: missing virtfs option for NetBSD



The following reply was made to PR pkg/59163; it has been noted by GNATS.

From: Taylor R Campbell <riastradh%NetBSD.org@localhost>
To: gnats-bugs%NetBSD.org@localhost
Cc: pkgsrc-bugs%NetBSD.org@localhost
Subject: Re: pkg/59163: emulators/qemu: missing virtfs option for NetBSD
Date: Mon, 10 Mar 2025 21:55:24 +0000

 This is a multi-part message in MIME format.
 --=_fvz4bw6Sgb7EvIjKFB6Nr1oMeWUc8Daj
 
 The attached patch adds an option `qemu-virtfs' to emulators/qemu and
 implements it on NetBSD.
 
 I tried to avoid changes that are likely to break other platforms --
 using __NetBSD__ for NetBSD-specific parts, CONFIG_BSD for things that
 I think will work on other BSDs as well, and changing CONFIG_LINUX or
 CONFIG_DARWIN only where it really made sense -- but I haven't tested
 on any platforms other than NetBSD.
 
 (For BSDs other than NetBSD, the option remains default-off, so it is
 unlikely to break there -- but testing and/or porting welcome!)
 
 --=_fvz4bw6Sgb7EvIjKFB6Nr1oMeWUc8Daj
 Content-Type: text/plain; charset="ISO-8859-1"; name="pr59163-qemu-virtfs-netbsd"
 Content-Transfer-Encoding: quoted-printable
 Content-Disposition: attachment; filename="pr59163-qemu-virtfs-netbsd.patch"
 
 >From 69ef2d26e9a0623c2bf46521d64711b9e17ecd99 Mon Sep 17 00:00:00 2001
 From: Taylor R Campbell <riastradh%NetBSD.org@localhost>
 Date: Sat, 31 Dec 2022 11:38:38 +0000
 Subject: [PATCH] emulators/qemu: New option qemu-virtfs.
 
 Add NetBSD support for qemu-virtfs.  (And pave the way for other BSD
 support too.)
 
 Narrow the existing virtfs-proxy-helper option to use
 --enable-virtfs-proxy-helper.  I doubt this option has worked in a
 long time, because I think virtfs-proxy-helper has been off by
 default even with virtfs enabled; maybe we should just delete it.
 
 PR pkg/59163: emulators/qemu: missing virtfs option for NetBSD
 ---
  emulators/qemu/Makefile                       |   2 +-
  emulators/qemu/distinfo                       |  10 +-
  emulators/qemu/options.mk                     |  11 +-
  .../qemu/patches/patch-fsdev_file-op-9p.h     |  18 +
  .../qemu/patches/patch-fsdev_meson.build      |  14 +
  .../qemu/patches/patch-hw_9pfs_9p-synth.c     |  30 ++
  .../qemu/patches/patch-hw_9pfs_9p-util.h      | 337 ++++++++++++++++++
  emulators/qemu/patches/patch-hw_9pfs_9p.c     |  93 +++++
  emulators/qemu/patches/patch-hw_9pfs_9p.h     |  16 +
  emulators/qemu/patches/patch-hw_9pfs_codir.c  |  42 +++
  .../qemu/patches/patch-hw_9pfs_meson.build    |  15 +
  emulators/qemu/patches/patch-meson.build      |  20 +-
  12 files changed, 601 insertions(+), 7 deletions(-)
  create mode 100644 emulators/qemu/patches/patch-fsdev_file-op-9p.h
  create mode 100644 emulators/qemu/patches/patch-fsdev_meson.build
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_9p-synth.c
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_9p-util.h
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_9p.c
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_9p.h
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_codir.c
  create mode 100644 emulators/qemu/patches/patch-hw_9pfs_meson.build
 
 diff --git a/emulators/qemu/Makefile b/emulators/qemu/Makefile
 index 81a92abe86a3..1404b1f95a6f 100644
 --- a/emulators/qemu/Makefile
 +++ b/emulators/qemu/Makefile
 @@ -1,7 +1,7 @@
  # $NetBSD: Makefile,v 1.368 2025/03/10 11:45:43 imil Exp $
 =20
  DISTNAME=3D	qemu-9.2.2
 -PKGREVISION=3D	2
 +PKGREVISION=3D	3
  CATEGORIES=3D	emulators
  MASTER_SITES=3D	https://download.qemu.org/
  EXTRACT_SUFX=3D	.tar.xz
 diff --git a/emulators/qemu/distinfo b/emulators/qemu/distinfo
 index e120cffcff96..2b8fa1c68f77 100644
 --- a/emulators/qemu/distinfo
 +++ b/emulators/qemu/distinfo
 @@ -7,14 +7,22 @@ BLAKE2s (qemu-9.2.2.tar.xz) =3D ad6aa908ac97ce61943832f76=
 8caa0794c184f5938cd69f4c5
  SHA512 (qemu-9.2.2.tar.xz) =3D b010876da9f91da01dbb9e06705a1358d5f062d0fdd=
 4ad5c8cd8ce3fd43adcefcf72a61216eb8d415281f6607b945ce1cfb6b5fc5692ada9163e8f=
 05b7fb5533
  Size (qemu-9.2.2.tar.xz) =3D 134756816 bytes
  SHA1 (patch-audio_jackaudio.c) =3D 771c2779e565242a500adc0223ef6b1ae5b2b91f
 +SHA1 (patch-fsdev_file-op-9p.h) =3D 92787132c233abaf87529679ac88e26ab00d15=
 70
 +SHA1 (patch-fsdev_meson.build) =3D 918a361056b9808caecf4fbd85f44cfc405a1606
  SHA1 (patch-hw-mips-Kconfig) =3D c74efac1b5d3a49d141387eb9316617039be737b
  SHA1 (patch-hw-mips-mipssim.c) =3D c72129c6ad961a62d3f1b443bbf373ee3c900dc0
 +SHA1 (patch-hw_9pfs_9p-synth.c) =3D 1f33481844707c6ea23bfa48aaaaa078ebb7a3=
 ea
 +SHA1 (patch-hw_9pfs_9p-util.h) =3D e9c23e21c1d5361b7568ed768445b8a6d8afbc4f
 +SHA1 (patch-hw_9pfs_9p.c) =3D 05c418eebf501dfbfff686d66d32953a1a41f9ca
 +SHA1 (patch-hw_9pfs_9p.h) =3D 4e2749619d2154f9fb341047aa278371b298e8a4
 +SHA1 (patch-hw_9pfs_codir.c) =3D c065762ee13fdeaef063632f56d9d0ead6b68f61
 +SHA1 (patch-hw_9pfs_meson.build) =3D d6d754fb38b4b0f95bdb8bebbe18e8adad035=
 e26
  SHA1 (patch-hw_mips_meson.build) =3D 06cc199b3b15add9f5d5ddcd84bf2791f96bd=
 5d3
  SHA1 (patch-hw_net_xilinx__axienet.c) =3D ebcd2676d64ce6f31e4a8c976d4fdf53=
 0ad5e8b7
  SHA1 (patch-hw_rtc_mc146818rtc.c) =3D cc7a3b28010966b65b7a16db756226ac2669=
 f310
  SHA1 (patch-hw_scsi_scsi-disk.c) =3D fdbf2f962a6dcb1a115a7f8a5b8790ff9295f=
 b33
  SHA1 (patch-hw_usb_dev-mtp.c) =3D f148a3ad6d72eb29f85684316af5fb219ddaeb71
 -SHA1 (patch-meson.build) =3D 6b0607903b84c84d26bd5c54f3f0b9e4b256d787
 +SHA1 (patch-meson.build) =3D 8a76d92303efa054b37d46b27d76d0fb75c15133
  SHA1 (patch-qemu-options.hx) =3D 6cf811ae421db1e8d45f7098bd36733c6dc7d9cf
  SHA1 (patch-roms_u-boot-sam460ex_Makefile) =3D 3a1bbf19b1422c10ebdd819eb0b=
 711fafc78e2f2
  SHA1 (patch-target_arm_tcg_translate-sve.c) =3D b5eeb08331e61a16b2cf4b7ab9=
 b668755aa9a04e
 diff --git a/emulators/qemu/options.mk b/emulators/qemu/options.mk
 index 15c61df60332..b04e416d282e 100644
 --- a/emulators/qemu/options.mk
 +++ b/emulators/qemu/options.mk
 @@ -10,6 +10,11 @@ PKG_SUGGESTED_OPTIONS+=3D	iscsi sdl spice
  PKG_SUPPORTED_OPTIONS+=3D	virtfs-proxy-helper
  .endif
 =20
 +.if ${OPSYS} =3D=3D "Linux" || ${OPSYS} =3D=3D "Darwin" || ${OPSYS} =3D=3D=
  "NetBSD"
 +PKG_SUPPORTED_OPTIONS+=3D	qemu-virtfs
 +PKG_SUGGESTED_OPTIONS+=3D	qemu-virtfs
 +.endif
 +
  .if ${OPSYS} !=3D "Darwin"
  # NetBSD<9.0 does not have EGL support in native X11,
  # so the QEMU OpenGL display driver cannot build.
 @@ -80,8 +85,10 @@ CONFIGURE_ARGS+=3D	--disable-xkbcommon
  # header/development libraries for libcap and libattr must be installed.
  .if ${OPSYS} =3D=3D "Linux" && !empty(PKG_OPTIONS:Mvirtfs-proxy-helper)
  PLIST.virtfs-proxy-helper=3D	yes
 -CONFIGURE_ARGS+=3D		--enable-virtfs
 -.elif ${OPSYS} =3D=3D "Darwin"
 +CONFIGURE_ARGS+=3D		--enable-virtfs-proxy-helper
 +.endif
 +
 +.if !empty(PKG_OPTIONS:Mqemu-virtfs)
  CONFIGURE_ARGS+=3D		--enable-virtfs
  .else
  CONFIGURE_ARGS+=3D		--disable-virtfs
 diff --git a/emulators/qemu/patches/patch-fsdev_file-op-9p.h b/emulators/qe=
 mu/patches/patch-fsdev_file-op-9p.h
 new file mode 100644
 index 000000000000..f5d4dd2d09ef
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-fsdev_file-op-9p.h
 @@ -0,0 +1,18 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- fsdev/file-op-9p.h.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ fsdev/file-op-9p.h
 +@@ -26,6 +26,11 @@
 + # include <sys/param.h>
 + # include <sys/mount.h>
 + #endif
 ++#ifdef CONFIG_BSD
 ++# include <sys/statvfs.h>
 ++# define statfs statvfs
 ++# define fstatfs fstatvfs
 ++#endif
 +=20
 + #define SM_LOCAL_MODE_BITS    0600
 + #define SM_LOCAL_DIR_MODE_BITS    0700
 diff --git a/emulators/qemu/patches/patch-fsdev_meson.build b/emulators/qem=
 u/patches/patch-fsdev_meson.build
 new file mode 100644
 index 000000000000..bbe7c4796fbb
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-fsdev_meson.build
 @@ -0,0 +1,14 @@
 +$NetBSD$
 +
 +Enable fsdev support on NetBSD.
 +
 +--- fsdev/meson.build.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ fsdev/meson.build
 +@@ -5,6 +5,6 @@ fsdev_ss.add(when: ['CONFIG_FSDEV_9P'],=20
 +   '9p-marshal.c',
 +   'qemu-fsdev.c',
 + ), if_false: files('qemu-fsdev-dummy.c'))
 +-if host_os in ['linux', 'darwin']
 ++if host_os in ['linux', 'darwin', 'netbsd']
 +   system_ss.add_all(fsdev_ss)
 + endif
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_9p-synth.c b/emulators/qe=
 mu/patches/patch-hw_9pfs_9p-synth.c
 new file mode 100644
 index 000000000000..353514195a1d
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_9p-synth.c
 @@ -0,0 +1,30 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/9p-synth.c.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/9p-synth.c
 +@@ -230,7 +230,7 @@ static void synth_direntry(V9fsSynthNode
 +     entry->d_ino =3D node->attr->inode;
 + #ifdef CONFIG_DARWIN
 +     entry->d_seekoff =3D off + 1;
 +-#else
 ++#elif defined CONFIG_LINUX
 +     entry->d_off =3D off + 1;
 + #endif
 + }
 +@@ -433,11 +433,13 @@ static int synth_fsync(FsContext *ctx, i
 + static int synth_statfs(FsContext *s, V9fsPath *fs_path,
 +                              struct statfs *stbuf)
 + {
 ++#ifndef CONFIG_BSD
 +     stbuf->f_type =3D 0xABCD;
 ++#endif
 +     stbuf->f_bsize =3D 512;
 +     stbuf->f_blocks =3D 0;
 +     stbuf->f_files =3D synth_node_count;
 +-#ifndef CONFIG_DARWIN
 ++#ifdef CONFIG_LINUX
 +     stbuf->f_namelen =3D NAME_MAX;
 + #endif
 +     return 0;
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_9p-util.h b/emulators/qem=
 u/patches/patch-hw_9pfs_9p-util.h
 new file mode 100644
 index 000000000000..f593a2157138
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_9p-util.h
 @@ -0,0 +1,337 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/9p-util.h.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/9p-util.h
 +@@ -64,6 +64,298 @@ static inline uint64_t host_dev_to_dotl_
 + static inline int errno_to_dotl(int err) {
 + #if defined(CONFIG_LINUX)
 +     /* nothing to translate (Linux -> Linux) */
 ++#elif defined(CONFIG_BSD)
 ++    switch (err) {
 ++        /* linux uapi/asm-generic/errno-base.h */
 ++    case EPERM:
 ++        return 1;
 ++    case ENOENT:
 ++        return 2;
 ++    case ESRCH:
 ++        return 3;
 ++    case EINTR:
 ++        return 4;
 ++    case EIO:
 ++        return 5;
 ++    case ENXIO:
 ++        return 6;
 ++    case E2BIG:
 ++        return 7;
 ++    case ENOEXEC:
 ++        return 8;
 ++    case EBADF:
 ++        return 9;
 ++    case ECHILD:
 ++        return 10;
 ++    case EAGAIN:
 ++        return 11;
 ++    case ENOMEM:
 ++        return 12;
 ++    case EACCES:
 ++        return 13;
 ++    case EFAULT:
 ++        return 14;
 ++    case ENOTBLK:
 ++        return 15;
 ++    case EBUSY:
 ++        return 16;
 ++    case EEXIST:
 ++        return 17;
 ++    case EXDEV:
 ++        return 18;
 ++    case ENODEV:
 ++        return 19;
 ++    case ENOTDIR:
 ++        return 20;
 ++    case EISDIR:
 ++        return 21;
 ++    case EINVAL:
 ++        return 22;
 ++    case ENFILE:
 ++        return 23;
 ++    case EMFILE:
 ++        return 24;
 ++    case ENOTTY:
 ++        return 25;
 ++    case ETXTBSY:
 ++        return 26;
 ++    case EFBIG:
 ++        return 27;
 ++    case ENOSPC:
 ++        return 28;
 ++    case ESPIPE:
 ++        return 29;
 ++    case EROFS:
 ++        return 30;
 ++    case EMLINK:
 ++        return 31;
 ++    case EPIPE:
 ++        return 32;
 ++    case EDOM:
 ++        return 33;
 ++    case ERANGE:
 ++        return 34;
 ++        /* linux uapi/asm-generic/errno.h */
 ++    case EDEADLK:
 ++        return 35;
 ++    case ENAMETOOLONG:
 ++        return 36;
 ++    case ENOLCK:
 ++        return 37;
 ++    case ENOSYS:
 ++        return 38;
 ++    case ENOTEMPTY:
 ++        return 39;
 ++    case ELOOP:
 ++        return 40;
 ++    case ENOMSG:
 ++        return 41;
 ++    case EIDRM:
 ++        return 43;
 ++# if 0
 ++    case ECHRNG:
 ++        return 44;
 ++    case EL2NSYNC:
 ++        return 45;
 ++    case EL3HLT:
 ++        return 46;
 ++    case EL3RST:
 ++        return 47;
 ++    case ELNRNG:
 ++        return 48;
 ++    case EUNATCH:
 ++        return 49;
 ++    case ENOCSI:
 ++        return 50;
 ++    case EL2HLT:
 ++        return 51;
 ++    case EBADE:
 ++        return 52;
 ++    case EBADR:
 ++        return 53;
 ++    case EXFULL:
 ++        return 54;
 ++    case ENOANO:
 ++        return 55;
 ++    case EBADRQC:
 ++        return 56;
 ++    case EBADSLT:
 ++        return 57;
 ++    case EBFONT:
 ++        return 58;
 ++# endif
 ++    case ENOSTR:
 ++        return 60;
 ++    case ENODATA:
 ++        return 61;
 ++    case ETIME:
 ++        return 62;
 ++    case ENOSR:
 ++        return 63;
 ++# if 0
 ++    case ENONET:
 ++        return 64;
 ++    case ENOPKG:
 ++        return 65;
 ++# endif
 ++    case ENOLINK:
 ++        return 66;
 ++# if 0
 ++    case EADV:
 ++        return 67;
 ++    case ESRMNT:
 ++        return 68;
 ++    case ECOMM:
 ++        return 69;
 ++# endif
 ++    case EPROTO:
 ++        return 70;
 ++    case EMULTIHOP:
 ++        return 71;
 ++# if 0
 ++    case EDOTDOT:
 ++        return 72;
 ++# endif
 ++    case EBADMSG:
 ++        return 73;
 ++    case EOVERFLOW:
 ++        return 74;
 ++# if 0
 ++    case ENOTUNIQ:
 ++        return 75;
 ++    case EBADFD:                /* Note: not EBADF */
 ++        return 77;
 ++    case EREMCHG:
 ++        return 78;
 ++    case ELIBACC:
 ++        return 79;
 ++    case ELIBBAD:
 ++        return 80;
 ++    case ELIBSCN:
 ++        return 81;
 ++    case ELIBMAX:
 ++        return 82;
 ++    case ELIBEXEC:
 ++        return 83;
 ++#endif
 ++    case EILSEQ:
 ++        return 84;
 ++#if 0
 ++    case ERESTART:              /* XXX not the same thing */
 ++        return 85;
 ++#endif
 ++#if 0
 ++    case ESTRPIPE:
 ++        return 86;
 ++#endif
 ++    case EUSERS:
 ++        return 87;
 ++    case ENOTSOCK:
 ++        return 88;
 ++    case EDESTADDRREQ:
 ++        return 89;
 ++    case EMSGSIZE:
 ++        return 90;
 ++    case EPROTOTYPE:
 ++        return 91;
 ++    case ENOPROTOOPT:
 ++        return 92;
 ++    case EPROTONOSUPPORT:
 ++        return 93;
 ++    case ESOCKTNOSUPPORT:
 ++        return 94;
 ++    case EOPNOTSUPP:
 ++        return 95;
 ++    case EPFNOSUPPORT:
 ++        return 96;
 ++    case EAFNOSUPPORT:
 ++        return 97;
 ++    case EADDRINUSE:
 ++        return 98;
 ++    case EADDRNOTAVAIL:
 ++        return 99;
 ++    case ENETDOWN:
 ++        return 100;
 ++    case ENETUNREACH:
 ++        return 101;
 ++    case ENETRESET:
 ++        return 102;
 ++    case ECONNABORTED:
 ++        return 103;
 ++    case ECONNRESET:
 ++        return 104;
 ++    case ENOBUFS:
 ++        return 105;
 ++    case EISCONN:
 ++        return 106;
 ++    case ENOTCONN:
 ++        return 107;
 ++    case ESHUTDOWN:
 ++        return 108;
 ++    case ETOOMANYREFS:
 ++        return 109;
 ++    case ETIMEDOUT:
 ++        return 110;
 ++    case ECONNREFUSED:
 ++        return 111;
 ++    case EHOSTDOWN:
 ++        return 112;
 ++    case EHOSTUNREACH:
 ++        return 113;
 ++    case EALREADY:
 ++        return 114;
 ++    case EINPROGRESS:
 ++        return 115;
 ++    case ESTALE:
 ++        return 116;
 ++# if 0
 ++    case EUCLEAN:
 ++        return 117;
 ++    case ENOTNAM:
 ++        return 118;
 ++    case ENAVAIL:
 ++        return 119;
 ++    case EISNAM:
 ++        return 120;
 ++    case EREMOTEIO:
 ++        return 121;
 ++# endif
 ++    case EDQUOT:
 ++        return 122;
 ++# if 0
 ++    case ENOMEDIUM:
 ++        return 123;
 ++    case EMEDIUMTYPE:
 ++        return 124;
 ++# endif
 ++    case ECANCELED:
 ++        return 125;
 ++# if 0
 ++    case ENOKEY:
 ++        return 126;
 ++    case EKEYEXPIRED:
 ++        return 127;
 ++    case EKEYREVOKED:
 ++        return 128;
 ++    case EKEYREJECTED:
 ++        return 129;
 ++    case EOWNERDEAD:
 ++        return 130;
 ++    case ENOTRECOVERABLE:
 ++        return 131;
 ++    case ERFKILL:
 ++        return 132;
 ++    case EHWPOISON:
 ++        return 133;
 ++# endif
 ++        /* extras */
 ++    case ENOTSUP:
 ++        return EOPNOTSUPP;
 ++    case ENOATTR:
 ++        return ENODATA;
 ++    default:
 ++        return EIO;
 ++    }
 + #elif defined(CONFIG_DARWIN)
 +     /*
 +      * translation mandatory for macOS hosts
 +@@ -154,13 +446,13 @@ static inline int openat_file(int dirfd,
 + {
 +     int fd, serrno, ret;
 +=20
 +-#ifndef CONFIG_DARWIN
 ++#ifdef O_NOATIME
 + again:
 + #endif
 +     fd =3D qemu_openat(dirfd, name, flags | O_NOFOLLOW | O_NOCTTY | O_NON=
 BLOCK,
 +                      mode);
 +     if (fd =3D=3D -1) {
 +-#ifndef CONFIG_DARWIN
 ++#ifdef O_NOATIME
 +         if (errno =3D=3D EPERM && (flags & O_NOATIME)) {
 +             /*
 +              * The client passed O_NOATIME but we lack permissions to hon=
 or it.
 +@@ -209,6 +501,7 @@ ssize_t fremovexattrat_nofollow(int dirf
 +  * so ensure it is manually injected earlier and call here when
 +  * needed.
 +  */
 ++#if defined(CONFIG_LINUX) || defined(CONFIG_DARWIN)
 + static inline off_t qemu_dirent_off(struct dirent *dent)
 + {
 + #ifdef CONFIG_DARWIN
 +@@ -217,6 +510,7 @@ static inline off_t qemu_dirent_off(stru
 +     return dent->d_off;
 + #endif
 + }
 ++#endif
 +=20
 + /**
 +  * qemu_dirent_dup() - Duplicate directory entry @dent.
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_9p.c b/emulators/qemu/pat=
 ches/patch-hw_9pfs_9p.c
 new file mode 100644
 index 000000000000..4f11728745ea
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_9p.c
 @@ -0,0 +1,93 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/9p.c.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/9p.c
 +@@ -136,8 +136,10 @@ static int dotl_to_open_flags(int flags)
 +         { P9_DOTL_NONBLOCK, O_NONBLOCK } ,
 +         { P9_DOTL_DSYNC, O_DSYNC },
 +         { P9_DOTL_FASYNC, FASYNC },
 +-#ifndef CONFIG_DARWIN
 ++#ifdef O_NOATIME
 +         { P9_DOTL_NOATIME, O_NOATIME },
 ++#endif
 ++#ifndef CONFIG_DARWIN
 +         /*
 +          *  On Darwin, we could map to F_NOCACHE, which is
 +          *  similar, but doesn't quite have the same
 +@@ -2293,6 +2295,13 @@ static int coroutine_fn v9fs_do_readdir_
 +         if (err || !dent) {
 +             break;
 +         }
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        const off_t next_dir_pos =3D v9fs_co_telldir(pdu, fidp);
 ++        if (next_dir_pos < 0) {
 ++            err =3D next_dir_pos;
 ++            break;
 ++        }
 ++#endif
 +         err =3D v9fs_co_name_to_path(pdu, &fidp->path, dent->d_name, &pat=
 h);
 +         if (err < 0) {
 +             break;
 +@@ -2329,7 +2338,11 @@ static int coroutine_fn v9fs_do_readdir_
 +         count +=3D len;
 +         v9fs_stat_free(&v9stat);
 +         v9fs_path_free(&path);
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        saved_dir_pos =3D next_dir_pos;
 ++#else
 +         saved_dir_pos =3D qemu_dirent_off(dent);
 ++#endif
 +     }
 +=20
 +     v9fs_readdir_unlock(&fidp->fs.dir);
 +@@ -2530,7 +2543,11 @@ static int coroutine_fn v9fs_do_readdir(
 +             qid.version =3D 0;
 +         }
 +=20
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        off =3D e->dirent_off;
 ++#else
 +         off =3D qemu_dirent_off(dent);
 ++#endif
 +         v9fs_string_init(&name);
 +         v9fs_string_sprintf(&name, "%s", dent->d_name);
 +=20
 +@@ -3575,7 +3592,11 @@ static int v9fs_fill_statfs(V9fsState *s
 +     if (!bsize_factor) {
 +         bsize_factor =3D 1;
 +     }
 ++#ifdef __NetBSD__
 ++    f_type  =3D 0;                /* XXX struct statvfs::f_type? (fstypen=
 ame?) */
 ++#else
 +     f_type  =3D stbuf->f_type;
 ++#endif
 +     f_bsize =3D stbuf->f_bsize;
 +     f_bsize *=3D bsize_factor;
 +     /*
 +@@ -3592,10 +3613,14 @@ static int v9fs_fill_statfs(V9fsState *s
 +     fsid_val =3D (unsigned int)stbuf->f_fsid.val[0] |
 +                (unsigned long long)stbuf->f_fsid.val[1] << 32;
 +     f_namelen =3D NAME_MAX;
 +-#else
 ++#elif defined CONFIG_LINUX
 +     fsid_val =3D (unsigned int) stbuf->f_fsid.__val[0] |
 +                (unsigned long long)stbuf->f_fsid.__val[1] << 32;
 +     f_namelen =3D stbuf->f_namelen;
 ++#elif defined __NetBSD__
 ++    fsid_val =3D (unsigned int) stbuf->f_fsidx.__fsid_val[0] |
 ++               (unsigned long long)stbuf->f_fsidx.__fsid_val[1] << 32;
 ++    f_namelen =3D NAME_MAX;
 + #endif
 +=20
 +     return pdu_marshal(pdu, offset, "ddqqqqqqd",
 +@@ -3966,7 +3991,7 @@ out_nofid:
 +     v9fs_string_free(&name);
 + }
 +=20
 +-#if defined(CONFIG_LINUX)
 ++#if defined(CONFIG_LINUX) || defined(__NetBSD__)
 + /* Currently, only Linux has XATTR_SIZE_MAX */
 + #define P9_XATTR_SIZE_MAX XATTR_SIZE_MAX
 + #elif defined(CONFIG_DARWIN)
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_9p.h b/emulators/qemu/pat=
 ches/patch-hw_9pfs_9p.h
 new file mode 100644
 index 000000000000..3d1537a262cd
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_9p.h
 @@ -0,0 +1,16 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/9p.h.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/9p.h
 +@@ -238,6 +238,9 @@ static inline void v9fs_readdir_init(P9P
 + typedef struct V9fsDirEnt {
 +     /* mandatory (must not be NULL) information for all readdir requests =
 */
 +     struct dirent *dent;
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++    off_t dirent_off;
 ++#endif
 +     /*
 +      * optional (may be NULL): A full stat of each directory entry is just
 +      * done if explicitly told to fs driver.
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_codir.c b/emulators/qemu/=
 patches/patch-hw_9pfs_codir.c
 new file mode 100644
 index 000000000000..8db91eeeb430
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_codir.c
 @@ -0,0 +1,42 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/codir.c.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/codir.c
 +@@ -122,6 +122,13 @@ do_readdir_many(V9fsPDU *pdu, V9fsFidSta
 +         if (err || !dent) {
 +             break;
 +         }
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        const off_t dirent_off =3D s->ops->telldir(&s->ctx, &fidp->fs);
 ++        if (dirent_off < 0) {
 ++            err =3D dirent_off;
 ++            break;
 ++        }
 ++#endif
 +=20
 +         /*
 +          * stop this loop as soon as it would exceed the allowed maximum
 +@@ -145,6 +152,9 @@ do_readdir_many(V9fsPDU *pdu, V9fsFidSta
 +             e =3D e->next =3D g_new0(V9fsDirEnt, 1);
 +         }
 +         e->dent =3D qemu_dirent_dup(dent);
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        e->dirent_off =3D dirent_off;
 ++#endif
 +=20
 +         /* perform a full stat() for directory entry if requested by call=
 er */
 +         if (dostat) {
 +@@ -167,7 +177,11 @@ do_readdir_many(V9fsPDU *pdu, V9fsFidSta
 +         }
 +=20
 +         size +=3D len;
 ++#if !defined(CONFIG_LINUX) && !defined(CONFIG_DARWIN)
 ++        saved_dir_pos =3D dirent_off;
 ++#else
 +         saved_dir_pos =3D qemu_dirent_off(dent);
 ++#endif
 +     }
 +=20
 +     /* restore (last) saved position */
 diff --git a/emulators/qemu/patches/patch-hw_9pfs_meson.build b/emulators/q=
 emu/patches/patch-hw_9pfs_meson.build
 new file mode 100644
 index 000000000000..d5f74a558135
 --- /dev/null
 +++ b/emulators/qemu/patches/patch-hw_9pfs_meson.build
 @@ -0,0 +1,15 @@
 +$NetBSD$
 +
 +Add BSD support for fsdev 9p.
 +
 +--- hw/9pfs/meson.build.orig	2024-12-10 23:46:36.000000000 +0000
 ++++ hw/9pfs/meson.build
 +@@ -14,7 +14,7 @@ fs_ss.add(files(
 + ))
 + if host_os =3D=3D 'darwin'
 +   fs_ss.add(files('9p-util-darwin.c'))
 +-elif host_os =3D=3D 'linux'
 ++elif host_os =3D=3D 'linux' or host_os =3D=3D 'netbsd'
 +   fs_ss.add(files('9p-util-linux.c'))
 + endif
 + fs_ss.add(when: 'CONFIG_XEN_BUS', if_true: files('xen-9p-backend.c'))
 diff --git a/emulators/qemu/patches/patch-meson.build b/emulators/qemu/patc=
 hes/patch-meson.build
 index bf2e3d5a7cde..418e2a61f458 100644
 --- a/emulators/qemu/patches/patch-meson.build
 +++ b/emulators/qemu/patches/patch-meson.build
 @@ -3,10 +3,11 @@ $NetBSD: patch-meson.build,v 1.15 2024/04/24 07:20:59 ada=
 m Exp $
  * Detect iconv in libc properly for pkgsrc (pkgsrc removes -liconv)
    to fix qemu-system-aarch64 link.
  * Detect curses (non-ncurses{,w} too)
 +* Allow building fsdev on non-Linux/Darwin
 =20
 ---- meson.build.orig	2024-04-10 17:43:26.000000000 +0000
 +--- meson.build.orig	2024-12-10 23:46:36.000000000 +0000
  +++ meson.build
 -@@ -1329,7 +1329,7 @@ if have_system and get_option('curses').
 +@@ -1471,7 +1471,7 @@ if have_system and get_option('curses').
         has_curses_h =3D cc.has_header('curses.h', args: curses_compile_arg=
 s)
       endif
       if has_curses_h
 @@ -15,7 +16,7 @@ $NetBSD: patch-meson.build,v 1.15 2024/04/24 07:20:59 ada=
 m Exp $
         foreach curses_libname : curses_libname_list
           libcurses =3D cc.find_library(curses_libname,
                                       required: false)
 -@@ -1346,7 +1346,7 @@ if have_system and get_option('curses').
 +@@ -1488,7 +1488,7 @@ if have_system and get_option('curses').
       endif
     endif
     if get_option('iconv').allowed()
 @@ -24,3 +25,16 @@ $NetBSD: patch-meson.build,v 1.15 2024/04/24 07:20:59 ad=
 am Exp $
         # Programs will be linked with glib and this will bring in libiconv=
  on FreeBSD.
         # We need to use libiconv if available because mixing libiconv's he=
 aders with
         # the system libc does not work.
 +@@ -2318,9 +2318,9 @@ dbus_display =3D get_option('dbus_display'
 +   .allowed()
 +=20
 + have_virtfs =3D get_option('virtfs') \
 +-    .require(host_os =3D=3D 'linux' or host_os =3D=3D 'darwin',
 +-             error_message: 'virtio-9p (virtfs) requires Linux or macOS')=
  \
 +-    .require(host_os =3D=3D 'linux' or cc.has_function('pthread_fchdir_np=
 '),
 ++    .require(host_os =3D=3D 'linux' or host_os =3D=3D 'darwin' or host_os=
  =3D=3D 'netbsd',
 ++             error_message: 'virtio-9p (virtfs) requires Linux, macOS, or=
  NetBSD') \
 ++    .require(host_os !=3D 'darwin' or cc.has_function('pthread_fchdir_np'=
 ),
 +              error_message: 'virtio-9p (virtfs) on macOS requires the pre=
 sence of pthread_fchdir_np') \
 +     .require(host_os =3D=3D 'darwin' or libattr.found(),
 +              error_message: 'virtio-9p (virtfs) on Linux requires libattr=
 -devel') \
 
 --=_fvz4bw6Sgb7EvIjKFB6Nr1oMeWUc8Daj--
 


Home | Main Index | Thread Index | Old Index