From Fedora Project Wiki

(Fix 2 typos)
No edit summary
 
(22 intermediate revisions by the same user not shown)
Line 1: Line 1:
= Rawhide synchronization for the GNU Binutils =
= Rawhide synchronization for the GNU Binutils =
*THIS PAGE IS UNDER DEVELOPMENT AND SHOULD NOT BE CONSIDERED READY FOR USE*


This page documents the process by which the rawhide binutils package is synced with the upstream GNU Binutils project.  The aim of this process is to make syncing simple and easy so that it can be performed on a regular basis.  Due to the fact that the binutils is an important component in the toolchain used to build many of the packages in rawhide however, it is important to extensively test a new binutils before putting it into the buildroot.  This does make the syncing process more time consuming and complicated.
This page documents the process by which the rawhide binutils package is synced with the upstream GNU Binutils project.  The aim of this process is to make syncing simple and easy so that it can be performed on a regular basis.  Due to the fact that the binutils is an important component in the toolchain used to build many of the packages in rawhide however, it is important to extensively test a new binutils before putting it into the buildroot.  This does make the syncing process more time consuming and complicated.


This process is based upon a similar process for the GNU C Library ([[GlibcRawhideSync]]), but tweaked to fit the binutils' way of handling patches.
This process is based upon a similar process for the GNU C Library ([[GlibcRawhideSync]]), but tweaked to fit the binutils' way of handling patches.
This process assumes that you already have a clone of the Fedora rawhide binutils.
The decision for '''when''' to perform a sync is a complicated one.  In general if there is a newly made official upstream release then that should be used.  Otherwise if there is a recent upstream branch snapshot available then that should be used.  Otherwise if there has not been a sync in the last two weeks then it is probably time for this procedure to be run.


Follow these steps:
Follow these steps:


1. Make sure that your clone of the upstream GNU Binutils is up to date, on the right branch and clean.  If there any problems or uncommitted changes, resolve them before continuing.
1. Check to see if there is a recent snapshot available:
 
  https://snapshots.sourceware.org/binutils/trunk/
 
If there is, then download it and proceed to step 2.  Otherwise proceed to step 5.
 
2. Go to your clone of the fedora binutils package and make sure that it is clean and up to date:
 
<pre>
cd <rawhide-binutils>
git switch rawhide
git pull
git clean -fdx
git status </pre>
 
3. Delete the current source tarball and then copy in the source tarball downloaded in step 1:
 
<pre>
rm -f *.tar.xz
cp ~/Downloads/binutils-*.tar.xz . </pre>
 
4. Edit the ''binutils.spec'' file and change the ''use_snapshot_tarball:'' field to reference the commit id in the new tarball:
 
<pre>
sed --in-place -e 's/use_snapshot_tarballs.*/use_snapshot_tarballs %(echo "COMMI_ID")/' binutils.spec
</pre>
 
Replace COMMIT_ID in the above command with the commit id of the tarball.
 
Also check that the ''use_commit_id_tarballs'' define in the spec file is set to 0.
 
Also increment the ''Release:'' field by one and add a changelog entry for the update:
 
<pre>
rpmdev-bumpspec -c "- Rebase to commit COMMIT_ID" binutils.spec
</pre>
 
Replace COMMIT_ID in the above command with the commit id of the tarball.
 
Goto step 10.
 
5. (This step is reached from step 1 if a suitable upstream source snapshot is unavailable).
 
Make sure that your clone of the upstream GNU Binutils is up to date, on the right branch and clean.  If there any problems or uncommitted changes, resolve them before continuing.


<pre>
<pre>
Line 18: Line 63:
git status</pre>
git status</pre>


2. Delete any old release tarballs and then create a source tarball from the upstream sources.  Change the version number in the tarball's name to a commit id.
Delete any old release tarballs and then create a source tarball from the upstream sources.  Change the version number in the tarball's name to a commit id.


<pre>
<pre>
Line 26: Line 71:
mv binutils-*.tar.xz binutils-$COMMIT_ID.tar.xz </pre>
mv binutils-*.tar.xz binutils-$COMMIT_ID.tar.xz </pre>


3. Go to your clone of the fedora binutils package and make sure that it is clean and up to date:
6. Go to your clone of the fedora binutils package and make sure that it is clean and up to date:


<pre>
<pre>
cd <rawhide-binutils>
pushd <rawhide-binutils>
git switch rawhide
git switch rawhide
git pull
git pull
Line 35: Line 80:
git status </pre>
git status </pre>


4. Delete the current source tarball and then copy in the source tarball created in step 2:
7. Delete the current source tarball and then copy in the source tarball created in step 5:


<pre>
<pre>
Line 41: Line 86:
cp <upstream-binutils>/binutils*.tar.xz . </pre>
cp <upstream-binutils>/binutils*.tar.xz . </pre>


5. Edit the ''binutils.spec'' file and change the ''Source0:'' field to reference the new tarball:
8. [Optional] Tidy up the upstream repository.
 
<pre>
pushd <upstream-binutils>
git clean -fdx
popd
</pre>
 
9. Edit the ''binutils.spec'' file and change the ''Source0:'' field to reference the new tarball:


<pre>
<pre>
Line 47: Line 100:


Also check that the ''use_commit_id_tarballs'' define in the spec file is set to 1.
Also check that the ''use_commit_id_tarballs'' define in the spec file is set to 1.
This define is set to zero when the binutils is rebased to an official GNU Binutils release and only set to 1 once the rawhide syncing process begins.


<pre>grep -e "define use_commit_id_tarballs" binutils.spec
Also check that the ''use_snapshot_tarballs'' define is set to 0.
</pre>


Also increment the ''Release:'' field by one.  ''FIXME: Create an awk command to do this''
Also increment the ''Release:'' field by one and add a changelog entry for the update:


<pre>
<pre>
s/Release: <N>%{?dist}/Release: <N + 1>%{?dist}/
rpmdev-bumpspec -c "- Rebase to commit $COMMIT_ID" binutils.spec
</pre>
</pre>


Also create a new entry in the %changelog section noting that the rebase has occurred and the new NVR.
10. Create a source tree and discover if any local patches no longer apply:
 
<pre>
%changelog
* <date> <user name> <email address> - <NVR>
- Rebase to commit $COMMIT_ID
</pre>
 
6. Create a source tree and discover if any local patches no longer apply:


<pre>
<pre>
Line 80: Line 123:
</pre>
</pre>


Optionally add a mention of this to the changelog entry created in step 6.
Optionally add a mention of this to the changelog entry created in step 5.
<pre>
<pre>
- Retire: <unneeded-patch>
- Retire: <unneeded-patch>
Line 87: Line 130:
Optionally renumber the remaining patches referenced in the ''binutils.spec'' file so that they are in a monotonically increasing order.
Optionally renumber the remaining patches referenced in the ''binutils.spec'' file so that they are in a monotonically increasing order.


7. Run a local build to ensure that there are no surprises.
11. Run a local build to ensure that there are no surprises.


<pre> fedpkg local </pre>
<pre> fedpkg local </pre>
Line 93: Line 136:
If there are problems, fix them.  Note, local builds run in parallel, so it is not always easy to discover the location of a build failure.  If the failure is due to a bug in the upstream sources, then it may be better to abort this sync and wait for the bug to be fixed.  Or to fix the bug upstream first and then start the sync process again.  If the failure is due to the local patches that are applied to the sources then they may need to be adjusted.  If a failure is due to a testsuite problem then either the test might need to be tweaked, or just skipped if there is no easy way to correct it.
If there are problems, fix them.  Note, local builds run in parallel, so it is not always easy to discover the location of a build failure.  If the failure is due to a bug in the upstream sources, then it may be better to abort this sync and wait for the bug to be fixed.  Or to fix the bug upstream first and then start the sync process again.  If the failure is due to the local patches that are applied to the sources then they may need to be adjusted.  If a failure is due to a testsuite problem then either the test might need to be tweaked, or just skipped if there is no easy way to correct it.


8. Then run a scratch build.
12. Then run a scratch build.


<pre>rm -f *.rpm
<pre>rm -f *.rpm
Line 99: Line 142:
fedpkg scratch-build --srpm *.rpm </pre>
fedpkg scratch-build --srpm *.rpm </pre>


If the build fails, investigate and fix the problems.  The most likely cause at this point is new failures in one of the testsuites.  Note - the ''build.log'' file created for the build for each architecture will include a uuencoded compressed tarballs of the logs from the testsuite runs.  Hence the logs can be downloaded and examined locally by:
If the build fails, investigate and fix the problems.  The most likely cause at this point is new failures in one of the testsuites.  Note - the ''build.log'' file created for the build for each architecture will include a uuencoded compressed tarball of the logs from the testsuite runs.  Hence the logs can be downloaded and examined locally by:


<pre>
<pre>
Line 107: Line 150:
</pre>
</pre>


9. ADD A STEP HERE TO USE THE MASS PRE-BUILDER TO CHECK THE NEW BINUTILS
13. [Optional] This next step is optional, but recommended.  It assumes that you have command line access to the COPR system and you have the ''mass-prebuild'' package installed.  Warning - this step will take a '''long''' time to complete, as in 3-4 days...
 
Set up a config script for the mass pre-build tool.
 
<pre>
archs: x86_64 aarch64 ppc64le s390x
chroot: fedora-rawhide
name: binutils-$COMMIT_ID
packages:
  binutils:
    src_type: file
    src: <path-to-source-rpm-created-in-step-8>
data: <path-to-results-directory>
verbose: 1
</pre>
 
Then use it to run a test of the new binutils
 
<pre>
mpb --config <config-file>
</pre>
 
If there are problems, try to find out what went wrong.


10. Finally check that the fedora repository has not received any other commits, add the new sources, and commit the changes.
14. Finally check that the fedora repository has not received any other commits, add the new sources, and commit the changes.


<pre>
<pre>
git pull
git pull
fedpkg new-sources binutils-*.tar.xz binutils-2.19.50.0.1-output-format.sed
fedpkg new-sources binutils-*.tar.xz binutils-2.19.50.0.1-output-format.sed
fedpkg commit -m "Rebase to $COMMIT_ID"
fedpkg commit -m "Rebase to commit $COMMIT_ID"
fedpkg push
fedpkg push
fedpkg build
fedpkg build
</pre>
</pre>


11.  Sit back and relax.  Have a cup of tea.  Then wait for the bug reports to flood in.
15.  Sit back and relax.  Have a cup of tea.  Then wait for the bug reports to flood in.

Latest revision as of 11:08, 28 May 2024

Rawhide synchronization for the GNU Binutils

This page documents the process by which the rawhide binutils package is synced with the upstream GNU Binutils project. The aim of this process is to make syncing simple and easy so that it can be performed on a regular basis. Due to the fact that the binutils is an important component in the toolchain used to build many of the packages in rawhide however, it is important to extensively test a new binutils before putting it into the buildroot. This does make the syncing process more time consuming and complicated.

This process is based upon a similar process for the GNU C Library (GlibcRawhideSync), but tweaked to fit the binutils' way of handling patches.

This process assumes that you already have a clone of the Fedora rawhide binutils.

The decision for when to perform a sync is a complicated one. In general if there is a newly made official upstream release then that should be used. Otherwise if there is a recent upstream branch snapshot available then that should be used. Otherwise if there has not been a sync in the last two weeks then it is probably time for this procedure to be run.

Follow these steps:

1. Check to see if there is a recent snapshot available:

 https://snapshots.sourceware.org/binutils/trunk/

If there is, then download it and proceed to step 2. Otherwise proceed to step 5.

2. Go to your clone of the fedora binutils package and make sure that it is clean and up to date:

cd <rawhide-binutils>
git switch rawhide
git pull
git clean -fdx
git status 

3. Delete the current source tarball and then copy in the source tarball downloaded in step 1:

rm -f *.tar.xz
cp ~/Downloads/binutils-*.tar.xz . 

4. Edit the binutils.spec file and change the use_snapshot_tarball: field to reference the commit id in the new tarball:

sed --in-place -e 's/use_snapshot_tarballs.*/use_snapshot_tarballs %(echo "COMMI_ID")/' binutils.spec 

Replace COMMIT_ID in the above command with the commit id of the tarball.

Also check that the use_commit_id_tarballs define in the spec file is set to 0.

Also increment the Release: field by one and add a changelog entry for the update:

rpmdev-bumpspec -c "- Rebase to commit COMMIT_ID" binutils.spec

Replace COMMIT_ID in the above command with the commit id of the tarball.

Goto step 10.

5. (This step is reached from step 1 if a suitable upstream source snapshot is unavailable).

Make sure that your clone of the upstream GNU Binutils is up to date, on the right branch and clean. If there any problems or uncommitted changes, resolve them before continuing.

cd <upstream-binutils>
git switch HEAD
git pull
git clean -fdx
git status

Delete any old release tarballs and then create a source tarball from the upstream sources. Change the version number in the tarball's name to a commit id.

rm -f *.xz
export COMMIT_ID=`git rev-parse HEAD`
./src-release.sh -x -r `git log -1 --format=%cd --date=format:%F $COMMIT_ID` binutils
mv binutils-*.tar.xz binutils-$COMMIT_ID.tar.xz 

6. Go to your clone of the fedora binutils package and make sure that it is clean and up to date:

pushd <rawhide-binutils>
git switch rawhide
git pull
git clean -fdx
git status 

7. Delete the current source tarball and then copy in the source tarball created in step 5:

rm -f *.tar.xz
cp <upstream-binutils>/binutils*.tar.xz . 

8. [Optional] Tidy up the upstream repository.

pushd <upstream-binutils>
git clean -fdx
popd

9. Edit the binutils.spec file and change the Source0: field to reference the new tarball:

sed --in-place -e "s/Source0:.*/Source0: `ls *.tar.xz`/" binutils.spec  

Also check that the use_commit_id_tarballs define in the spec file is set to 1.

Also check that the use_snapshot_tarballs define is set to 0.

Also increment the Release: field by one and add a changelog entry for the update:

rpmdev-bumpspec -c "- Rebase to commit $COMMIT_ID" binutils.spec

10. Create a source tree and discover if any local patches no longer apply:

fedpkg prep 

If a patch does not apply, decide if it is no longer necessary, or if it needs to be adjusted. Take whatever actions are necessary to resolve this issue and then repeat step 5 until a clean run is obtained.

If a patch is not needed, remove its entry from the binutils.spec file.

Also schedule the patch to be deleted from the repository:

git rm <unneeded-patch>

Optionally add a mention of this to the changelog entry created in step 5.

- Retire: <unneeded-patch>

Optionally renumber the remaining patches referenced in the binutils.spec file so that they are in a monotonically increasing order.

11. Run a local build to ensure that there are no surprises.

 fedpkg local 

If there are problems, fix them. Note, local builds run in parallel, so it is not always easy to discover the location of a build failure. If the failure is due to a bug in the upstream sources, then it may be better to abort this sync and wait for the bug to be fixed. Or to fix the bug upstream first and then start the sync process again. If the failure is due to the local patches that are applied to the sources then they may need to be adjusted. If a failure is due to a testsuite problem then either the test might need to be tweaked, or just skipped if there is no easy way to correct it.

12. Then run a scratch build.

rm -f *.rpm
fedpkg srpm
fedpkg scratch-build --srpm *.rpm 

If the build fails, investigate and fix the problems. The most likely cause at this point is new failures in one of the testsuites. Note - the build.log file created for the build for each architecture will include a uuencoded compressed tarball of the logs from the testsuite runs. Hence the logs can be downloaded and examined locally by:

[download build.log file]
uudecode build.log
tar xvf binutils-*.tar.xz

13. [Optional] This next step is optional, but recommended. It assumes that you have command line access to the COPR system and you have the mass-prebuild package installed. Warning - this step will take a long time to complete, as in 3-4 days...

Set up a config script for the mass pre-build tool.

archs: x86_64 aarch64 ppc64le s390x
chroot: fedora-rawhide
name: binutils-$COMMIT_ID
packages:
  binutils:
    src_type: file
    src: <path-to-source-rpm-created-in-step-8>
data: <path-to-results-directory>
verbose: 1

Then use it to run a test of the new binutils

mpb --config <config-file>

If there are problems, try to find out what went wrong.

14. Finally check that the fedora repository has not received any other commits, add the new sources, and commit the changes.

git pull
fedpkg new-sources binutils-*.tar.xz binutils-2.19.50.0.1-output-format.sed
fedpkg commit -m "Rebase to commit $COMMIT_ID"
fedpkg push
fedpkg build

15. Sit back and relax. Have a cup of tea. Then wait for the bug reports to flood in.