|  | <?xml version="1.0" encoding="UTF-8"?> | 
|  | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "xhtml1-transitional.dtd"> | 
|  | <!-- saved from url=(0013)about:internet --> | 
|  | <?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" xmlns:xlink="http://www.w3.org/1999/xlink" pref:renderer="mathplayer-dl"> | 
|  | <head> | 
|  | <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | 
|  | <style xmlns="" type="text/css"> | 
|  | /* This style sets a margin around the entire page */ | 
|  | html, body { | 
|  | margin: 10px; | 
|  | } | 
|  |  | 
|  | p { | 
|  | font: normal 16px verdana, sans-serif; | 
|  | margin: 0; | 
|  | padding-bottom:12px; | 
|  | } | 
|  |  | 
|  | h1 { | 
|  | font: bold 25px verdana, sans-serif; | 
|  | margin-top: 0; | 
|  | margin-bottom: 3px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  | h2 { | 
|  | font: bold 19px verdana, sans-serif; | 
|  | margin-top: 28px; | 
|  | margin-bottom: 3px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  | h3 { | 
|  | font: bold 19px verdana, sans-serif !important; | 
|  | margin-top: 28px; | 
|  | margin-bottom: 3px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  | li { | 
|  | font: normal 16px verdana, sans-serif; | 
|  | margin-top: 0; | 
|  | margin-bottom: 18px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  | .pdparam { | 
|  | font: italic 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | .term { | 
|  | font: italic 16px verdana, sans-serif; | 
|  | font-weight: normal; | 
|  | } | 
|  |  | 
|  | .type { | 
|  | font: normal 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | .parameter { | 
|  | font-style: italic; | 
|  | } | 
|  |  | 
|  | a:link, a:visited { | 
|  | color: blue; | 
|  | text-decoration: none; | 
|  | font: normal 16px; | 
|  | } | 
|  |  | 
|  | a:hover { | 
|  | background-color: #FFFF99; | 
|  | font: normal 16px; | 
|  | } | 
|  |  | 
|  | div.funcsynopsis { | 
|  | text-align: left; | 
|  | background-color: #e6e6e6; | 
|  | font: normal 16px verdana, sans-serif; | 
|  | padding-top: 10px; | 
|  | padding-bottom: 10px; | 
|  | } | 
|  |  | 
|  | div.funcsynopsis table { | 
|  | border-collapse: separate; | 
|  | font: normal 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | div.funcsynopsis td { | 
|  | background-color: #e6e6e6; | 
|  | border: 0 solid #000; | 
|  | padding: 1px; | 
|  | font: normal 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | div.refsect1 { | 
|  | font-family: verdana, sans-serif; | 
|  | font-size: 16px; | 
|  | } | 
|  |  | 
|  | code.constant { | 
|  | font: normal 16px courier new, monospace !important; | 
|  | } | 
|  |  | 
|  | span.errorname { | 
|  | font: normal 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | code.function { | 
|  | font: bold 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | b.fsfunc { | 
|  | font: bold 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | code.varname { | 
|  | font: italic 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | code.replaceable { | 
|  | font: italic 16px courier new, monospace; | 
|  | } | 
|  |  | 
|  | code.funcdef { | 
|  | font: normal 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | .citerefentry { | 
|  | font: normal 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | .parameter { | 
|  | font-style: italic; | 
|  | } | 
|  |  | 
|  | code.fsfunc { | 
|  | font: normal 16px verdana, sans-serif !important; | 
|  | } | 
|  |  | 
|  | /* PARAMETER: This style controls spacing between the terms in Parameter section */ | 
|  | dt { | 
|  | margin-top: 15px; | 
|  | } | 
|  |  | 
|  | /* TABLES: These styles apply to all tables OTHER than the Synopsis and Example tables */ | 
|  | div.refsect1 table { | 
|  | width: 100%; | 
|  | margin-top: 10px; | 
|  | background-color: #FFF; | 
|  | border-collapse: collapse; | 
|  | border-color: #000; | 
|  | border-width: 1px; | 
|  | font: normal 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | div.refsect1 th { | 
|  | border-collapse: collapse; | 
|  | border-color: #000; | 
|  | border-width: 1px; | 
|  | font: bold 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | div.refsect1 td { | 
|  | background-color: #FFF; | 
|  | padding: 5px; | 
|  | vertical-align: text-top; | 
|  | border-collapse: collapse; | 
|  | border-color: #000; | 
|  | border-width: 1px; | 
|  | font: normal 16px verdana, sans-serif; | 
|  | } | 
|  |  | 
|  | div.refsect1 p{ | 
|  | font: normal 16px verdana, sans-serif; | 
|  | margin-top: 8px; | 
|  | margin-bottom: 8px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  |  | 
|  | /* EXAMPLE: These styles apply only to the Example section */ | 
|  | div.refsect2 { | 
|  | font: normal 16px courier new, monospace !important; | 
|  | } | 
|  |  | 
|  | div.refsect2 table { | 
|  | margin-top: 0; | 
|  | background-color: #e6e6e6; | 
|  | width: 100%; | 
|  | border: 0 solid #000; | 
|  | padding: 2px; | 
|  | font: normal 16px courier new, monospace !important; | 
|  | } | 
|  |  | 
|  | div.refsect2 td { | 
|  | background-color: #e6e6e6; | 
|  | font: normal 16px courier new, monospace !important; | 
|  | white-space:pre; | 
|  | } | 
|  |  | 
|  | /* COPYRIGHT: This style formats the text of the copyright statement at the bottom of the page */ | 
|  | div.refsect3 { | 
|  | font: normal 11px verdana, sans-serif; | 
|  | margin-top: 50px; | 
|  | margin-bottom: 20px; | 
|  | padding-top: 0; | 
|  | padding-bottom: 0; | 
|  | } | 
|  |  | 
|  | </style> | 
|  | <title>__private</title> | 
|  | <meta name="generator" content="DocBook XSL Stylesheets V1.76.1" /> | 
|  | <meta name="keywords" content="__private" /> | 
|  | </head> | 
|  | <body> | 
|  | <div class="refentry"> | 
|  | <a id="idm5797952"></a> | 
|  | <div class="titlepage"></div> | 
|  | <div xmlns="" class="refnamediv"> | 
|  | <a xmlns="http://www.w3.org/1999/xhtml" id="__private"></a> | 
|  | <h1>__private</h1> | 
|  | <p> | 
|  | Address Space Qualifier. | 
|  | </p> | 
|  | </div> | 
|  | <div class="refsect2"> | 
|  | <a id="synopsis"></a> | 
|  | <h3> | 
|  | </h3> | 
|  | <div class="informaltable"> | 
|  | <table border="0"> | 
|  | <colgroup> | 
|  | <col align="left" class="col1" /> | 
|  | </colgroup> | 
|  | <tbody> | 
|  | <tr> | 
|  | <td align="left"> | 
|  | __private | 
|  | private | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | </div> | 
|  | <div class="refsect1"> | 
|  | <a id="description"></a> | 
|  | <h2>Description</h2> | 
|  | <p> | 
|  | OpenCL implements the following disjoint address spaces: <code class="function">__global</code>, | 
|  | <code class="function">__local</code>, <code class="function">__constant</code>, and | 
|  | <code class="function">__private</code> The address space qualifier may be used in variable | 
|  | declarations to specify the region of memory that is used to allocate the object. The | 
|  | C syntax for type qualifiers is extended in OpenCL to include an address space name as | 
|  | a valid type qualifier. If the type of an object is qualified by an address space name, | 
|  | the object is allocated in the specified address name; otherwise, the object is allocated | 
|  | in the generic address space. | 
|  | </p> | 
|  | <p> | 
|  | The address space names without the __prefix i.e. <code class="function">global</code>, | 
|  | <code class="function">local</code>, <code class="function">constant</code> and <code class="function">private</code> | 
|  | may be substituted for the corresponding address space names with the __prefix. | 
|  | </p> | 
|  | <p> | 
|  | The generic address space name for arguments to a function in a program, or local variables | 
|  | of a function is  <code class="function">__private</code>. All function arguments shall be in the | 
|  | <code class="function">__private</code> address space. | 
|  | </p> | 
|  | <p> | 
|  | <a class="citerefentry" href="functionQualifiers.html"><span class="citerefentry"><span class="refentrytitle">__kernel</span></span></a> | 
|  | function arguments declared to be a pointer of a type can point to one of the following | 
|  | address spaces only: <code class="function">__global</code>, <code class="function">__local</code> or | 
|  | <code class="function">__constant</code>.  A pointer to address space A can only be assigned to | 
|  | a pointer to the same address space A. Casting a pointer to address space A to a pointer | 
|  | to address space B is illegal. | 
|  | </p> | 
|  | <p> | 
|  | Function arguments of type | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image2d_t</span></span></a></span>, | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image3d_t</span></span></a></span>, | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image2d_array_t</span></span></a></span>, | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image1d_t</span></span></a></span>, | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image1d_buffer_t</span></span></a></span>, and | 
|  | <span class="type"><a class="citerefentry" href="otherDataTypes.html"><span class="citerefentry"><span class="refentrytitle">image1d_array_t</span></span></a></span> | 
|  | refer to image memory objects allocated in the <code class="function">__global</code> address space. | 
|  | </p> | 
|  | </div> | 
|  | <div class="refsect1"> | 
|  | <a id="notes"></a> | 
|  | <h2>Notes</h2> | 
|  | <p> | 
|  | Variables inside a <code class="function">__kernel</code> function not declared with an | 
|  | address space qualifier, all variables inside non-kernel functions, and all function | 
|  | arguments are in the <code class="function">__private</code> or <code class="function">private</code> | 
|  | address space. Variables declared as pointers are considered to point to the | 
|  | <code class="function">__private</code> address space if an address space qualifier is not | 
|  | specified. | 
|  | </p> | 
|  | <p> | 
|  | The <code class="function">__global</code>, <code class="function">__constant</code>, | 
|  | <code class="function">__local</code>, <code class="function">__private</code>, | 
|  | <code class="function">global</code>, <code class="function">constant</code>, <code class="function">local</code>, | 
|  | and <code class="function">private</code> names are reserved for use as address space qualifiers | 
|  | and shall not be used otherwise. | 
|  | </p> | 
|  | </div> | 
|  | <div class="refsect2"> | 
|  | <a id="example1"></a> | 
|  | <h3> | 
|  | Example | 
|  | </h3> | 
|  | <p> | 
|  | There is no generic address space name for program scope variables. All program scope | 
|  | variables must be declared in the <code class="function">__constant</code> address space. For example: | 
|  | </p> | 
|  | <div class="informaltable"> | 
|  | <table border="0"> | 
|  | <colgroup> | 
|  | <col align="left" class="col1" /> | 
|  | </colgroup> | 
|  | <tbody> | 
|  | <tr> | 
|  | <td align="left"> | 
|  | // declares a pointer p in the __private address space that | 
|  | // points to an int object in address space __global | 
|  | __global int *p; | 
|  |  | 
|  | // declares an array of 4 floats in the __private address space. | 
|  | float x[4]; | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | <p> | 
|  | There is no address space for function return values. Using an address space qualifier in | 
|  | a function return type declaration will generate a compilation error, unless the return | 
|  | type is declared as a pointer type and the qualifier is used on the points-to address space. | 
|  | </p> | 
|  | <p> | 
|  | For example: | 
|  | </p> | 
|  | <div class="informaltable"> | 
|  | <table border="0"> | 
|  | <colgroup> | 
|  | <col align="left" class="col1" /> | 
|  | </colgroup> | 
|  | <tbody> | 
|  | <tr> | 
|  | <td align="left"> | 
|  | __private int f() { ... } // should generate an error | 
|  | __local int *f() { ... } // allowed | 
|  | __local int * __private f() { ... }; // should generate an error. | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | <div class="informaltable"> | 
|  | <table border="0"> | 
|  | <colgroup> | 
|  | <col align="left" class="col1" /> | 
|  | </colgroup> | 
|  | <tbody> | 
|  | <tr> | 
|  | <td align="left"> | 
|  | // declares a pointer p in the __private address space that | 
|  | // points to an int object in address space __global | 
|  | __global int *p; | 
|  |  | 
|  | // declares an array of 4 floats in the __private address space. | 
|  | float x[4]; | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | </div> | 
|  | <div class="refsect1"> | 
|  | <a id="specification"></a> | 
|  | <h2>Specification</h2> | 
|  | <p> | 
|  | <img src="pdficon_small1.gif" /> | 
|  |  | 
|  | <a href="http://www.khronos.org/registry/cl/specs/opencl-1.2.pdf#page=222" target="OpenCL Spec">OpenCL Specification</a> | 
|  | </p> | 
|  | </div> | 
|  | <div class="refsect1"> | 
|  | <a id="seealso"></a> | 
|  | <h2>Also see</h2> | 
|  | <p> | 
|  | <a class="citerefentry" href="global.html"><span class="citerefentry"><span class="refentrytitle">__global</span></span></a>, | 
|  | <a class="citerefentry" href="local.html"><span class="citerefentry"><span class="refentrytitle">__local</span></span></a>, | 
|  | <a class="citerefentry" href="constant.html"><span class="citerefentry"><span class="refentrytitle">__constant</span></span></a> | 
|  | </p> | 
|  | </div> | 
|  | <div xmlns="" class="refsect3" lang="en" xml:lang="en"><a xmlns="http://www.w3.org/1999/xhtml" id="Copyright"></a><h4 xmlns="http://www.w3.org/1999/xhtml"></h4><img xmlns="http://www.w3.org/1999/xhtml" src="KhronosLogo.jpg" /><p xmlns="http://www.w3.org/1999/xhtml"></p>Copyright © 2007-2011 The Khronos Group Inc. | 
|  | Permission is hereby granted, free of charge, to any person obtaining a | 
|  | copy of this software and/or associated documentation files (the | 
|  | "Materials"), to deal in the Materials without restriction, including | 
|  | without limitation the rights to use, copy, modify, merge, publish, | 
|  | distribute, sublicense, and/or sell copies of the Materials, and to | 
|  | permit persons to whom the Materials are furnished to do so, subject to | 
|  | the condition that this copyright notice and permission notice shall be included | 
|  | in all copies or substantial portions of the Materials. | 
|  | </div> | 
|  | </div> | 
|  | </body> | 
|  | </html> |