KernelGitGuide
| Size: 1484 Comment:  | Size: 4392 Comment: Kernel sources gits moved to kernel.ubunt.com | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 4: | Line 4: | 
| = Current GIT Trees = * gutsy: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-gutsy.git * feisty: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-feisty.git * edgy: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-edgy.git * dapper: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-dapper.git (actually there are a few more and of special note are the -updates git trees (nb: there can be more than one -updates tree per stable release). To find out what else is available try browsing http://kernel.org/git/ and searching for ubuntu) ''Comment from GregorRosenauer'': The rsync://-URIs are not mentioned anymore on the official [http://git.kernel.org/ Kernel.org git]-pages, but there are git://-URIs which work perfectly (also on update using "pull"), e.g., for gutsy: * git://git.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-gutsy.git ''Comment from JurrieOvergoor'': It appears that as of Friday 18-05-2007 12:45 the kernel sources for Ubuntu have moved to kernel.ubuntu.com (see [http://git.kernel.org/?p=linux/kernel/git/bcollins/ubuntu.git;a=summary this commit]. New git://-URIs are: * git://kernel.ubuntu.com/ubuntu/ubuntu-dapper.git * git://kernel.ubuntu.com/ubuntu/ubuntu-edgy.git * git://kernel.ubuntu.com/ubuntu/ubuntu-feisty.git * git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git See also [http://kernel.ubuntu.com/git]. | |
| Line 5: | Line 24: | 
| 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 10: | Line 33: | 
| git clone rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-2.6.git ubuntu-2.6 | git clone rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-gutsy.git ubuntu-gutsy | 
| Line 13: | Line 36: | 
| 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 21: | Line 44: | 
| 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. | 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> }}} = Ubuntu kernel developers (with access to rookery) = The kernel team has a private ''git'' repo located on ''rookery'' in /srv/kernel-team. Take care when pushing to this repository. You can, if you want, create a clone for yourself in this directory, and just have your changes pulled when ready. | 
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.
Current GIT Trees
- gutsy: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-gutsy.git
- feisty: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-feisty.git
- edgy: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-edgy.git
- dapper: rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-dapper.git
(actually there are a few more and of special note are the -updates git trees (nb: there can be more than one -updates tree per stable release). To find out what else is available try browsing http://kernel.org/git/ and searching for ubuntu)
Comment from GregorRosenauer: The rsync://-URIs are not mentioned anymore on the official [http://git.kernel.org/ Kernel.org git]-pages, but there are git://-URIs which work perfectly (also on update using "pull"), e.g., for gutsy:
- git://git.kernel.org/pub/scm/linux/kernel/git/bcollins/ubuntu-gutsy.git
Comment from JurrieOvergoor: It appears that as of Friday 18-05-2007 12:45 the kernel sources for Ubuntu have moved to kernel.ubuntu.com (see [http://git.kernel.org/?p=linux/kernel/git/bcollins/ubuntu.git;a=summary this commit]. New git://-URIs are:
- git://kernel.ubuntu.com/ubuntu/ubuntu-dapper.git
- git://kernel.ubuntu.com/ubuntu/ubuntu-edgy.git
- git://kernel.ubuntu.com/ubuntu/ubuntu-feisty.git
- git://kernel.ubuntu.com/ubuntu/ubuntu-gutsy.git
See also [http://kernel.ubuntu.com/git].
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 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:
git clone rsync://rsync.kernel.org/pub/scm/linux/kernel/git/bcollins/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
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>
Ubuntu kernel developers (with access to rookery)
The kernel team has a private git repo located on rookery in /srv/kernel-team. Take care when pushing to this repository.
You can, if you want, create a clone for yourself in this directory, and just have your changes pulled when ready.
More information
Please read the documentation included with the git source for more details on git commands.
KernelTeam/KernelGitGuide (last edited 2010-06-28 23:55:41 by c-76-105-148-120)