From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:34487) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1a1H5J-0006mg-BD for qemu-devel@nongnu.org; Tue, 24 Nov 2015 12:08:54 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1a1H5G-0006Ad-4A for qemu-devel@nongnu.org; Tue, 24 Nov 2015 12:08:53 -0500 Received: from roura.ac.upc.edu ([147.83.33.10]:50133 helo=roura.ac.upc.es) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1a1H5F-00069c-Ku for qemu-devel@nongnu.org; Tue, 24 Nov 2015 12:08:50 -0500 From: =?utf-8?b?TGx1w61z?= Vilanova Date: Tue, 24 Nov 2015 18:08:47 +0100 Message-Id: <144838492534.3052.2948919558518613064.stgit@localhost> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [PATCH v2 00/10] trace: Per-vCPU tracing states List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Stefan Hajnoczi , Eduardo Habkost NOTE: This series completes the framework for guest code tracing. Next se= ries will add actual events. Provides per-vCPU dynamic controls of the tracing state of events tied to= a specific virtual CPU. Events with the "vcpu" property are identified as being tied to a particu= lar virtual CPU, like executing an instruction. The state of such events can = be controlled idependently; this is specially useful to, for example, trace = memory access events of a process executing on a specific virtual CPU. This event property plays in combination with the "tcg" property to avoid generating a call to the execution-time event tracer when a vCPU is not a= ctively tracing such event (i.e., avoids adding tracing overheads). Virtual CPUs tracing the same set of events use the same physical transla= tion cache, improving their reuse. The system has 2^N physical translation cac= hes, where "N" is the number of TCG events with the "vcpu" property. Every vCP= U has a bitmap with the states of these events, which can be controlled separatel= y, and uses it to select its physical translation cache. At translation time, QE= MU generates the code to trace an event at execution time only if the event = is enabled. Changes in v2 =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D * Rebase on 5522a84. * Improve patch descriptions. * Refactor code generation into a separate patch. * Fix forward declarations (Stefan Hajnoczi & Eduardo Habkost). * Fix "since" tags in QAPI interface (Eric Blake). * Unify QAPI/QMP interface with an optional 'vcpu' argument (Eric Blake). * Fix QMP+GTK header workaround (Stefan Hajnoczi). Signed-off-by: Llu=C3=ADs Vilanova --- Llu=C3=ADs Vilanova (10): trace: Add support for vCPU pointers in trace events trace: Add 'vcpu' event property trace: [tcg] Identify events with the 'vcpu' property exec: [tcg] Refactor flush of per-CPU virtual TB cache exec: [=C5=A7cg] Use multiple physical TB caches exec: [tcg] Track which vCPU is performing translation and executio= n [trivial] Track when QEMU has finished initialization disas: Remove unused macro '_' trace: [tcg] Add per-vCPU tracing states for events with the 'vcpu'= property trace: [tcg] Generate TCG code to trace guest events on a per-vCPU = basis Makefile.objs | 3 - bsd-user/main.c | 1=20 cpu-exec.c | 17 +++ cputlb.c | 2=20 disas/i386.c | 2=20 docs/tracing.txt | 40 ++++++++ include/disas/bfd.h | 1=20 include/exec/exec-all.h | 16 +++ include/qemu-common.h | 3 + include/qemu/typedefs.h | 1=20 include/qom/cpu.h | 10 ++ linux-user/main.c | 1=20 monitor.c | 4 - qapi/trace.json | 16 ++- qemu-common.c | 14 +++ qmp-commands.hx | 17 +++ qom/cpu.c | 21 ++++ scripts/tracetool/__init__.py | 24 ++++- scripts/tracetool/format/events_c.py | 11 ++ scripts/tracetool/format/events_h.py | 14 ++- scripts/tracetool/format/h.py | 4 + scripts/tracetool/format/tcg_h.py | 21 +++- scripts/tracetool/format/tcg_helper_c.py | 11 ++ scripts/tracetool/format/ust_events_c.py | 3 - scripts/tracetool/transform.py | 9 ++ stubs/Makefile.objs | 1=20 stubs/qemu-common-stub.c | 21 ++++ target-alpha/translate.c | 3 - target-arm/translate.c | 3 - target-arm/translate.h | 2=20 target-cris/translate.c | 3 - target-cris/translate_v10.c | 1=20 target-i386/translate.c | 3 - target-lm32/translate.c | 3 - target-m68k/translate.c | 3 - target-microblaze/translate.c | 3 - target-mips/translate.c | 3 - target-moxie/translate.c | 3 - target-openrisc/translate.c | 3 - target-ppc/translate.c | 3 - target-s390x/translate.c | 3 - target-sh4/translate.c | 3 - target-sparc/translate.c | 6 + target-tilegx/translate.c | 3 - target-tricore/translate.c | 3 - target-unicore32/translate.c | 3 - target-xtensa/translate.c | 3 - tcg/tcg-op.h | 2=20 tcg/tcg.h | 10 ++ trace/Makefile.objs | 2=20 trace/control-internal.h | 21 +++- trace/control-stub.c | 29 ++++++ trace/control-target.c | 69 +++++++++++++ trace/control.h | 64 ++++++++++++ trace/event-internal.h | 6 + trace/qmp.c | 139 ++++++++++++++++++++++--= --- translate-all.c | 156 ++++++++++++++++++++++++= ++---- translate-all.h | 49 +++++++++ vl.c | 2=20 59 files changed, 788 insertions(+), 109 deletions(-) create mode 100644 qemu-common.c create mode 100644 stubs/qemu-common-stub.c create mode 100644 trace/control-stub.c create mode 100644 trace/control-target.c To: qemu-devel@nongnu.org Cc: Stefan Hajnoczi Cc: Eduardo Habkost Cc: Eric Blake