sync: signal pt before sync_timeline object gets destroyed
authorPrakash Kamliya <pkamliya@codeaurora.org>
Fri, 4 Oct 2013 12:20:50 +0000 (17:50 +0530)
committerColin Cross <ccross@android.com>
Sun, 13 Oct 2013 00:36:03 +0000 (00:36 +0000)
commit763b334bd467a1f9453fe19ab19354e3b8c351e2
treec4280c0b1e9546818a368b4ecbef7be9959f6f44
parent4fe1f96d0bc0cce09c41a6818153fea81d645a39
sync: signal pt before sync_timeline object gets destroyed

There is a race condition

Assume we have *one* sync_fence object, with *one* sync_pt
which belongs to *one* sync_timeline, given this condition,
sync_timeline->kref will have two counts, one for sync_timeline
(implicit) and another for sync_pt.

Assume following is the situation on CPU

Theead-1 : (Thread which calls sync_timeline_destroy())
  -> (some function calls)
   -> sync_timeline_destory()
    -> sync_timeline_signal() (CPU is inside this
function after putting reference to sync_timeline)

At this time Thread-2 comes and does following

Thread-2 : (fclose on fence fd)
> sync_fence_release() -> because of fclose() on fence object
 -> sync_fence_free()
  -> sync_pt_free()
   -> kref_put(&pt->parent->kref, sync_timeline_free);
    -> sync_timeline_free() (CPU is inside this because
this time kref will be zero after _put)

Thread-2 will free sync_timeline object before Thread-1
has finished its work inside sync_timeline_signal.

With this change we signals all sync_pt before putting
reference to sync_timeline object.

Change-Id: Ic680e4d0bbef1c46bcb7cfba693395645241d203
Signed-off-by: Prakash Kamliya <pkamliya@codeaurora.org>
drivers/staging/android/sync.c