<div dir="ltr"><div class="gmail_default" style="font-family:georgia,serif">Below code should work:</div><div class="gmail_default" style="font-family:georgia,serif"><br></div><div class="gmail_default"><div class="gmail_default"><font face="monospace, monospace">    let blockSize = min(512, count)</font></div><div class="gmail_default"><font face="monospace, monospace">    let blockCount = (count+blockSize-1)/blockSize</font></div><div class="gmail_default"><font face="monospace, monospace">    </font></div><div class="gmail_default"><font face="monospace, monospace">    let boxedClosure = { (foo</font><span style="font-family:monospace,monospace">:inout MutableDeviceCollection</span><span style="font-family:monospace,monospace">) -&gt; () in</span></div><div class="gmail_default"><font face="monospace, monospace">        device.sync { // Launch CUDA kernel</font></div><div class="gmail_default"><font face="monospace, monospace">            try! fill&lt;&lt;&lt;(blockSize, blockCount)&gt;&gt;&gt;[</font></div><div class="gmail_default"><font face="monospace, monospace">                .pointer(to: foo), .value(value), .value(Int64(count))</font></div><div class="gmail_default"><font face="monospace, monospace">            ]</font></div><div class="gmail_default"><font face="monospace, monospace">        }</font></div><div class="gmail_default"><font face="monospace, monospace">    }</font></div><div class="gmail_default"><font face="monospace, monospace">    </font></div><div class="gmail_default"><font face="monospace, monospace">    boxedClosure(&amp;self)</font></div><div class="gmail_default"><font face="georgia, serif"><br></font></div><div class="gmail_default"><font face="georgia, serif">Zhaoxin</font></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Dec 16, 2016 at 5:12 PM, Richard Wei <span dir="ltr">&lt;<a href="mailto:rxrwei@gmail.com" target="_blank">rxrwei@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">The original file’s here:<br>
<a href="https://github.com/rxwei/cuda-swift/blob/master/Sources/Warp/CollectionOperations.swift" rel="noreferrer" target="_blank">https://github.com/rxwei/cuda-<wbr>swift/blob/master/Sources/<wbr>Warp/CollectionOperations.<wbr>swift</a><br>
<br>
I’m assuming this change has affected Dispatch users as well. It&#39;s not a good idea for such high-level APIs to rely on explicit pointers to pass mutating self for struct types.<br>
<span class="HOEnZb"><font color="#888888"><br>
-Richard<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
&gt; On Dec 16, 2016, at 03:05, Richard Wei &lt;<a href="mailto:rxrwei@gmail.com">rxrwei@gmail.com</a>&gt; wrote:<br>
&gt;<br>
&gt; It’s not the correct choice here :)<br>
&gt;<br>
&gt;&gt; On Dec 16, 2016, at 03:04, Rien &lt;Rien@Balancingrock.nl&gt; wrote:<br>
&gt;&gt;<br>
&gt;&gt; Just because it is called “Unsafe” does not mean it is unsafe :-)<br>
&gt;&gt; It all depends on how you use it.<br>
&gt;&gt;<br>
&gt;&gt; Regards,<br>
&gt;&gt; Rien<br>
&gt;&gt;<br>
&gt;&gt; Site: <a href="http://balancingrock.nl" rel="noreferrer" target="_blank">http://balancingrock.nl</a><br>
&gt;&gt; Blog: <a href="http://swiftrien.blogspot.com" rel="noreferrer" target="_blank">http://swiftrien.blogspot.com</a><br>
&gt;&gt; Github: <a href="http://github.com/Swiftrien" rel="noreferrer" target="_blank">http://github.com/Swiftrien</a><br>
&gt;&gt; Project: <a href="http://swiftfire.nl" rel="noreferrer" target="_blank">http://swiftfire.nl</a><br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;&gt; On 16 Dec 2016, at 09:52, Richard Wei &lt;<a href="mailto:rxrwei@gmail.com">rxrwei@gmail.com</a>&gt; wrote:<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Zhao, it’s not a class.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Rien, unsafe pointers is the last thing I would ever want to introduce in my library…<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Capturing self was clean, working perfectly, until Swift 3.0.2.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; -Richard<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; On Dec 16, 2016, at 02:49, Zhao Xin &lt;<a href="mailto:owenzx@gmail.com">owenzx@gmail.com</a>&gt; wrote:<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; What is the type of self? If it is a class, try [unowned self].<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; Zhaoxin<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; On Fri, Dec 16, 2016 at 4:33 PM, Rien via swift-users &lt;<a href="mailto:swift-users@swift.org">swift-users@swift.org</a>&gt; wrote:<br>
&gt;&gt;&gt;&gt; How about using:<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; UnsafeMutablePointer&lt;<wbr>TypeOfSelf&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; ?<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; Regards,<br>
&gt;&gt;&gt;&gt; Rien<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; Site: <a href="http://balancingrock.nl" rel="noreferrer" target="_blank">http://balancingrock.nl</a><br>
&gt;&gt;&gt;&gt; Blog: <a href="http://swiftrien.blogspot.com" rel="noreferrer" target="_blank">http://swiftrien.blogspot.com</a><br>
&gt;&gt;&gt;&gt; Github: <a href="http://github.com/Swiftrien" rel="noreferrer" target="_blank">http://github.com/Swiftrien</a><br>
&gt;&gt;&gt;&gt; Project: <a href="http://swiftfire.nl" rel="noreferrer" target="_blank">http://swiftfire.nl</a><br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; On 16 Dec 2016, at 09:10, Richard Wei via swift-users &lt;<a href="mailto:swift-users@swift.org">swift-users@swift.org</a>&gt; wrote:<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; Capturing makes it immutable, which unfortunately can&#39;t solve this problem.<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; -Richard<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; On Dec 16, 2016, at 02:05, Zhao Xin &lt;<a href="mailto:owenzx@gmail.com">owenzx@gmail.com</a>&gt; wrote:<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; I did not test the code. But if you cannot implicitly capture a mutating self, you should do it explicitly, right?<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; let blockSize = min(512, count)<br>
&gt;&gt;&gt;&gt;&gt;&gt; let blockCount = (count+blockSize-1)/blockSize<br>
&gt;&gt;&gt;&gt;&gt;&gt; device.sync { [self] () -&gt; () in // Launch CUDA kernel<br>
&gt;&gt;&gt;&gt;&gt;&gt;   try! fill&lt;&lt;&lt;(blockSize, blockCount)&gt;&gt;&gt;[<br>
&gt;&gt;&gt;&gt;&gt;&gt;       .pointer(to: &amp;self), .value(value), .value(Int64(count))<br>
&gt;&gt;&gt;&gt;&gt;&gt;   ]<br>
&gt;&gt;&gt;&gt;&gt;&gt; }<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; Hope above code works.<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; Zhaoxin<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; On Fri, Dec 16, 2016 at 3:46 PM, Richard Wei via swift-users &lt;<a href="mailto:swift-users@swift.org">swift-users@swift.org</a>&gt; wrote:<br>
&gt;&gt;&gt;&gt;&gt;&gt; Hi,<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; Swift 3.0.2 seems to have broken my code due to mutating self capture. But I have to pass inout self to the closure. Any workaround?<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt;   let blockSize = min(512, count)<br>
&gt;&gt;&gt;&gt;&gt;&gt;   let blockCount = (count+blockSize-1)/blockSize<br>
&gt;&gt;&gt;&gt;&gt;&gt;   device.sync { // Launch CUDA kernel<br>
&gt;&gt;&gt;&gt;&gt;&gt;       try! fill&lt;&lt;&lt;(blockSize, blockCount)&gt;&gt;&gt;[<br>
&gt;&gt;&gt;&gt;&gt;&gt;           .pointer(to: &amp;self), .value(value), .value(Int64(count))<br>
&gt;&gt;&gt;&gt;&gt;&gt;       ]<br>
&gt;&gt;&gt;&gt;&gt;&gt;   }<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; &lt;PastedGraphic-1.png&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; -Richard<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt; ______________________________<wbr>_________________<br>
&gt;&gt;&gt;&gt;&gt;&gt; swift-users mailing list<br>
&gt;&gt;&gt;&gt;&gt;&gt; <a href="mailto:swift-users@swift.org">swift-users@swift.org</a><br>
&gt;&gt;&gt;&gt;&gt;&gt; <a href="https://lists.swift.org/mailman/listinfo/swift-users" rel="noreferrer" target="_blank">https://lists.swift.org/<wbr>mailman/listinfo/swift-users</a><br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; ______________________________<wbr>_________________<br>
&gt;&gt;&gt;&gt;&gt; swift-users mailing list<br>
&gt;&gt;&gt;&gt;&gt; <a href="mailto:swift-users@swift.org">swift-users@swift.org</a><br>
&gt;&gt;&gt;&gt;&gt; <a href="https://lists.swift.org/mailman/listinfo/swift-users" rel="noreferrer" target="_blank">https://lists.swift.org/<wbr>mailman/listinfo/swift-users</a><br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; ______________________________<wbr>_________________<br>
&gt;&gt;&gt;&gt; swift-users mailing list<br>
&gt;&gt;&gt;&gt; <a href="mailto:swift-users@swift.org">swift-users@swift.org</a><br>
&gt;&gt;&gt;&gt; <a href="https://lists.swift.org/mailman/listinfo/swift-users" rel="noreferrer" target="_blank">https://lists.swift.org/<wbr>mailman/listinfo/swift-users</a><br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;<br>
&gt;&gt;<br>
&gt;<br>
<br>
</div></div></blockquote></div><br></div>