<html><body><div style="color:#000; background-color:#fff; font-family:arial, helvetica, sans-serif;font-size:10pt"><div><span>Hi,</span></div><div><br><span></span></div><div><span>I plan to work on parallelizing loops in LLVM in the near future. For the moment, the plan is to transform sequential loops into parallel loops at the IR level, by modifying their structure and inserting gomp calls. I do not plan to work on all structures available in OpenMP, for now, we focus only on loops. However, <br></span></div><div><span>if our work seems to be similar, we can keep in touch and exchange ideas. I'll be back with more details when I start the implementation.<br></span></div><div><br><span></span></div><div><span>Alexandra<br></span></div><div style="font-family: arial, helvetica, sans-serif; font-size: 10pt;"> <div style="font-family: times new roman, new york, times, serif; font-size: 12pt;"> <div dir="ltr"> <font face="Arial" size="2"> <hr
size="1"> <b><span style="font-weight:bold;">From:</span></b> Vlad Krylov <krvladislav@gmail.com><br> <b><span style="font-weight: bold;">To:</span></b> Tobias Grosser <tobias@grosser.es> <br><b><span style="font-weight: bold;">Cc:</span></b> Jimborean Alexandra <xinfinity_a@yahoo.com>; "polly-dev@googlegroups.com" <polly-dev@googlegroups.com>; Sebastian Pop <sebpop@gmail.com>; "llvmdev@cs.uiuc.edu" <llvmdev@cs.uiuc.edu> <br> <b><span style="font-weight: bold;">Sent:</span></b> Monday, January 16, 2012 3:04 AM<br> <b><span style="font-weight: bold;">Subject:</span></b> Re: [LLVMdev] multi-threading in llvm<br> </font> </div> <br>
I am interested. I would be grateful for your hints.<br><br>So OpenMP has various constructs such as parallel, barrier, single,<br>for, etc. And there is at least two libraries to generate OpenMP code:<br>libgomp and mpc. We want to be independent of specific library.<br><br>We should create an interface with methods which present manual<br>inserting of OpenMP pragmas in C or Fortran code. These sounds like<br>"this code block should be run with #parallel" or "this for loop<br>should be run with #parallel for loop". Constructs like barrier,<br>atomic can be simply presented by methods 'barrier' and 'atomic'. But<br>parallel or for constructs allows many modifiers (schedule, private,<br>shared, etc). Сan not devise a good solution for these cases.<br><br>Guess this interface is close to IRBuilder. You suggested it will be<br>OpenMPBuilder. This mean IR will be created from scratch. Other way is<br>to provide methods to modify existing IR, like user says
"I want this<br>loop to be parallel, do it for me". What you think about this?<br><br>Implementation is calls of OpenMP library functions in a way provided<br>by the library abi. For example, in mpc:<br><br> pragma omp for schedule(runtime)<br> for ( i=lb ; i COND b ; i+=incr ) { A ; }<br> -><br> if ( __mpcomp_runtime_loop_begin( ... ) ) {<br> do {<br> for ( ... ) {<br> A ;<br> }<br> } while ( __mpcomp_runtime_loop_next( ... ) ) ;<br> }<br> __mpcomp_runtime_loop_end() ;<br><br><br>I think this work is not simple for me, so any comments are welcomed.<br><br><br>2012/1/7 Tobias Grosser <<a ymailto="mailto:tobias@grosser.es" href="mailto:tobias@grosser.es">tobias@grosser.es</a>>:<br>> On 01/07/2012 12:38 AM, Vlad Krylov wrote:<br>>><br>>> Hi,<br>>><br>>> It was proposed to implement
OpenMP framework.<br>>> Is there any progress in this area? Was the question raised at the<br>>> Euro-LLVM? Does anybody work on implementation?<br>><br>><br>> I am not aware of any work that was done or is planned to be done in public.<br>><br>> At Euro-LLVM I had a short discussion with Alexandra about targeting the<br>> OpenMP run time. We would both be interested in code that can translate<br>> normal LLVM-IR loops in OpenMP parallel loops. I am not sure,<br>> if Alexandra has some code that she can share. I for myself looked into<br>> the problem. I believe the loop extractor is a good start to implement such<br>> functionality. Yet, I do not have any written code ready.<br>><br>> Do you happen to be interested to work on this? ;-) I can definitely give<br>> you some hints.<br>><br>> Cheers<br>> Tobi<br><br><br> </div> </div> </div></body></html>