rename upstream-man-pages to upstream-doc
[clinton/guile-figl.git] / upstream-doc / manglsl / imageAtomicCompSwap.xml
diff --git a/upstream-doc/manglsl/imageAtomicCompSwap.xml b/upstream-doc/manglsl/imageAtomicCompSwap.xml
new file mode 100644 (file)
index 0000000..f924eaf
--- /dev/null
@@ -0,0 +1,267 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook MathML Module V1.1b1//EN"\r
+              "http://www.oasis-open.org/docbook/xml/mathml/1.1CR1/dbmathml.dtd">\r
+<refentry id="imageAtomicCompSwap">\r
+    <refmeta>\r
+        <refmetainfo>\r
+            <copyright>\r
+                <year>2011</year>\r
+                <holder>Khronos Group</holder>\r
+            </copyright>\r
+        </refmetainfo>\r
+        <refentrytitle>imageAtomicCompSwap</refentrytitle>\r
+        <manvolnum>3G</manvolnum>\r
+    </refmeta>\r
+    <refnamediv>\r
+        <refname>imageAtomicCompSwap</refname>\r
+        <refpurpose>atomically compares supplied data with that in memory and conditionally stores it to memory</refpurpose>\r
+    </refnamediv>\r
+    <refsynopsisdiv><title>Declaration</title>\r
+        <funcsynopsis>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage1D <parameter>image</parameter></paramdef>\r
+                <paramdef>int <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2D <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage3D <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DRect <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimageCube <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gbufferImage <parameter>image</parameter></paramdef>\r
+                <paramdef>int <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage1DArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimageCubeArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DMS <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>sample</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>uint <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DMSArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>sample</parameter></paramdef>\r
+                <paramdef>uint <parameter>compare</parameter></paramdef>\r
+                <paramdef>uint <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage1D <parameter>image</parameter></paramdef>\r
+                <paramdef>int <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2D <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage3D <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DRect <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimageCube <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gbufferImage <parameter>image</parameter></paramdef>\r
+                <paramdef>int <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage1DArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimageCubeArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DMS <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec2 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>sample</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+            <funcprototype>\r
+                <funcdef>int <function>imageAtomicCompSwap</function></funcdef>\r
+                <paramdef>gimage2DMSArray <parameter>image</parameter></paramdef>\r
+                <paramdef>ivec3 <parameter>P</parameter></paramdef>\r
+                <paramdef>int <parameter>sample</parameter></paramdef>\r
+                <paramdef>int <parameter>compare</parameter></paramdef>\r
+                <paramdef>int <parameter>data</parameter></paramdef>\r
+            </funcprototype>\r
+        </funcsynopsis>\r
+    </refsynopsisdiv>\r
+    <refsect1 id="parameters"><title>Parameters</title>\r
+        <variablelist>\r
+        <varlistentry>\r
+            <term><parameter>image</parameter></term>\r
+            <listitem>\r
+                <para>\r
+                    Specify the image unit into which to compare and conditionally store <parameter>data</parameter>.\r
+                </para>\r
+            </listitem>\r
+        </varlistentry>\r
+        <varlistentry>\r
+            <term><parameter>P</parameter></term>\r
+            <listitem>\r
+                <para>\r
+                    Specify the coordinate at which to compare and conditionally store the data.\r
+                </para>\r
+            </listitem>\r
+        </varlistentry>\r
+        <varlistentry>\r
+            <term><parameter>sample</parameter></term>\r
+            <listitem>\r
+                <para>\r
+                    When present, specifies the sample within the image to compare and conditionally store into.\r
+                </para>\r
+            </listitem>\r
+        </varlistentry>\r
+        <varlistentry>\r
+            <term><parameter>compare</parameter></term>\r
+            <listitem>\r
+                <para>\r
+                    Specifies the value to compare with the content of the image.\r
+                </para>\r
+            </listitem>\r
+        </varlistentry>\r
+        <varlistentry>\r
+            <term><parameter>data</parameter></term>\r
+            <listitem>\r
+                <para>\r
+                    Specifies the value to store in the image if <parameter>compare</parameter> is equal to the existing image content.\r
+                </para>\r
+            </listitem>\r
+        </varlistentry>\r
+        </variablelist>\r
+    </refsect1>\r
+    <refsect1 id="description"><title>Description</title>\r
+        <para>\r
+            <function>imageAtomicCompSwap</function> atomically compares the value of <parameter>compare</parameter>\r
+            with that of the texel at coordinate <parameter>P</parameter> and <parameter>sample</parameter> (for multisampled forms) in the\r
+            image bound to uint <parameter>image</parameter>. If the values are equal, <parameter>data</parameter> is\r
+            stored into the texel, otherwise it is discarded. It returns the original value of the texel regardless of\r
+            the result of the comparison operation.\r
+        </para>\r
+    </refsect1>\r
+    <refsect1 id="versions"><title>Version Support</title>\r
+        <informaltable frame="topbot">\r
+            #VARTABLECOLS#\r
+                <thead>\r
+                    #FUNCTABLEHEADER#\r
+                    <row>\r
+                        <entry>imageAtomicCompSwap</entry>#newin42#\r
+                    </row>\r
+                </thead>\r
+            </tgroup>\r
+        </informaltable>\r
+    </refsect1>\r
+    <refsect1 id="seealso"><title>See Also</title>\r
+        <para>\r
+            <citerefentry><refentrytitle>imageLoad</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageStore</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicAdd</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicMin</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicMax</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicXor</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicOr</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicAnd</refentrytitle></citerefentry>,\r
+            <citerefentry><refentrytitle>imageAtomicCompSwap</refentrytitle></citerefentry>\r
+        </para>\r
+    </refsect1>\r
+    <refsect1 id="Copyright"><title>Copyright</title>\r
+        <para>\r
+            Copyright <trademark class="copyright"></trademark> 2011-2012 Khronos Group. \r
+            This material may be distributed subject to the terms and conditions set forth in \r
+            the Open Publication License, v 1.0, 8 June 1999.\r
+            <ulink url="http://opencontent.org/openpub/">http://opencontent.org/openpub/</ulink>.\r
+        </para>\r
+    </refsect1>\r
+</refentry>\r