xref: /linux/arch/microblaze/lib/mulsi3.S (revision 4d5e3b06e1fc1428be14cd4ebe3b37c1bb34f95d)
1/* SPDX-License-Identifier: GPL-2.0 */
2#include <linux/linkage.h>
3
4/*
5 * Multiply operation for 32 bit integers.
6 *	Input :	Operand1 in Reg r5
7 *		Operand2 in Reg r6
8 *	Output: Result [op1 * op2] in Reg r3
9 */
10	.text
11	.globl	__mulsi3
12	.type __mulsi3,  @function
13	.ent __mulsi3
14
15__mulsi3:
16	.frame	r1, 0, r15
17	add	r3, r0, r0
18	beqi	r5, result_is_zero /* multiply by zero */
19	beqi	r6, result_is_zero /* multiply by zero */
20	bgeid	r5, r5_pos
21	xor	r4, r5, r6 /* get the sign of the result */
22	rsubi	r5, r5, 0 /* make r5 positive */
23r5_pos:
24	bgei	r6, r6_pos
25	rsubi	r6, r6, 0 /* make r6 positive */
26r6_pos:
27	bri	l1
28l2:
29	add	r5, r5, r5
30l1:
31	srl	r6, r6
32	addc	r7, r0, r0
33	beqi	r7, l2
34	bneid	r6, l2
35	add	r3, r3, r5
36	blti	r4, negateresult
37	rtsd	r15, 8
38	nop
39negateresult:
40	rtsd	r15, 8
41	rsub	r3, r3, r0
42result_is_zero:
43	rtsd	r15, 8
44	addi	r3, r0, 0
45
46.size __mulsi3,  . - __mulsi3
47.end __mulsi3
48