mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-15 00:55:17 +00:00
3ad13c92a7
Commit f9ce7dad6 tried to kill uses of a raw street address, but missed a few instances. Automate things so we don't introduce new problems in the future. * cfg.mk (sc_copyright_address): New rule. (exclude_file_name_regexp--sc_copyright_address): Add exemption. * bootstrap.conf: Adjust offenders. * build-aux/augeas-gentest.pl: Likewise. * examples/systemtap/events.stp: Likewise. * examples/systemtap/qemu-monitor.stp: Likewise. * examples/systemtap/rpc-monitor.stp: Likewise. * src/dtrace2systemtap.pl: Likewise. * src/esx/esx_vi_generator.py: Likewise. * src/hyperv/hyperv_wmi_generator.py: Likewise. * src/remote/qemu_protocol.x: Likewise. * src/remote/remote_protocol.x: Likewise. * src/rpc/gensystemtap.pl: Likewise. * src/rpc/virnetprotocol.x: Likewise. * tests/object-locking.ml: Likewise. * tools/virt-xml-validate.in: Likewise.
81 lines
3.2 KiB
Plaintext
81 lines
3.2 KiB
Plaintext
#!/usr/bin/stap
|
|
#
|
|
# Copyright (C) 2011 Red Hat, Inc.
|
|
#
|
|
# This library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
#
|
|
# This library is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this library; if not, see
|
|
# <http://www.gnu.org/licenses/>.
|
|
#
|
|
# Author: Daniel P. Berrange <berrange@redhat.com>
|
|
#
|
|
# This script will monitor all messages sent/received between libvirt
|
|
# and the QEMU monitor
|
|
#
|
|
# stap qemu-monitor.stp
|
|
# 0.000 begin
|
|
# 3.848 ! 0x7f2dc00017b0 {"timestamp": {"seconds": 1319466931, "microseconds": 187755}, "event": "SHUTDOWN"}
|
|
# 5.773 > 0x7f2dc0007960 {"execute":"qmp_capabilities","id":"libvirt-1"}
|
|
# 5.774 < 0x7f2dc0007960 {"return": {}, "id": "libvirt-1"}
|
|
# 5.774 > 0x7f2dc0007960 {"execute":"query-commands","id":"libvirt-2"}
|
|
# 5.777 < 0x7f2dc0007960 {"return": [{"name": "quit"}, {"name": ....snip....
|
|
# 5.777 > 0x7f2dc0007960 {"execute":"query-chardev","id":"libvirt-3"}
|
|
# 5.778 < 0x7f2dc0007960 {"return": [{"filename": ....snip....
|
|
# 5.779 > 0x7f2dc0007960 {"execute":"query-cpus","id":"libvirt-4"}
|
|
# 5.780 < 0x7f2dc0007960 {"return": [{"current": true, "CPU": 0, "pc": 1048560, "halted": false, "thread_id": 13299}], "id": "libvirt-4"}
|
|
# 5.780 > 0x7f2dc0007960 {"execute":"set_password","arguments":{"protocol":"vnc","password":"123456","connected":"keep"},"id":"libvirt-5"}
|
|
# 5.782 < 0x7f2dc0007960 {"return": {}, "id": "libvirt-5"}
|
|
# 5.782 > 0x7f2dc0007960 {"execute":"expire_password","arguments":{"protocol":"vnc","time":"never"},"id":"libvirt-6"}
|
|
# 5.783 < 0x7f2dc0007960 {"return": {}, "id": "libvirt-6"}
|
|
# 5.783 > 0x7f2dc0007960 {"execute":"balloon","arguments":{"value":224395264},"id":"libvirt-7"}
|
|
# 5.785 < 0x7f2dc0007960 {"return": {}, "id": "libvirt-7"}
|
|
# 5.785 > 0x7f2dc0007960 {"execute":"cont","id":"libvirt-8"}
|
|
# 5.789 ! 0x7f2dc0007960 {"timestamp": {"seconds": 1319466933, "microseconds": 129980}, "event": "RESUME"}
|
|
# 5.789 < 0x7f2dc0007960 {"return": {}, "id": "libvirt-8"}
|
|
# 7.537 ! 0x7f2dc0007960 {"timestamp": {"seconds": 1319466934, "microseconds": 881214}, "event": "SHUTDOWN"}
|
|
#
|
|
|
|
|
|
global start
|
|
|
|
# Print a string, with a timestamp relative to the start of the script
|
|
function print_ts(msg)
|
|
{
|
|
now = gettimeofday_ns() / (1000*1000)
|
|
delta = (now - start)
|
|
|
|
printf("%3d.%03d %s\n", (delta / 1000), (delta % 1000), msg);
|
|
}
|
|
|
|
|
|
# Just so we know the script is now running
|
|
probe begin {
|
|
start = gettimeofday_ns() / (1000*1000)
|
|
print_ts("begin")
|
|
}
|
|
|
|
probe libvirt.qemu.monitor_send_msg {
|
|
if (fd != -1) {
|
|
print_ts(sprintf("> %p %s (fd=%d)", mon, substr(msg, 0, strlen(msg)-2), fd));
|
|
} else {
|
|
print_ts(sprintf("> %p %s", mon, substr(msg, 0, strlen(msg)-2)));
|
|
}
|
|
}
|
|
|
|
probe libvirt.qemu.monitor_recv_reply {
|
|
print_ts(sprintf("< %p %s", mon, reply));
|
|
}
|
|
|
|
probe libvirt.qemu.monitor_recv_event {
|
|
print_ts(sprintf("! %p %s", mon, event));
|
|
}
|