1 /* ===-- multi3.c - Implement __multi3 -------------------------------------===
3 * The LLVM Compiler Infrastructure
5 * This file is dual licensed under the MIT and the University of Illinois Open
6 * Source Licenses. See LICENSE.TXT for details.
8 * ===----------------------------------------------------------------------===
10 * This file implements __multi3 for the compiler_rt library.
12 * ===----------------------------------------------------------------------===
23 __mulddi3(du_int a
, du_int b
)
26 const int bits_in_dword_2
= (int)(sizeof(di_int
) * CHAR_BIT
) / 2;
27 const du_int lower_mask
= (du_int
)~0 >> bits_in_dword_2
;
28 r
.s
.low
= (a
& lower_mask
) * (b
& lower_mask
);
29 du_int t
= r
.s
.low
>> bits_in_dword_2
;
30 r
.s
.low
&= lower_mask
;
31 t
+= (a
>> bits_in_dword_2
) * (b
& lower_mask
);
32 r
.s
.low
+= (t
& lower_mask
) << bits_in_dword_2
;
33 r
.s
.high
= t
>> bits_in_dword_2
;
34 t
= r
.s
.low
>> bits_in_dword_2
;
35 r
.s
.low
&= lower_mask
;
36 t
+= (b
>> bits_in_dword_2
) * (a
& lower_mask
);
37 r
.s
.low
+= (t
& lower_mask
) << bits_in_dword_2
;
38 r
.s
.high
+= t
>> bits_in_dword_2
;
39 r
.s
.high
+= (a
>> bits_in_dword_2
) * (b
>> bits_in_dword_2
);
45 COMPILER_RT_ABI ti_int
46 __multi3(ti_int a
, ti_int b
)
53 r
.all
= __mulddi3(x
.s
.low
, y
.s
.low
);
54 r
.s
.high
+= x
.s
.high
* y
.s
.low
+ x
.s
.low
* y
.s
.high
;
58 #endif /* CRT_HAS_128BIT */