<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:SimSun;
panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:Consolas;
panose-1:2 11 6 9 2 2 4 3 2 4;}
@font-face
{font-family:"\@SimSun";
panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
{font-family:"
panose-1:0 0 0 0 0 0 0 0 0 0;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin-top:0in;
margin-right:0in;
margin-bottom:8.0pt;
margin-left:0in;
line-height:105%;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
color:black;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:#954F72;
text-decoration:underline;}
pre
{mso-style-priority:99;
mso-style-link:"HTML Preformatted Char";
margin:0in;
margin-bottom:.0001pt;
font-size:10.0pt;
font-family:"Courier New";
color:black;}
span.HTMLPreformattedChar
{mso-style-name:"HTML Preformatted Char";
mso-style-priority:99;
mso-style-link:"HTML Preformatted";
font-family:Consolas;
color:black;}
span.EmailStyle19
{mso-style-type:personal;
font-family:"Calibri",sans-serif;
color:windowtext;}
span.EmailStyle20
{mso-style-type:personal;
font-family:"Calibri",sans-serif;
color:#1F497D;}
span.EmailStyle21
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:#1F497D;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body bgcolor="white" lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal"><span style="color:#1F497D">For the firstprivate clause, the compiler generates code to pass it by value or by reference to the outlined function. The reason the first private scalars is generally passed by value is for the performance
reason.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">For this particular case, the compiler cannot generate code to pass the double @gg by value under i386-pc-linux-gnu since the value is 64 bit while the architecture is 32bit.
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">For the host compilation, the compiler generates the code to pass the data as well as the outlined function name to the OMP runtime.
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">For the target compilation, the compiler generates the outlined function so that it can be called by the OMP runtime.
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">So, the compiler is required to generate a single call on the host to support all the targets. All the target versions must have the same interface. So the common interface of the outline function should be used.
For this particular example, the variable @gcc should be passed by reference under x86_64-mic.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">Please let me know if you have more questions.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">Jin<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="margin-bottom:0in;margin-bottom:.0001pt;line-height:normal">
<a name="_____replyseparator"></a><b><span style="color:windowtext">From:</span></b><span style="color:windowtext"> Friedman, Eli [mailto:efriedma@codeaurora.org]
<br>
<b>Sent:</b> Wednesday, April 25, 2018 4:14 PM<br>
<b>To:</b> Lin, Jin <jin.lin@intel.com>; 'llvm-dev@lists.llvm.org' <llvm-dev@lists.llvm.org><br>
<b>Subject:</b> Re: [llvm-dev] [LLVM][RFC] Representing the target device information in the LLVM IR<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On 4/25/2018 3:48 PM, Lin, Jin wrote:<span style="font-size:12.0pt;line-height:105%"><o:p></o:p></span></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span style="color:#0070C0">Given a global variable @gg, the compiler has to generate code on the host to specify whether it is passed by value or passed by reference. In the following example, if the compiler generates the code for passing
by value, the outlined function on the target </span><span style="font-family:""",serif;color:#0070C0;border:none windowtext 1.0pt;padding:0in">i386-pc-linux-gnu</span><span style="color:#0070C0"> cannot get the correct value since it assumes the variable
@gg is passed by reference. </span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:#0070C0"> </span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:#0070C0">Here is the corresponding IR on the host side.</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:red"> %0 = load double, double* @gg, align 8, !tbaa !3</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:red"> %1 = bitcast double %0 to i64</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:#1F497D"> …</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:#0070C0"> %12 = getelementptr inbounds [4 x i8*], [4 x i8*]* %.offload_baseptrs, i32 0, i32 2</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:#0070C0"> %13 = bitcast i8** %12 to i64*</span><o:p></o:p></p>
<p class="MsoNormal"><span style="color:red"> store i64 %1, i64* %13, align 8</span><o:p></o:p></p>
</blockquote>
<p class="MsoNormal" style="margin-bottom:0in;margin-bottom:.0001pt;line-height:normal">
<span style="font-size:12.0pt;font-family:"Times New Roman",serif"><br>
Could you describe the overall process of calling an offloaded function in a bit more detail? How do you describe the ABI of the called function to the OpenMP runtime?<br>
<br>
I suspect you shouldn't be trying to store things which aren't pointers into offload_baseptrs.<br>
<br>
-Eli<br>
<br>
<br>
<o:p></o:p></span></p>
<pre>-- <o:p></o:p></pre>
<pre>Employee of Qualcomm Innovation Center, Inc.<o:p></o:p></pre>
<pre>Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project<o:p></o:p></pre>
</div>
</body>
</html>