From patchwork Fri Oct 25 06:37:05 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 177633 Delivered-To: patch@linaro.org Received: by 2002:a92:409a:0:0:0:0:0 with SMTP id d26csp3245368ill; Thu, 24 Oct 2019 23:54:15 -0700 (PDT) X-Google-Smtp-Source: APXvYqx3rNQaV54YCZfdMjdOwFzKc2pBsBBGqbfzLN0HINzVeCkfUdZaPk8udYMMpWvS2aoYHBeR X-Received: by 2002:a17:906:8288:: with SMTP id h8mr1926172ejx.251.1571986454997; Thu, 24 Oct 2019 23:54:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571986454; cv=none; d=google.com; s=arc-20160816; b=GAXivKbfwB0yCquG5Q9V3kgiooT5kj6ZIetZPgQS7uRbwo8mdiigZm55achNoAOAPK amYR4zKh0zNfYgmCQ3ECgsQryxTyolZdyyGo/Rut8LOVH6diZZBUsw2lJyYyAa8gVfQQ OfExECw0SZF4Y1EYh2z22dduLmm1Dwr/JNRy4vbh2S8o2nJ1XBrBSh1MbNjXCNfOcD6U zjzrQO8gm0XRU+o5ppZtQJrQA2i0SypHGnhV+/OHYHARmD2F8Ymio4OAoF+7Y2i8v3f4 ujflJAvzIwHTxLxnSo6V6vJ1uxaJOgpvYSXW8FwKN1IaPDxgzNeP3dqMo8aJ6F03uiR8 B17w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=yAGQHjJX6sN9vqBD9CUSIS92quPpG3GGj8bU/lL0Ji4=; b=G7o6DMzmfL/r4epYdOVUKWA07wxZ2gMgl9BNTzJzYGwNctvLw7XhBPlyAZ4tRf7mM9 /ACv4RgzxexEwINlP4dznxhzZ06bk7YGh9L1zxULsk4Kt5NRjlNyIP/7/ETs2af2OQxa 8t8ffJdyswxLYr4IUL5uhW/7qfJeDL0TXSHu+w3yj2EzffKDzlON1/xKCw5dmJebv6Hl 5zNWdVxSTffADMTKEt4GLTS5T3kKAcc4zO6LdL1myHlLHVU6iK+xMVm3bqxbRsDzvM21 VjtCQar8L/CkjI/dHC/j9lT5qC4201O2N4zIDTu3f5dEhLwLkYrcBorV+eaZRWwEZNp4 EsIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=nEchem4M; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id h22si676130edb.346.2019.10.24.23.54.14 for (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 24 Oct 2019 23:54:14 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=nEchem4M; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:56108 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1iNtUD-0004RP-Fj for patch@linaro.org; Fri, 25 Oct 2019 02:54:13 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:35591) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1iNtE5-0003Od-CW for qemu-devel@nongnu.org; Fri, 25 Oct 2019 02:37:35 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1iNtE2-0008Ru-2k for qemu-devel@nongnu.org; Fri, 25 Oct 2019 02:37:31 -0400 Received: from mail-wr1-x42b.google.com ([2a00:1450:4864:20::42b]:42516) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1iNtE1-0008RB-SD for qemu-devel@nongnu.org; Fri, 25 Oct 2019 02:37:30 -0400 Received: by mail-wr1-x42b.google.com with SMTP id r1so901940wrs.9 for ; Thu, 24 Oct 2019 23:37:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=yAGQHjJX6sN9vqBD9CUSIS92quPpG3GGj8bU/lL0Ji4=; b=nEchem4M3/M08Rd9orRMB8+/QD76x8Yhe9aigLpWlxq0bbIj3FYlSHgEFq9fL9MRIJ ZlfwjGZHFl6Vi8nsIqxaDTS/A1M8AitUzMmFgjNCHqEAG8tUayB1I3EyQEsH8OiSZbcY 1pcCuv0CkYcX7b9d3wgrhsTs1PGFeRhslLurY3mAPhFXeKnN4CbKqQtEgS39j5vHhE65 oVLZ29DQrgD6oLPbFXVsvBGu0dVLtDIt0RRKkhezRIfyncF9pZFN2unv+zPriSnn3tK8 FFRUea9mGz1KCfXFxjMLa2r/HDDwBrisHWuJOU6mVWoOYbTj2/dSYr6hYfxEQBnKoilV L9Lg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=yAGQHjJX6sN9vqBD9CUSIS92quPpG3GGj8bU/lL0Ji4=; b=BsYOyeiEQxwPmyEyW2l4cpucaW+NoxYyGjvAI08G+tQj3CJJVrSL6nJGeYvpFcnkOS WAw9CVxPVzG8qfHIGS62xLmRAB4nnYnrIR0mBAd0Xuiet2nuMcycJaiG9ffpkkHYE28U OEYkUwPJBmakQ5yy20bxx9gRPdiEuOowUOSDiNuPDf0Ml7pocJRyOmVC0ZHAPOGD1FVb n7S7jio0FVVjS4iAQ9u6Ds4xUcR4aRT5weNVeAOoL7xSNPyLbSpFQ1dN1zYiG1+BtJaw U6+QgnCIuLotci/m1nbrN6ZDUIuFyV6yqnFHlKXVMVR00YAg7dmra7ci8quUGRTk+Ht9 KYYw== X-Gm-Message-State: APjAAAWhnY1z8dW4fAyTOh8/B06zMEbPiwey42UUl+7f3Sp2l/iF1DQw 8mzYUm1vHrft3wlmi7w8jflViw== X-Received: by 2002:a5d:630b:: with SMTP id i11mr1189002wru.87.1571985448546; Thu, 24 Oct 2019 23:37:28 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id g10sm1189335wrr.28.2019.10.24.23.37.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 24 Oct 2019 23:37:24 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id D6BB71FFD7; Fri, 25 Oct 2019 07:37:19 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: peter.maydell@linaro.org Subject: [PULL v2 65/73] tests/plugin: add a hotblocks plugin Date: Fri, 25 Oct 2019 07:37:05 +0100 Message-Id: <20191025063713.23374-66-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20191025063713.23374-1-alex.bennee@linaro.org> References: <20191025063713.23374-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::42b X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Richard Henderson , =?utf-8?q?Alex_Benn?= =?utf-8?b?w6ll?= , qemu-devel@nongnu.org Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" This is a simple plugin to track which translation blocks are call most often. As we don't have a view of the internals of TCG we can only work by the address of the start of the block so we also need to tracks how often the address is translated. As there will be multiple blocks starting at the same address. We can try and work around this by futzing the value to feed to the hash with the insn count. Signed-off-by: Alex Bennée Reviewed-by: Richard Henderson -- 2.20.1 diff --git a/tests/plugin/Makefile b/tests/plugin/Makefile index f9a3546ea32..e74940eaac5 100644 --- a/tests/plugin/Makefile +++ b/tests/plugin/Makefile @@ -10,6 +10,7 @@ NAMES += bb NAMES += empty NAMES += insn NAMES += mem +NAMES += hotblocks SONAMES := $(addsuffix .so,$(addprefix lib,$(NAMES))) diff --git a/tests/plugin/hotblocks.c b/tests/plugin/hotblocks.c new file mode 100644 index 00000000000..1bd183849a1 --- /dev/null +++ b/tests/plugin/hotblocks.c @@ -0,0 +1,143 @@ +/* + * Copyright (C) 2019, Alex Bennée + * + * License: GNU GPL, version 2 or later. + * See the COPYING file in the top-level directory. + */ +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +static bool do_inline; + +/* Plugins need to take care of their own locking */ +static GMutex lock; +static GHashTable *hotblocks; +static guint64 limit = 20; + +/* + * Counting Structure + * + * The internals of the TCG are not exposed to plugins so we can only + * get the starting PC for each block. We cheat this slightly by + * xor'ing the number of instructions to the hash to help + * differentiate. + */ +typedef struct { + uint64_t start_addr; + uint64_t exec_count; + int trans_count; + unsigned long insns; +} ExecCount; + +static gint cmp_exec_count(gconstpointer a, gconstpointer b) +{ + ExecCount *ea = (ExecCount *) a; + ExecCount *eb = (ExecCount *) b; + return ea->exec_count > eb->exec_count ? -1 : 1; +} + +static void plugin_exit(qemu_plugin_id_t id, void *p) +{ + g_autoptr(GString) report = g_string_new("collected "); + GList *counts, *it; + int i; + + g_mutex_lock(&lock); + g_string_append_printf(report, "%d entries in the hash table\n", + g_hash_table_size(hotblocks)); + counts = g_hash_table_get_values(hotblocks); + it = g_list_sort(counts, cmp_exec_count); + + if (it) { + g_string_append_printf(report, "pc, tcount, icount, ecount\n"); + + for (i = 0; i < limit && it->next; i++, it = it->next) { + ExecCount *rec = (ExecCount *) it->data; + g_string_append_printf(report, "%#016"PRIx64", %d, %ld, %"PRId64"\n", + rec->start_addr, rec->trans_count, + rec->insns, rec->exec_count); + } + + g_list_free(it); + g_mutex_unlock(&lock); + } + + qemu_plugin_outs(report->str); +} + +static void plugin_init(void) +{ + hotblocks = g_hash_table_new(NULL, g_direct_equal); +} + +static void vcpu_tb_exec(unsigned int cpu_index, void *udata) +{ + ExecCount *cnt; + uint64_t hash = (uint64_t) udata; + + g_mutex_lock(&lock); + cnt = (ExecCount *) g_hash_table_lookup(hotblocks, (gconstpointer) hash); + /* should always succeed */ + g_assert(cnt); + cnt->exec_count++; + g_mutex_unlock(&lock); +} + +/* + * When do_inline we ask the plugin to increment the counter for us. + * Otherwise a helper is inserted which calls the vcpu_tb_exec + * callback. + */ +static void vcpu_tb_trans(qemu_plugin_id_t id, struct qemu_plugin_tb *tb) +{ + ExecCount *cnt; + uint64_t pc = qemu_plugin_tb_vaddr(tb); + unsigned long insns = qemu_plugin_tb_n_insns(tb); + uint64_t hash = pc ^ insns; + + g_mutex_lock(&lock); + cnt = (ExecCount *) g_hash_table_lookup(hotblocks, (gconstpointer) hash); + if (cnt) { + cnt->trans_count++; + } else { + cnt = g_new0(ExecCount, 1); + cnt->start_addr = pc; + cnt->trans_count = 1; + cnt->insns = insns; + g_hash_table_insert(hotblocks, (gpointer) hash, (gpointer) cnt); + } + + g_mutex_unlock(&lock); + + if (do_inline) { + qemu_plugin_register_vcpu_tb_exec_inline(tb, QEMU_PLUGIN_INLINE_ADD_U64, + &cnt->exec_count, 1); + } else { + qemu_plugin_register_vcpu_tb_exec_cb(tb, vcpu_tb_exec, + QEMU_PLUGIN_CB_NO_REGS, + (void *)hash); + } +} + +QEMU_PLUGIN_EXPORT +int qemu_plugin_install(qemu_plugin_id_t id, const qemu_info_t *info, + int argc, char **argv) +{ + if (argc && strcmp(argv[0], "inline") == 0) { + do_inline = true; + } + + plugin_init(); + + qemu_plugin_register_vcpu_tb_trans_cb(id, vcpu_tb_trans); + qemu_plugin_register_atexit_cb(id, plugin_exit, NULL); + return 0; +}