ANDROID: binder: Don't BUG_ON(!spin_is_locked()).
Because is_spin_locked() always returns false on UP systems. Use assert_spin_locked() instead, and remove the WARN_ON() instances, since those were easy to verify. Signed-off-by: Martijn Coenen <maco@android.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
abcc61537e
commit
858b271968
|
@ -987,7 +987,7 @@ binder_select_thread_ilocked(struct binder_proc *proc)
|
||||||
{
|
{
|
||||||
struct binder_thread *thread;
|
struct binder_thread *thread;
|
||||||
|
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
thread = list_first_entry_or_null(&proc->waiting_threads,
|
thread = list_first_entry_or_null(&proc->waiting_threads,
|
||||||
struct binder_thread,
|
struct binder_thread,
|
||||||
waiting_thread_node);
|
waiting_thread_node);
|
||||||
|
@ -1018,7 +1018,7 @@ static void binder_wakeup_thread_ilocked(struct binder_proc *proc,
|
||||||
struct binder_thread *thread,
|
struct binder_thread *thread,
|
||||||
bool sync)
|
bool sync)
|
||||||
{
|
{
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
|
|
||||||
if (thread) {
|
if (thread) {
|
||||||
if (sync)
|
if (sync)
|
||||||
|
@ -1075,7 +1075,7 @@ static struct binder_node *binder_get_node_ilocked(struct binder_proc *proc,
|
||||||
struct rb_node *n = proc->nodes.rb_node;
|
struct rb_node *n = proc->nodes.rb_node;
|
||||||
struct binder_node *node;
|
struct binder_node *node;
|
||||||
|
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
|
|
||||||
while (n) {
|
while (n) {
|
||||||
node = rb_entry(n, struct binder_node, rb_node);
|
node = rb_entry(n, struct binder_node, rb_node);
|
||||||
|
@ -1120,7 +1120,8 @@ static struct binder_node *binder_init_node_ilocked(
|
||||||
binder_uintptr_t cookie = fp ? fp->cookie : 0;
|
binder_uintptr_t cookie = fp ? fp->cookie : 0;
|
||||||
__u32 flags = fp ? fp->flags : 0;
|
__u32 flags = fp ? fp->flags : 0;
|
||||||
|
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
|
|
||||||
while (*p) {
|
while (*p) {
|
||||||
|
|
||||||
parent = *p;
|
parent = *p;
|
||||||
|
@ -1195,9 +1196,9 @@ static int binder_inc_node_nilocked(struct binder_node *node, int strong,
|
||||||
{
|
{
|
||||||
struct binder_proc *proc = node->proc;
|
struct binder_proc *proc = node->proc;
|
||||||
|
|
||||||
BUG_ON(!spin_is_locked(&node->lock));
|
assert_spin_locked(&node->lock);
|
||||||
if (proc)
|
if (proc)
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
if (strong) {
|
if (strong) {
|
||||||
if (internal) {
|
if (internal) {
|
||||||
if (target_list == NULL &&
|
if (target_list == NULL &&
|
||||||
|
@ -1248,9 +1249,9 @@ static bool binder_dec_node_nilocked(struct binder_node *node,
|
||||||
{
|
{
|
||||||
struct binder_proc *proc = node->proc;
|
struct binder_proc *proc = node->proc;
|
||||||
|
|
||||||
BUG_ON(!spin_is_locked(&node->lock));
|
assert_spin_locked(&node->lock);
|
||||||
if (proc)
|
if (proc)
|
||||||
BUG_ON(!spin_is_locked(&proc->inner_lock));
|
assert_spin_locked(&proc->inner_lock);
|
||||||
if (strong) {
|
if (strong) {
|
||||||
if (internal)
|
if (internal)
|
||||||
node->internal_strong_refs--;
|
node->internal_strong_refs--;
|
||||||
|
@ -1774,7 +1775,7 @@ static void binder_pop_transaction_ilocked(struct binder_thread *target_thread,
|
||||||
struct binder_transaction *t)
|
struct binder_transaction *t)
|
||||||
{
|
{
|
||||||
BUG_ON(!target_thread);
|
BUG_ON(!target_thread);
|
||||||
BUG_ON(!spin_is_locked(&target_thread->proc->inner_lock));
|
assert_spin_locked(&target_thread->proc->inner_lock);
|
||||||
BUG_ON(target_thread->transaction_stack != t);
|
BUG_ON(target_thread->transaction_stack != t);
|
||||||
BUG_ON(target_thread->transaction_stack->from != target_thread);
|
BUG_ON(target_thread->transaction_stack->from != target_thread);
|
||||||
target_thread->transaction_stack =
|
target_thread->transaction_stack =
|
||||||
|
@ -4896,7 +4897,6 @@ static void print_binder_transaction_ilocked(struct seq_file *m,
|
||||||
struct binder_proc *to_proc;
|
struct binder_proc *to_proc;
|
||||||
struct binder_buffer *buffer = t->buffer;
|
struct binder_buffer *buffer = t->buffer;
|
||||||
|
|
||||||
WARN_ON(!spin_is_locked(&proc->inner_lock));
|
|
||||||
spin_lock(&t->lock);
|
spin_lock(&t->lock);
|
||||||
to_proc = t->to_proc;
|
to_proc = t->to_proc;
|
||||||
seq_printf(m,
|
seq_printf(m,
|
||||||
|
@ -4984,7 +4984,6 @@ static void print_binder_thread_ilocked(struct seq_file *m,
|
||||||
size_t start_pos = m->count;
|
size_t start_pos = m->count;
|
||||||
size_t header_pos;
|
size_t header_pos;
|
||||||
|
|
||||||
WARN_ON(!spin_is_locked(&thread->proc->inner_lock));
|
|
||||||
seq_printf(m, " thread %d: l %02x need_return %d tr %d\n",
|
seq_printf(m, " thread %d: l %02x need_return %d tr %d\n",
|
||||||
thread->pid, thread->looper,
|
thread->pid, thread->looper,
|
||||||
thread->looper_need_return,
|
thread->looper_need_return,
|
||||||
|
@ -5021,10 +5020,6 @@ static void print_binder_node_nilocked(struct seq_file *m,
|
||||||
struct binder_work *w;
|
struct binder_work *w;
|
||||||
int count;
|
int count;
|
||||||
|
|
||||||
WARN_ON(!spin_is_locked(&node->lock));
|
|
||||||
if (node->proc)
|
|
||||||
WARN_ON(!spin_is_locked(&node->proc->inner_lock));
|
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
hlist_for_each_entry(ref, &node->refs, node_entry)
|
hlist_for_each_entry(ref, &node->refs, node_entry)
|
||||||
count++;
|
count++;
|
||||||
|
@ -5050,7 +5045,6 @@ static void print_binder_node_nilocked(struct seq_file *m,
|
||||||
static void print_binder_ref_olocked(struct seq_file *m,
|
static void print_binder_ref_olocked(struct seq_file *m,
|
||||||
struct binder_ref *ref)
|
struct binder_ref *ref)
|
||||||
{
|
{
|
||||||
WARN_ON(!spin_is_locked(&ref->proc->outer_lock));
|
|
||||||
binder_node_lock(ref->node);
|
binder_node_lock(ref->node);
|
||||||
seq_printf(m, " ref %d: desc %d %snode %d s %d w %d d %pK\n",
|
seq_printf(m, " ref %d: desc %d %snode %d s %d w %d d %pK\n",
|
||||||
ref->data.debug_id, ref->data.desc,
|
ref->data.debug_id, ref->data.desc,
|
||||||
|
|
Loading…
Reference in New Issue