[ 
https://issues.apache.org/jira/browse/HDFS-566?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Robert Chansler updated HDFS-566:
---------------------------------

         Priority: Blocker  (was: Minor)
    Fix Version/s: 0.21.0
       Issue Type: Bug  (was: Improvement)

> INode.permissions should be marked as volatile to avoid synchronization 
> problems
> --------------------------------------------------------------------------------
>
>                 Key: HDFS-566
>                 URL: https://issues.apache.org/jira/browse/HDFS-566
>             Project: Hadoop HDFS
>          Issue Type: Bug
>          Components: name-node
>    Affects Versions: 0.21.0
>            Reporter: Steve Loughran
>            Priority: Blocker
>             Fix For: 0.21.0
>
>
> Looking at INode, I can see that the long permissions field is updated in the 
> synchronized updatePermissions, read in other non-synchronized contexts
> I believe that to avoid race conditions and other synchronisation problems, 
> the field should be marked {{volatile}}
> # The Java language specification declares that {{long}} and {{double}} can 
> be written as two 32-bit writes, unless the field is {{volatile}} 
> http://java.sun.com/docs/books/jls/second_edition/html/memory.doc.html#28733
> # The JVM is free to re-order accesses to non-volatile data; reads of the 
> permission may pick up out of date values
> # Volatile data may be cached/optimised out, changes may not propagate
> I don't think its enough to make the write operation synchronised, as the 
> reads are still unsynchronized, and in other threads can pick up values 
> midway through the update, or cache the value.
> It's a simple fix: declare permissions as  {{volatile}}.
> {code}
> private volatile long permissions;
> {code}

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to