diff options
Diffstat (limited to 'lib/lcm.c')
-rw-r--r-- | lib/lcm.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/lib/lcm.c b/lib/lcm.c new file mode 100644 index 00000000..b9c8de46 --- /dev/null +++ b/lib/lcm.c @@ -0,0 +1,16 @@ +#include <linux/kernel.h> +#include <linux/gcd.h> +#include <linux/export.h> +#include <linux/lcm.h> + +/* Lowest common multiple */ +unsigned long lcm(unsigned long a, unsigned long b) +{ + if (a && b) + return (a * b) / gcd(a, b); + else if (b) + return b; + + return a; +} +EXPORT_SYMBOL_GPL(lcm); |