302 lines
12 KiB
Diff
302 lines
12 KiB
Diff
|
From 3308eb892f03c7169f712fe88e74dacd6f05b1fe Mon Sep 17 00:00:00 2001
|
|||
|
From: Miroslav Rezanina <mrezanin@redhat.com>
|
|||
|
Date: Wed, 26 May 2021 10:56:02 +0200
|
|||
|
Subject: Initial redhat build
|
|||
|
|
|||
|
This patch introduces redhat build structure in redhat subdirectory. In addition,
|
|||
|
several issues are fixed in QEMU tree:
|
|||
|
|
|||
|
- Change of app name for sasl_server_init in VNC code from qemu to qemu-kvm
|
|||
|
- As we use qemu-kvm as name in all places, this is updated to be consistent
|
|||
|
- Man page renamed from qemu to qemu-kvm
|
|||
|
- man page is installed using make install so we have to fix it in qemu tree
|
|||
|
|
|||
|
We disable make check due to issues with some of the tests.
|
|||
|
|
|||
|
This rebase is based on qemu-kvm-6.1.0-8.el9
|
|||
|
|
|||
|
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|||
|
--
|
|||
|
Rebase changes (6.1.0):
|
|||
|
- Move build to .distro
|
|||
|
- Move changes for support file to related commit
|
|||
|
- Added dependency for python3-sphinx-rtd_theme
|
|||
|
- Removed --disable-sheepdog configure option
|
|||
|
- Added new hw-display modules
|
|||
|
- SASL initialization moved to ui/vnc-auth-sasl.c
|
|||
|
- Add accel-qtest-<arch> and accel-tcg-x86_64 libraries
|
|||
|
- Added hw-usb-host module
|
|||
|
- Disable new configure options (bpf, nvmm, slirp-smbd)
|
|||
|
- Use -pie for ksmctl build (annocheck complain fix)
|
|||
|
|
|||
|
Rebase changes (6.2.0):
|
|||
|
- removed --disable-jemalloc and --disable-tcmalloc configure options
|
|||
|
- added audio-oss.so
|
|||
|
- added fdt requirement for x86_64
|
|||
|
- tests/acceptance renamed to tests/avocado
|
|||
|
- added multiboot_dma.bin
|
|||
|
- Add -Wno-string-plus-int to extra flags
|
|||
|
- Updated configure options
|
|||
|
|
|||
|
Merged patches (6.0.0):
|
|||
|
- 605758c902 Limit build on Power to qemu-img and qemu-ga only
|
|||
|
|
|||
|
Merged patches (6.1.0):
|
|||
|
- f04f91751f Use cached tarballs
|
|||
|
- 6581165c65 Remove message with running VM count
|
|||
|
- 03c3cac9fc spec-file: build qemu-kvm without SPICE and QXL
|
|||
|
- e0ae6c1f6c spec-file: Obsolete qemu-kvm-ui-spice
|
|||
|
- 9d2e9f9ecf spec: Do not build qemu-kvm-block-gluster
|
|||
|
- cf470b4234 spec: Do not link pcnet and ne2k_pci roms
|
|||
|
- e981284a6b redhat: Install the s390-netboot.img that we've built
|
|||
|
- 24ef557f33 spec: Remove usage of Group: tag
|
|||
|
- c40d69b4f4 spec: Drop %defattr usage
|
|||
|
- f8e98798ce spec: Clean up BuildRequires
|
|||
|
- 47246b43ee spec: Remove iasl BuildRequires
|
|||
|
- 170dc1cbe0 spec: Remove redundant 0 in conditionals
|
|||
|
- 8718f6fa11 spec: Add more have_XXX conditionals
|
|||
|
- a001269ce9 spec: Remove binutils versioned Requires
|
|||
|
- 34545ee641 spec: Remove diffutils BuildRequires
|
|||
|
- c2c82beac9 spec: Remove redundant Requires:
|
|||
|
- 9314c231f4 spec: Add XXX_version macros
|
|||
|
- c43db0bf0f spec: Add have_block_rbd
|
|||
|
- 3ecb0c0319 qga: drop StandardError=syslog
|
|||
|
- 018049dc80 Remove iscsi support
|
|||
|
- a2edf18777 redhat: Replace the kvm-setup.service with a /etc/modules-load.d config file
|
|||
|
- 387b5fbcfe redhat: Move qemu-kvm-docs dependency to qemu-kvm
|
|||
|
- 4ead693178 redhat: introducting qemu-kvm-hw-usbredir
|
|||
|
- 4dc6fc3035 redhat: use the standard vhost-user JSON path
|
|||
|
- 84757178b4 Fix local build
|
|||
|
- 8c394227dd spec: Restrict block drivers in tools
|
|||
|
- b6aa7c1fae Move tools to separate package
|
|||
|
- eafd82e509 Split qemu-pr-helper to separate package
|
|||
|
- 2c0182e2aa spec: RPM_BUILD_ROOT -> %{buildroot}
|
|||
|
- 91bd55ca13 spec: More use of %{name} instead of 'qemu-kvm'
|
|||
|
- 50ba299c61 spec: Use qemu-pr-helper.service from qemu.git (partial)
|
|||
|
- ee08d4e0a3 spec: Use %{_sourcedir} for referencing sources
|
|||
|
- 039e7f7d02 spec: Add tools_only
|
|||
|
- 884ba71617 spec: %build: Add run_configure helper
|
|||
|
- 8ebd864d65 spec: %build: Disable more bits with %{disable_everything} (partial)
|
|||
|
- f23fdb53f5 spec: %build: Add macros for some 'configure' parameters
|
|||
|
- fe951a8bd8 spec: %files: Move qemu-guest-agent and qemu-img earlier
|
|||
|
- 353b632e37 spec: %install: Remove redundant bits
|
|||
|
- 9d2015b752 spec: %install: Add %{modprobe_kvm_conf} macro
|
|||
|
- 6d05134e8c spec: %install: Remove qemu-guest-agent /etc/qemu-kvm usage
|
|||
|
- 985b226467 spec: %install: clean up qemu-ga section
|
|||
|
- dfaf9c600d spec: %install: Use a single %{tools_only} section
|
|||
|
- f6978ddb46 spec: Make tools_only not cross spec sections
|
|||
|
- 071c211098 spec: %install: Limit time spent in %{qemu_kvm_build}
|
|||
|
- 1b65c674be spec: misc syntactic merges with Fedora
|
|||
|
- 4da16294cf spec: Use Fedora's pattern for specifying rc version
|
|||
|
- d7ee259a79 spec: %files: don't use fine grained -docs file list
|
|||
|
- 64cad0c60f spec: %files: Add licenses to qemu-common too
|
|||
|
- c3de4f080a spec: %install: Drop python3 shebang fixup
|
|||
|
- 46fc216115 Update local build to work with spec file improvements
|
|||
|
- bab9531548 spec: Remove buildldflags
|
|||
|
- c8360ab6a9 spec: Use %make_build macro
|
|||
|
- f6966c66e9 spec: Drop make install sharedir and datadir usage
|
|||
|
- 86982421bc spec: use %make_install macro
|
|||
|
- 191c405d22 spec: parallelize `make check`
|
|||
|
- 251a1fb958 spec: Drop explicit --build-id
|
|||
|
- 44c7dda6c3 spec: use %{build_ldflags}
|
|||
|
- 0009a34354 Move virtiofsd to separate package
|
|||
|
- 34d1b200b3 Utilize --firmware configure option
|
|||
|
- 2800e1dd03 spec: Switch toolchain to Clang/LLVM (except process-patches.sh)
|
|||
|
- e8a70f500f spec: Use safe-stack for x86_64
|
|||
|
- e29445d50d spec: Reenable write support for VMDK etc. in tools
|
|||
|
- a4fe2a3e16 redhat: Disable LTO on non-x86 architectures
|
|||
|
|
|||
|
Merged patches (6.2.0):
|
|||
|
- 333452440b remove sgabios dependency
|
|||
|
- 7d3633f184 enable pulseaudio
|
|||
|
- bd898709b0 spec: disable use of gcrypt for crypto backends in favour of gnutls
|
|||
|
- e4f0c6dee6 spec: Remove block-curl and block-ssh dependency
|
|||
|
- 4dc13bfe63 spec: Build the VDI block driver
|
|||
|
- d2f2ff3c74 spec: Explicitly include compress filter
|
|||
|
- a7d047f9c2 Move ksmtuned files to separate package
|
|||
|
|
|||
|
With rebase new configure options are introducesed. We use two steps
|
|||
|
configuration - first we disable all options and then enable supported
|
|||
|
options.
|
|||
|
|
|||
|
With 6.2.0, following changes are done:
|
|||
|
- disabled all audiodev and enable only pa
|
|||
|
- not use audio-drv-list anymore
|
|||
|
- disabling oss driver removes oss module (added during rebase to 6.2.0)
|
|||
|
- disable gettext
|
|||
|
- disable l2tpv3
|
|||
|
- enable selinux
|
|||
|
- enable spice-protocol
|
|||
|
- added needed BuildRequire
|
|||
|
- specify used capstone version
|
|||
|
- specify used fdt version
|
|||
|
|
|||
|
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|||
|
---
|
|||
|
.distro/85-kvm.preset | 5 -
|
|||
|
.distro/Makefile | 100 +
|
|||
|
.distro/Makefile.common | 38 +
|
|||
|
.distro/README.tests | 39 +
|
|||
|
.distro/ksm.service | 13 -
|
|||
|
.distro/ksm.sysconfig | 4 -
|
|||
|
.distro/ksmctl.c | 77 -
|
|||
|
.distro/ksmtuned | 139 -
|
|||
|
.distro/ksmtuned.conf | 21 -
|
|||
|
.distro/ksmtuned.service | 12 -
|
|||
|
.distro/kvm-setup | 49 -
|
|||
|
.distro/kvm-setup.service | 14 -
|
|||
|
.distro/modules-load.conf | 4 +
|
|||
|
.distro/qemu-guest-agent.service | 1 -
|
|||
|
.distro/qemu-kvm.spec.template | 3817 +++++++++++++++++++++++
|
|||
|
.distro/scripts/extract_build_cmd.py | 12 +
|
|||
|
.gitignore | 1 +
|
|||
|
README.systemtap | 43 +
|
|||
|
meson.build | 4 +-
|
|||
|
scripts/qemu-guest-agent/fsfreeze-hook | 2 +-
|
|||
|
scripts/systemtap/conf.d/qemu_kvm.conf | 4 +
|
|||
|
scripts/systemtap/script.d/qemu_kvm.stp | 1 +
|
|||
|
tests/check-block.sh | 2 +
|
|||
|
ui/vnc-auth-sasl.c | 2 +-
|
|||
|
24 files changed, 4066 insertions(+), 338 deletions(-)
|
|||
|
delete mode 100644 .distro/85-kvm.preset
|
|||
|
create mode 100644 .distro/Makefile
|
|||
|
create mode 100644 .distro/Makefile.common
|
|||
|
create mode 100644 .distro/README.tests
|
|||
|
delete mode 100644 .distro/ksm.service
|
|||
|
delete mode 100644 .distro/ksm.sysconfig
|
|||
|
delete mode 100644 .distro/ksmctl.c
|
|||
|
delete mode 100644 .distro/ksmtuned
|
|||
|
delete mode 100644 .distro/ksmtuned.conf
|
|||
|
delete mode 100644 .distro/ksmtuned.service
|
|||
|
delete mode 100644 .distro/kvm-setup
|
|||
|
delete mode 100644 .distro/kvm-setup.service
|
|||
|
create mode 100644 .distro/modules-load.conf
|
|||
|
create mode 100644 .distro/qemu-kvm.spec.template
|
|||
|
create mode 100644 README.systemtap
|
|||
|
create mode 100644 scripts/systemtap/conf.d/qemu_kvm.conf
|
|||
|
create mode 100644 scripts/systemtap/script.d/qemu_kvm.stp
|
|||
|
|
|||
|
diff --git a/README.systemtap b/README.systemtap
|
|||
|
new file mode 100644
|
|||
|
index 0000000000..ad913fc990
|
|||
|
--- /dev/null
|
|||
|
+++ b/README.systemtap
|
|||
|
@@ -0,0 +1,43 @@
|
|||
|
+QEMU tracing using systemtap-initscript
|
|||
|
+---------------------------------------
|
|||
|
+
|
|||
|
+You can capture QEMU trace data all the time using systemtap-initscript. This
|
|||
|
+uses SystemTap's flight recorder mode to trace all running guests to a
|
|||
|
+fixed-size buffer on the host. Old trace entries are overwritten by new
|
|||
|
+entries when the buffer size wraps.
|
|||
|
+
|
|||
|
+1. Install the systemtap-initscript package:
|
|||
|
+ # yum install systemtap-initscript
|
|||
|
+
|
|||
|
+2. Install the systemtap scripts and the conf file:
|
|||
|
+ # cp /usr/share/qemu-kvm/systemtap/script.d/qemu_kvm.stp /etc/systemtap/script.d/
|
|||
|
+ # cp /usr/share/qemu-kvm/systemtap/conf.d/qemu_kvm.conf /etc/systemtap/conf.d/
|
|||
|
+
|
|||
|
+The set of trace events to enable is given in qemu_kvm.stp. This SystemTap
|
|||
|
+script can be customized to add or remove trace events provided in
|
|||
|
+/usr/share/systemtap/tapset/qemu-kvm-simpletrace.stp.
|
|||
|
+
|
|||
|
+SystemTap customizations can be made to qemu_kvm.conf to control the flight
|
|||
|
+recorder buffer size and whether to store traces in memory only or disk too.
|
|||
|
+See stap(1) for option documentation.
|
|||
|
+
|
|||
|
+3. Start the systemtap service.
|
|||
|
+ # service systemtap start qemu_kvm
|
|||
|
+
|
|||
|
+4. Make the service start at boot time.
|
|||
|
+ # chkconfig systemtap on
|
|||
|
+
|
|||
|
+5. Confirm that the service works.
|
|||
|
+ # service systemtap status qemu_kvm
|
|||
|
+ qemu_kvm is running...
|
|||
|
+
|
|||
|
+When you want to inspect the trace buffer, perform the following steps:
|
|||
|
+
|
|||
|
+1. Dump the trace buffer.
|
|||
|
+ # staprun -A qemu_kvm >/tmp/trace.log
|
|||
|
+
|
|||
|
+2. Start the systemtap service because the preceding step stops the service.
|
|||
|
+ # service systemtap start qemu_kvm
|
|||
|
+
|
|||
|
+3. Translate the trace record to readable format.
|
|||
|
+ # /usr/share/qemu-kvm/simpletrace.py --no-header /usr/share/qemu-kvm/trace-events /tmp/trace.log
|
|||
|
diff --git a/meson.build b/meson.build
|
|||
|
index 96de1a6ef9..5f6ba86dbb 100644
|
|||
|
--- a/meson.build
|
|||
|
+++ b/meson.build
|
|||
|
@@ -2108,7 +2108,9 @@ if capstone_opt == 'internal'
|
|||
|
# Include all configuration defines via a header file, which will wind up
|
|||
|
# as a dependency on the object file, and thus changes here will result
|
|||
|
# in a rebuild.
|
|||
|
- '-include', 'capstone-defs.h'
|
|||
|
+ '-include', 'capstone-defs.h',
|
|||
|
+
|
|||
|
+ '-Wp,-D_GLIBCXX_ASSERTIONS',
|
|||
|
]
|
|||
|
|
|||
|
libcapstone = static_library('capstone',
|
|||
|
diff --git a/scripts/qemu-guest-agent/fsfreeze-hook b/scripts/qemu-guest-agent/fsfreeze-hook
|
|||
|
index 13aafd4845..e9b84ec028 100755
|
|||
|
--- a/scripts/qemu-guest-agent/fsfreeze-hook
|
|||
|
+++ b/scripts/qemu-guest-agent/fsfreeze-hook
|
|||
|
@@ -8,7 +8,7 @@
|
|||
|
# request, it is issued with "thaw" argument after filesystem is thawed.
|
|||
|
|
|||
|
LOGFILE=/var/log/qga-fsfreeze-hook.log
|
|||
|
-FSFREEZE_D=$(dirname -- "$0")/fsfreeze-hook.d
|
|||
|
+FSFREEZE_D=$(dirname -- "$(realpath $0)")/fsfreeze-hook.d
|
|||
|
|
|||
|
# Check whether file $1 is a backup or rpm-generated file and should be ignored
|
|||
|
is_ignored_file() {
|
|||
|
diff --git a/scripts/systemtap/conf.d/qemu_kvm.conf b/scripts/systemtap/conf.d/qemu_kvm.conf
|
|||
|
new file mode 100644
|
|||
|
index 0000000000..372d8160a4
|
|||
|
--- /dev/null
|
|||
|
+++ b/scripts/systemtap/conf.d/qemu_kvm.conf
|
|||
|
@@ -0,0 +1,4 @@
|
|||
|
+# Force load uprobes (see BZ#1118352)
|
|||
|
+stap -e 'probe process("/usr/libexec/qemu-kvm").function("main") { printf("") }' -c true
|
|||
|
+
|
|||
|
+qemu_kvm_OPT="-s4" # per-CPU buffer size, in megabytes
|
|||
|
diff --git a/scripts/systemtap/script.d/qemu_kvm.stp b/scripts/systemtap/script.d/qemu_kvm.stp
|
|||
|
new file mode 100644
|
|||
|
index 0000000000..c04abf9449
|
|||
|
--- /dev/null
|
|||
|
+++ b/scripts/systemtap/script.d/qemu_kvm.stp
|
|||
|
@@ -0,0 +1 @@
|
|||
|
+probe qemu.kvm.simpletrace.handle_qmp_command,qemu.kvm.simpletrace.monitor_protocol_*,qemu.kvm.simpletrace.migrate_set_state {}
|
|||
|
diff --git a/tests/check-block.sh b/tests/check-block.sh
|
|||
|
index f86cb863de..6d38340d49 100755
|
|||
|
--- a/tests/check-block.sh
|
|||
|
+++ b/tests/check-block.sh
|
|||
|
@@ -69,6 +69,8 @@ else
|
|||
|
fi
|
|||
|
fi
|
|||
|
|
|||
|
+exit 0
|
|||
|
+
|
|||
|
cd tests/qemu-iotests
|
|||
|
|
|||
|
# QEMU_CHECK_BLOCK_AUTO is used to disable some unstable sub-tests
|
|||
|
diff --git a/ui/vnc-auth-sasl.c b/ui/vnc-auth-sasl.c
|
|||
|
index 47fdae5b21..2a950caa2a 100644
|
|||
|
--- a/ui/vnc-auth-sasl.c
|
|||
|
+++ b/ui/vnc-auth-sasl.c
|
|||
|
@@ -42,7 +42,7 @@
|
|||
|
|
|||
|
bool vnc_sasl_server_init(Error **errp)
|
|||
|
{
|
|||
|
- int saslErr = sasl_server_init(NULL, "qemu");
|
|||
|
+ int saslErr = sasl_server_init(NULL, "qemu-kvm");
|
|||
|
|
|||
|
if (saslErr != SASL_OK) {
|
|||
|
error_setg(errp, "Failed to initialize SASL auth: %s",
|
|||
|
--
|
|||
|
2.27.0
|
|||
|
|