<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"></head><body><div>I've opened #13182 to explore one possible approach to dataToTag# that strikes me as likely to be simpler and to have fewer potential gotchas. But there could be critical points I'm missing about why we do it as we do now.</div><div><br></div><div style="font-size:100%;color:#000000"><!-- originalMessage --><div>-------- Original message --------</div><div>From: Simon Peyton Jones <simonpj@microsoft.com> </div><div>Date: 1/23/17 4:47 PM (GMT-05:00) </div><div>To: David Feuer <david@well-typed.com> </div><div>Cc: ghc-devs@haskell.org </div><div>Subject: RE: Floating lazy primops </div><div><br></div></div>We should have this conversation on a ticket, perhaps #13027.<br><br>| good at the time). Are there actually any primops with lifted arguments<br>| where we *want* speculation? Perhaps the most important primop to<br>| consider is seq#, which is<br><br>I don't understand this question. comment:23 of #13027 specifically says to skip the ok-for-spec test for lifted args. So you as "are the any" whereas comment:23 says "all".<br><br>| 2. If dataToTag# is marked can_fail (an aspect of https://<br>| phabricator.haskell.org/rGHC5a9a1738023a), is it still possible for it to<br>| end up being applied to an unevaluated argument? If not, perhaps the<br>| CorePrep specials can be removed altogether.<br><br>That may be true, but it's not easy to GUARANTEE in the way that Lint guarantees types. So I'm happier leaving in the CorePrep stuff.. but please do add a comment there that points to the Note in primops.txt.pp and says that it seems unlikely this will ever occur.<br><br>| One more question: do you think it's *better* to let dataToTag# float and<br>| then fix it up later, or better to mark it can_fail? Unlike<br>| reallyUnsafePtrEquality#, dataToTag# is used all over the place, so it is<br>| important that it interacts as well as possible with the optimizer,<br>| whatever that entails.<br><br>I think better to do as now. That way the simplifier has the opportunity to common-up multiple evals into one. If we add them later that's harder. <br><br>By all means add Notes to explain this.<br><br>Thanks!<br><br>Simon<br><br><br>| -----Original Message-----<br>| From: David Feuer [mailto:david@well-typed.com]<br>| Sent: 18 January 2017 19:45<br>| To: Simon Peyton Jones <simonpj@microsoft.com><br>| Cc: ghc-devs@haskell.org<br>| Subject: Floating lazy primops<br>| <br>| I opened up https://phabricator.haskell.org/D2987 to mark<br>| reallyUnsafePtrEquality# can_fail, but in the process I realized a couple<br>| things.<br>| <br>| 1. Part of https://phabricator.haskell.org/rGHC5a9a1738023a may actually<br>| not have been such a hot idea after all (although it certainly sounded<br>| good at the time). Are there actually any primops with lifted arguments<br>| where we *want* speculation? Perhaps the most important primop to<br>| consider is seq#, which is<br>| (mysteriously?) marked neither can_fail nor has_side_effects, but another<br>| to look at is unpackClosure#, which seems likely to give different<br>| results before and after forcing. Most other primops with lifted<br>| arguments are marked has_side_effects, and therefore won't be floated out<br>| anyway.<br>| <br>| 2. If dataToTag# is marked can_fail (an aspect of https://<br>| phabricator.haskell.org/rGHC5a9a1738023a), is it still possible for it to<br>| end up being applied to an unevaluated argument? If not, perhaps the<br>| CorePrep specials can be removed altogether.<br>| <br>| David Feuer<br><br></body></html>