2020-08-12 00:53:07 +02:00
|
|
|
The qemu package includes a special maintenance workflow in order to support git
|
|
|
|
based patching. Please use it in order to have changes you make be acceptable to
|
|
|
|
the package maintainers.
|
|
|
|
|
|
|
|
Currently a local clone of the upstream repo(s) is required for the packaging
|
|
|
|
workflow. It is anticipated that the need for any extra setup will be reduced or
|
|
|
|
even eliminated entirely in the future, but for now, you will need do so some
|
|
|
|
setup. See config.sh for details.
|
2019-09-12 17:54:03 +02:00
|
|
|
|
|
|
|
The qemu.spec file is generated from a qemu.spec.in template, so to make changes
|
2020-08-12 00:53:07 +02:00
|
|
|
to the spec file beyond the patch name generation, patch reference and automated
|
|
|
|
versioning done by the scripts, you need to edit the template. Do not directly
|
|
|
|
edit the spec file. The spec file's version and patch references are added when
|
|
|
|
the update_git.sh script is passed certain commands, as described below.
|
2019-09-12 17:54:03 +02:00
|
|
|
|
|
|
|
If you are not modifying any patches or their order, but just need to update the
|
2019-09-28 17:46:49 +02:00
|
|
|
spec file from a changed template, run 'bash ./update_git.sh refresh'.
|
2019-09-12 17:54:03 +02:00
|
|
|
|
|
|
|
If the set of patches is being modified, including their order, you will want to
|
2019-10-10 04:07:57 +02:00
|
|
|
first run 'bash ./update_git.sh pkg2git', which makes the current package patch
|
2019-11-27 13:46:32 +01:00
|
|
|
queue available in a local git branch named frombundle (see config.sh for the
|
2019-10-10 04:07:57 +02:00
|
|
|
locations). This set of patches comes from a "bundle of git bundles", the
|
|
|
|
bundles.tar.xz file, which is included as a package source file. You will then
|
2019-11-27 13:46:32 +01:00
|
|
|
create an altered patch queue in the branch which corresponds to this release
|
2020-04-29 02:12:31 +02:00
|
|
|
(eg: opensuse-5.0), using the frombundle branch as the starting point for your
|
2019-11-27 13:46:32 +01:00
|
|
|
changes (eg perhaps start by doing git reset --hard frombundle, then cherry-pick
|
|
|
|
upstream patches from there). Once you have the patch queue ready to go run
|
|
|
|
'bash ./update_git.sh git2pkg' which updates the bundles.tar.xz file, as well as
|
|
|
|
the spec and patch files.
|
|
|
|
|
2020-08-12 00:53:07 +02:00
|
|
|
The default action for update_git.sh is git2pkg, which helps simplify repeated
|
|
|
|
package updates as you modify the patch queue from the local git repo.
|
|
|
|
|
2019-11-27 13:46:32 +01:00
|
|
|
The maintainer and automation use another workflow mode dealing with packaging
|
|
|
|
the latest upstream qemu. See 'LATEST' references in the scripts for details.
|
2019-09-12 17:54:03 +02:00
|
|
|
|
2020-08-12 00:53:07 +02:00
|
|
|
* * * * * * * * *
|
2019-09-12 17:54:03 +02:00
|
|
|
|
2019-10-10 04:07:57 +02:00
|
|
|
Additional Notes:
|
|
|
|
|
2019-09-12 17:54:03 +02:00
|
|
|
Patches which are from an upstream git repo should have the commit id recorded
|
|
|
|
just below the Subject line (after a blank line) as follows:
|
|
|
|
|
|
|
|
Git-commit: <40-char-sha-id>
|
|
|
|
|
|
|
|
If a patch is anticipated to be shortly included in upstream repo, mark that
|
|
|
|
fact by doing the above with 40 0's, which will flag it as needing to be updated
|
|
|
|
in the near future.
|
|
|
|
|
|
|
|
Bug or feature tracking identifiers should also be added to the patch similarly,
|
|
|
|
using the abbreviations identified here:
|
|
|
|
http://en.opensuse.org/openSUSE:Packaging_Patches_guidelines#Current_set_of_abbreviations
|
2020-04-29 02:12:31 +02:00
|
|
|
using the "Reference:" tag, with multiple entries comma separated.
|
2019-09-12 17:54:03 +02:00
|
|
|
|
|
|
|
The ability to provide a conditional inclusion of a patch (eg based on
|
|
|
|
architecture, is provided by using the "Include-If:" tag similarly, as follows:
|
|
|
|
|
|
|
|
Include-If: %ifarch aarch64
|
|
|
|
|
|
|
|
This will cause the patch application in the spec file to be done as follows:
|
|
|
|
%ifarch aarch64
|
|
|
|
%patch0013 -p1
|
|
|
|
%endif
|
|
|
|
|
2019-09-18 10:58:50 +02:00
|
|
|
A trick worth noting is, if a given git tracked patch is to be applied in a way
|
2020-08-12 00:53:07 +02:00
|
|
|
that can't be done in the normal patching section of the spec file, you can
|
|
|
|
still include the patch, and use it by name with the patch program elsewhere in
|
|
|
|
the spec file by doing something such as:
|
2019-09-12 17:54:03 +02:00
|
|
|
Include-If: %if 0%{?patch-possibly-applied-elsewhere}
|
2020-08-12 00:53:07 +02:00
|
|
|
(this variable will remain undefined in the spec file) And then elsewhere in the
|
|
|
|
spec file, the actual patch (eg specially-handled-change.patch) is referenced as
|
|
|
|
eg:
|
2019-09-12 17:54:03 +02:00
|
|
|
|
|
|
|
patch -p1 < %_sourcedir/specially-handled-change.patch
|