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

Ernest Burghardt closed GEODE-4599.
-----------------------------------

> Ensure native client checks if locks are acquired
> -------------------------------------------------
>
>                 Key: GEODE-4599
>                 URL: https://issues.apache.org/jira/browse/GEODE-4599
>             Project: Geode
>          Issue Type: Wish
>          Components: native client
>            Reporter: Addison
>            Priority: Major
>
> In several places NC tries to acquire a lock, but never checks that the lock 
> was successfully acquired. ACE documentation clearly states that this is bad 
> behavior:
> {noformat}
> Code like this is dangerous:
>   {
>     ACE_Guard<ACE_Lock> g(lock);
>     ... perform critical operation requiring lock to be held...
>   }
> Instead, one must do something like this:
>   {
>     ACE_Guard<ACE_Lock> g(lock);
>     if (! g.locked())
>       {
>         ... handle error ...
>       }
>     else
>       {
>         ... perform critical operation requiring lock to be held ...
>       }
>   }
> {noformat}
> It's worth noting that this may be linked to GEM-267 where the following code 
> was found with an error thrown inside a critical section of 
> {{ThinClientRegion.cpp}}.
> {noformat}
> if (m_resultCollectorLock != NULL) {
>     ACE_Guard < ACE_Recursive_Thread_Mutex > guard(
>         *m_resultCollectorLock);
>     m_rc->addResult(result);
> } else {
>     m_rc->addResult(result);
> }
> {noformat}
> We may need to investigate on a case-by-case basis how we should handle when 
> the lock isn't successfully acquired. There are roughly 200 other places 
> where this same behavior is present.



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to