aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390/lib/ucmpdi2.c
diff options
context:
space:
mode:
authorHeiko Carstens <heiko.carstens@de.ibm.com>2009-07-07 10:37:09 -0400
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2009-07-07 10:37:53 -0400
commit5075baca2e95840d76210c3cfda56134007462c9 (patch)
tree0cb0078bdbb4c2760d9846eae6466044ba92a21e /arch/s390/lib/ucmpdi2.c
parent2651fa2bcb1a7b06793441d50dcbf98efda592c6 (diff)
[S390] add __ucmpdi2() helper function
Provide __ucmpdi2() helper function on 31 bit so we don't run again and again in compile errors like this one: kernel/built-in.o: In function `T.689': perf_counter.c:(.text+0x56c86): undefined reference to `__ucmpdi2' Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'arch/s390/lib/ucmpdi2.c')
-rw-r--r--arch/s390/lib/ucmpdi2.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/arch/s390/lib/ucmpdi2.c b/arch/s390/lib/ucmpdi2.c
new file mode 100644
index 000000000000..3e05ff532582
--- /dev/null
+++ b/arch/s390/lib/ucmpdi2.c
@@ -0,0 +1,26 @@
1#include <linux/module.h>
2
3union ull_union {
4 unsigned long long ull;
5 struct {
6 unsigned int high;
7 unsigned int low;
8 } ui;
9};
10
11int __ucmpdi2(unsigned long long a, unsigned long long b)
12{
13 union ull_union au = {.ull = a};
14 union ull_union bu = {.ull = b};
15
16 if (au.ui.high < bu.ui.high)
17 return 0;
18 else if (au.ui.high > bu.ui.high)
19 return 2;
20 if (au.ui.low < bu.ui.low)
21 return 0;
22 else if (au.ui.low > bu.ui.low)
23 return 2;
24 return 1;
25}
26EXPORT_SYMBOL(__ucmpdi2);