summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard@openedhand.com>2006-11-02 10:18:03 +0000
committerRichard Purdie <richard@openedhand.com>2006-11-02 10:18:03 +0000
commit0d59c10f98ee7107b32e23909fd4fe0d7d89b078 (patch)
tree0722d3d2a05746a2be788ce30da00892d2de188e
parent5d6699af12ae61fb4919188c8cd35dbab53d06e2 (diff)
downloadpoky-0d59c10f98ee7107b32e23909fd4fe0d7d89b078.tar.gz
kernel.bbclass: Sync with updates in OE to work with kernels >= 2.6.18
git-svn-id: https://svn.o-hand.com/repos/poky/trunk@851 311d38ba-8fff-0310-9ca6-ca027cbcb966
-rw-r--r--meta/classes/kernel.bbclass30
-rw-r--r--meta/classes/linux-kernel-base.bbclass42
2 files changed, 45 insertions, 27 deletions
diff --git a/meta/classes/kernel.bbclass b/meta/classes/kernel.bbclass
index c81112ede7..3a7fd5b499 100644
--- a/meta/classes/kernel.bbclass
+++ b/meta/classes/kernel.bbclass
@@ -1,4 +1,4 @@
1inherit module_strip 1inherit linux-kernel-base module_strip
2 2
3PROVIDES += "virtual/kernel" 3PROVIDES += "virtual/kernel"
4DEPENDS += "virtual/${TARGET_PREFIX}depmod-${@get_kernelmajorversion('${PV}')} virtual/${TARGET_PREFIX}gcc${KERNEL_CCSUFFIX} update-modules" 4DEPENDS += "virtual/${TARGET_PREFIX}depmod-${@get_kernelmajorversion('${PV}')} virtual/${TARGET_PREFIX}gcc${KERNEL_CCSUFFIX} update-modules"
@@ -10,7 +10,7 @@ PACKAGES_DYNAMIC += "kernel-image-*"
10 10
11export OS = "${TARGET_OS}" 11export OS = "${TARGET_OS}"
12export CROSS_COMPILE = "${TARGET_PREFIX}" 12export CROSS_COMPILE = "${TARGET_PREFIX}"
13KERNEL_IMAGETYPE = "zImage" 13KERNEL_IMAGETYPE ?= "zImage"
14 14
15KERNEL_PRIORITY = "${@bb.data.getVar('PV',d,1).split('-')[0].split('.')[-1]}" 15KERNEL_PRIORITY = "${@bb.data.getVar('PV',d,1).split('-')[0].split('.')[-1]}"
16 16
@@ -43,31 +43,7 @@ KERNEL_IMAGEDEST = "boot"
43# 43#
44export CMDLINE_CONSOLE = "console=${@bb.data.getVar("KERNEL_CONSOLE",d,1) or "ttyS0"}" 44export CMDLINE_CONSOLE = "console=${@bb.data.getVar("KERNEL_CONSOLE",d,1) or "ttyS0"}"
45 45
46# parse kernel ABI version out of <linux/version.h> 46KERNEL_VERSION = "${@get_kernelversion('${S}')}"
47def get_kernelversion(p):
48 import re
49 try:
50 f = open(p, 'r')
51 except IOError:
52 return None
53 l = f.readlines()
54 f.close()
55 r = re.compile("#define UTS_RELEASE \"(.*)\"")
56 for s in l:
57 m = r.match(s)
58 if m:
59 return m.group(1)
60 return None
61
62def get_kernelmajorversion(p):
63 import re
64 r = re.compile("([0-9]+\.[0-9]+).*")
65 m = r.match(p);
66 if m:
67 return m.group(1)
68 return None
69
70KERNEL_VERSION = "${@get_kernelversion('${S}/include/linux/version.h')}"
71KERNEL_MAJOR_VERSION = "${@get_kernelmajorversion('${KERNEL_VERSION}')}" 47KERNEL_MAJOR_VERSION = "${@get_kernelmajorversion('${KERNEL_VERSION}')}"
72 48
73KERNEL_LOCALVERSION ?= "" 49KERNEL_LOCALVERSION ?= ""
diff --git a/meta/classes/linux-kernel-base.bbclass b/meta/classes/linux-kernel-base.bbclass
new file mode 100644
index 0000000000..e58c228080
--- /dev/null
+++ b/meta/classes/linux-kernel-base.bbclass
@@ -0,0 +1,42 @@
1# parse kernel ABI version out of <linux/version.h>
2def get_kernelversion(p):
3 import re, os
4
5 fn = p + '/include/linux/utsrelease.h'
6 if not os.path.isfile(fn):
7 fn = p + '/include/linux/version.h'
8
9 import re
10 try:
11 f = open(fn, 'r')
12 except IOError:
13 return None
14
15 l = f.readlines()
16 f.close()
17 r = re.compile("#define UTS_RELEASE \"(.*)\"")
18 for s in l:
19 m = r.match(s)
20 if m:
21 return m.group(1)
22 return None
23
24def get_kernelmajorversion(p):
25 import re
26 r = re.compile("([0-9]+\.[0-9]+).*")
27 m = r.match(p);
28 if m:
29 return m.group(1)
30 return None
31
32def linux_module_packages(s, d):
33 import bb, os.path
34 suffix = ""
35 if (bb.data.getVar("PARALLEL_INSTALL_MODULES", d, 1) == "1"):
36 file = bb.data.expand('${STAGING_KERNEL_DIR}/kernel-abiversion', d)
37 if (os.path.exists(file)):
38 suffix = "-%s" % (get_kernelmajorversion(base_read_file(file)))
39 return " ".join(map(lambda s: "kernel-module-%s%s" % (s.lower().replace('_', '-').replace('@', '+'), suffix), s.split()))
40
41# that's all
42