org.lwjgl.system.rpmalloc.RPMemoryMapCallbackI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lwjgl-rpmalloc Show documentation
Show all versions of lwjgl-rpmalloc Show documentation
A public domain cross platform lock free thread caching 16-byte aligned memory allocator implemented in C.
/*
* Copyright LWJGL. All rights reserved.
* License terms: https://www.lwjgl.org/license
* MACHINE GENERATED FILE, DO NOT EDIT
*/
package org.lwjgl.system.rpmalloc;
import org.lwjgl.system.*;
import org.lwjgl.system.libffi.*;
import static org.lwjgl.system.APIUtil.*;
import static org.lwjgl.system.MemoryUtil.*;
import static org.lwjgl.system.libffi.LibFFI.*;
/**
* Instances of this interface may be set to the {@link RPMallocConfig} struct.
*
* Type
*
*
* void * (*{@link #invoke}) (
* size_t size,
* size_t *offset
* )
*/
@FunctionalInterface
@NativeType("void * (*) (size_t, size_t *)")
public interface RPMemoryMapCallbackI extends CallbackI {
FFICIF CIF = apiCreateCIF(
FFI_DEFAULT_ABI,
ffi_type_pointer,
ffi_type_pointer, ffi_type_pointer
);
@Override
default FFICIF getCallInterface() { return CIF; }
@Override
default void callback(long ret, long args) {
long __result = invoke(
memGetAddress(memGetAddress(args)),
memGetAddress(memGetAddress(args + POINTER_SIZE))
);
apiClosureRetP(ret, __result);
}
/**
* Map memory pages for the given number of bytes.
*
* The returned address MUST be aligned to the rpmalloc span size, which will always be a power of two. Optionally the function can store an alignment
* offset in the offset variable in case it performs alignment and the returned pointer is offset from the actual start of the memory region due to this
* alignment. The alignment offset will be passed to the memory unmap function. The alignment offset MUST NOT be larger than 65535 (storable in an
* {@code uint16_t}), if it is you must use natural alignment to shift it into 16 bits.
*
* If you set a {@code memory_map} function, you must also set a {@code memory_unmap} function or else the default implementation will be used for
* both.
*
* @param size the number of bytes to map
* @param offset the alignment offset
*/
@NativeType("void *") long invoke(@NativeType("size_t") long size, @NativeType("size_t *") long offset);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy