1 <?xml version=
"1.0" encoding=
"UTF-8"?>
2 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN" "xhtml1-transitional.dtd">
3 <!-- saved from url=(0013)about:internet -->
4 <?xml-stylesheet type=
"text/xsl" href=
"mathml.xsl"?><html xmlns=
"http://www.w3.org/1999/xhtml" xmlns:
pref=
"http://www.w3.org/2002/Math/preference" pref:
renderer=
"mathplayer-dl"><head><meta http-equiv=
"Content-Type" content=
"text/html; charset=UTF-8" /><link rel=
"stylesheet" type=
"text/css" href=
"opengl-man.css" /><title>glGetBufferSubData - OpenGL
4 Reference Pages
</title><meta name=
"generator" content=
"DocBook XSL Stylesheets V1.69.1" /></head><body><div class=
"refentry" lang=
"en" xml:
lang=
"en"><a id=
"glGetBufferSubData"></a><div class=
"titlepage"></div><div class=
"refnamediv"><h2>Name
</h2><p>glGetBufferSubData — returns a subset of a buffer object's data store
</p></div><div class=
"refsynopsisdiv"><h2>C Specification
</h2><div class=
"funcsynopsis"><table border=
"0" summary=
"Function synopsis" cellspacing=
"0" cellpadding=
"0"><tr><td><code class=
"funcdef">void
<b class=
"fsfunc">glGetBufferSubData
</b>(
</code></td><td>GLenum
</td><td><var class=
"pdparam">target
</var>,
</td></tr><tr><td> </td><td>GLintptr
</td><td><var class=
"pdparam">offset
</var>,
</td></tr><tr><td> </td><td>GLsizeiptr
</td><td><var class=
"pdparam">size
</var>,
</td></tr><tr><td> </td><td>GLvoid *
</td><td><var class=
"pdparam">data
</var><code>)
</code>;
</td></tr></table></div></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"parameters"></a><h2>Parameters
</h2><div class=
"variablelist"><dl><dt><span class=
"term"><em class=
"parameter"><code>target
</code></em></span></dt><dd><p>
5 Specifies the target buffer object.
6 The symbolic constant must be
7 <code class=
"constant">GL_ARRAY_BUFFER
</code>,
8 <code class=
"constant">GL_ATOMIC_COUNTER_BUFFER
</code>,
9 <code class=
"constant">GL_COPY_READ_BUFFER
</code>,
10 <code class=
"constant">GL_COPY_WRITE_BUFFER
</code>,
11 <code class=
"constant">GL_DRAW_INDIRECT_BUFFER
</code>,
12 <code class=
"constant">GL_DISPATCH_INDIRECT_BUFFER
</code>,
13 <code class=
"constant">GL_ELEMENT_ARRAY_BUFFER
</code>,
14 <code class=
"constant">GL_PIXEL_PACK_BUFFER
</code>,
15 <code class=
"constant">GL_PIXEL_UNPACK_BUFFER
</code>,
16 <code class=
"constant">GL_TEXTURE_BUFFER
</code>,
17 <code class=
"constant">GL_TRANSFORM_FEEDBACK_BUFFER
</code>, or
18 <code class=
"constant">GL_UNIFORM_BUFFER
</code>.
19 </p></dd><dt><span class=
"term"><em class=
"parameter"><code>offset
</code></em></span></dt><dd><p>
20 Specifies the offset into the buffer object's data store from which data will be returned,
22 </p></dd><dt><span class=
"term"><em class=
"parameter"><code>size
</code></em></span></dt><dd><p>
23 Specifies the size in bytes of the data store region being returned.
24 </p></dd><dt><span class=
"term"><em class=
"parameter"><code>data
</code></em></span></dt><dd><p>
25 Specifies a pointer to the location where buffer object data is returned.
26 </p></dd></dl></div></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"description"></a><h2>Description
</h2><p>
27 <code class=
"function">glGetBufferSubData
</code> returns some or all of the data from the buffer object currently
28 bound to
<em class=
"parameter"><code>target
</code></em>. Data starting at byte offset
<em class=
"parameter"><code>offset
</code></em> and
29 extending for
<em class=
"parameter"><code>size
</code></em> bytes is copied from the data store to the memory pointed to by
30 <em class=
"parameter"><code>data
</code></em>. An error is thrown if the buffer object is currently mapped, or if
31 <em class=
"parameter"><code>offset
</code></em> and
<em class=
"parameter"><code>size
</code></em> together define a range beyond the bounds
32 of the buffer object's data store.
33 </p></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"notes"></a><h2>Notes
</h2><p>
34 If an error is generated,
35 no change is made to the contents of
<em class=
"parameter"><code>data
</code></em>.
37 The
<code class=
"constant">GL_ATOMIC_COUNTER_BUFER
</code> target is available only if the GL version is
4.2 or greater.
39 The
<code class=
"constant">GL_DISPATCH_INDIRECT_BUFFER
</code> target is available only if the GL version is
4.3 or greater.
40 </p></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"errors"></a><h2>Errors
</h2><p>
41 <code class=
"constant">GL_INVALID_ENUM
</code> is generated if
<em class=
"parameter"><code>target
</code></em> is not
42 <code class=
"constant">GL_ARRAY_BUFFER
</code>,
<code class=
"constant">GL_ELEMENT_ARRAY_BUFFER
</code>,
43 <code class=
"constant">GL_PIXEL_PACK_BUFFER
</code>, or
<code class=
"constant">GL_PIXEL_UNPACK_BUFFER
</code>.
45 <code class=
"constant">GL_INVALID_VALUE
</code> is generated if
<em class=
"parameter"><code>offset
</code></em> or
46 <em class=
"parameter"><code>size
</code></em> is negative, or if together they define a region of memory
47 that extends beyond the buffer object's allocated data store.
49 <code class=
"constant">GL_INVALID_OPERATION
</code> is generated if the reserved buffer object name
0 is bound to
<em class=
"parameter"><code>target
</code></em>.
51 <code class=
"constant">GL_INVALID_OPERATION
</code> is generated if the buffer object being queried is mapped.
52 </p></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"seealso"></a><h2>See Also
</h2><p>
53 <a href=
"glBindBuffer.xml"><span class=
"citerefentry"><span class=
"refentrytitle">glBindBuffer
</span></span></a>,
54 <a href=
"glBufferData.xml"><span class=
"citerefentry"><span class=
"refentrytitle">glBufferData
</span></span></a>,
55 <a href=
"glBufferSubData.xml"><span class=
"citerefentry"><span class=
"refentrytitle">glBufferSubData
</span></span></a>,
56 <a href=
"glMapBuffer.xml"><span class=
"citerefentry"><span class=
"refentrytitle">glMapBuffer
</span></span></a>,
57 <a href=
"glUnmapBuffer.xml"><span class=
"citerefentry"><span class=
"refentrytitle">glUnmapBuffer
</span></span></a>
58 </p></div><div class=
"refsect1" lang=
"en" xml:
lang=
"en"><a id=
"Copyright"></a><h2>Copyright
</h2><p>
59 Copyright
<span class=
"trademark"></span>©
2005 Addison-Wesley.
60 This material may be distributed subject to the terms and conditions set forth in
61 the Open Publication License, v
1.0,
8 June
1999.
62 <a href=
"http://opencontent.org/openpub/" target=
"_top">http://opencontent.org/openpub/
</a>.
63 </p></div></div></body></html>