<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=us-ascii"><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;}
/* 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:"Calibri","sans-serif";
        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:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><div style='border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt'><div><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal><b><span style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>From:</span></b><span style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'> kernelnewbies-bounces@kernelnewbies.org [mailto:kernelnewbies-bounces@kernelnewbies.org] <b>On Behalf Of </b>Prajosh Premdas<br><b>Sent:</b> Wednesday, November 02, 2011 2:02 AM<br><b>To:</b> kernelnewbies@kernelnewbies.org<br><b>Subject:</b> spin_lock behavior<o:p></o:p></span></p></div></div><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal>Hi&nbsp;<o:p></o:p></p><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal>I wrote a sample module which looked like this and i expected the module to hang as i have used 2 spin_lock simultaneously. But i find the print after the second spin_lock being printed and the module works perfectly fine. Can any body please help me in understanding this? I got this problem from a driver i wrote and had a typo &quot;spin_lock&quot; instead of &quot;spin_unlock&quot; the driver worked fine and i caught the mistake only during a review&nbsp;<o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><div><p class=MsoNormal><i>#include &lt;linux/module.h&gt;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>#include &lt;linux/spinlock.h&gt;</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>struct sp_q {</i><o:p></o:p></p></div><div><p class=MsoNormal><i>spinlock_t spinlock;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>uint8_t data;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>};</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>static int __init sp_lck_init(void)</i><o:p></o:p></p></div><div><p class=MsoNormal><i>{</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;struct sp_q test;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;/* Spin lock Init */</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;spin_lock_init(&amp;test.spinlock);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;&nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;printk(&quot;&lt;1&gt;Test start\n&quot;);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;spin_lock(&amp;test.spinlock);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;test.data = 0; &nbsp;&nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;spin_lock(&amp;test.spinlock); &nbsp;&nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;printk(&quot;&lt;1&gt;How come???\n&quot;);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>&nbsp; &nbsp;return 0;</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>}</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>static void __exit sp_lck_exit(void)</i><o:p></o:p></p></div><div><p class=MsoNormal><i>{</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>}</i><o:p></o:p></p></div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><div><p class=MsoNormal><i>module_init(sp_lck_init);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>module_exit(sp_lck_exit);</i><o:p></o:p></p></div><div><p class=MsoNormal><i>MODULE_LICENSE(&quot;GPL&quot;);</i><o:p></o:p></p></div></div><div><div><p class=MsoNormal><o:p>&nbsp;</o:p></p></div><p class=MsoNormal>-- <br>Regards,<br><br>Prajosh Premdas<o:p></o:p></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>On single processor systems, spin_lock() doesn&#8217;t actually spin on anything.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>The term spin_lock() is a bit of a misnomer in my opinion as it implies that some sort of spinning will go on if the lock has already been taken.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>It really means, sort of, &#8220;disable preemption, then serialize access on this variable among other threads on other CPUs, and I promise not to try to take this lock in any top or bottom half context on this CPU.&#8221;<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Of course, that would make for an unwieldy function name, so its call spin_lock().<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Jeff Haran<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p>&nbsp;</o:p></span></p></div></div></div><font face="monospace"></font></body></html>