.. | .. |
---|
7 | 7 | set -e |
---|
8 | 8 | |
---|
9 | 9 | is_enabled() { |
---|
10 | | - grep -q "^CONFIG_$1=y" $KCONFIG_CONFIG |
---|
| 10 | + grep -q "^$1=y" include/config/auto.conf |
---|
11 | 11 | } |
---|
12 | 12 | |
---|
13 | 13 | if_enabled_echo() { |
---|
.. | .. |
---|
31 | 31 | x86_64) |
---|
32 | 32 | debarch=amd64 ;; |
---|
33 | 33 | sparc*) |
---|
34 | | - debarch=sparc$(if_enabled_echo 64BIT 64) ;; |
---|
| 34 | + debarch=sparc$(if_enabled_echo CONFIG_64BIT 64) ;; |
---|
35 | 35 | s390*) |
---|
36 | 36 | debarch=s390x ;; |
---|
37 | 37 | ppc*) |
---|
38 | | - if is_enabled 64BIT; then |
---|
39 | | - debarch=ppc64$(if_enabled_echo CPU_LITTLE_ENDIAN el) |
---|
| 38 | + if is_enabled CONFIG_64BIT; then |
---|
| 39 | + debarch=ppc64$(if_enabled_echo CONFIG_CPU_LITTLE_ENDIAN el) |
---|
40 | 40 | else |
---|
41 | | - debarch=powerpc$(if_enabled_echo SPE spe) |
---|
| 41 | + debarch=powerpc$(if_enabled_echo CONFIG_SPE spe) |
---|
42 | 42 | fi |
---|
43 | 43 | ;; |
---|
44 | 44 | parisc*) |
---|
45 | 45 | debarch=hppa ;; |
---|
46 | 46 | mips*) |
---|
47 | | - if is_enabled CPU_LITTLE_ENDIAN; then |
---|
48 | | - debarch=mips$(if_enabled_echo 64BIT 64)$(if_enabled_echo CPU_MIPSR6 r6)el |
---|
49 | | - elif is_enabled CPU_MIPSR6; then |
---|
50 | | - debarch=mips$(if_enabled_echo 64BIT 64)r6 |
---|
| 47 | + if is_enabled CONFIG_CPU_LITTLE_ENDIAN; then |
---|
| 48 | + debarch=mips$(if_enabled_echo CONFIG_64BIT 64)$(if_enabled_echo CONFIG_CPU_MIPSR6 r6)el |
---|
| 49 | + elif is_enabled CONFIG_CPU_MIPSR6; then |
---|
| 50 | + debarch=mips$(if_enabled_echo CONFIG_64BIT 64)r6 |
---|
51 | 51 | else |
---|
52 | 52 | debarch=mips |
---|
53 | 53 | fi |
---|
.. | .. |
---|
55 | 55 | aarch64|arm64) |
---|
56 | 56 | debarch=arm64 ;; |
---|
57 | 57 | arm*) |
---|
58 | | - if is_enabled AEABI; then |
---|
59 | | - debarch=arm$(if_enabled_echo VFP hf el) |
---|
| 58 | + if is_enabled CONFIG_AEABI; then |
---|
| 59 | + debarch=arm$(if_enabled_echo CONFIG_VFP hf el) |
---|
60 | 60 | else |
---|
61 | 61 | debarch=arm |
---|
62 | 62 | fi |
---|
.. | .. |
---|
64 | 64 | openrisc) |
---|
65 | 65 | debarch=or1k ;; |
---|
66 | 66 | sh) |
---|
67 | | - if is_enabled CPU_SH3; then |
---|
68 | | - debarch=sh3$(if_enabled_echo CPU_BIG_ENDIAN eb) |
---|
69 | | - elif is_enabled CPU_SH4; then |
---|
70 | | - debarch=sh4$(if_enabled_echo CPU_BIG_ENDIAN eb) |
---|
| 67 | + if is_enabled CONFIG_CPU_SH3; then |
---|
| 68 | + debarch=sh3$(if_enabled_echo CONFIG_CPU_BIG_ENDIAN eb) |
---|
| 69 | + elif is_enabled CONFIG_CPU_SH4; then |
---|
| 70 | + debarch=sh4$(if_enabled_echo CONFIG_CPU_BIG_ENDIAN eb) |
---|
71 | 71 | fi |
---|
72 | 72 | ;; |
---|
73 | 73 | esac |
---|
.. | .. |
---|
94 | 94 | packageversion=$version-$revision |
---|
95 | 95 | fi |
---|
96 | 96 | sourcename=$KDEB_SOURCENAME |
---|
97 | | -packagename=linux-image-$version |
---|
98 | | -kernel_headers_packagename=linux-headers-$version |
---|
99 | | -dbg_packagename=$packagename-dbg |
---|
100 | | -debarch= |
---|
101 | | -set_debarch |
---|
102 | 97 | |
---|
103 | 98 | if [ "$ARCH" = "um" ] ; then |
---|
104 | | - packagename=user-mode-linux-$version |
---|
| 99 | + packagename=user-mode-linux |
---|
| 100 | +else |
---|
| 101 | + packagename=linux-image |
---|
105 | 102 | fi |
---|
| 103 | + |
---|
| 104 | +debarch= |
---|
| 105 | +set_debarch |
---|
106 | 106 | |
---|
107 | 107 | email=${DEBEMAIL-$EMAIL} |
---|
108 | 108 | |
---|
.. | .. |
---|
132 | 132 | echo >&2 "Install lsb-release or set \$KDEB_CHANGELOG_DIST explicitly" |
---|
133 | 133 | fi |
---|
134 | 134 | |
---|
135 | | -mkdir -p debian/ |
---|
| 135 | +mkdir -p debian/source/ |
---|
| 136 | +echo "1.0" > debian/source/format |
---|
| 137 | + |
---|
136 | 138 | echo $debarch > debian/arch |
---|
| 139 | +extra_build_depends=", $(if_enabled_echo CONFIG_UNWINDER_ORC libelf-dev:native)" |
---|
| 140 | +extra_build_depends="$extra_build_depends, $(if_enabled_echo CONFIG_SYSTEM_TRUSTED_KEYRING libssl-dev:native)" |
---|
137 | 141 | |
---|
138 | 142 | # Generate a simple changelog template |
---|
139 | 143 | cat <<EOF > debian/changelog |
---|
.. | .. |
---|
170 | 174 | Section: kernel |
---|
171 | 175 | Priority: optional |
---|
172 | 176 | Maintainer: $maintainer |
---|
173 | | -Build-Depends: bc, kmod, cpio |
---|
174 | | -Homepage: http://www.kernel.org/ |
---|
| 177 | +Rules-Requires-Root: no |
---|
| 178 | +Build-Depends: bc, rsync, kmod, cpio, bison, flex | flex:native $extra_build_depends |
---|
| 179 | +Homepage: https://www.kernel.org/ |
---|
175 | 180 | |
---|
176 | | -Package: $packagename |
---|
| 181 | +Package: $packagename-$version |
---|
177 | 182 | Architecture: $debarch |
---|
178 | 183 | Description: Linux kernel, version $version |
---|
179 | 184 | This package contains the Linux kernel, modules and corresponding other |
---|
180 | 185 | files, version: $version. |
---|
181 | | - |
---|
182 | | -Package: $kernel_headers_packagename |
---|
183 | | -Architecture: $debarch |
---|
184 | | -Description: Linux kernel headers for $version on $debarch |
---|
185 | | - This package provides kernel header files for $version on $debarch |
---|
186 | | - . |
---|
187 | | - This is useful for people who need to build external modules |
---|
188 | 186 | |
---|
189 | 187 | Package: linux-libc-dev |
---|
190 | 188 | Section: devel |
---|
.. | .. |
---|
193 | 191 | Description: Linux support headers for userspace development |
---|
194 | 192 | This package provides userspaces headers from the Linux kernel. These headers |
---|
195 | 193 | are used by the installed headers for GNU glibc and other system libraries. |
---|
| 194 | +Multi-Arch: same |
---|
| 195 | +EOF |
---|
196 | 196 | |
---|
197 | | -Package: $dbg_packagename |
---|
| 197 | +if is_enabled CONFIG_MODULES; then |
---|
| 198 | +cat <<EOF >> debian/control |
---|
| 199 | + |
---|
| 200 | +Package: linux-headers-$version |
---|
| 201 | +Architecture: $debarch |
---|
| 202 | +Description: Linux kernel headers for $version on $debarch |
---|
| 203 | + This package provides kernel header files for $version on $debarch |
---|
| 204 | + . |
---|
| 205 | + This is useful for people who need to build external modules |
---|
| 206 | +EOF |
---|
| 207 | +fi |
---|
| 208 | + |
---|
| 209 | +if is_enabled CONFIG_DEBUG_INFO; then |
---|
| 210 | +cat <<EOF >> debian/control |
---|
| 211 | + |
---|
| 212 | +Package: linux-image-$version-dbg |
---|
198 | 213 | Section: debug |
---|
199 | 214 | Architecture: $debarch |
---|
200 | 215 | Description: Linux kernel debugging symbols for $version |
---|
201 | 216 | This package will come in handy if you need to debug the kernel. It provides |
---|
202 | 217 | all the necessary debug symbols for the kernel and its modules. |
---|
203 | 218 | EOF |
---|
| 219 | +fi |
---|
204 | 220 | |
---|
205 | 221 | cat <<EOF > debian/rules |
---|
206 | 222 | #!$(command -v $MAKE) -f |
---|
207 | 223 | |
---|
208 | | -build: |
---|
209 | | - \$(MAKE) KERNELRELEASE=${version} ARCH=${ARCH} \ |
---|
210 | | - KBUILD_BUILD_VERSION=${revision} KBUILD_SRC= |
---|
| 224 | +srctree ?= . |
---|
211 | 225 | |
---|
212 | | -binary-arch: |
---|
| 226 | +build-indep: |
---|
| 227 | +build-arch: |
---|
213 | 228 | \$(MAKE) KERNELRELEASE=${version} ARCH=${ARCH} \ |
---|
214 | | - KBUILD_BUILD_VERSION=${revision} KBUILD_SRC= intdeb-pkg |
---|
| 229 | + KBUILD_BUILD_VERSION=${revision} -f \$(srctree)/Makefile |
---|
| 230 | + |
---|
| 231 | +build: build-arch |
---|
| 232 | + |
---|
| 233 | +binary-indep: |
---|
| 234 | +binary-arch: build-arch |
---|
| 235 | + \$(MAKE) KERNELRELEASE=${version} ARCH=${ARCH} \ |
---|
| 236 | + KBUILD_BUILD_VERSION=${revision} -f \$(srctree)/Makefile intdeb-pkg |
---|
215 | 237 | |
---|
216 | 238 | clean: |
---|
217 | 239 | rm -rf debian/*tmp debian/files |
---|
.. | .. |
---|
219 | 241 | |
---|
220 | 242 | binary: binary-arch |
---|
221 | 243 | EOF |
---|
| 244 | +chmod +x debian/rules |
---|
222 | 245 | |
---|
223 | 246 | exit 0 |
---|