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

org.lwjgl.opengl.EXTShaderImageLoadStore Maven / Gradle / Ivy

Go to download

The most widely adopted 2D and 3D graphics API in the industry, bringing thousands of applications to a wide variety of computer platforms.

There is a newer version: 3.3.5
Show newest version
/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.opengl;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;

/**
 * Native bindings to the EXT_shader_image_load_store extension.
 * 
 * 

This extension provides GLSL built-in functions allowing shaders to load from, store to, and perform atomic read-modify-write operations to a single * level of a texture object from any shader stage. These built-in functions are named imageLoad(), imageStore(), and imageAtomic*(), respectively, and * accept integer texel coordinates to identify the texel accessed. The extension adds the notion of "image units" to the OpenGL API, to which texture * levels are bound for access by the GLSL built-in functions. To allow shaders to specify the image unit to access, GLSL provides a new set of data types * ("image*") similar to samplers. Each image variable is assigned an integer value to identify an image unit to access, which is specified using * Uniform*() APIs in a manner similar to samplers. For implementations supporting the NV_gpu_program5 extensions, assembly language instructions to * perform image loads, stores, and atomics are also provided.

* *

This extension also provides the capability to explicitly enable "early" per-fragment tests, where operations like depth and stencil testing are * performed prior to fragment shader execution. In unextended OpenGL, fragment shaders never have any side effects and implementations can sometimes * perform per-fragment tests and discard some fragments prior to executing the fragment shader. Since this extension allows fragment shaders to write to * texture and buffer object memory using the built-in image functions, such optimizations could lead to non-deterministic results. To avoid this, * implementations supporting this extension may not perform such optimizations on shaders having such side effects. However, enabling early per-fragment * tests guarantees that such tests will be performed prior to fragment shader execution, and ensures that image stores and atomics will not be performed * by fragment shader invocations where these per-fragment tests fail.

* *

Finally, this extension provides both a GLSL built-in function and an OpenGL API function allowing applications some control over the ordering of image * loads, stores, and atomics relative to other OpenGL pipeline operations accessing the same memory. Because the extension provides the ability to * perform random accesses to texture or buffer object memory, such accesses are not easily tracked by the OpenGL driver. To avoid the need for * heavy-handed synchronization at the driver level, this extension requires manual synchronization. The MemoryBarrierEXT() OpenGL API function allows * applications to specify a bitfield indicating the set of OpenGL API operations to synchronize relative to shader memory access. The memoryBarrier() * GLSL built-in function provides a synchronization point within a given shader invocation to ensure that all memory accesses performed prior to the * synchronization point complete prior to any started after the synchronization point.

* *

Requires {@link GL30 OpenGL 3.0}.

*/ public class EXTShaderImageLoadStore { /** Accepted by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_MAX_IMAGE_UNITS_EXT = 0x8F38, GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS_EXT = 0x8F39, GL_MAX_IMAGE_SAMPLES_EXT = 0x906D; /** Accepted by the {@code target} parameter of GetIntegeri_v and GetBooleani_v. */ public static final int GL_IMAGE_BINDING_NAME_EXT = 0x8F3A, GL_IMAGE_BINDING_LEVEL_EXT = 0x8F3B, GL_IMAGE_BINDING_LAYERED_EXT = 0x8F3C, GL_IMAGE_BINDING_LAYER_EXT = 0x8F3D, GL_IMAGE_BINDING_ACCESS_EXT = 0x8F3E, GL_IMAGE_BINDING_FORMAT_EXT = 0x906E; /** Accepted by the {@code barriers} parameter of MemoryBarrierEXT. */ public static final int GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT_EXT = 0x1, GL_ELEMENT_ARRAY_BARRIER_BIT_EXT = 0x2, GL_UNIFORM_BARRIER_BIT_EXT = 0x4, GL_TEXTURE_FETCH_BARRIER_BIT_EXT = 0x8, GL_SHADER_IMAGE_ACCESS_BARRIER_BIT_EXT = 0x20, GL_COMMAND_BARRIER_BIT_EXT = 0x40, GL_PIXEL_BUFFER_BARRIER_BIT_EXT = 0x80, GL_TEXTURE_UPDATE_BARRIER_BIT_EXT = 0x100, GL_BUFFER_UPDATE_BARRIER_BIT_EXT = 0x200, GL_FRAMEBUFFER_BARRIER_BIT_EXT = 0x400, GL_TRANSFORM_FEEDBACK_BARRIER_BIT_EXT = 0x800, GL_ATOMIC_COUNTER_BARRIER_BIT_EXT = 0x1000, GL_ALL_BARRIER_BITS_EXT = 0xFFFFFFFF; /** Returned by the {@code type} parameter of GetActiveUniform. */ public static final int GL_IMAGE_1D_EXT = 0x904C, GL_IMAGE_2D_EXT = 0x904D, GL_IMAGE_3D_EXT = 0x904E, GL_IMAGE_2D_RECT_EXT = 0x904F, GL_IMAGE_CUBE_EXT = 0x9050, GL_IMAGE_BUFFER_EXT = 0x9051, GL_IMAGE_1D_ARRAY_EXT = 0x9052, GL_IMAGE_2D_ARRAY_EXT = 0x9053, GL_IMAGE_CUBE_MAP_ARRAY_EXT = 0x9054, GL_IMAGE_2D_MULTISAMPLE_EXT = 0x9055, GL_IMAGE_2D_MULTISAMPLE_ARRAY_EXT = 0x9056, GL_INT_IMAGE_1D_EXT = 0x9057, GL_INT_IMAGE_2D_EXT = 0x9058, GL_INT_IMAGE_3D_EXT = 0x9059, GL_INT_IMAGE_2D_RECT_EXT = 0x905A, GL_INT_IMAGE_CUBE_EXT = 0x905B, GL_INT_IMAGE_BUFFER_EXT = 0x905C, GL_INT_IMAGE_1D_ARRAY_EXT = 0x905D, GL_INT_IMAGE_2D_ARRAY_EXT = 0x905E, GL_INT_IMAGE_CUBE_MAP_ARRAY_EXT = 0x905F, GL_INT_IMAGE_2D_MULTISAMPLE_EXT = 0x9060, GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT = 0x9061, GL_UNSIGNED_INT_IMAGE_1D_EXT = 0x9062, GL_UNSIGNED_INT_IMAGE_2D_EXT = 0x9063, GL_UNSIGNED_INT_IMAGE_3D_EXT = 0x9064, GL_UNSIGNED_INT_IMAGE_2D_RECT_EXT = 0x9065, GL_UNSIGNED_INT_IMAGE_CUBE_EXT = 0x9066, GL_UNSIGNED_INT_IMAGE_BUFFER_EXT = 0x9067, GL_UNSIGNED_INT_IMAGE_1D_ARRAY_EXT = 0x9068, GL_UNSIGNED_INT_IMAGE_2D_ARRAY_EXT = 0x9069, GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY_EXT = 0x906A, GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_EXT = 0x906B, GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT = 0x906C; static { GL.initialize(); } protected EXTShaderImageLoadStore() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps) { return checkFunctions( caps.glBindImageTextureEXT, caps.glMemoryBarrierEXT ); } // --- [ glBindImageTextureEXT ] --- public static native void glBindImageTextureEXT(@NativeType("GLuint") int index, @NativeType("GLuint") int texture, @NativeType("GLint") int level, @NativeType("GLboolean") boolean layered, @NativeType("GLint") int layer, @NativeType("GLenum") int access, @NativeType("GLint") int format); // --- [ glMemoryBarrierEXT ] --- public static native void glMemoryBarrierEXT(@NativeType("GLbitfield") int barriers); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy