123456789101112131415161718192021222324252627282930313233343536373839 |
- /*
- * Copyright 2007 Analog Devices Inc.
- *
- * Licensed under the Clear BSD license or the GPL-2 (or later)
- */
- .align 2
- .global ___smulsi3_highpart;
- .type ___smulsi3_highpart, STT_FUNC;
- #ifdef CONFIG_ARITHMETIC_OPS_L1
- .section .l1.text
- #else
- .text
- #endif
- ___smulsi3_highpart:
- R2 = R1.L * R0.L (FU);
- R3 = R1.H * R0.L (IS,M);
- R0 = R0.H * R1.H, R1 = R0.H * R1.L (IS,M);
- R1.L = R2.H + R1.L;
- cc = ac0;
- R2 = cc;
- R1.L = R1.L + R3.L;
- cc = ac0;
- R1 >>>= 16;
- R3 >>>= 16;
- R1 = R1 + R3;
- R1 = R1 + R2;
- R2 = cc;
- R1 = R1 + R2;
- R0 = R0 + R1;
- RTS;
- .size ___smulsi3_highpart, .-___smulsi3_highpart
|