ANDROID: binder: clarify deferred thread work.
authorMartijn Coenen <maco@android.com>
Tue, 14 Nov 2017 16:04:12 +0000 (17:04 +0100)
committerDanny Wood <danwood76@gmail.com>
Tue, 8 Oct 2019 13:59:34 +0000 (14:59 +0100)
Rename the function to more accurately reflect what
it does, and add a comment explaining why we use it.

Change-Id: I8d011c017dfc6e24b5b54fc462578f8e153e5926
Signed-off-by: Martijn Coenen <maco@android.com>
drivers/android/binder.c

index 735782b6a51a2d3cdd6707213b83d33d97f998bb..02ef0d319e379477e82b2113f256c541362c84ea 100644 (file)
@@ -844,7 +844,7 @@ binder_enqueue_work_ilocked(struct binder_work *work,
 }
 
 /**
- * binder_enqueue_thread_work_ilocked_nowake() - Add thread work
+ * binder_enqueue_deferred_thread_work_ilocked() - Add deferred thread work
  * @thread:       thread to queue work to
  * @work:         struct binder_work to add to list
  *
@@ -855,8 +855,8 @@ binder_enqueue_work_ilocked(struct binder_work *work,
  * Requires the proc->inner_lock to be held.
  */
 static void
-binder_enqueue_thread_work_ilocked_nowake(struct binder_thread *thread,
-                                         struct binder_work *work)
+binder_enqueue_deferred_thread_work_ilocked(struct binder_thread *thread,
+                                           struct binder_work *work)
 {
        binder_enqueue_work_ilocked(work, &thread->todo);
 }
@@ -3341,7 +3341,14 @@ static void binder_transaction(struct binder_proc *proc,
        } else if (!(t->flags & TF_ONE_WAY)) {
                BUG_ON(t->buffer->async_transaction != 0);
                binder_inner_proc_lock(proc);
-               binder_enqueue_thread_work_ilocked_nowake(thread, tcomplete);
+               /*
+                * Defer the TRANSACTION_COMPLETE, so we don't return to
+                * userspace immediately; this allows the target process to
+                * immediately start processing this transaction, reducing
+                * latency. We will then return the TRANSACTION_COMPLETE when
+                * the target replies (or there is an error).
+                */
+               binder_enqueue_deferred_thread_work_ilocked(thread, tcomplete);
                t->need_reply = 1;
                t->from_parent = thread->transaction_stack;
                thread->transaction_stack = t;