
#10841: Run handler on STM retry -------------------------------------+------------------------------------- Reporter: shlevy | Owner: Type: feature request | Status: new Priority: normal | Milestone: Component: libraries | Version: 7.10.2 (other) | Resolution: | Keywords: stm Operating System: Unknown/Multiple | Architecture: | Unknown/Multiple Type of failure: None/Unknown | Test Case: Blocked By: | Blocking: Related Tickets: | Differential Revisions: -------------------------------------+------------------------------------- Comment (by fryguybob): Indeed, I don't think contention management is always automatic, just what practices make it viable. There is a danger with serializing via some lock that all future executions will become serial once the lock is taken once. You certainly don't want users to have to write `atomicWithAbortPolicy`! Also note that what I gave above might not work in a system that supports partial aborts like Le and Fluet's ICFP paper: http://www.cs.rit.edu/~ml9951/icfp15.pdf But their work in a way avoids the problem by keeping more progress which might be enough to get longer transactions through anyway. The pathological case being where your long transaction has a long enough prefix that never has a conflict and is always available to restart from. -- Ticket URL: http://ghc.haskell.org/trac/ghc/ticket/10841#comment:9 GHC http://www.haskell.org/ghc/ The Glasgow Haskell Compiler