10ba22f51SPetr Hosek //===-- muldi3.c - Implement __muldi3 -------------------------------------===// 20ba22f51SPetr Hosek // 30ba22f51SPetr Hosek // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 40ba22f51SPetr Hosek // See https://llvm.org/LICENSE.txt for license information. 50ba22f51SPetr Hosek // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 60ba22f51SPetr Hosek // 70ba22f51SPetr Hosek //===----------------------------------------------------------------------===// 80ba22f51SPetr Hosek // 90ba22f51SPetr Hosek // This file implements __muldi3 for the compiler_rt library. 100ba22f51SPetr Hosek // 110ba22f51SPetr Hosek //===----------------------------------------------------------------------===// 12a6b264b5SAlexey Samsonov 13a6b264b5SAlexey Samsonov #include "int_lib.h" 14a6b264b5SAlexey Samsonov 150ba22f51SPetr Hosek // Returns: a * b 16a6b264b5SAlexey Samsonov __muldsi3(su_int a,su_int b)17082b89b2SPetr Hosekstatic di_int __muldsi3(su_int a, su_int b) { 18a6b264b5SAlexey Samsonov dwords r; 19a6b264b5SAlexey Samsonov const int bits_in_word_2 = (int)(sizeof(si_int) * CHAR_BIT) / 2; 20a6b264b5SAlexey Samsonov const su_int lower_mask = (su_int)~0 >> bits_in_word_2; 21a6b264b5SAlexey Samsonov r.s.low = (a & lower_mask) * (b & lower_mask); 22a6b264b5SAlexey Samsonov su_int t = r.s.low >> bits_in_word_2; 23a6b264b5SAlexey Samsonov r.s.low &= lower_mask; 24a6b264b5SAlexey Samsonov t += (a >> bits_in_word_2) * (b & lower_mask); 25a6b264b5SAlexey Samsonov r.s.low += (t & lower_mask) << bits_in_word_2; 26a6b264b5SAlexey Samsonov r.s.high = t >> bits_in_word_2; 27a6b264b5SAlexey Samsonov t = r.s.low >> bits_in_word_2; 28a6b264b5SAlexey Samsonov r.s.low &= lower_mask; 29a6b264b5SAlexey Samsonov t += (b >> bits_in_word_2) * (a & lower_mask); 30a6b264b5SAlexey Samsonov r.s.low += (t & lower_mask) << bits_in_word_2; 31a6b264b5SAlexey Samsonov r.s.high += t >> bits_in_word_2; 32a6b264b5SAlexey Samsonov r.s.high += (a >> bits_in_word_2) * (b >> bits_in_word_2); 33a6b264b5SAlexey Samsonov return r.all; 34a6b264b5SAlexey Samsonov } 35a6b264b5SAlexey Samsonov 360ba22f51SPetr Hosek // Returns: a * b 37a6b264b5SAlexey Samsonov __muldi3(di_int a,di_int b)38082b89b2SPetr HosekCOMPILER_RT_ABI di_int __muldi3(di_int a, di_int b) { 39a6b264b5SAlexey Samsonov dwords x; 40a6b264b5SAlexey Samsonov x.all = a; 41a6b264b5SAlexey Samsonov dwords y; 42a6b264b5SAlexey Samsonov y.all = b; 43a6b264b5SAlexey Samsonov dwords r; 44a6b264b5SAlexey Samsonov r.all = __muldsi3(x.s.low, y.s.low); 45a6b264b5SAlexey Samsonov r.s.high += x.s.high * y.s.low + x.s.low * y.s.high; 46a6b264b5SAlexey Samsonov return r.all; 47a6b264b5SAlexey Samsonov } 4836ac5ddfSSaleem Abdulrasool 4936ac5ddfSSaleem Abdulrasool #if defined(__ARM_EABI__) 50*84da0e1bSPetr Hosek COMPILER_RT_ALIAS(__muldi3, __aeabi_lmul) 5136ac5ddfSSaleem Abdulrasool #endif 52