<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic About Distributed Reader-Writer Mutex by Dmitry Vyukov in Intel® Moderncode for Parallel Architectures</title>
    <link>https://community.intel.com/t5/Intel-Moderncode-for-Parallel/About-Distributed-Reader-Writer-Mutex-by-Dmitry-Vyukov/m-p/993826#M6313</link>
    <description>&lt;DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;Hello,&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;&amp;nbsp;Dmitry Vyukov&amp;nbsp; wrote this: &lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;"In order to a reader-writer mutex to scale reader's time under mutex 
must &lt;/DIV&gt;
&lt;DIV&gt;be significant, on the order of, let's say, 10'000 cycles. And the 
more hardware &lt;/DIV&gt;
&lt;DIV&gt;threads you have the longer the time must be. Otherwise, 
inter-reader synchronization &lt;/DIV&gt;
&lt;DIV&gt;overheads dominate, and the system does not scale." &lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;Read here:&lt;/DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;&lt;A href="http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex"&gt;http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex&lt;/A&gt;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;I have done some tests with&amp;nbsp;my light weight MREW and my lockfree mpmc 
&lt;/DIV&gt;
&lt;DIV&gt;fifo queue and what i think is that&amp;nbsp;the CAS is generating a lot of 
contention this is is why &lt;/DIV&gt;
&lt;DIV&gt;my rwlock is&amp;nbsp;not scaling.&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;What you are doing &lt;SPAN style="font-size: xx-small;"&gt;Dmitry Vyukov&lt;/SPAN&gt;in in your distributed 
rwlock is lowering the contention &lt;/DIV&gt;
&lt;DIV&gt;using the same method as lock striping it is why it is scaling, but there 
is still a possibility &lt;/DIV&gt;
&lt;DIV&gt;of contention that can cause a problem&amp;nbsp;to the&amp;nbsp;scalability if you are not 
setting the number &lt;/DIV&gt;
&lt;DIV&gt;of rwlocks inside your distributed rwlock correctly.&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;other&amp;nbsp;than that:&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;I have looked at the Distributed Reader-Writer Mutex by Dmitry Vyukov, look 
&lt;BR /&gt;at it here:"&lt;BR /&gt;&lt;BR /&gt;&lt;A&gt;http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex&lt;/A&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;and 
i think there is a problem with this method,&amp;nbsp; cause look at the write &lt;BR /&gt;lock 
function:&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;int&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; distr_rw_mutex_wrlock(distr_rw_mutex_t* 
mtx)&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; int&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; i;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (i = 0; i != 
mtx-&amp;gt;proc_count; i += 1)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
pthread_rwlock_wrlock(&amp;amp;mtx-&amp;gt;cell&lt;I&gt;.mtx);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; return 
0;&lt;BR /&gt;}&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;What is wrong with it ? suppose two or more writers want to 
lock this&lt;BR /&gt;distributed rwlock there is a possibility of a deadlock.&lt;BR /&gt;&lt;BR /&gt;So 
i think you have to use a critical section around the for loop to be able&lt;BR /&gt;to 
lock all the rwlocks atomically to avoid the deadlock 
problem..&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;Thank you,&lt;BR /&gt;Amine Moulay 
Ramdane.&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;/I&gt;&lt;/DIV&gt;&lt;/DIV&gt;</description>
    <pubDate>Sat, 25 Aug 2012 23:50:53 GMT</pubDate>
    <dc:creator>aminer10</dc:creator>
    <dc:date>2012-08-25T23:50:53Z</dc:date>
    <item>
      <title>About Distributed Reader-Writer Mutex by Dmitry Vyukov</title>
      <link>https://community.intel.com/t5/Intel-Moderncode-for-Parallel/About-Distributed-Reader-Writer-Mutex-by-Dmitry-Vyukov/m-p/993826#M6313</link>
      <description>&lt;DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;Hello,&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;&amp;nbsp;Dmitry Vyukov&amp;nbsp; wrote this: &lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;"In order to a reader-writer mutex to scale reader's time under mutex 
must &lt;/DIV&gt;
&lt;DIV&gt;be significant, on the order of, let's say, 10'000 cycles. And the 
more hardware &lt;/DIV&gt;
&lt;DIV&gt;threads you have the longer the time must be. Otherwise, 
inter-reader synchronization &lt;/DIV&gt;
&lt;DIV&gt;overheads dominate, and the system does not scale." &lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;Read here:&lt;/DIV&gt;
&lt;DIV&gt;&lt;BR /&gt;&lt;A href="http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex"&gt;http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex&lt;/A&gt;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;I have done some tests with&amp;nbsp;my light weight MREW and my lockfree mpmc 
&lt;/DIV&gt;
&lt;DIV&gt;fifo queue and what i think is that&amp;nbsp;the CAS is generating a lot of 
contention this is is why &lt;/DIV&gt;
&lt;DIV&gt;my rwlock is&amp;nbsp;not scaling.&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;What you are doing &lt;SPAN style="font-size: xx-small;"&gt;Dmitry Vyukov&lt;/SPAN&gt;in in your distributed 
rwlock is lowering the contention &lt;/DIV&gt;
&lt;DIV&gt;using the same method as lock striping it is why it is scaling, but there 
is still a possibility &lt;/DIV&gt;
&lt;DIV&gt;of contention that can cause a problem&amp;nbsp;to the&amp;nbsp;scalability if you are not 
setting the number &lt;/DIV&gt;
&lt;DIV&gt;of rwlocks inside your distributed rwlock correctly.&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;other&amp;nbsp;than that:&lt;/DIV&gt;
&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;
&lt;DIV&gt;I have looked at the Distributed Reader-Writer Mutex by Dmitry Vyukov, look 
&lt;BR /&gt;at it here:"&lt;BR /&gt;&lt;BR /&gt;&lt;A&gt;http://www.1024cores.net/home/lock-free-algorithms/reader-writer-problem/distributed-reader-writer-mutex&lt;/A&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;and 
i think there is a problem with this method,&amp;nbsp; cause look at the write &lt;BR /&gt;lock 
function:&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;int&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; distr_rw_mutex_wrlock(distr_rw_mutex_t* 
mtx)&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; int&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; i;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (i = 0; i != 
mtx-&amp;gt;proc_count; i += 1)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
pthread_rwlock_wrlock(&amp;amp;mtx-&amp;gt;cell&lt;I&gt;.mtx);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; return 
0;&lt;BR /&gt;}&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;What is wrong with it ? suppose two or more writers want to 
lock this&lt;BR /&gt;distributed rwlock there is a possibility of a deadlock.&lt;BR /&gt;&lt;BR /&gt;So 
i think you have to use a critical section around the for loop to be able&lt;BR /&gt;to 
lock all the rwlocks atomically to avoid the deadlock 
problem..&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;Thank you,&lt;BR /&gt;Amine Moulay 
Ramdane.&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;/I&gt;&lt;/DIV&gt;&lt;/DIV&gt;</description>
      <pubDate>Sat, 25 Aug 2012 23:50:53 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-Moderncode-for-Parallel/About-Distributed-Reader-Writer-Mutex-by-Dmitry-Vyukov/m-p/993826#M6313</guid>
      <dc:creator>aminer10</dc:creator>
      <dc:date>2012-08-25T23:50:53Z</dc:date>
    </item>
  </channel>
</rss>

