diff options
author | Ulrich Müller <ulm@gentoo.org> | 2021-08-28 07:25:48 +0200 |
---|---|---|
committer | Ulrich Müller <ulm@gentoo.org> | 2021-08-30 00:50:57 +0200 |
commit | 6edd821aefef800ad5bb3aeccbc8e4fefe27bd20 (patch) | |
tree | af386cf8bdca989bb863275df5c2611e62f77139 /eclass/linux-info.eclass | |
parent | kernel-2.eclass: Replace bit-shift arithmetic by ver_test (diff) | |
download | gentoo-6edd821aefef800ad5bb3aeccbc8e4fefe27bd20.tar.gz gentoo-6edd821aefef800ad5bb3aeccbc8e4fefe27bd20.tar.bz2 gentoo-6edd821aefef800ad5bb3aeccbc8e4fefe27bd20.zip |
linux-info.eclass: Replace bit-shift arithmetic by ver_test
There are kernel versions like 4.9.280, therefore shifting version
components by 8 bits in kernel_is() may fail.
Signed-off-by: Ulrich Müller <ulm@gentoo.org>
Diffstat (limited to 'eclass/linux-info.eclass')
-rw-r--r-- | eclass/linux-info.eclass | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass index 124fb70e78ad..8edd17c317d4 100644 --- a/eclass/linux-info.eclass +++ b/eclass/linux-info.eclass @@ -395,7 +395,7 @@ kernel_is() { linux-info_get_any_version # Now we can continue - local operator test value + local operator case ${1#-} in lt) operator="-lt"; shift;; @@ -407,9 +407,10 @@ kernel_is() { esac [[ $# -gt 3 ]] && die "Error in kernel-2_kernel_is(): too many parameters" - : $(( test = (KV_MAJOR << 16) + (KV_MINOR << 8) + KV_PATCH )) - : $(( value = (${1:-${KV_MAJOR}} << 16) + (${2:-${KV_MINOR}} << 8) + ${3:-${KV_PATCH}} )) - [ ${test} ${operator} ${value} ] + ver_test \ + "${KV_MAJOR:-0}.${KV_MINOR:-0}.${KV_PATCH:-0}" \ + "${operator}" \ + "${1:-${KV_MAJOR:-0}}.${2:-${KV_MINOR:-0}}.${3:-${KV_PATCH:-0}}" } get_localversion() { |