efi_loader: replace efi_div10 by do_div
authorHeinrich Schuchardt <xypron.glpk@gmx.de>
Thu, 5 Oct 2017 14:14:14 +0000 (16:14 +0200)
committerAlexander Graf <agraf@suse.de>
Mon, 9 Oct 2017 05:00:29 +0000 (07:00 +0200)
We should use the existing 64bit division instead of
reinventing the wheel.

Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Signed-off-by: Alexander Graf <agraf@suse.de>
lib/efi_loader/efi_boottime.c

index df75dd903225d9f63523933bfb439ac35c967b1a..66ce92f6548f156248186f3bf56e34e57f1feff7 100644 (file)
@@ -7,6 +7,7 @@
  */
 
 #include <common.h>
+#include <div64.h>
 #include <efi_loader.h>
 #include <environment.h>
 #include <malloc.h>
@@ -128,39 +129,6 @@ const char *__efi_nesting_dec(void)
        return indent_string(--nesting_level);
 }
 
-/* Low 32 bit */
-#define EFI_LOW32(a) (a & 0xFFFFFFFFULL)
-/* High 32 bit */
-#define EFI_HIGH32(a) (a >> 32)
-
-/*
- * 64bit division by 10 implemented as multiplication by 1 / 10
- *
- * Decimals of one tenth: 0x1 / 0xA = 0x0.19999...
- */
-#define EFI_TENTH 0x199999999999999A
-static u64 efi_div10(u64 a)
-{
-       u64 prod;
-       u64 rem;
-       u64 ret;
-
-       ret  = EFI_HIGH32(a) * EFI_HIGH32(EFI_TENTH);
-       prod = EFI_HIGH32(a) * EFI_LOW32(EFI_TENTH);
-       rem  = EFI_LOW32(prod);
-       ret += EFI_HIGH32(prod);
-       prod = EFI_LOW32(a) * EFI_HIGH32(EFI_TENTH);
-       rem += EFI_LOW32(prod);
-       ret += EFI_HIGH32(prod);
-       prod = EFI_LOW32(a) * EFI_LOW32(EFI_TENTH);
-       rem += EFI_HIGH32(prod);
-       ret += EFI_HIGH32(rem);
-       /* Round to nearest integer */
-       if (rem >= (1 << 31))
-               ++ret;
-       return ret;
-}
-
 /*
  * Queue an EFI event.
  *
@@ -523,7 +491,7 @@ efi_status_t efi_set_timer(struct efi_event *event, enum efi_timer_delay type,
         * The parameter defines a multiple of 100ns.
         * We use multiples of 1000ns. So divide by 10.
         */
-       trigger_time = efi_div10(trigger_time);
+       do_div(trigger_time, 10);
 
        for (i = 0; i < ARRAY_SIZE(efi_events); ++i) {
                if (event != &efi_events[i])