GitKernelBuild

Revision 12 as of 2008-01-18 21:38:37

Clear message

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 /usr/src
    • {{{ cd /usr/src

}}}

  1. Clone the mainline kernel git tree.
    • {{{ sudo 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.
    • {{{ sudo cp /boot/config-uname -r .config

}}}

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

}}}

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

}}}

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

}}}

  1. Build the linux-image and linux-header .deb files.
    • {{{ sudo 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="==")