Hi Giuseppe, On Tue, 13 Apr 2021 16:28:36 +0200 Giuseppe Eletto <giuseppe.eletto@xxxxxxxxxxxx> wrote: > Hello, > I want to share with you a new plugin developed by me, under the > supervision of Dario Faggioli, which allows the new version of KernelShark > (the v2-beta) to open and view the Xen traces created using the "xentrace" tool. > > In fact, KernelShark is a well known tool for graphical visualization > Linux kernel traces, obtained via "ftrace" and "trace-cmd". Anyway thanks > to its modular architecture, it is now possible to implement plugins which > open and display traces with arbitrary format, for example, as in in > this case, traces of the Xen hypervisor. I'm guessing you have trace events coming from Xen itself? > > For more information on how to build the plugin and/or > to view the source code I leave the repository below: > https://github.com/giuseppe998e/kernelshark-xentrace-plugin > > > In short: > > $ sudo apt install git build-essential libjson-c-dev > $ git clone --recurse-submodules > https://github.com/giuseppe998e/kernelshark-xentrace-plugin.git > $ cd kernelshark-xentrace-plugin/ > $ make > > $ export XEN_CPUHZ=3G # Sets the CPU frequency ((G)hz/(M)hz/(K)hz/hz) > $ kernelshark -p out/ks-xentrace.so trace.xen > > > You will need the development version of KernelShark, available here: > https://git.kernel.org/pub/scm/utils/trace-cmd/kernel-shark.git This will soon be the main repository, as we are going to deprecate the version in the trace-cmd.git repo soon. And because libtracecmd 1.0 has already been released. > > A screenshot of the plugin in action is available here: > https://github.com/giuseppe998e/kernelshark-xentrace-plugin/raw/master/.github/img/ks-xentrace.png > > I'm happy to receive whatever feedback you may have about it, > and to answer any question. > Thanks for doing this. What would be nice is to have the xen traces along side the linux tracing. Perhaps we can update trace-cmd agent to work with Xen as well. Does xen implement vsock or some other way to communicate between the guests and the Dom0 kernel? If not, we should add one. The you could do the following: 1. On each guest, run as root: trace-cmd agent --xen 2. On Dom0 run: trace-cmd record -e (events on Dom0) \ --xen (commands to do tracing in Xen HV) \ -A <guest-name1> -e (events on guest) And then you would get a trace.dat file for Dom0 and the guest, and also have a trace file for Xen (however that is done). And then on KernelShark, we have a KVM plugin in development that does this. But you can do the same with Xen. For KVM, we have: 1. On each guest: trace-cmd agent 2. On the host: trace-cmd record -e kvm -e sched -e irq \ -A guest-name -e all The above produces trace.dat for the host trace, and trace-<guest-name>.dat for the guest. 3. kernelshark trace.dat -a trace-Fedora21.dat (I have a guest called Fedora21). http://rostedt.org/private/kernelshark-kvm.png Where you can see the kvm hypervisor task KVM-2356 is the host task running the guest VCPU 0, and you see the switch between the two. Perhaps we can do something like that with Xen as well. The plugin is still in the works, but should be published soon. And when it is, you could use that as a template for Xen. -- Steve