summaryrefslogtreecommitdiffstats
path: root/arch/metag/lib/ashrdi3.S
blob: 7cb7ed3bb1ad6f422e687641e5f50274141caa1f (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
! Copyright (C) 2012 by Imagination Technologies Ltd.
!
! 64-bit arithmetic shift right routine.
!

	.text
	.global ___ashrdi3
	.type   ___ashrdi3,function

___ashrdi3:
	MOV     D0Re0,D0Ar2
	MOV     D1Re0,D1Ar1
	CMP     D1Ar3,#0                ! COUNT == 0
	MOVEQ   PC,D1RtP                ! Yes, return

	MOV     D0Ar4,D1Ar3
	SUBS    D1Ar3,D1Ar3,#32         ! N = COUNT - 32
	BGE     $L20

!! Shift < 32
	NEG     D1Ar3,D1Ar3             ! N = - N
	LSR     D0Re0,D0Re0,D0Ar4       ! LO = LO >> COUNT
	LSL     D0Ar6,D1Re0,D1Ar3       ! TMP= HI << -(COUNT - 32)
	OR      D0Re0,D0Re0,D0Ar6       ! LO = LO | TMP
	SWAP    D1Ar3,D0Ar4
	ASR     D1Re0,D1Re0,D1Ar3       ! HI = HI >> COUNT
	MOV     PC,D1RtP
$L20:
!! Shift >= 32
	ASR     D0Re0,D1Re0,D1Ar3       ! LO = HI >> N
	ASR     D1Re0,D1Re0,#31         ! HI = HI >> 31
	MOV     PC,D1RtP
	.size ___ashrdi3,.-___ashrdi3