<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
</head>
<body>
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Arial,Helvetica,sans-serif;" dir="ltr">
<p>I don't see that you've actually created an MPI_Win object anywhere.  My guess is that you need to use MPI_Win_create to initialize your window before you can do any locks or other RMA operations with it.<br>
</p>
</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> Ask Jakobsen <afj@qeye-labs.com><br>
<b>Sent:</b> Saturday, March 4, 2017 3:30:09 AM<br>
<b>To:</b> discuss@mpich.org<br>
<b>Subject:</b> [mpich-discuss] MCS lock and MPI RMA problem</font>
<div> </div>
</div>
<div>
<div dir="ltr">Hi,<br>
<br>
I have downloaded the source code for the MCS lock from the excellent book "Using Advanced MPI" from
<a href="http://www.mcs.anl.gov/research/projects/mpi/usingmpi/examples-advmpi/rma2/mcs-lock.c">
http://www.mcs.anl.gov/research/projects/mpi/usingmpi/examples-advmpi/rma2/mcs-lock.c</a>
<div><br>
</div>
<div>I have made a very simple piece of test code for testing the MCS lock but it works at random and often never escapes the busy loops in the acquire and release functions (see attached source code). The code appears semantically correct to my eyes.</div>
<div><br>
</div>
<div>
<div><font face="monospace, monospace">#include <stdio.h></font></div>
<div><font face="monospace, monospace">#include <mpi.h></font></div>
<div><font face="monospace, monospace">#include "mcs-lock.h"</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">int main(int argc, char *argv[])</font></div>
<div><font face="monospace, monospace">{</font></div>
<div><font face="monospace, monospace">  MPI_Win win;</font></div>
<div><font face="monospace, monospace">  MPI_Init( &argc, &argv );</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">  MCSLockInit(MPI_COMM_WORLD, &win);</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">  int rank, size;</font></div>
<div><font face="monospace, monospace">  MPI_Comm_rank(MPI_COMM_WORLD, &rank);</font></div>
<div><font face="monospace, monospace">  MPI_Comm_size(MPI_COMM_WORLD, &size);</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">  printf("rank: %d, size: %d\n", rank, size);</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">  MCSLockAcquire(win);</font></div>
<div><font face="monospace, monospace">  printf("rank %d aquired lock\n", rank);   fflush(stdout);</font></div>
<div><font face="monospace, monospace">  MCSLockRelease(win);</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><font face="monospace, monospace">  MPI_Win_free(&win); </font></div>
<div><font face="monospace, monospace">  MPI_Finalize();</font></div>
<div><font face="monospace, monospace">  return 0;</font></div>
<div><font face="monospace, monospace">}</font></div>
</div>
<div><font face="monospace, monospace"><br>
</font></div>
<div><br>
</div>
<div>I have tested on several hardware platforms and mpich-3.2 and mpich-3.3a2 but with no luck.
<div>
<div><font face="monospace, monospace" style="font-size:12.8px"><br>
</font></div>
<div>It appears that the MPI_Win_Sync are not "refreshing" the local data or I have a bug I can't spot.</div>
<div><br>
</div>
</div>
</div>
<div>A simple unfair lock like <a href="http://www.mcs.anl.gov/research/projects/mpi/usingmpi/examples-advmpi/rma2/ga_mutex1.c">
http://www.mcs.anl.gov/research/projects/mpi/usingmpi/examples-advmpi/rma2/ga_mutex1.c</a> works perfectly.</div>
<div><br>
</div>
<div>Best regards, Ask Jakobsen<br>
<div>
<div>
<div><br>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>