/openbmc/linux/include/linux/ |
H A D | math64.h | 17 * @dividend: unsigned 64bit dividend 21 * Return: sets ``*remainder``, then returns dividend / divisor 26 static inline u64 div_u64_rem(u64 dividend, u32 divisor, u32 *remainder) in div_u64_rem() argument 28 *remainder = dividend % divisor; in div_u64_rem() 29 return dividend / divisor; in div_u64_rem() 34 * @dividend: signed 64bit dividend 38 * Return: sets ``*remainder``, then returns dividend / divisor 40 static inline s64 div_s64_rem(s64 dividend, s32 divisor, s32 *remainder) in div_s64_rem() argument 42 *remainder = dividend % divisor; in div_s64_rem() 43 return dividend / divisor; in div_s64_rem() [all …]
|
/openbmc/linux/arch/arm/lib/ |
H A D | lib1funcs.S | 40 .macro ARM_DIV_BODY dividend, divisor, result, curbit 45 clz \result, \dividend 66 @ larger than the dividend. 68 cmplo \divisor, \dividend 76 cmplo \divisor, \dividend 86 1: cmp \dividend, \divisor 87 subhs \dividend, \dividend, \divisor 89 cmp \dividend, \divisor, lsr #1 90 subhs \dividend, \dividend, \divisor, lsr #1 92 cmp \dividend, \divisor, lsr #2 [all …]
|
H A D | div64.S | 5 * Optimized computation of 64-bit dividend / 32-bit divisor 29 * __do_div64: perform a division with 64-bit dividend and 32-bit divisor. 35 * xh-xl = dividend (clobbered) 59 @ Align divisor with upper part of dividend. 85 @ Break out early if dividend reaches 0.
|
/openbmc/u-boot/arch/arm/lib/ |
H A D | lib1funcs.S | 26 .macro ARM_DIV_BODY dividend, divisor, result, curbit 31 clz \result, \dividend 52 @ larger than the dividend. 54 cmplo \divisor, \dividend 62 cmplo \divisor, \dividend 72 1: cmp \dividend, \divisor 73 subhs \dividend, \dividend, \divisor 75 cmp \dividend, \divisor, lsr #1 76 subhs \dividend, \dividend, \divisor, lsr #1 78 cmp \dividend, \divisor, lsr #2 [all …]
|
H A D | div64.S | 5 * Optimized computation of 64-bit dividend / 32-bit divisor 31 * __do_div64: perform a division with 64-bit dividend and 32-bit divisor. 37 * xh-xl = dividend (clobbered) 62 @ Align divisor with upper part of dividend. 88 @ Break out early if dividend reaches 0.
|
/openbmc/u-boot/include/linux/ |
H A D | math64.h | 19 static inline u64 div_u64_rem(u64 dividend, u32 divisor, u32 *remainder) in div_u64_rem() argument 21 *remainder = dividend % divisor; in div_u64_rem() 22 return dividend / divisor; in div_u64_rem() 28 static inline s64 div_s64_rem(s64 dividend, s32 divisor, s32 *remainder) in div_s64_rem() argument 30 *remainder = dividend % divisor; in div_s64_rem() 31 return dividend / divisor; in div_s64_rem() 37 static inline u64 div64_u64_rem(u64 dividend, u64 divisor, u64 *remainder) in div64_u64_rem() argument 39 *remainder = dividend % divisor; in div64_u64_rem() 40 return dividend / divisor; in div64_u64_rem() 46 static inline u64 div64_u64(u64 dividend, u64 divisor) in div64_u64() argument [all …]
|
/openbmc/u-boot/lib/ |
H A D | div64.c | 64 s64 div_s64_rem(s64 dividend, s32 divisor, s32 *remainder) in div_s64_rem() argument 68 if (dividend < 0) { in div_s64_rem() 69 quotient = div_u64_rem(-dividend, abs(divisor), (u32 *)remainder); in div_s64_rem() 74 quotient = div_u64_rem(dividend, abs(divisor), (u32 *)remainder); in div_s64_rem() 85 * @dividend: 64bit dividend 95 u64 div64_u64_rem(u64 dividend, u64 divisor, u64 *remainder) in div64_u64_rem() argument 102 quot = div_u64_rem(dividend, divisor, &rem32); in div64_u64_rem() 106 quot = div_u64(dividend >> n, divisor >> n); in div64_u64_rem() 111 *remainder = dividend - quot * divisor; in div64_u64_rem() 125 * @dividend: 64bit dividend [all …]
|
/openbmc/linux/lib/math/ |
H A D | div64.c | 67 s64 div_s64_rem(s64 dividend, s32 divisor, s32 *remainder) in div_s64_rem() argument 71 if (dividend < 0) { in div_s64_rem() 72 quotient = div_u64_rem(-dividend, abs(divisor), (u32 *)remainder); in div_s64_rem() 77 quotient = div_u64_rem(dividend, abs(divisor), (u32 *)remainder); in div_s64_rem() 88 * @dividend: 64bit dividend 98 u64 div64_u64_rem(u64 dividend, u64 divisor, u64 *remainder) in div64_u64_rem() argument 105 quot = div_u64_rem(dividend, divisor, &rem32); in div64_u64_rem() 109 quot = div_u64(dividend >> n, divisor >> n); in div64_u64_rem() 114 *remainder = dividend - quot * divisor; in div64_u64_rem() 128 * @dividend: 64bit dividend [all …]
|
H A D | test_div64.c | 163 #define test_div64_one(dividend, divisor, i, j) ({ \ argument 168 quotient = dividend; \ 172 dividend, divisor, quotient, remainder); \ 188 u64 dividend; in test_div64() local 192 dividend = test_div64_dividends[i]; in test_div64() 193 if (!test_div64_one(dividend, TEST_DIV64_DIVISOR_0, i, 0)) in test_div64() 195 if (!test_div64_one(dividend, TEST_DIV64_DIVISOR_1, i, 1)) in test_div64() 197 if (!test_div64_one(dividend, TEST_DIV64_DIVISOR_2, i, 2)) in test_div64() 199 if (!test_div64_one(dividend, TEST_DIV64_DIVISOR_3, i, 3)) in test_div64() 201 if (!test_div64_one(dividend, TEST_DIV64_DIVISOR_4, i, 4)) in test_div64() [all …]
|
/openbmc/linux/arch/powerpc/lib/ |
H A D | div64.S | 4 * This routine assumes that the top 32 bits of the dividend are 6 * On entry, r3 points to the dividend, which get overwritten with 16 lwz r5,0(r3) # get the dividend into r5/r6 22 divwu r7,r5,r4 # if dividend.hi >= divisor, 23 mullw r0,r7,r4 # quotient.hi = dividend.hi / divisor 24 subf. r5,r0,r5 # dividend.hi %= divisor 26 1: mr r11,r5 # here dividend.hi != 0 29 cntlzw r0,r5 # we are shifting the dividend right
|
/openbmc/u-boot/arch/x86/lib/ |
H A D | div64.c | 57 static u64 _64bit_divide(u64 dividend, u64 divider, u64 *rem_p) in _64bit_divide() argument 69 if (dividend <= MAX_32BIT_UINT) { in _64bit_divide() 75 result = (u32)dividend / (u32)divider; in _64bit_divide() 77 *rem_p = (u32)dividend % (u32)divider; in _64bit_divide() 82 while (divider <= dividend) { in _64bit_divide() 84 u64 limit = __lshrdi3(dividend, 1); in _64bit_divide() 92 dividend -= locald; in _64bit_divide() 96 *rem_p = dividend; in _64bit_divide()
|
/openbmc/linux/include/vdso/ |
H A D | math64.h | 6 __iter_div_u64_rem(u64 dividend, u32 divisor, u64 *remainder) in __iter_div_u64_rem() argument 10 while (dividend >= divisor) { in __iter_div_u64_rem() 13 asm("" : "+rm"(dividend)); in __iter_div_u64_rem() 15 dividend -= divisor; in __iter_div_u64_rem() 19 *remainder = dividend; in __iter_div_u64_rem()
|
/openbmc/linux/drivers/net/wireless/realtek/rtw89/ |
H A D | util.h | 35 /* The result of negative dividend and positive divisor is undefined, but it 41 static inline s32 s32_div_u32_round_down(s32 dividend, u32 divisor, s32 *remainder) in s32_div_u32_round_down() argument 47 quotient = dividend / i_divisor; in s32_div_u32_round_down() 48 i_remainder = dividend % i_divisor; in s32_div_u32_round_down() 60 static inline s32 s32_div_u32_round_closest(s32 dividend, u32 divisor) in s32_div_u32_round_closest() argument 62 return s32_div_u32_round_down(dividend + divisor / 2, divisor, NULL); in s32_div_u32_round_closest()
|
/openbmc/linux/arch/powerpc/boot/ |
H A D | div64.S | 4 * This routine assumes that the top 32 bits of the dividend are 6 * On entry, r3 points to the dividend, which get overwritten with 16 lwz r5,0(r3) # get the dividend into r5/r6 22 divwu r7,r5,r4 # if dividend.hi >= divisor, 23 mullw r0,r7,r4 # quotient.hi = dividend.hi / divisor 24 subf. r5,r0,r5 # dividend.hi %= divisor 26 1: mr r11,r5 # here dividend.hi != 0 29 cntlzw r0,r5 # we are shifting the dividend right
|
/openbmc/linux/lib/crypto/mpi/ |
H A D | mpi-div.c | 18 void mpi_fdiv_qr(MPI quot, MPI rem, MPI dividend, MPI divisor); 20 void mpi_fdiv_r(MPI rem, MPI dividend, MPI divisor) in mpi_fdiv_r() argument 34 mpi_tdiv_r(rem, dividend, divisor); in mpi_fdiv_r() 36 if (((divisor_sign?1:0) ^ (dividend->sign?1:0)) && rem->nlimbs) in mpi_fdiv_r() 43 void mpi_fdiv_q(MPI quot, MPI dividend, MPI divisor) in mpi_fdiv_q() argument 46 mpi_fdiv_qr(quot, tmp, dividend, divisor); in mpi_fdiv_q() 50 void mpi_fdiv_qr(MPI quot, MPI rem, MPI dividend, MPI divisor) in mpi_fdiv_qr() argument 60 mpi_tdiv_qr(quot, rem, dividend, divisor); in mpi_fdiv_qr() 62 if ((divisor_sign ^ dividend->sign) && rem->nlimbs) { in mpi_fdiv_qr()
|
/openbmc/linux/arch/xtensa/lib/ |
H A D | udivsi3.S | 14 mov a6, a2 /* keep dividend in a6 */ 15 do_nsau a5, a6, a2, a7 /* dividend_shift = nsau (dividend) */ 42 addi a2, a2, 1 /* increment quotient if dividend >= divisor */ 47 beqz a3, .Lerror /* if divisor == 1, return the dividend */ 51 /* return dividend >= divisor */
|
H A D | divsi3.S | 12 xor a7, a2, a3 /* sign = dividend ^ divisor */ 13 do_abs a6, a2, a4 /* udividend = abs (dividend) */ 56 bltu a6, a3, .Lreturn0 /* if dividend < divisor, return 0 */
|
/openbmc/qemu/tests/unit/ |
H A D | test-div128.c | 42 /* Dividend fits in 64 bits */ 62 /* Dividend > 64 bits, with MSB 0 */ 73 /* Dividend > 64 bits, with MSB 1 */ 89 * and high 64 bits of dividend >= divisor 99 /* Dividend > 64 bits, divisor almost as big */ 106 /* Positive dividend, positive/negative divisors */ 132 /* Negative dividend, positive/negative divisors */
|
/openbmc/linux/arch/m68k/ifpsp060/src/ |
H A D | ilsp.S | 75 # 0x8(sp) = hi(dividend) # 76 # 0xc(sp) = lo(dividend) # 138 mov.l 0xc(%a6), %d5 # get dividend hi 139 mov.l 0x10(%a6), %d6 # get dividend lo 152 # save the sign of the dividend 153 # make dividend unsigned if it's negative 155 tst.l %d5 # chk sign of hi(dividend) 156 slt NDIVIDEND(%a6) # save sign of dividend 160 negx.l %d6 # complement signed dividend 164 # - is (dividend == 0) ? [all …]
|
/openbmc/linux/drivers/acpi/acpica/ |
H A D | utmath.c | 242 * PARAMETERS: dividend - 64-bit dividend 256 acpi_ut_short_divide(u64 dividend, in acpi_ut_short_divide() argument 272 dividend_ovl.full = dividend; in acpi_ut_short_divide() 300 * PARAMETERS: in_dividend - Dividend 315 union uint64_overlay dividend; in acpi_ut_divide() local 335 dividend.full = in_dividend; in acpi_ut_divide() 347 ACPI_DIV_64_BY_32(0, dividend.part.hi, divisor.part.lo, in acpi_ut_divide() 350 ACPI_DIV_64_BY_32(partial1, dividend.part.lo, divisor.part.lo, in acpi_ut_divide() 360 normalized_dividend = dividend; in acpi_ut_divide() 392 if (partial3.part.lo >= dividend.part.hi) { in acpi_ut_divide() [all …]
|
/openbmc/linux/arch/m68k/lib/ |
H A D | udivsi3.S | 92 movel sp@(8), d0 /* d0 = dividend */ 102 movew sp@(10), d2 /* get low dividend + high rest */ 109 lsrl IMM (1), d0 /* shift dividend */ 117 greater than the dividend, the tentative quotient was too large. */ 127 cmpl sp@(8), d1 /* compare the sum with the dividend */ 128 jls L6 /* if sum > dividend, quotient was too large */
|
/openbmc/u-boot/lib/libavb/ |
H A D | avb_sysdeps_posix.c | 31 uint32_t avb_div_by_10(uint64_t* dividend) { in avb_div_by_10() argument 32 uint32_t rem = (uint32_t)(*dividend % 10); in avb_div_by_10() 33 *dividend /= 10; in avb_div_by_10()
|
/openbmc/linux/lib/zstd/common/ |
H A D | zstd_deps.h | 60 * U64 ZSTD_div64(U64 dividend, U32 divisor) 68 static uint64_t ZSTD_div64(uint64_t dividend, uint32_t divisor) { in ZSTD_div64() argument 69 return div_u64(dividend, divisor); in ZSTD_div64()
|
/openbmc/linux/arch/x86/include/asm/ |
H A D | div64.h | 16 * - modifies the 64-bit dividend _in_place_ 43 static inline u64 div_u64_rem(u64 dividend, u32 divisor, u32 *remainder) in div_u64_rem() argument 48 } d = { dividend }; in div_u64_rem()
|
/openbmc/linux/drivers/clk/versatile/ |
H A D | icst.c | 29 u64 dividend = p->ref * 2 * (u64)(vco.v + 8); in icst_hz() local 32 do_div(dividend, divisor); in icst_hz() 33 return (unsigned long)dividend; in icst_hz()
|