KernelGitGuide
Size: 3890
Comment:
|
Size: 6014
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 4: | Line 4: |
= Where is it? = http://kernel.ubuntu.com/ = Current GIT Trees = * gutsy: git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git * feisty: git://kernel.ubuntu.com/ubuntu/ubuntu-feisty.git * edgy: git://kernel.ubuntu.com/ubuntu/ubuntu-edgy.git * dapper: git://kernel.ubuntu.com/ubuntu/ubuntu-dapper.git (actually there are a few more and of special note are the -updates git trees. To find out what else is available try browsing http://kernel.ubuntu.com/git and searching for ubuntu) |
|
Line 5: | Line 18: |
To obtain the git binaries, please go to [http://www.kernel.org/pub/software/scm/git-core kernel.org] and download the latest source. Folow the build instructions included, and make sure to install them in a location in your PATH. | To obtain the git binaries, simply install the `git-core` package from dapper, e.g.: {{{ sudo apt-get install git-core }}} '''Note that the `git` package is an entirely different tool which will not do what you want.''' |
Line 8: | Line 27: |
The Ubuntu Linux kernel git repository is located at rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-2.6.git. To download a local copy of the repo, use this command: | The Ubuntu Linux kernel git repository is located at git://kernel.ubuntu.com/ubuntu/ubuntu-<release>.git. To download a local copy of the repo, use this command: |
Line 10: | Line 29: |
git clone rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-2.6.git ubuntu-2.6 | git clone git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git ubuntu-gutsy |
Line 13: | Line 32: |
This will take some time depending on your connection. There's around 110Megs of data to download currently (and this always increases). | This will take some time depending on your connection. There's around 220 MiB of data to download currently (and this always increases). |
Line 18: | Line 37: |
}}} '''** Warning **''' During development, the kernel git repository is being constantly rebased against Linus' tree. IOW, Ubuntu specific changes are not being ''merged'', but rather popped off, the tree rebased and then pushed on to keep them on top. This will cause git pull to fail. Hence, there are two ways to track the kernel git tree, depending on whether you have local changes or not. '''No Local Changes''' {{{ git fetch -f origin git checkout origin git branch -f master origin git checkout master }}} '''Preserve Local Changes''' {{{ # Save away local commits git log origin..HEAD | grep ^commit | awk '{print $2}' | tac > local-commits git branch new-head git checkout new-head # This will stop on first error. Cleaning up failures is an excercize for the user for cmt in `cat local-commits`; do git-cherry-pick $cmt || exit; done git branch -f master new-head git checkout master git branch -D new-head |
|
Line 26: | Line 70: |
In "debian/commit-templates/" there are several templates that must be used when commiting changes that you expect to be integrated with the Ubuntu kernel repo. The commit templates contain comments for how to fill out the required information. Also note that all commits must have a Signed-off-by line (the "-s" option to "git-commit"). An example commit log will look like such: | In ''debian/commit-templates/'' there are several templates that must be used when commiting changes that you expect to be integrated with the Ubuntu kernel repo. The commit templates contain comments for how to fill out the required information. Also note that all commits must have a Signed-off-by line (the "-s" option to ''git-commit''). A typical ''git-commit'' command will look like: |
Line 28: | Line 72: |
[UBUNTU:scsi] My cool change to the scsi subsystem | git-commit -s -F debian/commit-templates/patch -e }}} Note that the -e (edit) option must follow the -F option, else git will not let you edit the commit-template before committing. An example commit log will look like such: {{{ UBUNTU: scsi: My cool change to the scsi subsystem |
Line 33: | Line 83: |
magically to 1.7Gb/sec. | magically to 124GiB/sec. |
Line 38: | Line 88: |
= Ubuntu kernel developers (with access to rookery) = In order to have your git repo pulled automatically, follow these instructions. |
= Patch acceptance criteria = In general, Ubuntu will apply the same criteria applicable to upstream kernel. Here is a checklist of reading and tools related to posting kernel patches: |
Line 41: | Line 91: |
First, login to rookery, and perform these commands. In order to have the git commands in your PATH, you can either install your own version locally in your homedirectory, or use some already there (adding ''/home/bcollins/bin'' to your path should work). Then perform these commands: | * <kernel-directory>/Documentation/SubmittingPatches * <kernel-directory>/scripts/checkpatch.pl * <kernel-directory>/scripts/cleanpatch * <kernel-directory>/scripts/cleanfile * <kernel-directory>/scripts/Lindent If you are creating a new file, it is helpful to run it through ''cleanfile'' and/or ''Linent'' before creating a patch[[BR]] If you have generated a patch, it helps running it through ''checkpatch.pl'' and ''cleanpatch'' if necessary[[BR]] Also, using the commit template described above is a good idea for Ubuntu-specific patches = Developers with access to kernel.ubuntu.com = The kernel team has a ''git'' repo located on ''kernel.ubuntu.com'' (AKA zinc.ubuntu.com) in /srv/kernel.ubuntu.com/git/ubuntu. You can, if you want, create a clone for yourself in your directory, and just have your changes pulled when ready. Suggested way to do this: |
Line 43: | Line 109: |
mkdir public_html/archives cd public_html/archives git clone -s -n -l /home/bcollins/public_html/archives/ubuntu-2.6.git ubuntu-2.6 mv ubuntu-2.6/.git ubuntu-2.6.git rmdir ubuntu-2.6 |
git-clone -l -n -s /srv/kernel.ubuntu.com/git/ubuntu/ubuntu-gutsy.git vi ubuntu-gutsy/.git/description ( give it a descriptive name ) mv ubuntu-gutsy/.git /srv/kernel.ubuntu.com/git/<user>/my-git-tree.git |
Line 50: | Line 115: |
This will create ~/public_html/archives/ubuntu-2.6.git. Note, this is not used for your to pull from (since you should always pull from rsync.kernel.org). However, you can let others pull from this repo if you have things you want them to test. The ''-s'' flag allows your repo to share objects with the main one. This helps reduce space used on rookery. | You can now push your changes to this tree via '''ssh'''. Note the '''-l -n -s''' options do a few special things, mainly making your repo share objects with ours (saves space). |
Line 52: | Line 117: |
To push your repo to your rookery clone, do: | Suggest method for keeping this tree synced with the ubuntu tree, instead of git-pull, is to do: |
Line 54: | Line 120: |
git push ssh://rookery.ubuntu.com/home/<yourname>/public_html/archives/ubuntu-2.6.git | cd my-tree git-fetch origin git-rebase origin |
Line 57: | Line 125: |
You must email the [mailto:kernel-team@lists.ubuntu.com kernel-team] mailing list with your username, in order to be added to the list of repo's to pull into the main repo. Any work you do in the master (HEAD) will '''automatically''' be merged into the main repo. Any work that you perform that you wish to keep locally, should be done on a branch. |
This will keep your changes on top of the original tree (as opposed to being merged). This is also a good idea because during development (e.g. while following the upstream git repo), we frequently rebase to linux-2.6.git upstream, so the '''HEAD''' is not always suitable for pull/merge. |
Line 62: | Line 128: |
Please read the documentation included with the git source for more details on git commands. | Please read the documentation included with the '''git-core''' package for more details on git commands. |
Summary
Git is the new SCM used by the Linux kernel developers. Ubuntu has adopted this tool for our own Linux kernel source code so that we can interact better with the community and the other kernel developers.
Where is it?
Current GIT Trees
- gutsy: git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git
- feisty: git://kernel.ubuntu.com/ubuntu/ubuntu-feisty.git
- edgy: git://kernel.ubuntu.com/ubuntu/ubuntu-edgy.git
- dapper: git://kernel.ubuntu.com/ubuntu/ubuntu-dapper.git
(actually there are a few more and of special note are the -updates git trees. To find out what else is available try browsing http://kernel.ubuntu.com/git and searching for ubuntu)
Getting GIT
To obtain the git binaries, simply install the git-core package from dapper, e.g.:
sudo apt-get install git-core
Note that the git package is an entirely different tool which will not do what you want.
Getting the Ubuntu Linux kernel repo
The Ubuntu Linux kernel git repository is located at git://kernel.ubuntu.com/ubuntu/ubuntu-<release>.git. To download a local copy of the repo, use this command:
git clone git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git ubuntu-gutsy
This will take some time depending on your connection. There's around 220 MiB of data to download currently (and this always increases).
Once this is complete, you can keep your tree up-to-date by running this command:
git pull
** Warning ** During development, the kernel git repository is being constantly rebased against Linus' tree. IOW, Ubuntu specific changes are not being merged, but rather popped off, the tree rebased and then pushed on to keep them on top. This will cause git pull to fail. Hence, there are two ways to track the kernel git tree, depending on whether you have local changes or not.
No Local Changes
git fetch -f origin git checkout origin git branch -f master origin git checkout master
Preserve Local Changes
# Save away local commits git log origin..HEAD | grep ^commit | awk '{print $2}' | tac > local-commits git branch new-head git checkout new-head # This will stop on first error. Cleaning up failures is an excercize for the user for cmt in `cat local-commits`; do git-cherry-pick $cmt || exit; done git branch -f master new-head git checkout master git branch -D new-head
Pushing changes to the main repo
Since the main repo is not publicly writable, the primary means for sending patches to the kernel team is using git-format-patch. The output from this command can then be sent to the [mailto:kernel-team@lists.ubuntu.com kernel-team] mailing list.
Alternatively, if you have a publicly available git repository for which changes can be pulled from, you can use git-request-pull to generate an email message to send to the [mailto:kernel-team@lists.ubuntu.com kernel-team] mailing list.
Commit templates
In debian/commit-templates/ there are several templates that must be used when commiting changes that you expect to be integrated with the Ubuntu kernel repo. The commit templates contain comments for how to fill out the required information. Also note that all commits must have a Signed-off-by line (the "-s" option to git-commit). A typical git-commit command will look like:
git-commit -s -F debian/commit-templates/patch -e
Note that the -e (edit) option must follow the -F option, else git will not let you edit the commit-template before committing.
An example commit log will look like such:
UBUNTU: scsi: My cool change to the scsi subsystem UpstreamStatus: Merged with 2.6.15-rc3 My cool change to the scsi subsystem makes scsi transfers increase magically to 124GiB/sec. Signed-off-by: Joe Cool Hacker <jch@reet.com>
Patch acceptance criteria
In general, Ubuntu will apply the same criteria applicable to upstream kernel. Here is a checklist of reading and tools related to posting kernel patches:
<kernel-directory>/Documentation/SubmittingPatches
<kernel-directory>/scripts/checkpatch.pl
<kernel-directory>/scripts/cleanpatch
<kernel-directory>/scripts/cleanfile
<kernel-directory>/scripts/Lindent
If you are creating a new file, it is helpful to run it through cleanfile and/or Linent before creating a patchBR If you have generated a patch, it helps running it through checkpatch.pl and cleanpatch if necessaryBR Also, using the commit template described above is a good idea for Ubuntu-specific patches
Developers with access to kernel.ubuntu.com
The kernel team has a git repo located on kernel.ubuntu.com (AKA zinc.ubuntu.com) in /srv/kernel.ubuntu.com/git/ubuntu.
You can, if you want, create a clone for yourself in your directory, and just have your changes pulled when ready.
Suggested way to do this:
git-clone -l -n -s /srv/kernel.ubuntu.com/git/ubuntu/ubuntu-gutsy.git vi ubuntu-gutsy/.git/description ( give it a descriptive name ) mv ubuntu-gutsy/.git /srv/kernel.ubuntu.com/git/<user>/my-git-tree.git
You can now push your changes to this tree via ssh. Note the -l -n -s options do a few special things, mainly making your repo share objects with ours (saves space).
Suggest method for keeping this tree synced with the ubuntu tree, instead of git-pull, is to do:
cd my-tree git-fetch origin git-rebase origin
This will keep your changes on top of the original tree (as opposed to being merged). This is also a good idea because during development (e.g. while following the upstream git repo), we frequently rebase to linux-2.6.git upstream, so the HEAD is not always suitable for pull/merge.
More information
Please read the documentation included with the git-core package for more details on git commands.
KernelTeam/KernelGitGuide (last edited 2010-06-28 23:55:41 by c-76-105-148-120)