aboutsummaryrefslogtreecommitdiff
path: root/arch/frv/lib/__ucmpdi2.S
blob: d892f16ffaa921d1d84b2684fa3194097ca820ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* __ucmpdi2.S: 64-bit unsigned compare
 *
 * Copyright (C) 2006 Red Hat, Inc. All Rights Reserved.
 * Written by David Howells (dhowells@redhat.com)
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version
 * 2 of the License, or (at your option) any later version.
 */


        .text
        .p2align	4

###############################################################################
#
# int __ucmpdi2(unsigned long long a [GR8:GR9],
#		unsigned long long b [GR10:GR11])
#
# - returns 0, 1, or 2 as a <, =, > b respectively.
#
###############################################################################
        .globl		__ucmpdi2
        .type		__ucmpdi2,@function
__ucmpdi2:
	or.p		gr8,gr0,gr4
	subcc		gr8,gr10,gr0,icc0
	setlos.p	#0,gr8
	bclr		icc0,#2			; a.msw < b.msw

	setlos.p	#2,gr8
	bhilr		icc0,#0			; a.msw > b.msw

	subcc.p		gr9,gr11,gr0,icc1
	setlos		#0,gr8
	setlos.p	#2,gr9
	setlos		#1,gr7
	cknc		icc1,cc6
	cor.p		gr9,gr0,gr8,		cc6,#1
	cckls		icc1,cc4,		cc6,#1
	andcr		cc6,cc4,cc4
	cor		gr7,gr0,gr8,		cc4,#1
	bralr
	.size		__ucmpdi2, .-__ucmpdi2