<div dir="ltr">Hi Michael,<div><br></div><div>Thank you for review!</div><div>Yes, currently <span style="font-family:arial,sans-serif;font-size:12.800000190734863px">CodeGenFunction::InsertHelper is used only for adding metadata to the instruction that is passed as first parameter, and the others are just passed for possible future uses (basically passing everything we get from IRBuilder).</span></div>
<div><span style="font-family:arial,sans-serif;font-size:12.800000190734863px"><br></span></div><div><span style="font-family:arial,sans-serif;font-size:12.800000190734863px">Thanks,</span></div><div><span style="font-family:arial,sans-serif;font-size:12.800000190734863px">Alexander</span></div>
</div><div class="gmail_extra"><br><br><div class="gmail_quote">2014-05-20 11:49 GMT+04:00 Michael Wong <span dir="ltr"><<a href="mailto:fraggamuffin@gmail.com" target="_blank">fraggamuffin@gmail.com</a>></span>:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div>Sorry this is in digest format(but I am changing it). But for the fix above. <br></div>Code looks good. One minor question and I suspect this is because you are preparing the following function for other things in future. As it stands, it does not use any of the other parameters but the first one in the call to LoopStack.<br>
</div><div>Is that the reason this function have excessive unused parameters?<br></div><div><br><table><tbody><tr><td colspan="2">void CodeGenFunction::InsertHelper(llvm::Instruction *I,
</td></tr><tr><td><br></td><td colspan="2"><span></span> const llvm::Twine &Name,
</td></tr><tr><td><br></td><td colspan="2"><span></span> llvm::BasicBlock *BB,
</td></tr><tr><td><br></td><td colspan="2"><span></span> llvm::BasicBlock::iterator InsertPt) const {
</td></tr><tr><td><br></td><td colspan="2"><span></span> LoopStack.InsertHelper(I);
</td></tr><tr><td><br></td><td colspan="2"><span></span>}</td></tr></tbody></table><br></div>Otherwise, LGTM and builds fine.<br><div><div><div><div class="gmail_extra"><br><br><div class="gmail_quote">
On Wed, May 7, 2014 at 4:56 PM, <span dir="ltr"><<a href="mailto:cfe-commits-request@cs.uiuc.edu" target="_blank">cfe-commits-request@cs.uiuc.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0pt 0pt 0pt 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Send cfe-commits mailing list submissions to<br>
<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
<br>
To subscribe or unsubscribe via the World Wide Web, visit<br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
or, via email, send a message with subject or body 'help' to<br>
<a href="mailto:cfe-commits-request@cs.uiuc.edu" target="_blank">cfe-commits-request@cs.uiuc.edu</a><br>
<br>
You can reach the person managing the list at<br>
<a href="mailto:cfe-commits-owner@cs.uiuc.edu" target="_blank">cfe-commits-owner@cs.uiuc.edu</a><br>
<br>
When replying, please edit your Subject line so it is more specific<br>
than "Re: Contents of cfe-commits digest..."<br>
<br>
<br>
Today's Topics:<br>
<br>
1. Re: PATCH for libcxxabi - harmonize nmstr implementations<br>
(Joerg Sonnenberger)<br>
2. [libcxxabi] r208246 - Make libc++abi use the implementation<br>
of __numstr from libc++. No functionality change, just removal of<br>
duplicated code. (Marshall Clow)<br>
3. Re: [PATCH] [OPENMP] A helper for marking intstructions with<br>
llvm.mem.parallel_loop_access (Alexander Musman)<br>
4. Re: [PATCH] Suggest fix-it ':' when '=' used in<br>
for-range-declaration while initializing an auto (Ismail Pazarbasi)<br>
<br>
<br>
----------------------------------------------------------------------<br>
<br>
Message: 1<br>
Date: Wed, 7 May 2014 22:11:36 +0200<br>
From: Joerg Sonnenberger <<a href="mailto:joerg@britannica.bec.de" target="_blank">joerg@britannica.bec.de</a>><br>
To: <a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
Subject: Re: PATCH for libcxxabi - harmonize nmstr implementations<br>
Message-ID: <<a href="mailto:20140507201136.GA18859@britannica.bec.de" target="_blank">20140507201136.GA18859@britannica.bec.de</a>><br>
Content-Type: text/plain; charset=utf-8<br>
<br>
On Sun, May 04, 2014 at 12:37:04PM -0700, Marshall Clow wrote:<br>
> Now that jboerg has made the __nmstr implementation in libc++ match the one in libc++abi,<br>
> it?s time to kill one off one of the two implementations.<br>
><br>
> Make libc++abi include the version from libc++.<br>
<br>
LGTM.<br>
<br>
Joerg<br>
<br>
<br>
------------------------------<br>
<br>
Message: 2<br>
Date: Wed, 07 May 2014 20:17:41 -0000<br>
From: Marshall Clow <<a href="mailto:mclow.lists@gmail.com" target="_blank">mclow.lists@gmail.com</a>><br>
To: <a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
Subject: [libcxxabi] r208246 - Make libc++abi use the implementation<br>
of __numstr from libc++. No functionality change, just removal of<br>
duplicated code.<br>
Message-ID: <<a href="mailto:20140507201741.45CD02A6C03C@llvm.org" target="_blank">20140507201741.45CD02A6C03C@llvm.org</a>><br>
Content-Type: text/plain; charset="utf-8"<br>
<br>
Author: marshall<br>
Date: Wed May 7 15:17:41 2014<br>
New Revision: 208246<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=208246&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=208246&view=rev</a><br>
Log:<br>
Make libc++abi use the implementation of __numstr from libc++. No functionality change, just removal of duplicated code.<br>
<br>
Modified:<br>
libcxxabi/trunk/src/stdexcept.cpp<br>
<br>
Modified: libcxxabi/trunk/src/stdexcept.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxxabi/trunk/src/stdexcept.cpp?rev=208246&r1=208245&r2=208246&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/libcxxabi/trunk/src/stdexcept.cpp?rev=208246&r1=208245&r2=208246&view=diff</a><br>
==============================================================================<br>
--- libcxxabi/trunk/src/stdexcept.cpp (original)<br>
+++ libcxxabi/trunk/src/stdexcept.cpp Wed May 7 15:17:41 2014<br>
@@ -7,6 +7,7 @@<br>
//<br>
//===----------------------------------------------------------------------===//<br>
<br>
+#include "__refstring"<br>
#include "stdexcept"<br>
#include "new"<br>
#include <cstdlib><br>
@@ -14,147 +15,25 @@<br>
#include <cstdint><br>
#include <cstddef><br>
<br>
-#if __APPLE__<br>
-#include <dlfcn.h><br>
-#include <mach-o/dyld.h><br>
-#endif<br>
-<br>
-// Note: optimize for size<br>
-<br>
-#pragma GCC visibility push(hidden)<br>
-<br>
-namespace<br>
-{<br>
-<br>
-class __libcpp_nmstr<br>
-{<br>
-private:<br>
- const char* str_;<br>
-<br>
- typedef int count_t;<br>
-<br>
- struct _Rep_base<br>
- {<br>
- std::size_t len;<br>
- std::size_t cap;<br>
- count_t count;<br>
- };<br>
-<br>
- static const std::ptrdiff_t offset = static_cast<std::ptrdiff_t>(sizeof(_Rep_base));<br>
-<br>
- count_t& count() const _NOEXCEPT {return ((_Rep_base*)(str_ - offset))->count;}<br>
-<br>
-#if __APPLE__<br>
- static<br>
- const void*<br>
- compute_gcc_empty_string_storage() _NOEXCEPT<br>
- {<br>
- void* handle = dlopen("/usr/lib/libstdc++.6.dylib", RTLD_NOLOAD);<br>
- if (handle == 0)<br>
- return 0;<br>
- return (const char*)dlsym(handle, "_ZNSs4_Rep20_S_empty_rep_storageE") + offset;<br>
- }<br>
-<br>
- static<br>
- const void*<br>
- get_gcc_empty_string_storage() _NOEXCEPT<br>
- {<br>
- static const void* p = compute_gcc_empty_string_storage();<br>
- return p;<br>
- }<br>
-#endif<br>
-<br>
-public:<br>
- explicit __libcpp_nmstr(const char* msg);<br>
- __libcpp_nmstr(const __libcpp_nmstr& s) _NOEXCEPT;<br>
- __libcpp_nmstr& operator=(const __libcpp_nmstr& s) _NOEXCEPT;<br>
- ~__libcpp_nmstr();<br>
- const char* c_str() const _NOEXCEPT {return str_;}<br>
-};<br>
-<br>
-__libcpp_nmstr::__libcpp_nmstr(const char* msg)<br>
-{<br>
- std::size_t len = strlen(msg);<br>
- str_ = static_cast<const char*>(::operator new(len + 1 + offset));<br>
- _Rep_base* c = (_Rep_base*)str_;<br>
- c->len = c->cap = len;<br>
- str_ += offset;<br>
- count() = 0;<br>
- std::memcpy(const_cast<char*>(c_str()), msg, len + 1);<br>
-}<br>
-<br>
-inline<br>
-__libcpp_nmstr::__libcpp_nmstr(const __libcpp_nmstr& s) _NOEXCEPT<br>
- : str_(s.str_)<br>
-{<br>
-#if __APPLE__<br>
- if (str_ != get_gcc_empty_string_storage())<br>
-#endif<br>
- __sync_add_and_fetch(&count(), 1);<br>
-}<br>
-<br>
-__libcpp_nmstr&<br>
-__libcpp_nmstr::operator=(const __libcpp_nmstr& s) _NOEXCEPT<br>
-{<br>
- const char* p = str_;<br>
- str_ = s.str_;<br>
-#if __APPLE__<br>
- if (str_ != get_gcc_empty_string_storage())<br>
-#endif<br>
- __sync_add_and_fetch(&count(), 1);<br>
-#if __APPLE__<br>
- if (p != get_gcc_empty_string_storage())<br>
-#endif<br>
- if (__sync_add_and_fetch((count_t*)(p-sizeof(count_t)), count_t(-1)) < 0)<br>
- {<br>
- ::operator delete(const_cast<char*>(p-offset));<br>
- }<br>
- return *this;<br>
-}<br>
-<br>
-inline<br>
-__libcpp_nmstr::~__libcpp_nmstr()<br>
-{<br>
-#if __APPLE__<br>
- if (str_ != get_gcc_empty_string_storage())<br>
-#endif<br>
- if (__sync_add_and_fetch(&count(), count_t(-1)) < 0)<br>
- {<br>
- ::operator delete(const_cast<char*>(str_ - offset));<br>
- }<br>
-}<br>
-<br>
-}<br>
-<br>
-#pragma GCC visibility pop<br>
+static_assert(sizeof(std::__libcpp_refstring) == sizeof(const char *), "");<br>
<br>
namespace std // purposefully not using versioning namespace<br>
{<br>
<br>
-logic_error::~logic_error() _NOEXCEPT<br>
-{<br>
- __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_;<br>
- s.~__libcpp_nmstr();<br>
-}<br>
+logic_error::~logic_error() _NOEXCEPT {}<br>
<br>
const char*<br>
logic_error::what() const _NOEXCEPT<br>
{<br>
- __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_;<br>
- return s.c_str();<br>
+ return __imp_.c_str();<br>
}<br>
<br>
-runtime_error::~runtime_error() _NOEXCEPT<br>
-{<br>
- __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_;<br>
- s.~__libcpp_nmstr();<br>
-}<br>
+runtime_error::~runtime_error() _NOEXCEPT {}<br>
<br>
const char*<br>
runtime_error::what() const _NOEXCEPT<br>
{<br>
- __libcpp_nmstr& s = (__libcpp_nmstr&)__imp_;<br>
- return s.c_str();<br>
+ return __imp_.c_str();<br>
}<br>
<br>
domain_error::~domain_error() _NOEXCEPT {}<br>
<br>
<br>
<br>
<br>
------------------------------<br>
<br>
Message: 3<br>
Date: Thu, 8 May 2014 00:45:21 +0400<br>
From: Alexander Musman <<a href="mailto:alexander.musman@gmail.com" target="_blank">alexander.musman@gmail.com</a>><br>
To: Hal Finkel <<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>><br>
Cc: Alexey Bataev <<a href="mailto:a.bataev@hotmail.com" target="_blank">a.bataev@hotmail.com</a>>, <a href="mailto:rjmccall@gmail.com" target="_blank">rjmccall@gmail.com</a>, C<br>
Bergstr?m <<a href="mailto:cbergstrom@pathscale.com" target="_blank">cbergstrom@pathscale.com</a>>, Richard Smith<br>
<<a href="mailto:richard@metafoo.co.uk" target="_blank">richard@metafoo.co.uk</a>>, llvm cfe <<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a>><br>
Subject: Re: [PATCH] [OPENMP] A helper for marking intstructions with<br>
llvm.mem.parallel_loop_access<br>
Message-ID:<br>
<CAPMY8no+Z1TQDMxQ6HSrhTtbOu7g2wM=-<a href="mailto:d%2BepmfFNVdPv3YMBg@mail.gmail.com" target="_blank">d+epmfFNVdPv3YMBg@mail.gmail.com</a>><br>
Content-Type: text/plain; charset="utf-8"<br>
<br>
Hi Tyler, Hal,<br>
<br>
> Looks like this implementation is an alternative to the patch I am<br>
proposing.<br>
<br>
I agree with Hal, I think both approaches (#pragma loop vectorize and<br>
#pragma omp simd) can co-exist.<br>
#pragma omp simd follows Openmp standard and #pragma loop vectorize has<br>
more freedom to add any hints specific for tuning vectorizer.<br>
<br>
1) Actually it is part of AST - for example, see<br>
test/OpenMP/simd_ast_print.cpp for serialization and ast printing. There is<br>
a separate AST node (see OMPSimdDirective declaration in<br>
include/clang/AST/StmtOpenMP.h).<br>
<br>
2) Templates - this part is also implemented, there is a test for non-type<br>
parameter in 'safelen' clause in the same file. If you are interested how<br>
template instatiation is done, I suggest to look at<br>
TransformOMPSafelenClause (in lib/Sema/TreeTransform.h). (I'm not sure that<br>
the same approach will work for pragma loop vectorize though, because it<br>
uses attributes while OMPSimdDirective has a separate AST node).<br>
<br>
3) No, it is not a separate pass - routine InsertHelper is called for each<br>
instruction from IR Builder, so that, when it is in the "parallel" loop<br>
body, it will mark load/store instructions with<br>
llvm.mem.parallel_loop_access.<br>
<br>
Thanks,<br>
Alexander<br>
<br>
<br>
2014-05-07 22:47 GMT+04:00 Hal Finkel <<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>>:<br>
<br>
><br>
><br>
> ----- Original Message -----<br>
> > From: "Tyler Nowicki" <<a href="mailto:tnowicki@apple.com" target="_blank">tnowicki@apple.com</a>><br>
> > To: "Alexander Musman" <<a href="mailto:alexander.musman@gmail.com" target="_blank">alexander.musman@gmail.com</a>><br>
> > Cc: "Douglas Gregor" <<a href="mailto:dgregor@apple.com" target="_blank">dgregor@apple.com</a>>, <a href="mailto:rjmccall@gmail.com" target="_blank">rjmccall@gmail.com</a>, "Richard<br>
> Smith" <<a href="mailto:richard@metafoo.co.uk" target="_blank">richard@metafoo.co.uk</a>>, "Alexey<br>
> > Bataev" <<a href="mailto:a.bataev@hotmail.com" target="_blank">a.bataev@hotmail.com</a>>, "Hal Finkel" <<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>>,<br>
> <a href="mailto:gribozavr@gmail.com" target="_blank">gribozavr@gmail.com</a>, <a href="mailto:cbergstrom@pathscale.com" target="_blank">cbergstrom@pathscale.com</a>,<br>
> > "renato golin" <<a href="mailto:renato.golin@linaro.org" target="_blank">renato.golin@linaro.org</a>>, "llvm cfe" <<br>
> <a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a>><br>
> > Sent: Wednesday, May 7, 2014 12:18:17 PM<br>
> > Subject: Re: [PATCH] [OPENMP] A helper for marking intstructions with<br>
> llvm.mem.parallel_loop_access<br>
> ><br>
> > Hi Alexander,<br>
> ><br>
> > Looks like this implementation is an alternative to the patch I am<br>
> > proposing.<br>
><br>
> Just to provide a small amount of additional context:<br>
><br>
> OpenMP 4 specifies standard pragmas for loop vectorization. These differ,<br>
> generically, from vendor-specific vectorization pragmas because they 1)<br>
> assert safety and must work (or produce an error; they are not just hints)<br>
> and 2) the standard specifies a restricted syntax for the loops which the<br>
> frontend must check. This is not an alternative to what you've proposed: we<br>
> need both! That having been said, we should obviously unify the<br>
> implementation to the extent possible.<br>
><br>
> -Hal<br>
><br>
> > I?m pretty sure I also saw something like this on the<br>
> > list before. There are a few things I am concerned about with this<br>
> > approach. I am new to clang development though so please let me know<br>
> > what I misunderstood anything.<br>
> ><br>
> > 1. The pragma is not part of the AST. This makes the pragmas hidden<br>
> > to any passes over the AST. That may cause problems for features<br>
> > like serialization/deserialization and ast-print. If the pragma is<br>
> > an AST node those are easily supported.<br>
> ><br>
> > 2. Templates. I know there is a lot of interest in allowing the loop<br>
> > vectorization pragmas to take non-type template parameters. It has<br>
> > been a much requested feature on my patch. One of the challenges I<br>
> > am finding is that the non-type template parameters should be<br>
> > resolved on template instantiation. This probably has to occur when<br>
> > AST nodes are visited during semantic analysis. A few people have<br>
> > commented that they don?t want it in CodeGen because that would mean<br>
> > the verification of the input values would occur in codegen as well<br>
> > (see link [1] below). I?m still trying to figure this one out. But I<br>
> > am wondering how would you do it?<br>
> ><br>
> > 2. Efficiency. It looks like you have to make an extra pass over<br>
> > every loop.cond and loop.body even if metadata was not attached to<br>
> > those loops? Or did I miss something?<br>
> ><br>
> > As I said, I?m new to clang so if I misunderstood anything please let<br>
> > me know.<br>
> ><br>
> > Tyler<br>
> ><br>
> > [1] -<br>
> ><br>
> <a href="http://lists.cs.uiuc.edu/pipermail/cfe-commits/Week-of-Mon-20140505/104925.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/cfe-commits/Week-of-Mon-20140505/104925.html</a><br>
> ><br>
> > On May 7, 2014, at 6:13 AM, Alexander Musman<br>
> > <<a href="mailto:alexander.musman@gmail.com" target="_blank">alexander.musman@gmail.com</a>> wrote:<br>
> ><br>
> > > Hi doug.gregor, rjmccall, rsmith, ABataev, hfinkel, gribozavr,<br>
> > > cbergstrom, rengolin, TylerNowicki,<br>
> > ><br>
> > > This patch adds a helper class (CGLoopInfo) for marking memory<br>
> > > instructions with llvm.mem.parallel_loop_access metadata.<br>
> > > It also adds a simple initial version of codegen for pragma omp<br>
> > > simd (it will change in the future to support all the clauses).<br>
> > ><br>
> > > <a href="http://reviews.llvm.org/D3644" target="_blank">http://reviews.llvm.org/D3644</a><br>
> > ><br>
> > > Files:<br>
> > > lib/CodeGen/CGBuilder.h<br>
> > > lib/CodeGen/CGLoopInfo.cpp<br>
> > > lib/CodeGen/CGLoopInfo.h<br>
> > > lib/CodeGen/CGStmt.cpp<br>
> > > lib/CodeGen/CGStmtOpenMP.cpp<br>
> > > lib/CodeGen/CMakeLists.txt<br>
> > > lib/CodeGen/CodeGenFunction.cpp<br>
> > > lib/CodeGen/CodeGenFunction.h<br>
> > > test/OpenMP/simd_metadata.c<br>
> > > <D3644.9161.patch><br>
> ><br>
> ><br>
><br>
> --<br>
> Hal Finkel<br>
> Assistant Computational Scientist<br>
> Leadership Computing Facility<br>
> Argonne National Laboratory<br>
><br>
-------------- next part --------------<br>
An HTML attachment was scrubbed...<br>
URL: <<a href="http://lists.cs.uiuc.edu/pipermail/cfe-commits/attachments/20140508/c627e2ee/attachment-0001.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/cfe-commits/attachments/20140508/c627e2ee/attachment-0001.html</a>><br>
<br>
------------------------------<br>
<br>
Message: 4<br>
Date: Wed, 7 May 2014 20:56:46 +0000<br>
From: Ismail Pazarbasi <<a href="mailto:ismail.pazarbasi@gmail.com" target="_blank">ismail.pazarbasi@gmail.com</a>><br>
To: <a href="mailto:ismail.pazarbasi@gmail.com" target="_blank">ismail.pazarbasi@gmail.com</a>, <a href="mailto:benny.kra@gmail.com" target="_blank">benny.kra@gmail.com</a>,<br>
<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a><br>
Cc: <a href="mailto:richard@metafoo.co.uk" target="_blank">richard@metafoo.co.uk</a>, <a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
Subject: Re: [PATCH] Suggest fix-it ':' when '=' used in<br>
for-range-declaration while initializing an auto<br>
Message-ID: <ebc156f7fabfb21d6e17a50cc47abbc0@localhost.localdomain><br>
Content-Type: text/plain; charset="utf-8"<br>
<br>
Richard,<br>
<br>
thank you for feedback. Briefly, changes since last revision:<br>
* Replaced warning with an error. This is going to be the only diagnostics emitted for this case.<br>
* TypeContainsAuto is removed from check; I thought `auto` (strongly) suggests that this is a range-based for, while an `int`, for example, is not that strong.<br>
* Pass `ForRangeInit` down to `ParseDeclarationAfterDeclaratorAndAttributes` to set `ForRangeInit::ColonLoc`; this tells parser to treat a `for` statement as a "range-based for".<br>
* Fix-it uses spelling location for replacement to handle macro expansions<br>
<br>
<a href="http://reviews.llvm.org/D3370" target="_blank">http://reviews.llvm.org/D3370</a><br>
<br>
Files:<br>
include/clang/Basic/DiagnosticParseKinds.td<br>
include/clang/Parse/Parser.h<br>
lib/Parse/ParseDecl.cpp<br>
lib/Parse/ParseStmt.cpp<br>
test/Parser/cxx0x-for-range.cpp<br>
-------------- next part --------------<br>
A non-text attachment was scrubbed...<br>
Name: D3370.9188.patch<br>
Type: text/x-patch<br>
Size: 7251 bytes<br>
Desc: not available<br>
URL: <<a href="http://lists.cs.uiuc.edu/pipermail/cfe-commits/attachments/20140507/c1721db4/attachment.bin" target="_blank">http://lists.cs.uiuc.edu/pipermail/cfe-commits/attachments/20140507/c1721db4/attachment.bin</a>><br>
<br>
------------------------------<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
<br>
<br>
End of cfe-commits Digest, Vol 83, Issue 154<br>
********************************************<br>
</blockquote></div><br></div></div></div></div></div>
<br>_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
<br></blockquote></div><br></div>