Received: by 2002:a05:7412:8521:b0:e2:908c:2ebd with SMTP id t33csp2438203rdf; Mon, 6 Nov 2023 14:24:26 -0800 (PST) X-Google-Smtp-Source: AGHT+IE7bg7EIzhJLCOsruMXCHmm9GRSlOgNOMprjX7sEbP2U0yVB9380onb8TznZA6sT9DKcGo7 X-Received: by 2002:a17:903:238b:b0:1cc:6597:f41e with SMTP id v11-20020a170903238b00b001cc6597f41emr22347593plh.0.1699309466514; Mon, 06 Nov 2023 14:24:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1699309466; cv=none; d=google.com; s=arc-20160816; b=ZR65OBbHzPZCcKK3v7Kok7r39a08NmokmdYYR5W2mcytye/cvEQhs/raU/pJOwJQxR 60sODs6KoI6IJJOpFoGAiWSzjVrh72k9woUww+DlR4ivFgo9OxGFrHw6Floq6C2Q367l 7LbD+vxhsqTItGTaokXwp2eJtgPJTgC+iNMtwuoaKCE5efM6efIAniXVQ360rAaJHZJ8 65XfAvrmIQWXYkrnNQJ7kKx/y3eDvHbrjoZlHavY2H2GFurL3u3AEcMuIzBnJW9Exc65 1zpEH0V5Bvb52zoyvpF6YWMWsIC489b/L9BTYVDNbnD5hYF6BCLOeUYD7dHFpUga/JBV iDyg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version; bh=0sjKRBWVMhtVuSCA3zI1jgmAVa8xNbtbw+dfy0NqKyc=; fh=3WTSs7UC6fBcuvLqctXuGxfybfts09seX57Bhczo9Es=; b=e4IvpHvwllqv9E4oYiZJlIoblUeWGW6g5tB5+1zE3OFBHh94mSpQP5LuqNRbuUf6je SwkkrSD1lrpek6KLWqlOQWzvyit8Xu811ZTJgx2TTPv7ATxi1jBbQm6jv39HU5pXDULR 749eicFs3c0TirbeZ+YeeSFuG7yHVMrksyvOLTFxkgCvt1v6tW83FCPtjeYyf2bSjeYG iXCX55vB/rQbPzQV0OFGRuDtcmwtnJRA4fpHZKMlEh1kV4vuJrRgXTcvNa7XSVsSSwBI E3hEnvH7SVKeszCCjcAdgRbGntAmEX2l4c1CyqKMgDz5jX0rLbId4JcJllubfXsF1jmd FVMA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from groat.vger.email (groat.vger.email. [23.128.96.35]) by mx.google.com with ESMTPS id t21-20020a170902d15500b001cc0f6028bbsi8329590plt.402.2023.11.06.14.24.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 06 Nov 2023 14:24:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) client-ip=23.128.96.35; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 00C1980B1A29; Mon, 6 Nov 2023 14:24:22 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232152AbjKFWYD convert rfc822-to-8bit (ORCPT + 99 others); Mon, 6 Nov 2023 17:24:03 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41898 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232005AbjKFWYB (ORCPT ); Mon, 6 Nov 2023 17:24:01 -0500 Received: from mail-pf1-f180.google.com (mail-pf1-f180.google.com [209.85.210.180]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 489821BC; Mon, 6 Nov 2023 14:23:59 -0800 (PST) Received: by mail-pf1-f180.google.com with SMTP id d2e1a72fcca58-6c398717726so2192012b3a.2; Mon, 06 Nov 2023 14:23:59 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1699309439; x=1699914239; h=content-transfer-encoding:cc: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=+5KSCOu691NT1PfrO1kzMKbd/+BqwCFGmhMLBYbiDMU=; b=Xm1ulYXiL5xj9GhPzCf9lO/xEW1P9Mb8RB9RM9tleL9PYBjX7foVpfQcOo0Bo1tHvU +EMGJrCFEEPjooWI8XytCGgCzgtRhC29cwWFY3o/lWeGc5L7qx3MIPiMGsdzfKzdp0hY +ftaCPdr2fFpv3mtyrDXf2KJm69uep3KHIsEG4sa+pdc7rhVQRBOD9xg5k+YV/gHNJ2R 4/GQyCnl4aeV9yotcsR9nFp9TV2obZ3MhbvxoLU5/5FYeYyyfaIfwmAfmP85da/Qb7p7 4LCAODY1U4Hs9KFy+nfJMPbxq744+M7Is9gv0tigYp6Nbwk6Z1Umft9hxHNgUltzLuoj VFyQ== X-Gm-Message-State: AOJu0YxlJ/ezJI4X9njZiJ3zxTliIlka8cgq9JQKQ0BhU35i9LbMl8An 62n9aJdTNUmQEeT0acV1iNwQ1uE5W0QYydxVe94= X-Received: by 2002:a05:6a20:3945:b0:182:2282:fd7a with SMTP id r5-20020a056a20394500b001822282fd7amr8559206pzg.19.1699309438609; Mon, 06 Nov 2023 14:23:58 -0800 (PST) MIME-Version: 1.0 References: <20231103191907.54531-1-namhyung@kernel.org> <20231103191907.54531-2-namhyung@kernel.org> In-Reply-To: From: Namhyung Kim Date: Mon, 6 Nov 2023 14:23:47 -0800 Message-ID: Subject: Re: [PATCH 1/5] perf annotate: Split struct cycles_info To: Arnaldo Carvalho de Melo Cc: Jiri Olsa , Ian Rogers , Adrian Hunter , Peter Zijlstra , Ingo Molnar , LKML , linux-perf-users@vger.kernel.org, Christophe JAILLET Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT X-Spam-Status: No, score=-1.0 required=5.0 tests=MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Mon, 06 Nov 2023 14:24:23 -0800 (PST) Hi Arnaldo, On Mon, Nov 6, 2023 at 11:53 AM Arnaldo Carvalho de Melo wrote: > > Em Mon, Nov 06, 2023 at 04:34:51PM -0300, Arnaldo Carvalho de Melo escreveu: > > Em Fri, Nov 03, 2023 at 12:19:03PM -0700, Namhyung Kim escreveu: > > > The cycles info is used only when branch stack is provided. Split them > > > into a separate struct and lazy allocate them to save some memory. > > > > > > Signed-off-by: Namhyung Kim > > > --- > > > tools/perf/ui/browsers/annotate.c | 2 +- > > > tools/perf/util/annotate.c | 34 ++++++++++++++++++------------- > > > tools/perf/util/annotate.h | 14 ++++++++----- > > > 3 files changed, 30 insertions(+), 20 deletions(-) > > > > > > diff --git a/tools/perf/ui/browsers/annotate.c b/tools/perf/ui/browsers/annotate.c > > > index ccdb2cd11fbf..d2470f87344d 100644 > > > --- a/tools/perf/ui/browsers/annotate.c > > > +++ b/tools/perf/ui/browsers/annotate.c > > > @@ -337,7 +337,7 @@ static void annotate_browser__calc_percent(struct annotate_browser *browser, > > > max_percent = percent; > > > } > > > > > > - if (max_percent < 0.01 && pos->al.ipc == 0) { > > > + if (max_percent < 0.01 && (!pos->al.cycles || pos->al.cycles->ipc == 0)) { > > > RB_CLEAR_NODE(&pos->al.rb_node); > > > continue; > > > } > > > diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c > > > index 82956adf9963..3e7f75827270 100644 > > > --- a/tools/perf/util/annotate.c > > > +++ b/tools/perf/util/annotate.c > > > @@ -1100,8 +1100,8 @@ static void annotation__count_and_fill(struct annotation *notes, u64 start, u64 > > > for (offset = start; offset <= end; offset++) { > > > struct annotation_line *al = notes->offsets[offset]; > > > > > > - if (al && al->ipc == 0.0) { > > > - al->ipc = ipc; > > > + if (al && al->cycles && al->cycles->ipc == 0.0) { > > > + al->cycles->ipc = ipc; > > > cover_insn++; > > > } > > > } > > > @@ -1134,13 +1134,18 @@ void annotation__compute_ipc(struct annotation *notes, size_t size) > > > if (ch && ch->cycles) { > > > struct annotation_line *al; > > > > > > + al = notes->offsets[offset]; > > > + if (al && al->cycles == NULL) { > > > + al->cycles = zalloc(sizeof(*al->cycles)); > > > + if (al->cycles == NULL) > > > > Shouldn't we stop here and tell the user that his system is really tight > > on memory instead of just ignoring it? > > > > if (al->cycles == NULL) { > > ui__error("Not enough memory for allocating branch stack cycles info!\n"); > > return ... its a void function :-\ > > } > > > > Since its a void function, can't we detect that we need al->cycles > > allocated at the tool start and allocate it there, then propagate back > > the error? > > > > Its per line, so doing it lazily is indeed easier, so make that function > > return an error and bail out when not being able to calculate the ipc > > for the remaining lines? > > I.e. with this folded into this patch, all but one of the callers of > symbol__annotate2() already call a ui error messagem for instance: > > err = symbol__annotate2(ms, evsel, opts, &browser.arch); > if (err) { > char msg[BUFSIZ]; > dso->annotate_warned = true; > symbol__strerror_disassemble(ms, err, msg, sizeof(msg)); > ui__error("Couldn't annotate %s:\n%s", sym->name, msg); > > - Arnaldo Looks good to me, thanks for doing this! Namhyung > > diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c > index 3e7f758272703554..99ff3bb9cad8daa6 100644 > --- a/tools/perf/util/annotate.c > +++ b/tools/perf/util/annotate.c > @@ -1114,12 +1114,13 @@ static void annotation__count_and_fill(struct annotation *notes, u64 start, u64 > } > } > > -void annotation__compute_ipc(struct annotation *notes, size_t size) > +static int annotation__compute_ipc(struct annotation *notes, size_t size) > { > + int err = 0; > s64 offset; > > if (!notes->src || !notes->src->cycles_hist) > - return; > + return 0; > > notes->total_insn = annotation__count_insn(notes, 0, size - 1); > notes->hit_cycles = 0; > @@ -1137,8 +1138,10 @@ void annotation__compute_ipc(struct annotation *notes, size_t size) > al = notes->offsets[offset]; > if (al && al->cycles == NULL) { > al->cycles = zalloc(sizeof(*al->cycles)); > - if (al->cycles == NULL) > - continue; > + if (al->cycles == NULL) { > + err = ENOMEM; > + break; > + } > } > if (ch->have_start) > annotation__count_and_fill(notes, ch->start, offset, ch); > @@ -1150,7 +1153,21 @@ void annotation__compute_ipc(struct annotation *notes, size_t size) > notes->have_cycles = true; > } > } > + > + if (err) { > + while (++offset < (s64)size) { > + struct cyc_hist *ch = ¬es->src->cycles_hist[offset]; > + > + if (ch && ch->cycles) { > + struct annotation_line *al = notes->offsets[offset]; > + if (al) > + zfree(&al->cycles); > + } > + } > + } > + > annotation__unlock(notes); > + return 0; > } > > int addr_map_symbol__inc_samples(struct addr_map_symbol *ams, struct perf_sample *sample, > @@ -3270,7 +3287,11 @@ int symbol__annotate2(struct map_symbol *ms, struct evsel *evsel, > > annotation__set_offsets(notes, size); > annotation__mark_jump_targets(notes, sym); > - annotation__compute_ipc(notes, size); > + > + err = annotation__compute_ipc(notes, size); > + if (err) > + goto out_free_offsets; > + > annotation__init_column_widths(notes, sym); > notes->nr_events = nr_pcnt; > > diff --git a/tools/perf/util/annotate.h b/tools/perf/util/annotate.h > index 16d27952fd5c1b47..19bc2f03917575a8 100644 > --- a/tools/perf/util/annotate.h > +++ b/tools/perf/util/annotate.h > @@ -329,7 +329,6 @@ static inline bool annotation_line__filter(struct annotation_line *al, struct an > } > > void annotation__set_offsets(struct annotation *notes, s64 size); > -void annotation__compute_ipc(struct annotation *notes, size_t size); > void annotation__mark_jump_targets(struct annotation *notes, struct symbol *sym); > void annotation__update_column_widths(struct annotation *notes); > void annotation__init_column_widths(struct annotation *notes, struct symbol *sym);