Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp6901008rdb; Tue, 2 Jan 2024 19:01:24 -0800 (PST) X-Google-Smtp-Source: AGHT+IEYLTxNpl5ILwl4OEKJs6hpTUUC9qgQpS0oDrZCZ1Dul3GhQmT3c3mlKMzJPEAKlEc7PnR6 X-Received: by 2002:a05:600c:4e43:b0:40d:8fd0:e20d with SMTP id e3-20020a05600c4e4300b0040d8fd0e20dmr185526wmq.249.1704250883883; Tue, 02 Jan 2024 19:01:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704250883; cv=none; d=google.com; s=arc-20160816; b=na79pt/RKlhnUD/mpblf8T/DwrHDGoIbuKDHJ+140KtK38oQcahQ8/niXlj0FV4NCD 0akyRwUxjAXOfnmZcVgMd/rj51WJbUsBvwaN8jCL8wJqHkzUrvz30tl3SC6zxnA6JPaP 8n62FQAk6MNXM7A+FVYn5YzsWYqhmSOOCMIraxy8qaG63IqZ++EOvQdo8ngorjOQSS42 1dnazc5feEQ90XLJT1z1tbidoupz9gq/bf0pHAGlogb0xsgGQb9DKQGCLE3HNiZbjlMx /HiA4VBSJVVGvGbZYMO5s24qpO2LdHQST8pz28T+RCb+UGpwi1BSl+a96ScBt18jrP+P HHkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:to:subject:message-id:date:from :in-reply-to:references:mime-version:list-unsubscribe:list-subscribe :list-id:precedence:dkim-signature; bh=wEqAS6lUOK244Og0QhQ14SjtB7KhQXvIvbYkplos8Zw=; fh=Nivlo0YQfQzsqI6oCBexWNBxsRa3lb52QCtEiVsblvk=; b=NfEba0FPfIDJwDRpgOvorjSRUHdqqc/mo2Op0kYKOTyGKdx63xTAQlaKWZEWxZW18N ZREt8aAJx2+PGgTly9tX8RgSdrfe093k1uRDhizYJ0Nx+eteAVzksoV2ZGoi+NmBOp2n vZM56zzBY3mGcrbFaC8CkapDUSFh8HYlvq7eZzKLPKsHH6xcMQnXJZ8+5bmJoGHJlwIA x57rx5FqGTII2Lj/togP2GAnhNznudYXIBE6LucWX9dHVhtFiKOi+4ZoF6PmXuY1x5pW XOotmkTL5IU7hlRfzBamNiKhCFFgsz8KgSNldis047KtzCR5yzXR4503jj/XCWTjLutY Y+aQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=aHYirBzc; spf=pass (google.com: domain of linux-kernel+bounces-15109-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-15109-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id v4-20020a1709062f0400b00a280a150ffcsi1940525eji.199.2024.01.02.19.01.23 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Jan 2024 19:01:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-15109-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=aHYirBzc; spf=pass (google.com: domain of linux-kernel+bounces-15109-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-15109-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 4A0351F22F7B for ; Wed, 3 Jan 2024 03:01:23 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id F047F4A3B; Wed, 3 Jan 2024 03:01:09 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="aHYirBzc" X-Original-To: linux-kernel@vger.kernel.org Received: from mail-lf1-f44.google.com (mail-lf1-f44.google.com [209.85.167.44]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 65C5C17980 for ; Wed, 3 Jan 2024 03:01:07 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=google.com Received: by mail-lf1-f44.google.com with SMTP id 2adb3069b0e04-50e70d8273fso1324e87.0 for ; Tue, 02 Jan 2024 19:01:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1704250865; x=1704855665; darn=vger.kernel.org; h=content-transfer-encoding:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=wEqAS6lUOK244Og0QhQ14SjtB7KhQXvIvbYkplos8Zw=; b=aHYirBzcvnLrtWBFeX4Fv7MTP+tuQvvzHudbBsZ3RyBhHSbQXY1v50t/5/gJ9aNapP AjCCQKkqAU/OnwKv5TGl/ansfR+n9eO753guKBiLDxDCwX8rZ7a0izIg+pW5B0SFbM9s /OSYRzmja+/EEOvi26KRJl6YKm8NNbWy4CsluAALsYniKKBwIWcAJODqPNpVWSQsYSbe Y/VTwZRtstGhMtcsGsmdfawMec5LSv8d4iaxyA73Nibl31C2R62HTBcCGvfw8Su7U9rY BxLtCDLJ4vy0sttJT4SWUamawrZ19e2lQyNHkH5uaeSXJ3dN+CdDBzS4qRLwctpU+w3x 2wkg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1704250865; x=1704855665; h=content-transfer-encoding:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=wEqAS6lUOK244Og0QhQ14SjtB7KhQXvIvbYkplos8Zw=; b=XQK/JqnW3hEPw45k7oi1TMnmlmPTJHybn5vBfsfx5oTFpCCPWlUJZbKBLk6xmx2h1m oNo8LHA0b6zZEoRK+xAxycdApxJnoyzsPXhNqW5hidZkG3vcEQoJHNdGy+lgq4Cx2GSy yffobTnIYXXySJgBMW0WMNGK7MCFR1ltK94XR+GHeWroufwjcGGm8i5iwo74KyRub1QJ ebssKhymW1/Yi/RfyjTdeUwN8jrbZ0WWj4agCRUTdl3+LsxkUxzYJs8PNL5mnoVNddGA G2kvU9fdkdVYw6nlu+rGUEV+fGjwpqhsT2053m1mnEGPK7UiV926B6MvQMTeeFYNGBj4 tUOA== X-Gm-Message-State: AOJu0YwZAPmRb1oNWbrawMGzL8oqb1x3TsUEKfN+dCMy3gPQajQGuAtc eAJrfz2OF9ZHwHXYT//M8IMXxa1r+vyNhsKkpxh0J02clymK X-Received: by 2002:ac2:4e65:0:b0:50e:a747:917 with SMTP id y5-20020ac24e65000000b0050ea7470917mr13180lfs.5.1704250865081; Tue, 02 Jan 2024 19:01:05 -0800 (PST) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 References: <20231207014655.1252484-1-irogers@google.com> In-Reply-To: <20231207014655.1252484-1-irogers@google.com> From: Ian Rogers Date: Tue, 2 Jan 2024 19:00:53 -0800 Message-ID: Subject: Re: [PATCH v1] perf env: Avoid recursively taking env->bpf_progs.lock To: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Ian Rogers , Adrian Hunter , Song Liu , Ming Wang , Ravi Bangoria , Huacai Chen , Kan Liang , K Prateek Nayak , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, bpf@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Wed, Dec 6, 2023 at 5:46=E2=80=AFPM Ian Rogers wrot= e: > > Add variants of perf_env__insert_bpf_prog_info, perf_env__insert_btf > and perf_env__find_btf prefixed with __ to indicate the > env->bpf_progs.lock is assumed held. Call these variants when the lock > is held to avoid recursively taking it and potentially having a thread > deadlock with itself. > > Signed-off-by: Ian Rogers Ping. Thanks, Ian > --- > Previously this patch was part of a larger set: > https://lore.kernel.org/lkml/20231127220902.1315692-51-irogers@google.com= / > --- > tools/perf/util/bpf-event.c | 8 +++--- > tools/perf/util/bpf-event.h | 12 ++++----- > tools/perf/util/env.c | 53 +++++++++++++++++++++++-------------- > tools/perf/util/env.h | 4 +++ > tools/perf/util/header.c | 8 +++--- > 5 files changed, 51 insertions(+), 34 deletions(-) > > diff --git a/tools/perf/util/bpf-event.c b/tools/perf/util/bpf-event.c > index 830711cae30d..3573e0b7ef3e 100644 > --- a/tools/perf/util/bpf-event.c > +++ b/tools/perf/util/bpf-event.c > @@ -545,9 +545,9 @@ int evlist__add_bpf_sb_event(struct evlist *evlist, s= truct perf_env *env) > return evlist__add_sb_event(evlist, &attr, bpf_event__sb_cb, env)= ; > } > > -void bpf_event__print_bpf_prog_info(struct bpf_prog_info *info, > - struct perf_env *env, > - FILE *fp) > +void __bpf_event__print_bpf_prog_info(struct bpf_prog_info *info, > + struct perf_env *env, > + FILE *fp) > { > __u32 *prog_lens =3D (__u32 *)(uintptr_t)(info->jited_func_lens); > __u64 *prog_addrs =3D (__u64 *)(uintptr_t)(info->jited_ksyms); > @@ -563,7 +563,7 @@ void bpf_event__print_bpf_prog_info(struct bpf_prog_i= nfo *info, > if (info->btf_id) { > struct btf_node *node; > > - node =3D perf_env__find_btf(env, info->btf_id); > + node =3D __perf_env__find_btf(env, info->btf_id); > if (node) > btf =3D btf__new((__u8 *)(node->data), > node->data_size); > diff --git a/tools/perf/util/bpf-event.h b/tools/perf/util/bpf-event.h > index 1bcbd4fb6c66..e2f0420905f5 100644 > --- a/tools/perf/util/bpf-event.h > +++ b/tools/perf/util/bpf-event.h > @@ -33,9 +33,9 @@ struct btf_node { > int machine__process_bpf(struct machine *machine, union perf_event *even= t, > struct perf_sample *sample); > int evlist__add_bpf_sb_event(struct evlist *evlist, struct perf_env *env= ); > -void bpf_event__print_bpf_prog_info(struct bpf_prog_info *info, > - struct perf_env *env, > - FILE *fp); > +void __bpf_event__print_bpf_prog_info(struct bpf_prog_info *info, > + struct perf_env *env, > + FILE *fp); > #else > static inline int machine__process_bpf(struct machine *machine __maybe_u= nused, > union perf_event *event __maybe_un= used, > @@ -50,9 +50,9 @@ static inline int evlist__add_bpf_sb_event(struct evlis= t *evlist __maybe_unused, > return 0; > } > > -static inline void bpf_event__print_bpf_prog_info(struct bpf_prog_info *= info __maybe_unused, > - struct perf_env *env __= maybe_unused, > - FILE *fp __maybe_unused= ) > +static inline void __bpf_event__print_bpf_prog_info(struct bpf_prog_info= *info __maybe_unused, > + struct perf_env *env = __maybe_unused, > + FILE *fp __maybe_unus= ed) > { > > } > diff --git a/tools/perf/util/env.c b/tools/perf/util/env.c > index c68b7a004f29..cfdacbf29456 100644 > --- a/tools/perf/util/env.c > +++ b/tools/perf/util/env.c > @@ -22,15 +22,20 @@ struct perf_env perf_env; > #include "bpf-utils.h" > #include > > -void perf_env__insert_bpf_prog_info(struct perf_env *env, > - struct bpf_prog_info_node *info_node) > +void perf_env__insert_bpf_prog_info(struct perf_env *env, struct bpf_pro= g_info_node *info_node) > +{ > + down_write(&env->bpf_progs.lock); > + __perf_env__insert_bpf_prog_info(env, info_node); > + up_write(&env->bpf_progs.lock); > +} > + > +void __perf_env__insert_bpf_prog_info(struct perf_env *env, struct bpf_p= rog_info_node *info_node) > { > __u32 prog_id =3D info_node->info_linear->info.id; > struct bpf_prog_info_node *node; > struct rb_node *parent =3D NULL; > struct rb_node **p; > > - down_write(&env->bpf_progs.lock); > p =3D &env->bpf_progs.infos.rb_node; > > while (*p !=3D NULL) { > @@ -42,15 +47,13 @@ void perf_env__insert_bpf_prog_info(struct perf_env *= env, > p =3D &(*p)->rb_right; > } else { > pr_debug("duplicated bpf prog info %u\n", prog_id= ); > - goto out; > + return; > } > } > > rb_link_node(&info_node->rb_node, parent, p); > rb_insert_color(&info_node->rb_node, &env->bpf_progs.infos); > env->bpf_progs.infos_cnt++; > -out: > - up_write(&env->bpf_progs.lock); > } > > struct bpf_prog_info_node *perf_env__find_bpf_prog_info(struct perf_env = *env, > @@ -79,14 +82,22 @@ struct bpf_prog_info_node *perf_env__find_bpf_prog_in= fo(struct perf_env *env, > } > > bool perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_nod= e) > +{ > + bool ret; > + > + down_write(&env->bpf_progs.lock); > + ret =3D __perf_env__insert_btf(env, btf_node); > + up_write(&env->bpf_progs.lock); > + return ret; > +} > + > +bool __perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_n= ode) > { > struct rb_node *parent =3D NULL; > __u32 btf_id =3D btf_node->id; > struct btf_node *node; > struct rb_node **p; > - bool ret =3D true; > > - down_write(&env->bpf_progs.lock); > p =3D &env->bpf_progs.btfs.rb_node; > > while (*p !=3D NULL) { > @@ -98,25 +109,31 @@ bool perf_env__insert_btf(struct perf_env *env, stru= ct btf_node *btf_node) > p =3D &(*p)->rb_right; > } else { > pr_debug("duplicated btf %u\n", btf_id); > - ret =3D false; > - goto out; > + return false; > } > } > > rb_link_node(&btf_node->rb_node, parent, p); > rb_insert_color(&btf_node->rb_node, &env->bpf_progs.btfs); > env->bpf_progs.btfs_cnt++; > -out: > - up_write(&env->bpf_progs.lock); > - return ret; > + return true; > } > > struct btf_node *perf_env__find_btf(struct perf_env *env, __u32 btf_id) > +{ > + struct btf_node *res; > + > + down_read(&env->bpf_progs.lock); > + res =3D __perf_env__find_btf(env, btf_id); > + up_read(&env->bpf_progs.lock); > + return res; > +} > + > +struct btf_node *__perf_env__find_btf(struct perf_env *env, __u32 btf_id= ) > { > struct btf_node *node =3D NULL; > struct rb_node *n; > > - down_read(&env->bpf_progs.lock); > n =3D env->bpf_progs.btfs.rb_node; > > while (n) { > @@ -126,13 +143,9 @@ struct btf_node *perf_env__find_btf(struct perf_env = *env, __u32 btf_id) > else if (btf_id > node->id) > n =3D n->rb_right; > else > - goto out; > + return node; > } > - node =3D NULL; > - > -out: > - up_read(&env->bpf_progs.lock); > - return node; > + return NULL; > } > > /* purge data in bpf_progs.infos tree */ > diff --git a/tools/perf/util/env.h b/tools/perf/util/env.h > index bf7e3c4c211f..7c527e65c186 100644 > --- a/tools/perf/util/env.h > +++ b/tools/perf/util/env.h > @@ -175,12 +175,16 @@ const char *perf_env__raw_arch(struct perf_env *env= ); > int perf_env__nr_cpus_avail(struct perf_env *env); > > void perf_env__init(struct perf_env *env); > +void __perf_env__insert_bpf_prog_info(struct perf_env *env, > + struct bpf_prog_info_node *info_nod= e); > void perf_env__insert_bpf_prog_info(struct perf_env *env, > struct bpf_prog_info_node *info_node)= ; > struct bpf_prog_info_node *perf_env__find_bpf_prog_info(struct perf_env = *env, > __u32 prog_id); > bool perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_nod= e); > +bool __perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_n= ode); > struct btf_node *perf_env__find_btf(struct perf_env *env, __u32 btf_id); > +struct btf_node *__perf_env__find_btf(struct perf_env *env, __u32 btf_id= ); > > int perf_env__numa_node(struct perf_env *env, struct perf_cpu cpu); > char *perf_env__find_pmu_cap(struct perf_env *env, const char *pmu_name, > diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c > index 08cc2febabde..02bf9d8b5f74 100644 > --- a/tools/perf/util/header.c > +++ b/tools/perf/util/header.c > @@ -1849,8 +1849,8 @@ static void print_bpf_prog_info(struct feat_fd *ff,= FILE *fp) > node =3D rb_entry(next, struct bpf_prog_info_node, rb_nod= e); > next =3D rb_next(&node->rb_node); > > - bpf_event__print_bpf_prog_info(&node->info_linear->info, > - env, fp); > + __bpf_event__print_bpf_prog_info(&node->info_linear->info= , > + env, fp); > } > > up_read(&env->bpf_progs.lock); > @@ -3188,7 +3188,7 @@ static int process_bpf_prog_info(struct feat_fd *ff= , void *data __maybe_unused) > /* after reading from file, translate offset to address *= / > bpil_offs_to_addr(info_linear); > info_node->info_linear =3D info_linear; > - perf_env__insert_bpf_prog_info(env, info_node); > + __perf_env__insert_bpf_prog_info(env, info_node); > } > > up_write(&env->bpf_progs.lock); > @@ -3235,7 +3235,7 @@ static int process_bpf_btf(struct feat_fd *ff, void= *data __maybe_unused) > if (__do_read(ff, node->data, data_size)) > goto out; > > - perf_env__insert_btf(env, node); > + __perf_env__insert_btf(env, node); > node =3D NULL; > } > > -- > 2.43.0.rc2.451.g8631bc7472-goog >