Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4629671pxu; Thu, 10 Dec 2020 01:09:54 -0800 (PST) X-Google-Smtp-Source: ABdhPJyja8L40/DRPTmhJz3ztvsw6ojUNCBZlHcQ1qorLunGQSPvW8zO7R0RZSfe8hVpmtSJEA8W X-Received: by 2002:a17:906:8594:: with SMTP id v20mr5426983ejx.470.1607591394015; Thu, 10 Dec 2020 01:09:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607591394; cv=none; d=google.com; s=arc-20160816; b=DfHSohxGu1TsVP8Yp4E7RxiVgBAXqGxpouCJZoRLwnuDDGtnH0TPh4K5X8mB3vGMe3 Ugsexg1mKbqsefn5S9SeMbvjON/lMDuWPlc8kiTMxep8EAEDSQ4AxbWksmJuOsvu5wRq s3LcvoC1/AHIlbpeexCv/Jrju0LoTJSBh1nw6CB17C+IOFpHriNYszzAckFrLgtTLKh5 jSqyTZUmOAyZ28ujor8eeBX5MvNMutDMmHDKi9RtQ9NciBSdVzvJgVidpJKsIs5f9dqW 4kLkJQOcMt/lLuWVoBfajshPOoaHz6C+c8c8uH+EcfuqqbICcPn7baBwCDh153BdTGfi ZRAg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=3uonUYFJ1jfpSOenKoqFcnoFV/xVcx9wCxu7MefN3Rw=; b=W3mLZKRK2fzENQv/x9dvzB2dlw5TwoNVjuMumogzWpsxwZe+u2aE+clj0tThjaK22r tXIquBJY2T+8lX30kqFVEnfVOGhW6L7zGzPJt2xq+Ka/4HsslD1cChlyLm/pKceg8b8U WgqzjC7oIsZ62r/NQe+qMcjxPZZwC9tcA/gCz43Q2S1ou9WALYnRACEDc7dHYxNCwA1Y QAC/4AR+iRJp/4PXleTJNNWjwA8ztb7P2xF2U+0UWPVrXYz3UtjdEQ4A+SLu1gFkQIui 109p3ZT8kaIVCsgNIv0rTolfCMutI1df4qb6zU9ie+1twTeizD9OXyZng3YIX3ku3Kgi 4Sbw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b22si2136779ejk.400.2020.12.10.01.09.30; Thu, 10 Dec 2020 01:09:54 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730941AbgLJJG4 (ORCPT + 99 others); Thu, 10 Dec 2020 04:06:56 -0500 Received: from mga11.intel.com ([192.55.52.93]:6076 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726796AbgLJJGz (ORCPT ); Thu, 10 Dec 2020 04:06:55 -0500 IronPort-SDR: 1fb38IoryaVspFtWOXGAbrROe5LQ9tCDwfmYl2UveLTENxCyXfJTBOj1q9caKNM6JEyx8J77y5 zLv/o0Apz2WA== X-IronPort-AV: E=McAfee;i="6000,8403,9830"; a="170712753" X-IronPort-AV: E=Sophos;i="5.78,408,1599548400"; d="scan'208";a="170712753" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Dec 2020 01:04:03 -0800 IronPort-SDR: 97jHIvZ34VQvCjPcJ2/HelrjxTsJNB194hC/gJceyWG4QuSRvKyhntHdbJvHTvmeq//L0tCZKL HNdpGutU265A== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.78,408,1599548400"; d="scan'208";a="408450143" Received: from nntpdsd52-183.inn.intel.com ([10.125.52.183]) by orsmga001.jf.intel.com with ESMTP; 10 Dec 2020 01:03:57 -0800 From: Alexander Antonov To: acme@kernel.org Cc: linux-kernel@vger.kernel.org, jolsa@redhat.com, alexander.shishkin@linux.intel.com, mark.rutland@arm.com, namhyung@kernel.org, mingo@redhat.com, peterz@infradead.org, ak@linux.intel.com, alexander.antonov@linux.intel.com Subject: [PATCH 4/5] perf stat: Helper functions for IIO stacks list in iiostat mode Date: Thu, 10 Dec 2020 12:03:39 +0300 Message-Id: <20201210090340.14358-5-alexander.antonov@linux.intel.com> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20201210090340.14358-1-alexander.antonov@linux.intel.com> References: <20201210090340.14358-1-alexander.antonov@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Introduce helper functions to control IIO stacks list. These helpers will be used in the follow-up patch. Signed-off-by: Alexander Antonov --- tools/perf/arch/x86/util/iiostat.c | 125 +++++++++++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 tools/perf/arch/x86/util/iiostat.c diff --git a/tools/perf/arch/x86/util/iiostat.c b/tools/perf/arch/x86/util/iiostat.c new file mode 100644 index 000000000000..70f93a96723f --- /dev/null +++ b/tools/perf/arch/x86/util/iiostat.c @@ -0,0 +1,125 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * perf stat --iiostat + * + * Copyright (C) 2020, Intel Corporation + * + * Authors: Alexander Antonov + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "util/cpumap.h" +#include "util/debug.h" +#include "util/iiostat.h" +#include "util/counts.h" +#include "path.h" + +struct iio_root_port { + u32 domain; + u8 bus; + u8 die; + u8 pmu_idx; + int idx; +}; + +struct iio_root_ports_list { + struct iio_root_port **rps; + int nr_entries; +}; + +static void iio_root_port_show(FILE *output, const struct iio_root_port * const rp) +{ + if (output && rp) + fprintf(output, "S%d-uncore_iio_%d<%04x:%02x>\n", + rp->die, rp->pmu_idx, rp->domain, rp->bus); +} + +static struct iio_root_port *iio_root_port_new(u32 domain, u8 bus, u8 die, u8 pmu_idx) +{ + struct iio_root_port *p = calloc(1, sizeof(*p)); + + if (p) { + p->domain = domain; + p->bus = bus; + p->die = die; + p->pmu_idx = pmu_idx; + } + return p; +} + +static struct iio_root_ports_list *iio_root_ports_list_new(void) +{ + struct iio_root_ports_list *list = calloc(1, sizeof(*list)); + + if (list) { + list->rps = calloc(1, sizeof(struct iio_root_port *)); + if (!list->rps) { + free(list); + list = NULL; + } + } + + return list; +} + +static void iio_root_ports_list_free(struct iio_root_ports_list *list) +{ + int idx; + + if (list) { + for (idx = 0; idx < list->nr_entries; idx++) + free(list->rps[idx]); + free(list->rps); + free(list); + } +} + +static +struct iio_root_port *iio_root_port_find_by_notation(const struct iio_root_ports_list * const list, + u32 domain, u8 bus) +{ + int idx; + struct iio_root_port *rp; + + if (list) { + for (idx = 0; idx < list->nr_entries; idx++) { + rp = list->rps[idx]; + if (rp && rp->domain == domain && rp->bus == bus) + return rp; + } + } + return NULL; +} + +static int iio_root_ports_list_insert(struct iio_root_ports_list *list, + struct iio_root_port * const rp) +{ + struct iio_root_port **tmp_buf; + + if (list && rp) { + rp->idx = list->nr_entries++; + /* One more for NULL.*/ + tmp_buf = realloc(list->rps, (list->nr_entries + 1) * sizeof(*list->rps)); + if (!tmp_buf) { + pr_err("Failed to realloc memory\n"); + return -ENOMEM; + } + tmp_buf[rp->idx] = rp; + tmp_buf[list->nr_entries] = NULL; + list->rps = tmp_buf; + } + return 0; +} -- 2.19.1