<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Dec 27, 2012, at 4:41 AM, Alexey Bataev <<a href="mailto:a.bataev@gmx.com">a.bataev@gmx.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><span style="font-family:Verdana"><span style="font-size:12px">Chandler,<br>
Sorry, my bad. See document in attach.<br></span></span></blockquote><div><br></div><div>Some comments on the design document...</div><div><br></div><div><div>> General approach of parsing these directives is to use standard </div><div>> pragma parsing harness. This invlolves implementation of ``PragmaHandler``-based</div></div><div><br></div><div>Typo "invlolves".</div><div><br></div><div><div>> class for all OpenMP pragmas or several PragmaHandlers for each particular</div><div>> pragma. Then each pragma, generally processed by ``Preprocessor``, should be turned</div><div>> into some particular statement-like construct (using</div><div>> ``Preprocessor::EnterTokenStream``), which then should be parsed in ``Parser``'s</div><div>> context.</div></div><div><br></div><div>Okay, that's the right approach. PragmaNamespace makes it fairly easy to have separate handlers for the various omp pragmas.</div><div><br></div><div><div>> This construct may represent some custom construct or could be</div><div>> transformed into some standard language construct. Olaf Krzikalla made `a proposal</div><div>> <<a href="http://clang-developers.42468.n3.nabble.com/OpenMP-support-in-CLANG-A-proposal-td4027258.html">http://clang-developers.42468.n3.nabble.com/OpenMP-support-in-CLANG-A-proposal-td4027258.html</a>>`_</div><div>> to handle OpenMP constructs as attributes. So, we can try to translate OpenMP </div><div>> pragmas into some form of GCC or C++11 attributes and use standard approach to</div><div>> parse these attributes. However, it requires at least two parsing passes,</div><div>> with first one transforming pragmas into attributes and second one translating</div><div>> attributes and verifying their semantic correctness. Thus, it seems that a</div><div>> better solution would be to introduce new annotation token for OpenMP pragmas</div><div>> and custom parsing procedures for translating OpenMP pragmas into some special</div><div>> new Stmts.</div><div><br></div><div>I agree that attributes is not the best way to go. The parser can parse the OpenMP pragma into a reasonable AST for that pragma. That AST goes to the normal statement parsing (e.g., an OpenMP parallel directive gets parsed and passed to the "for" statement parser), and gets carried along to semantic analysis. As part of type-checking the for loop, we'll check the OpenMP constraints.</div><div><br></div><div>I think separate statements makes sense, but it depends somewhat on how different they'll actually be and how many there are. Do you have a good sense of which statements we'll need?</div><div><br></div><div><div>> This approach allows separation of subsequent CodeGen stage for</div><div>> OpenMP Stmts from CodeGen stage for standard statements, while handling OpenMP</div><div>> pragmas as attributes requires rework of CodeGen procedures for almost all</div><div>> statements -- in order to handle these new OpenMP specific attributes.</div></div><div><br></div><div>Perhaps. I think it depends a bit on how function outlining is handled. In particular, I could certainly imagine that Sema is involved in outlining, e.g., by keeping track of which variables are captured (which it knows how to do for lambdas/blocks) and having an explicit outlined statement that specifies its captures. If that's the case, an OpenMP parallel for (for example), could be a ForStmt whose body is an outlined statement and that has the OpenMP parallel for AST added to it. Anyway, I'd love to hear more thoughts on how you want to tackle outlining.</div><div><br></div><div>> #. Implement support of ``-fopenmp`` and ``-fno-openmp`` compiler options.</div><div><br></div><div>We have the -cc1 -fopenmp now; the driver-level options can wait until the feature is complete.</div><div><br></div><div><div>> #. Develop AST representation for each OpenMP directive and clause representing </div><div>> OpenMP constructions as statements.</div><div><br></div><div>Okay. Let's take a sample one.</div><div><br></div><div><div>> #. Implement parsing and semantic analysis for each directive using standard </div><div>> pragma processing approach (implies implementing of single PragmaHandler for </div><div>> all directives, parsing procedures for directives, clauses and their </div><div>> arguments, and semantic checking of all OpenMP construct).</div><div><br></div><div>Sure, let's take this in stages: pick an OpenMP directive and write a parser for it w/ tests. Then add some semantic analysis, then ASTs, and we'll see how things shape up.</div><div><br></div><div>> #. Implement CodeGen stage (to be discussed later) for each OpenMP construct.</div><div><br></div><div>Some of this will tie into the runtime. I'm most interested in your approach to handling outlining, because that's going to affect the ASTs.</div><div><br></div><div><div>> Some of OpenMP directives still could be represented as attributes, for</div><div>> example ``omp threadprivate`` directive. This directive specifies that variables </div><div>> from a list following the directive are "replicated, with each thread having its</div><div>> own copy". This is a declarative directive, so it would be better to represent</div><div>> it as an attribute of a varible, not a statement.</div><div><br></div><div>That seems reasonable.</div><div><br></div><div>I think this is a good start. Looking forward to more patches!</div><div><br></div></div></div></div><div><span class="Apple-tab-span" style="white-space: pre; "> </span>- Doug</div></div><div><br></div><br><blockquote type="cite"><span style="font-family:Verdana"><span style="font-size:12px">
Best regards,
<div>
Alexey Bataev</div>
<div>
=============</div>
<div>
Software Engineer</div>
<div>
Intel Compiler Team</div>
<div>
Intel Corp.</div>
<br><p style="margin:0px; padding:0px;">
</p>
<blockquote style="border-left: 1px solid #CCC; padding-left: 5px; margin-left: 5px; margin-bottom: 0px; margin-top: 0px; margin-right: 0px;" type="cite"><div style="margin: 0px; padding: 0px; ">
<span style="font-family:Verdana"><span style="font-size:12px">----- Original Message -----</span></span></div><div style="margin: 0px; padding: 0px; ">
<span style="font-family:Verdana"><span style="font-size:12px">From: Chandler Carruth</span></span></div><div style="margin: 0px; padding: 0px; ">
<span style="font-family:Verdana"><span style="font-size:12px">Sent: 12/27/12 07:48 AM</span></span></div><div style="margin: 0px; padding: 0px; ">
<span style="font-family:Verdana"><span style="font-size:12px">To: Alexey Bataev</span></span></div><div style="margin: 0px; padding: 0px; ">
<span style="font-family:Verdana"><span style="font-size:12px">Subject: Re: [cfe-dev] [RFC] OpenMP Support in Clang</span></span></div>
<br>
<div>
<div style="font-family: arial, helvetica, sans-serif; font-size: 10pt">
<div>
<div class="gmail_default" style="">
On Wed, Dec 26, 2012 at 8:28 AM, Alexey Bataev <span><<a class="cremed" href="mailto:a.bataev@gmx.com" target="_blank">a.bataev@gmx.com</a>></span> wrote:</div>
<div class="gmail_extra">
<div class="gmail_quote">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi All,<br>
<br>
We'd like to make a proposal for OpenMP support in Clang as discussed later.<br>
Included document contains some general design description and a proposal on<br>
OpenMP constructs representation in AST.<br>
We seek feedback on the proposed design and ways to improve it.<br>
Main authors of the proposal are Alexey Bataev and Andrey Bokhanko.<br>
The document in rst format is attached to the message.<br>
OpenMP_design.rst<br>
<<a class="cremed" href="http://clang-developers.42468.n3.nabble.com/file/n4029194/OpenMP_design.rst" target="_blank">http://clang-developers.42468.n3.nabble.com/file/n4029194/OpenMP_design.rst</a>></blockquote>
<div>
</div>
<div style="">
This link doesn't work for me -- at least it doesn't work the right way. It's not laid out as plain text but instead as raw html.</div>
<div style="">
</div>
<div style="">
Maybe actually attach it via email rather than nabble's link-embedding approach? Dunno.</div>
<div>
</div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Yours,<br>
Alexey Bataev<br>
Andrey Bokhanko<br>
=============<br>
Software Engineers<br>
Intel Compiler Team<br>
Intel Corp.<br>
<br>
<br>
<br>
--<br>
View this message in context: <a class="cremed" href="http://clang-developers.42468.n3.nabble.com/RFC-OpenMP-Support-in-Clang-tp4029194.html" target="_blank">http://clang-developers.42468.n3.nabble.com/RFC-OpenMP-Support-in-Clang-tp4029194.html</a><br>
Sent from the Clang Developers mailing list archive at <a href="http://Nabble.com">Nabble.com</a>.<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a class="cremed" href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br>
<a class="cremed" href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a></blockquote>
</div>
</div>
</div>
</div>
</div>
</blockquote><p style="margin:0px; padding:0px;">
</p>
<br>
</span></span>
<span><OpenMP_design.rst></span>_______________________________________________<br>cfe-dev mailing list<br><a href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br>http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev<br></blockquote></div><br></body></html>