Home | History | Annotate | Download | only in Ia32
      1 #------------------------------------------------------------------------------
      2 #
      3 # Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
      4 # This program and the accompanying materials
      5 # are licensed and made available under the terms and conditions of the BSD License
      6 # which accompanies this distribution.  The full text of the license may be found at
      7 # http://opensource.org/licenses/bsd-license.php.
      8 #
      9 # THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
     10 # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
     11 #
     12 # Module Name:
     13 #
     14 #   DivError.S
     15 #
     16 # Abstract:
     17 #
     18 #   Set error flag for all division functions
     19 #
     20 #------------------------------------------------------------------------------
     21 
     22 ASM_GLOBAL ASM_PFX(InternalMathDivRemU64x32)
     23 
     24 #------------------------------------------------------------------------------
     25 # UINT64
     26 # EFIAPI
     27 # InternalMathDivRemU64x32 (
     28 #   IN      UINT64                    Dividend,
     29 #   IN      UINT32                    Divisor,
     30 #   OUT     UINT32                    *Remainder
     31 #   );
     32 #------------------------------------------------------------------------------
     33 ASM_PFX(InternalMathDivRemU64x32):
     34     movl    12(%esp), %ecx          # ecx <- divisor
     35     movl    8(%esp), %eax           # eax <- dividend[32..63]
     36     xorl    %edx, %edx
     37     divl    %ecx                    # eax <- quotient[32..63], edx <- remainder
     38     push    %eax
     39     movl    8(%esp), %eax           # eax <- dividend[0..31]
     40     divl    %ecx                    # eax <- quotient[0..31]
     41     movl    20(%esp), %ecx          # ecx <- Remainder
     42     jecxz   L1                      # abandon remainder if Remainder == NULL
     43     movl    %edx, (%ecx)
     44 L1:
     45     pop     %edx                    # edx <- quotient[32..63]
     46     ret
     47