GitKernelBuild

Differences between revisions 2 and 13 (spanning 11 versions)
Revision 2 as of 2007-12-13 21:33:53
Size: 5347
Editor: c-67-160-148-53
Comment:
Revision 13 as of 2008-03-14 20:07:17
Size: 3531
Editor: sites
Comment: no sudo, add parallel option example
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
||<tablestyle="float:right; font-size: 0.9em; width:40%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;">'''Contents'''[[BR]][[TableOfContents]]||
Line 3: Line 5:
The following document should help users build their own kernel from the upstream mainline kernel to help verify if a bug still exists or not. If a bug is still present in the upstream kernel, it is encouraged that the bug be reported to http://bugzilla.kernel.org . The bug submission process for http://bugzilla.kernel.org will be outlined at the end of the document. Please note that the following steps are targeted towards Ubuntu users and will focus on building the mainline kernel from the git repository at http://git.kernel.org . The following document should help users build their own kernel from the upstream mainline kernel to help verify if a bug still exists or not. If a bug is still present in the upstream kernel, it is encouraged that the bug be reported to http://bugzilla.kernel.org . The bug submission process for http://bugzilla.kernel.org is outlined at the end of the document. Please note that the following steps are targeted towards Ubuntu users and focuses on building the mainline kernel from the git repository at http://git.kernel.org .
Line 7: Line 9:
There are a few tools that are necessary in order to build your own kernel(s). The 'git-core' package provides the git revision control system which will be used to clone the mainline git repository. The 'kernel-package' provides the make-kpkg utility which automatically build your kernel and generate the linux-image and linux-header .deb files which will get installed. Please install both of these packages. There are a few tools that are necessary in order to build your own kernel(s). The 'git-core' package provides the git revision control system which will be used to clone the mainline git repository. The 'kernel-package' provides the make-kpkg utility which automatically build your kernel and generate the linux-image and linux-header .deb files which can be installed. You will need to install both of these packages.
Line 10: Line 12:
sudo apt-get install git-core kernel-package sudo apt-get install git-core kernel-package fakeroot
Line 14: Line 16:
 1. Change to the directory where you want to clone the git tree. In this example we will use /usr/src
  {{{ cd /usr/src
 1. Change to the directory where you want to clone the git tree. In this example we will use /home/ubuntu
  {{{ cd /home/ubuntu
Line 18: Line 20:
  {{{ sudo git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git   {{{ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
Line 24: Line 26:
  {{{ sudo cp /boot/config-`uname -r`.config .   {{{ cp /boot/config-`uname -r` .config
Line 27: Line 29:
  {{{ sudo make oldconfig   {{{ make oldconfig
Line 30: Line 32:
  {{{ sudo make menuconfig   {{{ make menuconfig
Line 33: Line 35:
  {{{ sudo make-kpkg clean   {{{ make-kpkg clean
Line 35: Line 37:
 1. Build the linux-image and linux-header .deb files.
  {{{ sudo fakeroot make-kpkg --initrd --append-to-version=-custom kernel_image kernel_headers
 1. Build the linux-image and linux-header .deb files (where "N" is how many CPUs to use to build the kernel).
  {{{ MAKEFLAGS="-jN" fakeroot make-kpkg --initrd --append-to-version=-custom kernel_image kernel_headers
Line 41: Line 43:
 1. Now install the .deb files. In this example the files are linux-image-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb and linux-headers-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb and  1. Now install the .deb files. In this example, the files are linux-image-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb and linux-headers-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb. You may receive warnings about '/lib/firmware/2.6.24-rc5-custom/' - this is expected and will only be problematic if the driver you are trying to test requires firmware.
Line 45: Line 47:
 1. You are now ready to boot into your new kernel. Just to make sure you select the new kernel when you boot.  1. You are now ready to boot into your new kernel. Just make sure you select the new kernel when you boot.
Line 50: Line 52:
Unfortunately it is sometimes the case that bugs can still exist in the mainline kernel. The mainline kernel has their own bugtracking system at http://bugzilla.kernel.org . It would be helpful if you would also report your bug there. It is often the case that once a bug is escalated upstream there is a quick resolution through the help and support of the mainline kernel community. Bug reports in Launchpad can also be set up to monitor bugs reported in other bugtracking systems. The following steps should help you report your bug upstream and monitor it in Launchpad:

 1. Go to http://bugzilla.kernel.org
 1. Verify your bug does not already exist in the upstream bugtracking system.
  i. If it does exist, please add any useful information that may be lacking in the current report.
   * Link your Launchpad report to the upstream kernel bug report (see step 5).
  i. If your bug does not exist, proceed to the next step.
 1. Enter your bug report at http://bugzilla.kernel.org/enter_bug.cgi . Follow the instructions on that page.
 1. When creating your bug report be sure to _attach_ any relevant information. This will usually include:
  i. the version of the kernel you are running (uname -r)
  i. dmesg output.
  i. lspci -vvnn output.
  i. If the bug is about interrupts, then /proc/interrupts is also helpful.
  i. If a BIOS issue is suspected, dmidecode output is also helpful.
  i. If the bug is regarding memory oddities, /proc/mtrr info is also helpful.
  i. Most importantly, if this is a regression, the best information you can provide the kernel developers is the information from doing a git bisect. This will hopefully narrow down the exact patch that is causing the regression.
   * http://www.reactivated.net/weblog/archives/2006/01/using-git-bisect-to-find-buggy-kernel-patches/
 1. After you've reported your bug to the kernel bugzilla, remember to set up your Launchpad bug report to monitor the upstream bugzilla report.
  i. On your Launchpad bug report page, look in the "Actions" area on the left hand side of the page.
  i. Click the "Also affects project" link.
  i. Enter the URL of your bugzilla report.
  i. Click the "Add to Bug Report" button.
  i. Your Launchpad report is not monitoring your upstream bugzilla report.
[[Include(KernelTeamBugPolicies, , from="== Reporting Bugs Upstream ==$", to="==")]]

Many times patches for bugs are committed upstream but have yet to make their way down to the Ubuntu kernel. It is often helpful if users are able to verify if the upstream patches do indeed resolve the issue they are witnessing. Likewise, in the opposite situation, it is useful to know if a bug may still exist upstream.

The following document should help users build their own kernel from the upstream mainline kernel to help verify if a bug still exists or not. If a bug is still present in the upstream kernel, it is encouraged that the bug be reported to http://bugzilla.kernel.org . The bug submission process for http://bugzilla.kernel.org is outlined at the end of the document. Please note that the following steps are targeted towards Ubuntu users and focuses on building the mainline kernel from the git repository at http://git.kernel.org .

Prerequisites

There are a few tools that are necessary in order to build your own kernel(s). The 'git-core' package provides the git revision control system which will be used to clone the mainline git repository. The 'kernel-package' provides the make-kpkg utility which automatically build your kernel and generate the linux-image and linux-header .deb files which can be installed. You will need to install both of these packages.

sudo apt-get install git-core kernel-package fakeroot

Kernel Build and Installation

  1. Change to the directory where you want to clone the git tree. In this example we will use /home/ubuntu
    • {{{ cd /home/ubuntu

}}}

  1. Clone the mainline kernel git tree.
    • {{{ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git

}}}

  1. Change to linux-2.6 directory.
    • {{{ cd linux-2.6

}}}

  1. Copy the kernel config file from your existing system to the kernel tree.
    • {{{ cp /boot/config-uname -r .config

}}}

  1. Bring the config file up to date. (Answer any questions that get prompted).
    • {{{ make oldconfig

}}}

  1. (optional) If you need to make any kernel config changes, do the following and save your changes when prompted:
    • {{{ make menuconfig

}}}

  1. Clean the kernel source directory.
    • {{{ make-kpkg clean

}}}

  1. Build the linux-image and linux-header .deb files (where "N" is how many CPUs to use to build the kernel).
    • {{{ MAKEFLAGS="-jN" fakeroot make-kpkg --initrd --append-to-version=-custom kernel_image kernel_headers

}}}

  1. Change to one directory level up (this is where the linux-image and linux-header .deb files were put)
    • {{{ cd ..

}}}

  1. Now install the .deb files. In this example, the files are linux-image-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb and linux-headers-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb. You may receive warnings about '/lib/firmware/2.6.24-rc5-custom/' - this is expected and will only be problematic if the driver you are trying to test requires firmware.
    • {{{ sudo dpkg -i linux-image-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb

sudo dpkg -i linux-headers-2.6.24-rc5-custom_2.6.24-rc5-custom-10.00.Custom_i386.deb }}}

  1. You are now ready to boot into your new kernel. Just make sure you select the new kernel when you boot.
    • {{{ sudo reboot

}}}

Reporting Bugs Upstream

Include(KernelTeamBugPolicies, , from="== Reporting Bugs Upstream ==$", to="==")

KernelTeam/GitKernelBuild (last edited 2025-01-31 23:23:40 by tim-richardson)