https://bitbucket.org/daniel_fort/magic-lantern
Raw File
Tip revision: 664fe3454fe1f680f1556601b6e77b9bb0017c07 authored by Daniel Fort on 04 June 2017, 06:46:37 UTC
Closed branch qemu-EOSM2
Tip revision: 664fe34
imath.c
/* integer math */

#include "dryos.h"
#include "math.h"

int powi(int base, int power)
{
    int result = 1;
    while (power)
    {
        if (power & 1)
            result *= base;
        power >>= 1;
        base *= base;
    }
    return result;
}

int log2i(int x)
{
    int result = 0;
    while (x >>= 1) result++;
    return result;
}

int log10i(int x)
{
    int result = 0;
    while(x /= 10) result++;
    return result;
}

/* todo: integer-only implementation? */
uint32_t log_length(int v)
{
    if (!v) return 0;
    return (unsigned int)(log2f(v) * 100);
}
back to top