All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lwjgl.system.rpmalloc.RPMemoryMapCallbackI Maven / Gradle / Ivy

Go to download

A public domain cross platform lock free thread caching 16-byte aligned memory allocator implemented in C.

There is a newer version: 3.3.4
Show newest version
/*
 * 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