003 File Manager
Current Path:
/usr/src/sys/contrib/openzfs/include/os/freebsd/spl/sys
usr
/
src
/
sys
/
contrib
/
openzfs
/
include
/
os
/
freebsd
/
spl
/
sys
/
📁
..
📄
Makefile.am
(859 B)
📄
acl.h
(7.15 KB)
📄
acl_impl.h
(1.52 KB)
📄
atomic.h
(5.25 KB)
📄
byteorder.h
(2.99 KB)
📄
callb.h
(7.01 KB)
📄
ccompat.h
(4.02 KB)
📄
ccompile.h
(7.92 KB)
📄
cmn_err.h
(2.18 KB)
📄
condvar.h
(5.72 KB)
📄
console.h
(1.48 KB)
📄
cred.h
(5.17 KB)
📄
ctype.h
(1.8 KB)
📄
debug.h
(5.91 KB)
📄
dirent.h
(1.68 KB)
📄
disp.h
(1.51 KB)
📄
dkio.h
(14.73 KB)
📄
extdirent.h
(2.17 KB)
📄
file.h
(1.8 KB)
📄
freebsd_rwlock.h
(1.46 KB)
📄
idmap.h
(3.21 KB)
📄
inttypes.h
(20 B)
📄
isa_defs.h
(19.68 KB)
📄
kidmap.h
(1.68 KB)
📄
kmem.h
(3.65 KB)
📄
kmem_cache.h
(1.96 KB)
📄
kstat.h
(7.61 KB)
📄
list.h
(1.8 KB)
📄
list_impl.h
(1.26 KB)
📄
lock.h
(1.79 KB)
📄
misc.h
(1.95 KB)
📄
mod_os.h
(4.01 KB)
📄
mode.h
(20 B)
📄
mount.h
(1.65 KB)
📄
mutex.h
(2.59 KB)
📄
param.h
(1.63 KB)
📄
policy.h
(3.47 KB)
📄
proc.h
(3.33 KB)
📄
processor.h
(1.46 KB)
📄
procfs_list.h
(2 KB)
📄
random.h
(1.71 KB)
📄
rwlock.h
(3.31 KB)
📄
sdt.h
(1.76 KB)
📄
sid.h
(2.47 KB)
📄
sig.h
(2.11 KB)
📄
simd.h
(1.68 KB)
📄
simd_x86.h
(7.07 KB)
📄
spl_condvar.h
(3.04 KB)
📄
string.h
(1.64 KB)
📄
strings.h
(20 B)
📄
sunddi.h
(2.28 KB)
📄
sysmacros.h
(11.66 KB)
📄
systeminfo.h
(1.45 KB)
📄
systm.h
(1.68 KB)
📄
taskq.h
(3.75 KB)
📄
thread.h
(1.47 KB)
📄
time.h
(3 KB)
📄
timer.h
(1.65 KB)
📄
trace.h
(14 B)
📄
trace_zfs.h
(14 B)
📄
types.h
(2.99 KB)
📄
types32.h
(1.52 KB)
📄
uio.h
(2.91 KB)
📄
uuid.h
(2.93 KB)
📄
vfs.h
(4.55 KB)
📄
vm.h
(2.54 KB)
📄
vmsystm.h
(1.42 KB)
📄
vnode.h
(6.07 KB)
📄
vnode_impl.h
(10.47 KB)
📄
zmod.h
(1.87 KB)
📄
zone.h
(2.29 KB)
Editing: kmem.h
/* * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org> * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $FreeBSD$ */ #ifndef _OPENSOLARIS_SYS_KMEM_H_ #define _OPENSOLARIS_SYS_KMEM_H_ #ifdef _KERNEL #include <sys/param.h> #include <sys/malloc.h> #include <sys/vmem.h> #include <sys/counter.h> #include <vm/uma.h> #include <vm/vm.h> #include <vm/vm_extern.h> MALLOC_DECLARE(M_SOLARIS); #define POINTER_IS_VALID(p) (!((uintptr_t)(p) & 0x3)) #define POINTER_INVALIDATE(pp) (*(pp) = (void *)((uintptr_t)(*(pp)) | 0x1)) #define KM_SLEEP M_WAITOK #define KM_PUSHPAGE M_WAITOK #define KM_NOSLEEP M_NOWAIT #define KM_NORMALPRI 0 #define KMC_NODEBUG UMA_ZONE_NODUMP typedef struct vmem vmem_t; extern char *kmem_asprintf(const char *, ...); extern char *kmem_vasprintf(const char *fmt, va_list ap); typedef struct kmem_cache { char kc_name[32]; #if !defined(KMEM_DEBUG) uma_zone_t kc_zone; #else size_t kc_size; #endif int (*kc_constructor)(void *, void *, int); void (*kc_destructor)(void *, void *); void *kc_private; } kmem_cache_t; extern uint64_t spl_kmem_cache_inuse(kmem_cache_t *cache); extern uint64_t spl_kmem_cache_entry_size(kmem_cache_t *cache); void *zfs_kmem_alloc(size_t size, int kmflags); void zfs_kmem_free(void *buf, size_t size); uint64_t kmem_size(void); kmem_cache_t *kmem_cache_create(char *name, size_t bufsize, size_t align, int (*constructor)(void *, void *, int), void (*destructor)(void *, void *), void (*reclaim)(void *) __unused, void *private, vmem_t *vmp, int cflags); void kmem_cache_destroy(kmem_cache_t *cache); void *kmem_cache_alloc(kmem_cache_t *cache, int flags); void kmem_cache_free(kmem_cache_t *cache, void *buf); boolean_t kmem_cache_reap_active(void); void kmem_cache_reap_soon(kmem_cache_t *); void kmem_reap(void); int kmem_debugging(void); void *calloc(size_t n, size_t s); #define kmem_cache_reap_now kmem_cache_reap_soon #define freemem vm_free_count() #define minfree vm_cnt.v_free_min #define kmem_alloc(size, kmflags) zfs_kmem_alloc((size), (kmflags)) #define kmem_zalloc(size, kmflags) \ zfs_kmem_alloc((size), (kmflags) | M_ZERO) #define kmem_free(buf, size) zfs_kmem_free((buf), (size)) #endif /* _KERNEL */ #ifdef _STANDALONE /* * At the moment, we just need it for the type. We redirect the alloc/free * routines to the usual Free and Malloc in that environment. */ typedef int kmem_cache_t; #endif /* _STANDALONE */ #endif /* _OPENSOLARIS_SYS_KMEM_H_ */
Upload File
Create Folder