# Use the default kernel version if the Makefile doesn't override it
-ifeq ($(LINUX_VERSION),)
- ifeq ($(KERNEL),2.4)
- LINUX_VERSION:=2.4.34
- LINUX_RELEASE:=1
- LINUX_KERNEL_MD5SUM:=f59665540a7f3351ea416a0dad104b55
- else
- LINUX_VERSION:=2.6.21.4
- LINUX_RELEASE:=1
- LINUX_KERNEL_MD5SUM:=c50995d713ba2d73f148e10073342568
- endif
-endif
-KERNEL:=2.$(word 2,$(subst ., ,$(strip $(LINUX_VERSION))))
+ifeq ($(KERNEL),2.4)
+ LINUX_VERSION?=2.4.37.2
+else
+ LINUX_VERSION?=2.6.21.7
+endif
+LINUX_RELEASE?=1
+
+ifeq ($(LINUX_VERSION),2.4.37.2)
+ LINUX_KERNEL_MD5SUM:=8a390c782991a2bfe7d4f2fc93dab059
+endif
+ifeq ($(LINUX_VERSION),2.6.21.7)
+ LINUX_KERNEL_MD5SUM:=bc15fad1487336d5dcb0945cd039d8ed
+endif
+ifeq ($(LINUX_VERSION),2.6.23.17)
+ LINUX_KERNEL_MD5SUM:=a0300a393ac91ce9c64bf31522b45e2e
+endif
+ifeq ($(LINUX_VERSION),2.6.25.20)
+ LINUX_KERNEL_MD5SUM:=0da698edccf03e2235abc2830a495114
+endif
+ifeq ($(LINUX_VERSION),2.6.27.27)
+ LINUX_KERNEL_MD5SUM:=69c2ec59da6fcc0d2dfb4c470a721957
+endif
+ifeq ($(LINUX_VERSION),2.6.28.10)
+ LINUX_KERNEL_MD5SUM:=c4efb2c494d749cb5de274f8ae41c3fa
+endif
+ifeq ($(LINUX_VERSION),2.6.30.2)
+ LINUX_KERNEL_MD5SUM:=890a03483dc9843100c6b51deebfc3bd
+endif
+
+# disable the md5sum check for unknown kernel versions
+LINUX_KERNEL_MD5SUM?=x
+
+split_version=$(subst ., ,$(1))
+merge_version=$(subst $(space),.,$(1))
+KERNEL_BASE=$(firstword $(subst -, ,$(LINUX_VERSION)))
+KERNEL=$(call merge_version,$(wordlist 1,2,$(call split_version,$(KERNEL_BASE))))
+KERNEL_PATCHVER=$(call merge_version,$(wordlist 1,3,$(call split_version,$(KERNEL_BASE))))