/* SPDX-License-Identifier: GPL-2.0 */ #include <linux/linkage.h> /* * Multiply operation for 32 bit integers. * Input : Operand1 in Reg r5 * Operand2 in Reg r6 * Output: Result [op1 * op2] in Reg r3 */ .text .globl __mulsi3 .type __mulsi3, @function .ent __mulsi3 __mulsi3: .frame r1, 0, r15 add r3, r0, r0 beqi r5, result_is_zero /* multiply by zero */ beqi r6, result_is_zero /* multiply by zero */ bgeid r5, r5_pos xor r4, r5, r6 /* get the sign of the result */ rsubi r5, r5, 0 /* make r5 positive */ r5_pos: bgei r6, r6_pos rsubi r6, r6, 0 /* make r6 positive */ r6_pos: bri l1 l2: add r5, r5, r5 l1: srl r6, r6 addc r7, r0, r0 beqi r7, l2 bneid r6, l2 add r3, r3, r5 blti r4, negateresult rtsd r15, 8 nop negateresult: rtsd r15, 8 rsub r3, r3, r0 result_is_zero: rtsd r15, 8 addi r3, r0, 0 .size __mulsi3, . - __mulsi3 .end __mulsi3