1 ; Copyright (c) 2004, Intel Corporation
2 ; All rights reserved. This program and the accompanying materials
3 ; are licensed and made available under the terms and conditions of the BSD License
4 ; which accompanies this distribution. The full text of the license may be found at
5 ; http://opensource.org/licenses/bsd-license.php
7 ; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
8 ; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
16 ; Set error flag for all division functions
18 ;------------------------------------------------------------------------------
24 ;------------------------------------------------------------------------------
27 ; InternalMathDivRemU64x32 (
30 ; OUT UINT32 *Remainder
32 ;------------------------------------------------------------------------------
33 InternalMathDivRemU64x32 PROC
34 mov ecx, [esp + 12] ; ecx <- divisor
35 mov eax, [esp + 8] ; eax <- dividend[32..63]
37 div ecx ; eax <- quotient[32..63], edx <- remainder
39 mov eax, [esp + 8] ; eax <- dividend[0..31]
40 div ecx ; eax <- quotient[0..31]
41 mov ecx, [esp + 20] ; ecx <- Remainder
42 jecxz @F ; abandon remainder if Remainder == NULL
45 pop edx ; edx <- quotient[32..63]
47 InternalMathDivRemU64x32 ENDP