<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=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@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;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman",serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-reply;
        font-family:Consolas;
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@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 lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Consolas;color:#1F497D">It was my mistake. I got your email late, and had reverted the change and re-committed it again at r268424.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Consolas;color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in"><span style="font-size:9.0pt;font-family:Consolas">------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas">r268424 | liu12295 | 2016-05-03 12:30:48 -0700 (Tue, 03 May 2016) | 6 lines<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas"><o:p> </o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas">[SROA] Function canConvertValue needs to check whether both NewTy and OldTy pointers are<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas">pointing to the same addr space. This can prevent SROA from creating a bitcast<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas">between pointers with different addr spaces.<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas"><o:p> </o:p></span></p>
<p class="MsoNormal" style="margin-left:.5in;text-autospace:none"><span style="font-size:9.0pt;font-family:Consolas">Differential Revision: http://reviews.llvm.org/D19697<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Consolas;color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Consolas;color:#1F497D">Sorry about the confusion.<o:p></o:p></span></p>
<p class="MsoNormal"><a name="_MailEndCompose"><span style="font-size:11.0pt;font-family:Consolas;color:#1F497D"><o:p> </o:p></span></a></p>
<p class="MsoNormal"><a name="_____replyseparator"></a><b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif">From:</span></b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif"> David Blaikie [mailto:dblaikie@gmail.com]
<br>
<b>Sent:</b> Tuesday, May 3, 2016 12:59 PM<br>
<b>To:</b> Liu, Jack <jack.liu@intel.com><br>
<b>Cc:</b> llvm-commits <llvm-commits@lists.llvm.org><br>
<b>Subject:</b> Re: [llvm] r268409 -<o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Missing commit message? (could you provide it in a reply here - and try to include commit messages in the commit in the future (ie: don't bother reverting & recommitting this just to add a commit message unless you particularly want to
 - some people might appreciate it when trawling through the logs))<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On Tue, May 3, 2016 at 11:01 AM, Jack Liu via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<p class="MsoNormal">Author: liu12295<br>
Date: Tue May  3 13:01:43 2016<br>
New Revision: 268409<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=268409&view=rev" target="_blank">
http://llvm.org/viewvc/llvm-project?rev=268409&view=rev</a><br>
Log: (empty)<br>
<br>
Modified:<br>
    llvm/trunk/lib/Transforms/Scalar/SROA.cpp<br>
    llvm/trunk/test/Transforms/SROA/address-spaces.ll<br>
<br>
Modified: llvm/trunk/lib/Transforms/Scalar/SROA.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/SROA.cpp?rev=268409&r1=268408&r2=268409&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/SROA.cpp?rev=268409&r1=268408&r2=268409&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/Transforms/Scalar/SROA.cpp (original)<br>
+++ llvm/trunk/lib/Transforms/Scalar/SROA.cpp Tue May  3 13:01:43 2016<br>
@@ -1635,8 +1635,10 @@ static bool canConvertValue(const DataLa<br>
   OldTy = OldTy->getScalarType();<br>
   NewTy = NewTy->getScalarType();<br>
   if (NewTy->isPointerTy() || OldTy->isPointerTy()) {<br>
-    if (NewTy->isPointerTy() && OldTy->isPointerTy())<br>
-      return true;<br>
+    if (NewTy->isPointerTy() && OldTy->isPointerTy()) {<br>
+      return cast<PointerType>(NewTy)->getPointerAddressSpace() ==<br>
+        cast<PointerType>(OldTy)->getPointerAddressSpace();<br>
+    }<br>
     if (NewTy->isIntegerTy() || OldTy->isIntegerTy())<br>
       return true;<br>
     return false;<br>
<br>
Modified: llvm/trunk/test/Transforms/SROA/address-spaces.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/SROA/address-spaces.ll?rev=268409&r1=268408&r2=268409&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/SROA/address-spaces.ll?rev=268409&r1=268408&r2=268409&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/Transforms/SROA/address-spaces.ll (original)<br>
+++ llvm/trunk/test/Transforms/SROA/address-spaces.ll Tue May  3 13:01:43 2016<br>
@@ -52,7 +52,7 @@ define void @test_address_space_0_1(<2 x<br>
<br>
 %struct.struct_test_27.0.13 = type { i32, float, i64, i8, [4 x i32] }<br>
<br>
-; Function Attrs:  nounwind<br>
+; Function Attrs: nounwind<br>
 define void @copy_struct([5 x i64] %in.coerce) {<br>
 ; CHECK-LABEL: @copy_struct(<br>
 ; CHECK-NOT: memcpy<br>
@@ -66,3 +66,20 @@ for.end:<br>
   ret void<br>
 }<br>
<br>
+%union.anon = type { i32* }<br>
+<br>
+@g = common global i32 0, align 4<br>
+@l = common addrspace(3) global i32 0, align 4<br>
+<br>
+; Make sure an illegal bitcast isn't introduced<br>
+define void @pr27557() {<br>
+; CHECK-LABEL: @pr27557(<br>
+; CHECK: %[[CAST:.*]] = bitcast i32** {{.*}} to i32 addrspace(3)**<br>
+; CHECK: store i32 addrspace(3)* @l, i32 addrspace(3)** %[[CAST]]<br>
+  %1 = alloca %union.anon, align 8<br>
+  %2 = bitcast %union.anon* %1 to i32**<br>
+  store i32* @g, i32** %2, align 8<br>
+  %3 = bitcast %union.anon* %1 to i32 addrspace(3)**<br>
+  store i32 addrspace(3)* @l, i32 addrspace(3)** %3, align 8<br>
+  ret void<br>
+}<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><o:p></o:p></p>
</blockquote>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
</body>
</html>