xref: /openbmc/u-boot/arch/sh/lib/ashlsi3.S (revision 7e86242b)
1/* SPDX-License-Identifier: GPL-2.0+ */
2/* Copyright (C) 1994, 1995, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
3   2004, 2005, 2006
4   Free Software Foundation, Inc.
5 */
6
7!! libgcc routines for the Renesas / SuperH SH CPUs.
8!! Contributed by Steve Chamberlain.
9!! sac@cygnus.com
10
11!! ashiftrt_r4_x, ___ashrsi3, ___ashlsi3, ___lshrsi3 routines
12!! recoded in assembly by Toshiyasu Morita
13!! tm@netcom.com
14
15/* SH2 optimizations for ___ashrsi3, ___ashlsi3, ___lshrsi3 and
16   ELF local label prefixes by J"orn Rennecke
17   amylaar@cygnus.com  */
18
19!
20! GLOBAL(ashlsi3)
21!
22! Entry:
23!
24! r4: Value to shift
25! r5: Shifts
26!
27! Exit:
28!
29! r0: Result
30!
31! Destroys:
32!
33! (none)
34!
35	.global	__ashlsi3
36	.align	2
37__ashlsi3:
38	mov	#31,r0
39	and	r0,r5
40	mova	__ashlsi3_table,r0
41	mov.b	@(r0,r5),r5
42#ifdef __sh1__
43	add	r5,r0
44	jmp	@r0
45#else
46	braf	r5
47#endif
48	mov	r4,r0
49
50	.align	2
51__ashlsi3_table:
52	.byte		__ashlsi3_0-__ashlsi3_table
53	.byte		__ashlsi3_1-__ashlsi3_table
54	.byte		__ashlsi3_2-__ashlsi3_table
55	.byte		__ashlsi3_3-__ashlsi3_table
56	.byte		__ashlsi3_4-__ashlsi3_table
57	.byte		__ashlsi3_5-__ashlsi3_table
58	.byte		__ashlsi3_6-__ashlsi3_table
59	.byte		__ashlsi3_7-__ashlsi3_table
60	.byte		__ashlsi3_8-__ashlsi3_table
61	.byte		__ashlsi3_9-__ashlsi3_table
62	.byte		__ashlsi3_10-__ashlsi3_table
63	.byte		__ashlsi3_11-__ashlsi3_table
64	.byte		__ashlsi3_12-__ashlsi3_table
65	.byte		__ashlsi3_13-__ashlsi3_table
66	.byte		__ashlsi3_14-__ashlsi3_table
67	.byte		__ashlsi3_15-__ashlsi3_table
68	.byte		__ashlsi3_16-__ashlsi3_table
69	.byte		__ashlsi3_17-__ashlsi3_table
70	.byte		__ashlsi3_18-__ashlsi3_table
71	.byte		__ashlsi3_19-__ashlsi3_table
72	.byte		__ashlsi3_20-__ashlsi3_table
73	.byte		__ashlsi3_21-__ashlsi3_table
74	.byte		__ashlsi3_22-__ashlsi3_table
75	.byte		__ashlsi3_23-__ashlsi3_table
76	.byte		__ashlsi3_24-__ashlsi3_table
77	.byte		__ashlsi3_25-__ashlsi3_table
78	.byte		__ashlsi3_26-__ashlsi3_table
79	.byte		__ashlsi3_27-__ashlsi3_table
80	.byte		__ashlsi3_28-__ashlsi3_table
81	.byte		__ashlsi3_29-__ashlsi3_table
82	.byte		__ashlsi3_30-__ashlsi3_table
83	.byte		__ashlsi3_31-__ashlsi3_table
84
85__ashlsi3_6:
86	shll2	r0
87__ashlsi3_4:
88	shll2	r0
89__ashlsi3_2:
90	rts
91	shll2	r0
92
93__ashlsi3_7:
94	shll2	r0
95__ashlsi3_5:
96	shll2	r0
97__ashlsi3_3:
98	shll2	r0
99__ashlsi3_1:
100	rts
101	shll	r0
102
103__ashlsi3_14:
104	shll2	r0
105__ashlsi3_12:
106	shll2	r0
107__ashlsi3_10:
108	shll2	r0
109__ashlsi3_8:
110	rts
111	shll8	r0
112
113__ashlsi3_15:
114	shll2	r0
115__ashlsi3_13:
116	shll2	r0
117__ashlsi3_11:
118	shll2	r0
119__ashlsi3_9:
120	shll8	r0
121	rts
122	shll	r0
123
124__ashlsi3_22:
125	shll2	r0
126__ashlsi3_20:
127	shll2	r0
128__ashlsi3_18:
129	shll2	r0
130__ashlsi3_16:
131	rts
132	shll16	r0
133
134__ashlsi3_23:
135	shll2	r0
136__ashlsi3_21:
137	shll2	r0
138__ashlsi3_19:
139	shll2	r0
140__ashlsi3_17:
141	shll16	r0
142	rts
143	shll	r0
144
145__ashlsi3_30:
146	shll2	r0
147__ashlsi3_28:
148	shll2	r0
149__ashlsi3_26:
150	shll2	r0
151__ashlsi3_24:
152	shll16	r0
153	rts
154	shll8	r0
155
156__ashlsi3_31:
157	shll2	r0
158__ashlsi3_29:
159	shll2	r0
160__ashlsi3_27:
161	shll2	r0
162__ashlsi3_25:
163	shll16	r0
164	shll8	r0
165	rts
166	shll	r0
167
168__ashlsi3_0:
169	rts
170	nop
171