003 File Manager
Current Path:
/usr/local/lib/perl5/site_perl/mach/5.32/sys
usr
/
local
/
lib
/
perl5
/
site_perl
/
mach
/
5.32
/
sys
/
📁
..
📄
_atomic64e.ph
(1.7 KB)
📄
_atomic_subword.ph
(5.32 KB)
📄
_bitset.ph
(834 B)
📄
_blockcount.ph
(809 B)
📄
_bus_dma.ph
(324 B)
📄
_callout.ph
(199 B)
📄
_cpuset.ph
(487 B)
📄
_cscan_atomic.ph
(29.03 KB)
📄
_cscan_bus.ph
(13.04 KB)
📄
_domainset.ph
(547 B)
📄
_eventhandler.ph
(738 B)
📄
_ffcounter.ph
(180 B)
📄
_iovec.ph
(316 B)
📄
_lock.ph
(1.19 KB)
📄
_lockmgr.ph
(276 B)
📄
_mutex.ph
(200 B)
📄
_null.ph
(651 B)
📄
_pctrie.ph
(171 B)
📄
_pthreadtypes.ph
(317 B)
📄
_rangeset.ph
(204 B)
📄
_rmlock.ph
(485 B)
📄
_rwlock.ph
(203 B)
📄
_semaphore.ph
(285 B)
📄
_seqc.ph
(165 B)
📄
_sigset.ph
(858 B)
📄
_smr.ph
(908 B)
📄
_sockaddr_storage.ph
(665 B)
📄
_stack.ph
(230 B)
📄
_stdarg.ph
(1.09 KB)
📄
_stdint.ph
(1.62 KB)
📄
_sx.ph
(159 B)
📄
_task.ph
(578 B)
📄
_termios.ph
(7.26 KB)
📄
_timespec.ph
(325 B)
📄
_timeval.ph
(456 B)
📄
_types.ph
(944 B)
📄
_ucontext.ph
(177 B)
📄
_uio.ph
(548 B)
📄
_umtx.ph
(265 B)
📄
_unrhdr.ph
(193 B)
📄
_winsize.ph
(174 B)
📄
aac_ioctl.ph
(7.36 KB)
📄
abi_compat.ph
(1.81 KB)
📄
acct.ph
(859 B)
📄
acl.ph
(6.91 KB)
📄
agpio.ph
(5.3 KB)
📄
aio.ph
(2.17 KB)
📄
alq.ph
(648 B)
📄
apm.ph
(87 B)
📄
arb.ph
(35.53 KB)
📄
assym.ph
(1.5 KB)
📄
ata.ph
(50.51 KB)
📄
atomic_common.ph
(3.28 KB)
📄
auxv.ph
(220 B)
📄
backlight.ph
(903 B)
📄
bio.ph
(2.23 KB)
📄
bitset.ph
(9.24 KB)
📄
bitstring.ph
(1.61 KB)
📄
blist.ph
(552 B)
📄
blockcount.ph
(1.6 KB)
📄
boot.ph
(247 B)
📄
buf.ph
(11.05 KB)
📄
buf_ring.ph
(1.55 KB)
📄
bufobj.ph
(2.18 KB)
📄
bus.ph
(24.54 KB)
📄
bus_dma.ph
(4.55 KB)
📄
bus_dma_internal.ph
(186 B)
📄
busdma_bufalloc.ph
(262 B)
📄
callout.ph
(5.06 KB)
📄
caprights.ph
(534 B)
📄
capsicum.ph
(12.44 KB)
📄
cdefs.ph
(33.03 KB)
📄
cdio.ph
(5.68 KB)
📄
cdrio.ph
(3.6 KB)
📄
cfictl.ph
(741 B)
📄
chio.ph
(6.57 KB)
📄
ck.ph
(503 B)
📄
clock.ph
(990 B)
📄
cnv.ph
(540 B)
📄
compressor.ph
(349 B)
📄
condvar.ph
(1.85 KB)
📄
conf.ph
(4.53 KB)
📄
cons.ph
(1.59 KB)
📄
consio.ph
(17.3 KB)
📄
copyright.ph
(608 B)
📄
counter.ph
(1.61 KB)
📄
coverage.ph
(745 B)
📄
cpu.ph
(2.36 KB)
📄
cpuctl.ph
(1.04 KB)
📄
cpuset.ph
(4.91 KB)
📄
csan.ph
(349 B)
📄
ctf.ph
(8.35 KB)
📄
ctf_api.ph
(1.04 KB)
📄
ctype.ph
(1.51 KB)
📄
devctl.ph
(168 B)
📄
devicestat.ph
(4.25 KB)
📄
devmap.ph
(352 B)
📄
dirent.ph
(1.88 KB)
📄
disk.ph
(2.75 KB)
📄
disk_zone.ph
(4.48 KB)
📄
disklabel.ph
(1.75 KB)
📄
diskmbr.ph
(329 B)
📄
dkstat.ph
(199 B)
📄
dnv.ph
(427 B)
📄
domain.ph
(1.16 KB)
📄
domainset.ph
(5.58 KB)
📄
dtrace.ph
(52.95 KB)
📄
dtrace_bsd.ph
(177 B)
📄
dvdio.ph
(2.61 KB)
📄
efi.ph
(3.33 KB)
📄
efiio.ph
(821 B)
📄
elf.ph
(273 B)
📄
elf32.ph
(1.41 KB)
📄
elf64.ph
(1.91 KB)
📄
elf_common.ph
(85.24 KB)
📄
elf_generic.ph
(2.06 KB)
📄
endian.ph
(5.87 KB)
📄
epoch.ph
(2.43 KB)
📄
errno.ph
(6.93 KB)
📄
eui64.ph
(323 B)
📄
event.ph
(7.54 KB)
📄
eventfd.ph
(458 B)
📄
eventhandler.ph
(4.88 KB)
📄
eventvar.ph
(858 B)
📄
exec.ph
(1.19 KB)
📄
extattr.ph
(1.12 KB)
📄
fail.ph
(5.77 KB)
📄
fbio.ph
(17.58 KB)
📄
fcntl.ph
(9.1 KB)
📄
fdcio.ph
(5.37 KB)
📄
file.ph
(6.54 KB)
📄
filedesc.ph
(6.85 KB)
📄
filio.ph
(1.99 KB)
📄
firmware.ph
(332 B)
📄
fnv_hash.ph
(1.52 KB)
📄
font.ph
(930 B)
📄
gmon.ph
(2.57 KB)
📄
gpio.ph
(3.4 KB)
📄
gpt.ph
(300 B)
📄
gsb_crc32.ph
(744 B)
📄
gtaskqueue.ph
(1.85 KB)
📄
hash.ph
(440 B)
📄
hhook.ph
(1.42 KB)
📄
iconv.ph
(4.33 KB)
📄
imgact.ph
(476 B)
📄
imgact_aout.ph
(4.63 KB)
📄
imgact_binmisc.ph
(1.75 KB)
📄
imgact_elf.ph
(1.45 KB)
📄
interrupt.ph
(1.45 KB)
📄
intr.ph
(1.61 KB)
📄
ioccom.ph
(2.62 KB)
📄
ioctl.ph
(387 B)
📄
ioctl_compat.ph
(5.35 KB)
📄
iov.ph
(1.34 KB)
📄
iov_schema.ph
(358 B)
📄
ipc.ph
(2.21 KB)
📄
ipmi.ph
(6.15 KB)
📄
jail.ph
(7.65 KB)
📄
joystick.ph
(819 B)
📄
kbio.ph
(8.69 KB)
📄
kcov.ph
(1.19 KB)
📄
kdb.ph
(2.3 KB)
📄
kenv.ph
(578 B)
📄
kern_prefetch.ph
(385 B)
📄
kernel.ph
(13.29 KB)
📄
kerneldump.ph
(3.28 KB)
📄
khelp.ph
(325 B)
📄
kobj.ph
(3.16 KB)
📄
kpilite.ph
(860 B)
📄
ksem.ph
(432 B)
📄
kthread.ph
(199 B)
📄
ktls.ph
(1.67 KB)
📄
ktr.ph
(12.26 KB)
📄
ktr_class.ph
(2.53 KB)
📄
ktrace.ph
(4.95 KB)
📄
libkern.ph
(3.61 KB)
📄
limits.ph
(2.99 KB)
📄
link_aout.ph
(4.54 KB)
📄
link_elf.ph
(971 B)
📄
linker.ph
(3.66 KB)
📄
linker_set.ph
(2.81 KB)
📄
lock.ph
(10.56 KB)
📄
lock_profile.ph
(1.31 KB)
📄
lockf.ph
(307 B)
📄
lockmgr.ph
(6.64 KB)
📄
lockstat.ph
(4.38 KB)
📄
loginclass.ph
(180 B)
📄
mac.ph
(740 B)
📄
malloc.ph
(3.64 KB)
📄
mbuf.ph
(33.44 KB)
📄
mchain.ph
(494 B)
📄
md4.ph
(213 B)
📄
md5.ph
(497 B)
📄
mdioctl.ph
(1.7 KB)
📄
memdesc.ph
(2.53 KB)
📄
memrange.ph
(1.99 KB)
📄
mman.ph
(9.09 KB)
📄
module.ph
(4.84 KB)
📄
module_khelp.ph
(1.18 KB)
📄
mount.ph
(22.18 KB)
📄
mouse.ph
(15.1 KB)
📄
mpt_ioctl.ph
(1.95 KB)
📄
mqueue.ph
(202 B)
📄
msg.ph
(1.24 KB)
📄
msgbuf.ph
(993 B)
📄
mtio.ph
(8.56 KB)
📄
mutex.ph
(17.47 KB)
📄
namei.ph
(7.81 KB)
📄
nlist_aout.ph
(1.88 KB)
📄
nv.ph
(2.02 KB)
📄
nvpair.ph
(4.36 KB)
📄
osd.ph
(3.22 KB)
📄
param.ph
(9.24 KB)
📄
pciio.ph
(2.92 KB)
📄
pcpu.ph
(6.97 KB)
📄
pctrie.ph
(2.74 KB)
📄
physmem.ph
(886 B)
📄
pidctrl.ph
(435 B)
📄
pipe.ph
(2.25 KB)
📄
pmc.ph
(22.72 KB)
📄
pmckern.ph
(6.13 KB)
📄
pmclog.ph
(3.2 KB)
📄
poll.ph
(1.58 KB)
📄
posix4.ph
(1.2 KB)
📄
power.ph
(986 B)
📄
priority.ph
(3.44 KB)
📄
priv.ph
(19.61 KB)
📄
prng.ph
(328 B)
📄
proc.ph
(30.83 KB)
📄
procctl.ph
(4.3 KB)
📄
procdesc.ph
(1.48 KB)
📄
procfs.ph
(535 B)
📄
protosw.ph
(4.83 KB)
📄
ptio.ph
(395 B)
📄
ptrace.ph
(4.63 KB)
📄
qmath.ph
(19.54 KB)
📄
queue.ph
(30.6 KB)
📄
racct.ph
(6.48 KB)
📄
random.ph
(4.47 KB)
📄
rangelock.ph
(1.45 KB)
📄
rangeset.ph
(234 B)
📄
rctl.ph
(4.19 KB)
📄
reboot.ph
(1.86 KB)
📄
refcount.ph
(4.03 KB)
📄
regression.ph
(218 B)
📄
resource.ph
(3.04 KB)
📄
resourcevar.ph
(1.14 KB)
📄
rman.ph
(1.89 KB)
📄
rmlock.ph
(4.18 KB)
📄
rtprio.ph
(1.44 KB)
📄
runq.ph
(296 B)
📄
rwlock.ph
(10.78 KB)
📄
sbuf.ph
(1.55 KB)
📄
sched.ph
(3.04 KB)
📄
sdt.ph
(21.91 KB)
📄
select.ph
(2.28 KB)
📄
selinfo.ph
(371 B)
📄
sem.ph
(1.97 KB)
📄
sema.ph
(919 B)
📄
seqc.ph
(2.19 KB)
📄
serial.ph
(2.12 KB)
📄
sf_buf.ph
(2.32 KB)
📄
sglist.ph
(715 B)
📄
shm.ph
(1.8 KB)
📄
sigio.ph
(323 B)
📄
signal.ph
(12.78 KB)
📄
signalvar.ph
(9.63 KB)
📄
sleepqueue.ph
(975 B)
📄
slicer.ph
(1000 B)
📄
smp.ph
(3.05 KB)
📄
smr.ph
(1.49 KB)
📄
smr_types.ph
(2.14 KB)
📄
snoop.ph
(625 B)
📄
sockbuf.ph
(4.14 KB)
📄
socket.ph
(20.01 KB)
📄
socketvar.ph
(7.29 KB)
📄
sockio.ph
(8.23 KB)
📄
sockopt.ph
(375 B)
📄
soundcard.ph
(66.67 KB)
📄
specialfd.ph
(257 B)
📄
spigenio.ph
(1.06 KB)
📄
stack.ph
(845 B)
📄
stat.ph
(9.2 KB)
📄
stats.ph
(30.3 KB)
📄
statvfs.ph
(485 B)
📄
stdatomic.ph
(15.26 KB)
📄
stddef.ph
(518 B)
📄
stdint.ph
(915 B)
📄
sx.ph
(10.75 KB)
📄
syscall.ph
(28.09 KB)
📄
syscallsubr.ph
(521 B)
📄
sysctl.ph
(46.96 KB)
📄
sysent.ph
(6.09 KB)
📄
syslimits.ph
(1.32 KB)
📄
syslog.ph
(4.03 KB)
📄
sysproto.ph
(43.73 KB)
📄
systm.ph
(12.58 KB)
📄
taskqueue.ph
(3.65 KB)
📄
terminal.ph
(5.68 KB)
📄
termios.ph
(223 B)
📄
thr.ph
(691 B)
📄
tiio.ph
(4.04 KB)
📄
tim_filter.ph
(540 B)
📄
time.ph
(12.88 KB)
📄
timeb.ph
(488 B)
📄
timeet.ph
(996 B)
📄
timeffc.ph
(3.86 KB)
📄
timepps.ph
(5.73 KB)
📄
timers.ph
(1.15 KB)
📄
times.ph
(379 B)
📄
timespec.ph
(735 B)
📄
timetc.ph
(444 B)
📄
timex.ph
(3.16 KB)
📄
tree.ph
(29.45 KB)
📄
tslog.ph
(2.24 KB)
📄
tty.ph
(3.84 KB)
📄
ttycom.ph
(5.65 KB)
📄
ttydefaults.ph
(2.62 KB)
📄
ttydevsw.ph
(2.84 KB)
📄
ttydisc.ph
(1.02 KB)
📄
ttyhook.ph
(2.25 KB)
📄
ttyqueue.ph
(2.15 KB)
📄
turnstile.ph
(357 B)
📄
types.ph
(7.97 KB)
📄
ucontext.ph
(695 B)
📄
ucred.ph
(1.19 KB)
📄
uio.ph
(681 B)
📄
umtx.ph
(6.12 KB)
📄
un.ph
(1.07 KB)
📄
unistd.ph
(7.59 KB)
📄
unpcb.ph
(1.19 KB)
📄
user.ph
(8.58 KB)
📄
utsname.ph
(553 B)
📄
uuid.ph
(543 B)
📄
vdso.ph
(1.28 KB)
📄
vmem.ph
(643 B)
📄
vmmeter.ph
(2.21 KB)
📄
vnode.ph
(24.18 KB)
📄
vtoc.ph
(88 B)
📄
wait.ph
(4.11 KB)
📄
watchdog.ph
(2.72 KB)
Editing: mount.ph
require '_h2ph_pre.ph'; no warnings qw(redefine misc); unless(defined(&_SYS_MOUNT_H_)) { eval 'sub _SYS_MOUNT_H_ () {1;}' unless defined(&_SYS_MOUNT_H_); require 'sys/ucred.ph'; require 'sys/queue.ph'; if(defined(&_KERNEL)) { require 'sys/lock.ph'; require 'sys/lockmgr.ph'; require 'sys/tslog.ph'; require 'sys/_mutex.ph'; require 'sys/_sx.ph'; } eval 'sub fsidcmp { my($a, $b) = @_; eval q( &memcmp(($a), ($b), $sizeof{ &fsid_t})); }' unless defined(&fsidcmp); eval 'sub MAXFIDSZ () {16;}' unless defined(&MAXFIDSZ); eval 'sub MFSNAMELEN () {16;}' unless defined(&MFSNAMELEN); eval 'sub MNAMELEN () {1024;}' unless defined(&MNAMELEN); eval 'sub STATFS_VERSION () {0x20140518;}' unless defined(&STATFS_VERSION); if(defined(&_WANT_FREEBSD11_STATFS) || defined(&_KERNEL)) { eval 'sub FREEBSD11_STATFS_VERSION () {0x20030518;}' unless defined(&FREEBSD11_STATFS_VERSION); } if(defined(&_KERNEL)) { eval 'sub OMFSNAMELEN () {16;}' unless defined(&OMFSNAMELEN); eval 'sub OMNAMELEN () {(88- 2* $sizeof{\'long\'});}' unless defined(&OMNAMELEN); eval 'sub mnt_startzero () { &mnt_list;}' unless defined(&mnt_startzero); eval 'sub mnt_endzero () { &mnt_gjprovider;}' unless defined(&mnt_endzero); eval 'sub MNT_VNODE_FOREACH_ALL { my($vp, $mp, $mvp) = @_; eval q( &for ($vp = &__mnt_vnode_first_all(($mvp), ($mp)); ($vp) != &NULL; $vp = &__mnt_vnode_next_all(($mvp), ($mp)))); }' unless defined(&MNT_VNODE_FOREACH_ALL); eval 'sub MNT_VNODE_FOREACH_ALL_ABORT { my($mp, $mvp) = @_; eval q( &do { &MNT_ILOCK($mp); &__mnt_vnode_markerfree_all(($mvp), ($mp)); &mtx_assert( &MNT_MTX($mp), &MA_NOTOWNED); } &while (0)); }' unless defined(&MNT_VNODE_FOREACH_ALL_ABORT); eval 'sub MNT_VNODE_FOREACH_LAZY { my($vp, $mp, $mvp, $cb, $cbarg) = @_; eval q( &for ($vp = &__mnt_vnode_first_lazy(($mvp), ($mp), ($cb), ($cbarg)); ($vp) != &NULL; $vp = &__mnt_vnode_next_lazy(($mvp), ($mp), ($cb), ($cbarg)))); }' unless defined(&MNT_VNODE_FOREACH_LAZY); eval 'sub MNT_VNODE_FOREACH_LAZY_ABORT { my($mp, $mvp) = @_; eval q( &__mnt_vnode_markerfree_lazy(($mvp), ($mp))); }' unless defined(&MNT_VNODE_FOREACH_LAZY_ABORT); eval 'sub MNT_ILOCK { my($mp) = @_; eval q( &mtx_lock(($mp)-> &mnt_mtx)); }' unless defined(&MNT_ILOCK); eval 'sub MNT_ITRYLOCK { my($mp) = @_; eval q( &mtx_trylock(($mp)-> &mnt_mtx)); }' unless defined(&MNT_ITRYLOCK); eval 'sub MNT_IUNLOCK { my($mp) = @_; eval q( &mtx_unlock(($mp)-> &mnt_mtx)); }' unless defined(&MNT_IUNLOCK); eval 'sub MNT_MTX { my($mp) = @_; eval q((($mp)-> &mnt_mtx)); }' unless defined(&MNT_MTX); eval 'sub MNT_REF { my($mp) = @_; eval q( &do { &mtx_assert( &MNT_MTX($mp), &MA_OWNED); ($mp->{mnt_ref})++; } &while (0)); }' unless defined(&MNT_REF); eval 'sub MNT_REL { my($mp) = @_; eval q( &do { &mtx_assert( &MNT_MTX($mp), &MA_OWNED); ($mp)-> &mnt_ref--; &if (($mp)-> &mnt_vfs_ops && ($mp)-> &mnt_ref < 0) &vfs_dump_mount_counters($mp); &if (($mp)-> &mnt_ref == 0 && ($mp)-> &mnt_vfs_ops) &wakeup(($mp)); } &while (0)); }' unless defined(&MNT_REL); } if(defined(&_WANT_MNTOPTNAMES) || defined(&_KERNEL)) { eval 'sub MNTOPT_NAMES () {{ &MNT_ASYNC, "asynchronous" }, { &MNT_EXPORTED, "NFS exported" }, { &MNT_LOCAL, "local" }, { &MNT_NOATIME, "noatime" }, { &MNT_NOEXEC, "noexec" }, { &MNT_NOSUID, "nosuid" }, { &MNT_NOSYMFOLLOW, "nosymfollow" }, { &MNT_QUOTA, "with quotas" }, { &MNT_RDONLY, "read-only" }, { &MNT_SYNCHRONOUS, "synchronous" }, { &MNT_UNION, "union" }, { &MNT_NOCLUSTERR, "noclusterr" }, { &MNT_NOCLUSTERW, "noclusterw" }, { &MNT_SUIDDIR, "suiddir" }, { &MNT_SOFTDEP, "soft-updates" }, { &MNT_SUJ, "journaled soft-updates" }, { &MNT_MULTILABEL, "multilabel" }, { &MNT_ACLS, "acls" }, { &MNT_NFS4ACLS, "nfsv4acls" }, { &MNT_GJOURNAL, "gjournal" }, { &MNT_AUTOMOUNTED, "automounted" }, { &MNT_VERIFIED, "verified" }, { &MNT_UNTRUSTED, "untrusted" }, { &MNT_NOCOVER, "nocover" }, { &MNT_EMPTYDIR, "emptydir" }, { &MNT_UPDATE, "update" }, { &MNT_DELEXPORT, "delexport" }, { &MNT_RELOAD, "reload" }, { &MNT_FORCE, "force" }, { &MNT_SNAPSHOT, "snapshot" }, { 0, &NULL };}' unless defined(&MNTOPT_NAMES); } eval 'sub MNT_RDONLY () {0x1;}' unless defined(&MNT_RDONLY); eval 'sub MNT_SYNCHRONOUS () {0x2;}' unless defined(&MNT_SYNCHRONOUS); eval 'sub MNT_NOEXEC () {0x4;}' unless defined(&MNT_NOEXEC); eval 'sub MNT_NOSUID () {0x8;}' unless defined(&MNT_NOSUID); eval 'sub MNT_NFS4ACLS () {0x10;}' unless defined(&MNT_NFS4ACLS); eval 'sub MNT_UNION () {0x20;}' unless defined(&MNT_UNION); eval 'sub MNT_ASYNC () {0x40;}' unless defined(&MNT_ASYNC); eval 'sub MNT_SUIDDIR () {0x100000;}' unless defined(&MNT_SUIDDIR); eval 'sub MNT_SOFTDEP () {0x200000;}' unless defined(&MNT_SOFTDEP); eval 'sub MNT_NOSYMFOLLOW () {0x400000;}' unless defined(&MNT_NOSYMFOLLOW); eval 'sub MNT_GJOURNAL () {0x2000000;}' unless defined(&MNT_GJOURNAL); eval 'sub MNT_MULTILABEL () {0x4000000;}' unless defined(&MNT_MULTILABEL); eval 'sub MNT_ACLS () {0x8000000;}' unless defined(&MNT_ACLS); eval 'sub MNT_NOATIME () {0x10000000;}' unless defined(&MNT_NOATIME); eval 'sub MNT_NOCLUSTERR () {0x40000000;}' unless defined(&MNT_NOCLUSTERR); eval 'sub MNT_NOCLUSTERW () {0x80000000;}' unless defined(&MNT_NOCLUSTERW); eval 'sub MNT_SUJ () {0x100000000;}' unless defined(&MNT_SUJ); eval 'sub MNT_AUTOMOUNTED () {0x200000000;}' unless defined(&MNT_AUTOMOUNTED); eval 'sub MNT_UNTRUSTED () {0x800000000;}' unless defined(&MNT_UNTRUSTED); eval 'sub MNT_EXRDONLY () {0x80;}' unless defined(&MNT_EXRDONLY); eval 'sub MNT_EXPORTED () {0x100;}' unless defined(&MNT_EXPORTED); eval 'sub MNT_DEFEXPORTED () {0x200;}' unless defined(&MNT_DEFEXPORTED); eval 'sub MNT_EXPORTANON () {0x400;}' unless defined(&MNT_EXPORTANON); eval 'sub MNT_EXKERB () {0x800;}' unless defined(&MNT_EXKERB); eval 'sub MNT_EXPUBLIC () {0x20000000;}' unless defined(&MNT_EXPUBLIC); eval 'sub MNT_EXTLS () {0x4000000000;}' unless defined(&MNT_EXTLS); eval 'sub MNT_EXTLSCERT () {0x8000000000;}' unless defined(&MNT_EXTLSCERT); eval 'sub MNT_EXTLSCERTUSER () {0x10000000000;}' unless defined(&MNT_EXTLSCERTUSER); eval 'sub MNT_LOCAL () {0x1000;}' unless defined(&MNT_LOCAL); eval 'sub MNT_QUOTA () {0x2000;}' unless defined(&MNT_QUOTA); eval 'sub MNT_ROOTFS () {0x4000;}' unless defined(&MNT_ROOTFS); eval 'sub MNT_USER () {0x8000;}' unless defined(&MNT_USER); eval 'sub MNT_IGNORE () {0x800000;}' unless defined(&MNT_IGNORE); eval 'sub MNT_VERIFIED () {0x400000000;}' unless defined(&MNT_VERIFIED); eval 'sub MNT_VISFLAGMASK () {( &MNT_RDONLY | &MNT_SYNCHRONOUS | &MNT_NOEXEC | &MNT_NOSUID | &MNT_UNION | &MNT_SUJ | &MNT_ASYNC | &MNT_EXRDONLY | &MNT_EXPORTED | &MNT_DEFEXPORTED | &MNT_EXPORTANON| &MNT_EXKERB | &MNT_LOCAL | &MNT_USER | &MNT_QUOTA | &MNT_ROOTFS | &MNT_NOATIME | &MNT_NOCLUSTERR| &MNT_NOCLUSTERW | &MNT_SUIDDIR | &MNT_SOFTDEP | &MNT_IGNORE | &MNT_EXPUBLIC | &MNT_NOSYMFOLLOW | &MNT_GJOURNAL | &MNT_MULTILABEL | &MNT_ACLS | &MNT_NFS4ACLS | &MNT_AUTOMOUNTED | &MNT_VERIFIED | &MNT_UNTRUSTED);}' unless defined(&MNT_VISFLAGMASK); eval 'sub MNT_UPDATEMASK () {( &MNT_NOSUID | &MNT_NOEXEC | &MNT_SYNCHRONOUS | &MNT_UNION | &MNT_ASYNC | &MNT_NOATIME | &MNT_NOSYMFOLLOW | &MNT_IGNORE | &MNT_NOCLUSTERR | &MNT_NOCLUSTERW | &MNT_SUIDDIR | &MNT_ACLS | &MNT_USER | &MNT_NFS4ACLS | &MNT_AUTOMOUNTED | &MNT_UNTRUSTED);}' unless defined(&MNT_UPDATEMASK); eval 'sub MNT_UPDATE () {0x10000;}' unless defined(&MNT_UPDATE); eval 'sub MNT_DELEXPORT () {0x20000;}' unless defined(&MNT_DELEXPORT); eval 'sub MNT_RELOAD () {0x40000;}' unless defined(&MNT_RELOAD); eval 'sub MNT_FORCE () {0x80000;}' unless defined(&MNT_FORCE); eval 'sub MNT_SNAPSHOT () {0x1000000;}' unless defined(&MNT_SNAPSHOT); eval 'sub MNT_NONBUSY () {0x4000000;}' unless defined(&MNT_NONBUSY); eval 'sub MNT_BYFSID () {0x8000000;}' unless defined(&MNT_BYFSID); eval 'sub MNT_NOCOVER () {0x1000000000;}' unless defined(&MNT_NOCOVER); eval 'sub MNT_EMPTYDIR () {0x2000000000;}' unless defined(&MNT_EMPTYDIR); eval 'sub MNT_CMDFLAGS () {( &MNT_UPDATE | &MNT_DELEXPORT | &MNT_RELOAD | &MNT_FORCE | &MNT_SNAPSHOT | &MNT_NONBUSY | &MNT_BYFSID | &MNT_NOCOVER | &MNT_EMPTYDIR);}' unless defined(&MNT_CMDFLAGS); eval 'sub MNTK_UNMOUNTF () {0x1;}' unless defined(&MNTK_UNMOUNTF); eval 'sub MNTK_ASYNC () {0x2;}' unless defined(&MNTK_ASYNC); eval 'sub MNTK_SOFTDEP () {0x4;}' unless defined(&MNTK_SOFTDEP); eval 'sub MNTK_NOMSYNC () {0x8;}' unless defined(&MNTK_NOMSYNC); eval 'sub MNTK_DRAINING () {0x10;}' unless defined(&MNTK_DRAINING); eval 'sub MNTK_REFEXPIRE () {0x20;}' unless defined(&MNTK_REFEXPIRE); eval 'sub MNTK_EXTENDED_SHARED () {0x40;}' unless defined(&MNTK_EXTENDED_SHARED); eval 'sub MNTK_SHARED_WRITES () {0x80;}' unless defined(&MNTK_SHARED_WRITES); eval 'sub MNTK_NO_IOPF () {0x100;}' unless defined(&MNTK_NO_IOPF); eval 'sub MNTK_VGONE_UPPER () {0x200;}' unless defined(&MNTK_VGONE_UPPER); eval 'sub MNTK_VGONE_WAITER () {0x400;}' unless defined(&MNTK_VGONE_WAITER); eval 'sub MNTK_LOOKUP_EXCL_DOTDOT () {0x800;}' unless defined(&MNTK_LOOKUP_EXCL_DOTDOT); eval 'sub MNTK_MARKER () {0x1000;}' unless defined(&MNTK_MARKER); eval 'sub MNTK_UNMAPPED_BUFS () {0x2000;}' unless defined(&MNTK_UNMAPPED_BUFS); eval 'sub MNTK_USES_BCACHE () {0x4000;}' unless defined(&MNTK_USES_BCACHE); eval 'sub MNTK_TEXT_REFS () {0x8000;}' unless defined(&MNTK_TEXT_REFS); eval 'sub MNTK_VMSETSIZE_BUG () {0x10000;}' unless defined(&MNTK_VMSETSIZE_BUG); eval 'sub MNTK_UNIONFS () {0x20000;}' unless defined(&MNTK_UNIONFS); eval 'sub MNTK_FPLOOKUP () {0x40000;}' unless defined(&MNTK_FPLOOKUP); eval 'sub MNTK_SUSPEND_ALL () {0x80000;}' unless defined(&MNTK_SUSPEND_ALL); eval 'sub MNTK_NOASYNC () {0x800000;}' unless defined(&MNTK_NOASYNC); eval 'sub MNTK_UNMOUNT () {0x1000000;}' unless defined(&MNTK_UNMOUNT); eval 'sub MNTK_MWAIT () {0x2000000;}' unless defined(&MNTK_MWAIT); eval 'sub MNTK_SUSPEND () {0x8000000;}' unless defined(&MNTK_SUSPEND); eval 'sub MNTK_SUSPEND2 () {0x4000000;}' unless defined(&MNTK_SUSPEND2); eval 'sub MNTK_SUSPENDED () {0x10000000;}' unless defined(&MNTK_SUSPENDED); eval 'sub MNTK_NULL_NOCACHE () {0x20000000;}' unless defined(&MNTK_NULL_NOCACHE); eval 'sub MNTK_LOOKUP_SHARED () {0x40000000;}' unless defined(&MNTK_LOOKUP_SHARED); eval 'sub MNTK_NOKNOTE () {0x80000000;}' unless defined(&MNTK_NOKNOTE); if(defined(&_KERNEL)) { eval 'sub MNT_SHARED_WRITES { my($mp) = @_; eval q({ ($mp != &NULL && ( ($mp->{mnt_kern_flag}) & &MNTK_SHARED_WRITES) != 0); }); }' unless defined(&MNT_SHARED_WRITES); eval 'sub MNT_EXTENDED_SHARED { my($mp) = @_; eval q({ ($mp != &NULL && ( ($mp->{mnt_kern_flag}) & &MNTK_EXTENDED_SHARED) != 0); }); }' unless defined(&MNT_EXTENDED_SHARED); } eval 'sub VFS_VFSCONF () {0;}' unless defined(&VFS_VFSCONF); eval 'sub VFS_GENERIC () {0;}' unless defined(&VFS_GENERIC); eval 'sub VFS_MAXTYPENUM () {1;}' unless defined(&VFS_MAXTYPENUM); eval 'sub VFS_CONF () {2;}' unless defined(&VFS_CONF); eval 'sub MNT_WAIT () {1;}' unless defined(&MNT_WAIT); eval 'sub MNT_NOWAIT () {2;}' unless defined(&MNT_NOWAIT); eval 'sub MNT_LAZY () {3;}' unless defined(&MNT_LAZY); eval 'sub MNT_SUSPEND () {4;}' unless defined(&MNT_SUSPEND); eval 'sub MAXSECFLAVORS () {5;}' unless defined(&MAXSECFLAVORS); unless(defined(&BURN_BRIDGES)) { } eval 'sub VFCF_STATIC () {0x10000;}' unless defined(&VFCF_STATIC); eval 'sub VFCF_NETWORK () {0x20000;}' unless defined(&VFCF_NETWORK); eval 'sub VFCF_READONLY () {0x40000;}' unless defined(&VFCF_READONLY); eval 'sub VFCF_SYNTHETIC () {0x80000;}' unless defined(&VFCF_SYNTHETIC); eval 'sub VFCF_LOOPBACK () {0x100000;}' unless defined(&VFCF_LOOPBACK); eval 'sub VFCF_UNICODE () {0x200000;}' unless defined(&VFCF_UNICODE); eval 'sub VFCF_JAIL () {0x400000;}' unless defined(&VFCF_JAIL); eval 'sub VFCF_DELEGADMIN () {0x800000;}' unless defined(&VFCF_DELEGADMIN); eval 'sub VFCF_SBDRY () {0x1000000;}' unless defined(&VFCF_SBDRY); eval 'sub VFS_CTL_VERS1 () {0x1;}' unless defined(&VFS_CTL_VERS1); eval 'sub VFS_CTL_QUERY () {0x10001;}' unless defined(&VFS_CTL_QUERY); eval 'sub VFS_CTL_TIMEO () {0x10002;}' unless defined(&VFS_CTL_TIMEO); eval 'sub VFS_CTL_NOLOCKS () {0x10003;}' unless defined(&VFS_CTL_NOLOCKS); eval 'sub VQ_NOTRESP () {0x1;}' unless defined(&VQ_NOTRESP); eval 'sub VQ_NEEDAUTH () {0x2;}' unless defined(&VQ_NEEDAUTH); eval 'sub VQ_LOWDISK () {0x4;}' unless defined(&VQ_LOWDISK); eval 'sub VQ_MOUNT () {0x8;}' unless defined(&VQ_MOUNT); eval 'sub VQ_UNMOUNT () {0x10;}' unless defined(&VQ_UNMOUNT); eval 'sub VQ_DEAD () {0x20;}' unless defined(&VQ_DEAD); eval 'sub VQ_ASSIST () {0x40;}' unless defined(&VQ_ASSIST); eval 'sub VQ_NOTRESPLOCK () {0x80;}' unless defined(&VQ_NOTRESPLOCK); eval 'sub VQ_FLAG0100 () {0x100;}' unless defined(&VQ_FLAG0100); eval 'sub VQ_FLAG0200 () {0x200;}' unless defined(&VQ_FLAG0200); eval 'sub VQ_FLAG0400 () {0x400;}' unless defined(&VQ_FLAG0400); eval 'sub VQ_FLAG0800 () {0x800;}' unless defined(&VQ_FLAG0800); eval 'sub VQ_FLAG1000 () {0x1000;}' unless defined(&VQ_FLAG1000); eval 'sub VQ_FLAG2000 () {0x2000;}' unless defined(&VQ_FLAG2000); eval 'sub VQ_FLAG4000 () {0x4000;}' unless defined(&VQ_FLAG4000); eval 'sub VQ_FLAG8000 () {0x8000;}' unless defined(&VQ_FLAG8000); if(defined(&_KERNEL)) { eval 'sub VCTLTOREQ { my($vc, $req) = @_; eval q( &do { ($req)-> &newptr = ($vc)-> &vc_ptr; ($req)-> &newlen = ($vc)-> &vc_len; ($req)-> &newidx = 0; } &while (0)); }' unless defined(&VCTLTOREQ); } if(defined(&_KERNEL)) { eval 'sub MBF_NOWAIT () {0x1;}' unless defined(&MBF_NOWAIT); eval 'sub MBF_MNTLSTLOCK () {0x2;}' unless defined(&MBF_MNTLSTLOCK); eval 'sub MBF_MASK () {( &MBF_NOWAIT | &MBF_MNTLSTLOCK);}' unless defined(&MBF_MASK); if(defined(&MALLOC_DECLARE)) { } eval 'sub VFS_MOUNT { my($MP) = @_; eval q(({ \'int\' &_rc; &TSRAW( &curthread, &TS_ENTER, \\"VFS_MOUNT\\", ($MP)-> ($mnt_vfc->{vfc_name})); &_rc = (*($MP)-> ($mnt_op->{vfs_mount}))($MP); &TSRAW( &curthread, &TS_EXIT, \\"VFS_MOUNT\\", ($MP)-> ($mnt_vfc->{vfc_name})); &_rc; })); }' unless defined(&VFS_MOUNT); eval 'sub VFS_UNMOUNT { my($MP, $FORCE) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_unmount}))($MP, $FORCE); &_rc; })); }' unless defined(&VFS_UNMOUNT); eval 'sub VFS_ROOT { my($MP, $FLAGS, $VPP) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_root}))($MP, $FLAGS, $VPP); &_rc; })); }' unless defined(&VFS_ROOT); eval 'sub VFS_CACHEDROOT { my($MP, $FLAGS, $VPP) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_cachedroot}))($MP, $FLAGS, $VPP); &_rc; })); }' unless defined(&VFS_CACHEDROOT); eval 'sub VFS_QUOTACTL { my($MP, $C, $U, $A) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_quotactl}))($MP, $C, $U, $A); &_rc; })); }' unless defined(&VFS_QUOTACTL); eval 'sub VFS_STATFS { my($MP, $SBP) = @_; eval q(({ \'int\' &_rc; &_rc = &__vfs_statfs(($MP), ($SBP)); &_rc; })); }' unless defined(&VFS_STATFS); eval 'sub VFS_SYNC { my($MP, $WAIT) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_sync}))($MP, $WAIT); &_rc; })); }' unless defined(&VFS_SYNC); eval 'sub VFS_VGET { my($MP, $INO, $FLAGS, $VPP) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_vget}))($MP, $INO, $FLAGS, $VPP); &_rc; })); }' unless defined(&VFS_VGET); eval 'sub VFS_FHTOVP { my($MP, $FIDP, $FLAGS, $VPP) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_fhtovp}))($MP, $FIDP, $FLAGS, $VPP); &_rc; })); }' unless defined(&VFS_FHTOVP); eval 'sub VFS_CHECKEXP { my($MP, $NAM, $EXFLG, $CRED, $NUMSEC, $SEC) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_checkexp}))($MP, $NAM, $EXFLG, $CRED, $NUMSEC, $SEC); &_rc; })); }' unless defined(&VFS_CHECKEXP); eval 'sub VFS_EXTATTRCTL { my($MP, $C, $FN, $NS, $N) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_extattrctl}))($MP, $C, $FN, $NS, $N); &_rc; })); }' unless defined(&VFS_EXTATTRCTL); eval 'sub VFS_SYSCTL { my($MP, $OP, $REQ) = @_; eval q(({ \'int\' &_rc; &_rc = (*($MP)-> ($mnt_op->{vfs_sysctl}))($MP, $OP, $REQ); &_rc; })); }' unless defined(&VFS_SYSCTL); eval 'sub VFS_SUSP_CLEAN { my($MP) = @_; eval q( &do { &if (*($MP)-> ($mnt_op->{vfs_susp_clean}) != &NULL) { (*($MP)-> ($mnt_op->{vfs_susp_clean}))($MP); } } &while (0)); }' unless defined(&VFS_SUSP_CLEAN); eval 'sub VFS_RECLAIM_LOWERVP { my($MP, $VP) = @_; eval q( &do { &if (*($MP)-> ($mnt_op->{vfs_reclaim_lowervp}) != &NULL) { (*($MP)-> ($mnt_op->{vfs_reclaim_lowervp}))(($MP), ($VP)); } } &while (0)); }' unless defined(&VFS_RECLAIM_LOWERVP); eval 'sub VFS_UNLINK_LOWERVP { my($MP, $VP) = @_; eval q( &do { &if (*($MP)-> ($mnt_op->{vfs_unlink_lowervp}) != &NULL) { (*($MP)-> ($mnt_op->{vfs_unlink_lowervp}))(($MP), ($VP)); } } &while (0)); }' unless defined(&VFS_UNLINK_LOWERVP); eval 'sub VFS_PURGE { my($MP) = @_; eval q( &do { &if (*($MP)-> ($mnt_op->{vfs_purge}) != &NULL) { (*($MP)-> ($mnt_op->{vfs_purge}))($MP); } } &while (0)); }' unless defined(&VFS_PURGE); eval 'sub VFS_KNOTE_LOCKED { my($vp, $hint) = @_; eval q( &do { &if ((($vp)-> &v_vflag & &VV_NOKNOTE) == 0) &VN_KNOTE(($vp), ($hint), &KNF_LISTLOCKED); } &while (0)); }' unless defined(&VFS_KNOTE_LOCKED); eval 'sub VFS_KNOTE_UNLOCKED { my($vp, $hint) = @_; eval q( &do { &if ((($vp)-> &v_vflag & &VV_NOKNOTE) == 0) &VN_KNOTE(($vp), ($hint), 0); } &while (0)); }' unless defined(&VFS_KNOTE_UNLOCKED); eval 'sub VFS_NOTIFY_UPPER_RECLAIM () {1;}' unless defined(&VFS_NOTIFY_UPPER_RECLAIM); eval 'sub VFS_NOTIFY_UPPER_UNLINK () {2;}' unless defined(&VFS_NOTIFY_UPPER_UNLINK); require 'sys/module.ph'; eval 'sub VFS_VERSION_00 () {0x19660120;}' unless defined(&VFS_VERSION_00); eval 'sub VFS_VERSION_01 () {0x20121030;}' unless defined(&VFS_VERSION_01); eval 'sub VFS_VERSION_02 () {0x20180504;}' unless defined(&VFS_VERSION_02); eval 'sub VFS_VERSION () { &VFS_VERSION_02;}' unless defined(&VFS_VERSION); eval 'sub VFS_SET { my($vfsops, $fsname, $flags) = @_; eval q( &static \'struct vfsconf\' $fsname &_vfsconf = { . &vfc_version = &VFS_VERSION, . &vfc_name = $fsname, . &vfc_vfsops = $vfsops, . &vfc_typenum = -1, . &vfc_flags = $flags, }; &static &moduledata_t $fsname &_mod = { $fsname, &vfs_modevent, & $fsname &_vfsconf }; &DECLARE_MODULE($fsname, $fsname &_mod, &SI_SUB_VFS, &SI_ORDER_MIDDLE)); }' unless defined(&VFS_SET); eval 'sub vfsconf_lock () { eval q( &sx_xlock( &vfsconf_sx)); }' unless defined(&vfsconf_lock); eval 'sub vfsconf_unlock () { eval q( &sx_xunlock( &vfsconf_sx)); }' unless defined(&vfsconf_unlock); eval 'sub vfsconf_slock () { eval q( &sx_slock( &vfsconf_sx)); }' unless defined(&vfsconf_slock); eval 'sub vfsconf_sunlock () { eval q( &sx_sunlock( &vfsconf_sx)); }' unless defined(&vfsconf_sunlock); if(defined(&DIAGNOSTIC)) { } else { eval 'sub vfs_assert_mount_counters { my($mp) = @_; eval q( &do { } &while (0)); }' unless defined(&vfs_assert_mount_counters); eval 'sub vfs_dump_mount_counters { my($mp) = @_; eval q( &do { } &while (0)); }' unless defined(&vfs_dump_mount_counters); } eval("sub MNT_COUNT_REF () { 0; }") unless defined(&MNT_COUNT_REF); eval("sub MNT_COUNT_LOCKREF () { 1; }") unless defined(&MNT_COUNT_LOCKREF); eval("sub MNT_COUNT_WRITEOPCOUNT () { 2; }") unless defined(&MNT_COUNT_WRITEOPCOUNT); eval 'sub vfs_mount_pcpu { my($mp) = @_; eval q( &zpcpu_get( ($mp->{mnt_pcpu}))); }' unless defined(&vfs_mount_pcpu); eval 'sub vfs_mount_pcpu_remote { my($mp, $cpu) = @_; eval q( &zpcpu_get_cpu( ($mp->{mnt_pcpu}), $cpu)); }' unless defined(&vfs_mount_pcpu_remote); eval 'sub vfs_op_thread_entered { my($mp) = @_; eval q(({ &MPASS( ($curthread->{td_critnest}) > 0); \'struct mount_pcpu\' * &_mpcpu = &vfs_mount_pcpu($mp); ($_$mpcpu->{mntp_thread_in_ops}) == 1; })); }' unless defined(&vfs_op_thread_entered); eval 'sub vfs_op_thread_enter_crit { my($mp, $_mpcpu) = @_; eval q(({ &bool &_retval_crit = &true; &MPASS( ($curthread->{td_critnest}) > 0); $_mpcpu = &vfs_mount_pcpu($mp); &MPASS( ($mpcpu->{mntp_thread_in_ops}) == 0); ($_$mpcpu->{mntp_thread_in_ops}) = 1; &atomic_interrupt_fence(); &if ( &__predict_false( ($mp->{mnt_vfs_ops}) > 0)) { &vfs_op_thread_exit_crit($mp, $_mpcpu); &_retval_crit = &false; } &_retval_crit; })); }' unless defined(&vfs_op_thread_enter_crit); eval 'sub vfs_op_thread_enter { my($mp, $_mpcpu) = @_; eval q(({ &bool &_retval; &critical_enter(); &_retval = &vfs_op_thread_enter_crit($mp, $_mpcpu); &if ( &__predict_false(! &_retval)) &critical_exit(); &_retval; })); }' unless defined(&vfs_op_thread_enter); eval 'sub vfs_op_thread_exit_crit { my($mp, $_mpcpu) = @_; eval q( &do { &MPASS($_mpcpu == &vfs_mount_pcpu($mp)); &MPASS( ($_$mpcpu->{mntp_thread_in_ops}) == 1); &atomic_interrupt_fence(); ($_$mpcpu->{mntp_thread_in_ops}) = 0; } &while (0)); }' unless defined(&vfs_op_thread_exit_crit); eval 'sub vfs_op_thread_exit { my($mp, $_mpcpu) = @_; eval q( &do { &vfs_op_thread_exit_crit($mp, $_mpcpu); &critical_exit(); } &while (0)); }' unless defined(&vfs_op_thread_exit); eval 'sub vfs_mp_count_add_pcpu { my($_mpcpu, $count, $val) = @_; eval q( &do { &MPASS( ($_mpcpu->{mntp_thread_in_ops}) == 1); ($_mpcpu->{mntp_})$count += $val; } &while (0)); }' unless defined(&vfs_mp_count_add_pcpu); eval 'sub vfs_mp_count_sub_pcpu { my($_mpcpu, $count, $val) = @_; eval q( &do { &MPASS( ($_mpcpu->{mntp_thread_in_ops}) == 1); ($_mpcpu->{mntp_})$count -= $val; } &while (0)); }' unless defined(&vfs_mp_count_sub_pcpu); } else { require 'sys/cdefs.ph'; } } 1;
Upload File
Create Folder