blob: a867318b8a50b150a1d3a4026c6d3f7fd43f227a [file] [log] [blame]
plarsfea599e2003-02-27 16:53:21 +00001/*
2 *
3 * Copyright (c) International Business Machines Corp., 2003
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
13 * the GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 */
19
20/*
21 *
22 * AUTHOR
23 * Paul Larson <plars@linuxtestproject.org>
24 *
25 * DESCRIPTION
26 * Compare a given kernel version against the current kernel version.
27 * If they are the same - return 0
28 * If the argument is > current kernel version - return positive int
29 * If the argument is < current kernel version - return negative int
30 *
31 */
32
33
robbiew88e7b182003-03-13 19:00:13 +000034#include <stdlib.h>
plarsfea599e2003-02-27 16:53:21 +000035#include <unistd.h>
36#include <string.h>
37#include <sys/utsname.h>
38
39void get_kver(int *k1, int *k2, int *k3)
40{
41 struct utsname uval;
42 char *kver;
43 char *r1, *r2, *r3;
mridgee6508f82005-01-04 21:00:17 +000044 extern char *strsep(); /* shut up some compilers */
45
plarsfea599e2003-02-27 16:53:21 +000046 uname(&uval);
47 kver = uval.release;
48 r1 = strsep(&kver, ".");
49 r2 = strsep(&kver, ".");
50 r3 = strsep(&kver, ".");
51
52 *k1 = atoi(r1);
53 *k2 = atoi(r2);
54 *k3 = atoi(r3);
55}
56
plars255c3522003-03-03 21:40:43 +000057int tst_kvercmp(int r1, int r2, int r3) {
plarsfea599e2003-02-27 16:53:21 +000058 int a1, a2, a3;
59 int testver, currver;
60
61 get_kver(&a1, &a2, &a3);
62 testver = (r1 << 16) + (r2 << 8) + r3;
63 currver = (a1 << 16) + (a2 << 8) + a3;
64
plars878713c2003-03-03 22:02:07 +000065 return currver - testver;
plarsfea599e2003-02-27 16:53:21 +000066}