This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org

Difference between revisions of "Reviewing Code for Race Conditions"

From OWASP
Jump to: navigation, search
m (Added navigation to facilitate sequential reading online)
 
(9 intermediate revisions by 2 users not shown)
Line 1: Line 1:
[[OWASP Code Review Guide Table of Contents]]__TOC__
+
{{LinkBar
 +
  | useprev=PrevLink | prev=Reviewing Code for Session Integrity | lblprev=
 +
  | usemain=MainLink | main=OWASP Code Review Guide Table of Contents | lblmain=Table of Contents
 +
  | usenext=NextLink | next=Java Gotchas | lblnext=
 +
}}
 +
__TOC__
  
 
== Introduction ==
 
== Introduction ==
Race Conditions occur when a piece of code does not work as it is supposed to (like many security issues). They are the result of an unexpected ordering of events which can result in the finite state machine of the code to transition to a undefined state and also give rise to contention of more than one thread of execution over the same resource. Multiple threads of execution acting or manipulating the same area in memory or persisted data which gives rise to integrity issues.
+
Race Conditions occur when a piece of code does not work as it is supposed to (like many security issues). They are the result of an unexpected ordering of events, which can result in the finite state machine of the code to transition to a undefined state, and also give rise to contention of more than one thread of execution over the same resource. Multiple threads of execution acting or manipulating the same area in memory or persisted data which gives rise to integrity issues.
  
==How they work:==
+
==How They Work==
With competing tasks manipulating the same resource we can easily get a race condition as the resource is not in step-lock or utilises a token based multi-use system such as semaphores.
+
With competing tasks manipulating the same resource, we can easily get a race condition as the resource is not in step-lock or utilises a token based multi-use system such as semaphores.  
  
Say we have two processes (Thread 1, T1) and (Thread 2, T2).
+
Say we have two processes (Thread 1, T1) and (Thread 2, T2). The code in question adds 10 to an integer X. The initial value of X is 5.  
The code in question adds 10 to an integer X. The initial value of X is 5.
 
  
 
  X = X + 10
 
  X = X + 10
  
So with no controls surrounding this code in a multithreaded environment we get the following problem:
+
With no controls surrounding this code in a multithreaded environment, we get the following problem:  
  
 
  T1 places X into a register in thread 1
 
  T1 places X into a register in thread 1
Line 21: Line 25:
 
  T1 saves the register value (15) into X.
 
  T1 saves the register value (15) into X.
  
The value should actually be 25 as each thread added 10 to the initial value of 5. But the actual value is 15 due to T2 not letting T1 save into X before it takes a value of X for its addition.
+
The value should actually be 25, as each thread added 10 to the initial value of 5. But the actual value is 15 due to T2 not letting T1 save into X before it takes a value of X for its addition.
  
==How to locate the potentially vulnerable code==
+
==How to Locate the Potentially Vulnerable Code==
  
 
===.NET===
 
===.NET===
 
Look for code which used multithreaded environments:
 
Look for code which used multithreaded environments:
  
Keywords such as:
 
 
  Thread
 
  Thread
 
  System.Threading
 
  System.Threading
Line 46: Line 49:
  
 
===Classic ASP===
 
===Classic ASP===
Notice multithreading is not directly supported feature of classic ASP so this kind of race conditions could be present only when using COM objects.
+
Multithreading is not a directly supported feature of classic ASP, so this kind of race condition could be present only when using COM objects.
  
 
==Vulnerable Patterns for Race Conditions==  
 
==Vulnerable Patterns for Race Conditions==  
 +
Static methods (One per class, not one per object) are an issue particularly if there is a shared state among multiple threads. For example, in Apache, struts static members should not be used to store information relating to a particular request. The same instance of a class can be used by multiple threads, and the value of the static member can not be guaranteed.
  
Static methods (One per class, not one per object) are an issue particularly if there is a shared state among multiple threads.
+
Instances of classes do not need to be thread safe as one is made per operation/request. Static states must be thread safe.  
For example in Apache struts static members should not be used to store information relating to a particular request. The same instance of a class can be used by multiple threads and the value of the static member can not be guaranteed.
+
#References to static variables, these must be thread locked.
 
 
Instances of classes do not need to be thread safe as one is made per operation/request. Static states must be thread safe.
 
 
 
#References to static variables, these much be thread locked.
 
 
#Releasing a lock in places other then finally{} may cause issues
 
#Releasing a lock in places other then finally{} may cause issues
 
#Static methods that alter static state
 
#Static methods that alter static state
Line 62: Line 62:
  
 
http://msdn2.microsoft.com/en-us/library/f857xew0(vs.71).aspx
 
http://msdn2.microsoft.com/en-us/library/f857xew0(vs.71).aspx
 +
 +
{{LinkBar
 +
  | useprev=PrevLink | prev=Reviewing Code for Session Integrity | lblprev=
 +
  | usemain=MainLink | main=OWASP Code Review Guide Table of Contents | lblmain=Table of Contents
 +
  | usenext=NextLink | next=Java Gotchas | lblnext=
 +
}}
  
 
[[Category:OWASP Code Review Project]]
 
[[Category:OWASP Code Review Project]]
 
[[Category:Data Integrity|TOCTTOU]]
 
[[Category:Data Integrity|TOCTTOU]]
 +
[[Category:FIXME|the second category doesn't exist; which should be there?]]
 +
[[Category:Externally Linked Page]]

Latest revision as of 16:40, 9 September 2010

«««« Main
(Table of Contents)
»»»»

Introduction

Race Conditions occur when a piece of code does not work as it is supposed to (like many security issues). They are the result of an unexpected ordering of events, which can result in the finite state machine of the code to transition to a undefined state, and also give rise to contention of more than one thread of execution over the same resource. Multiple threads of execution acting or manipulating the same area in memory or persisted data which gives rise to integrity issues.

How They Work

With competing tasks manipulating the same resource, we can easily get a race condition as the resource is not in step-lock or utilises a token based multi-use system such as semaphores.

Say we have two processes (Thread 1, T1) and (Thread 2, T2). The code in question adds 10 to an integer X. The initial value of X is 5.

X = X + 10

With no controls surrounding this code in a multithreaded environment, we get the following problem:

T1 places X into a register in thread 1
T2 places X into a register in thread 2
T1 adds 10 to the value in T1's register resulting in 15
T2 adds 10 to the value in T2's register resulting in 15
T1 saves the register value (15) into X.
T1 saves the register value (15) into X.

The value should actually be 25, as each thread added 10 to the initial value of 5. But the actual value is 15 due to T2 not letting T1 save into X before it takes a value of X for its addition.

How to Locate the Potentially Vulnerable Code

.NET

Look for code which used multithreaded environments:

Thread
System.Threading
ThreadPool
System.Threading.Interlocked

Java

java.lang.Thread
start()
stop()
destroy()
init()
synchronized 
wait()
notify()
notifyAll()

Classic ASP

Multithreading is not a directly supported feature of classic ASP, so this kind of race condition could be present only when using COM objects.

Vulnerable Patterns for Race Conditions

Static methods (One per class, not one per object) are an issue particularly if there is a shared state among multiple threads. For example, in Apache, struts static members should not be used to store information relating to a particular request. The same instance of a class can be used by multiple threads, and the value of the static member can not be guaranteed.

Instances of classes do not need to be thread safe as one is made per operation/request. Static states must be thread safe.

  1. References to static variables, these must be thread locked.
  2. Releasing a lock in places other then finally{} may cause issues
  3. Static methods that alter static state

Related Articles

http://msdn2.microsoft.com/en-us/library/f857xew0(vs.71).aspx


«««« Main
(Table of Contents)
»»»»