<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:x="urn:schemas-microsoft-com:office:excel" 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 14 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 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:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";
        color:black;
        mso-fareast-language:EN-US;}
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;}
pre
        {mso-style-priority:99;
        mso-style-link:"HTML Preformatted Char";
        margin:0cm;
        margin-bottom:.0001pt;
        font-size:10.0pt;
        font-family:"Courier New";
        color:black;}
span.EmailStyle17
        {mso-style-type:personal;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
span.HTMLPreformattedChar
        {mso-style-name:"HTML Preformatted Char";
        mso-style-priority:99;
        mso-style-link:"HTML Preformatted";
        font-family:Consolas;
        color:black;
        mso-fareast-language:EN-US;}
span.EmailStyle20
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
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 bgcolor="white" lang="EN-GB" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="color:#1F497D">Ok, take a look at <a href="https://bitbucket.org/krisvale/stacklessswitching">
https://bitbucket.org/krisvale/stacklessswitching</a><o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0cm 0cm 0cm 4.0pt">
<div>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:10.0pt;font-family:"Tahoma","sans-serif";color:windowtext;mso-fareast-language:EN-GB">From:</span></b><span lang="EN-US" style="font-size:10.0pt;font-family:"Tahoma","sans-serif";color:windowtext;mso-fareast-language:EN-GB">
 Christian Tismer [mailto:tismer@stackless.com] <br>
<b>Sent:</b> 29. nóvember 2012 01:25<br>
<b>To:</b> The Stackless Python Mailing List<br>
<b>Cc:</b> Kristján Valur Jónsson<br>
<b>Subject:</b> Re: [Stackless] switching improvements<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Hi Kristjan,<br>
<br>
how about checking it into a branch firt, let us try and check that<br>
intensively, and after enough confidence merge it in?<br>
That's the way that works best for me with Mercurial/Git.<br>
<br>
If you don't like to put a branch into python.org, you also can do a clone<br>
on bitbucket easily and let us use that for review.<br>
<br>
cheers - chris<br>
<br>
On 28.11.12 16:11, Kristján Valur Jónsson wrote:<o:p></o:p></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="IS">Hello All.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">I was recently prompted to add a flag to stackless, a way to block all tasklet switching.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">This springs from the way that we are embedding stackless python in an game engine (UnReal) which sometimes makes callbacks into python.  Sometimes, this code will do nasty stuff that results in tasks switching, causing
 havoc with the control flow of the game engine.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">To simplify this, I added a per-thread flag, switch_trap, which can be controlled in a similar way to block_trap.  If the logic causes a switch to be attempted, this should be trappable and the code should be easily fixable,
 or we can otherwise deal with it.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS"> </span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">Anyway, doing this, adding it to slp_schedule_task(), and so on, uncovered a subtle flaw in stackless:</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">It turns out that slp_schedule_task() had no way of differentiating whether an exception result from this call came as a result of a failure to switch, or an exception being sent to the tasklet when it wakes up again.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS"> </span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">So, I have changed the interface to be able to do this properly.  There are other reasons why switching can fail, including memory allocation failures and so on, so this seems like a necessary change.  I also fixed code
 both in stacklesseval.c and taskletmodule and channelobject to be able to cope with switch failure like this.</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS"> </span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">Now:</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">How does this sound to you?  The change is somewhat large and I would hesitate to simply check it in without some sort of review or otherwise approval.  Any suggestions?</span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS"> </span><o:p></o:p></p>
<p class="MsoNormal"><span lang="IS">K</span><o:p></o:p></p>
<p class="MsoNormal"><span style="font-size:12.0pt;font-family:"Times New Roman","serif";mso-fareast-language:EN-GB"><br>
<br>
<br>
<o:p></o:p></span></p>
<pre>_______________________________________________<o:p></o:p></pre>
<pre>Stackless mailing list<o:p></o:p></pre>
<pre><a href="mailto:Stackless@stackless.com">Stackless@stackless.com</a><o:p></o:p></pre>
<pre><a href="http://www.stackless.com/mailman/listinfo/stackless">http://www.stackless.com/mailman/listinfo/stackless</a><o:p></o:p></pre>
</blockquote>
<p class="MsoNormal"><span style="font-size:12.0pt;font-family:"Times New Roman","serif";mso-fareast-language:EN-GB"><br>
<br>
<br>
<o:p></o:p></span></p>
<pre>-- <o:p></o:p></pre>
<pre>Christian Tismer             :^)   <a href="mailto:tismer@stackless.com"><mailto:tismer@stackless.com></a><o:p></o:p></pre>
<pre>Software Consulting          :     Have a break! Take a ride on Python's<o:p></o:p></pre>
<pre>Karl-Liebknecht-Str. 121     :    *Starship* <a href="http://starship.python.net/">http://starship.python.net/</a><o:p></o:p></pre>
<pre>14482 Potsdam                :     PGP key -> <a href="http://pgp.uni-mainz.de">http://pgp.uni-mainz.de</a><o:p></o:p></pre>
<pre>phone +49 173 24 18 776  fax +49 (30) 700143-0023<o:p></o:p></pre>
<pre>PGP 0x57F3BF04       9064 F4E1 D754 C2FF 1619  305B C09C 5A3B 57F3 BF04<o:p></o:p></pre>
<pre>      whom do you want to sponsor today?   <a href="http://www.stackless.com/">http://www.stackless.com/</a><o:p></o:p></pre>
</div>
</div>
</body>
</html>