2006-04-22 00:54:32 +02:00
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
;
|
|
|
|
; Copyright (c) 2006, Intel Corporation
|
|
|
|
; All rights reserved. This program and the accompanying materials
|
|
|
|
; are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
; which accompanies this distribution. The full text of the license may be found at
|
|
|
|
; http://opensource.org/licenses/bsd-license.php
|
|
|
|
;
|
|
|
|
; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
;
|
|
|
|
; Module Name:
|
|
|
|
;
|
|
|
|
; DivError.asm
|
|
|
|
;
|
|
|
|
; Abstract:
|
|
|
|
;
|
|
|
|
; Set error flag for all division functions
|
|
|
|
;
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
.386
|
|
|
|
.model flat,C
|
|
|
|
.code
|
|
|
|
|
2006-07-21 10:47:38 +02:00
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
; UINT64
|
|
|
|
; EFIAPI
|
|
|
|
; InternalMathDivRemU64x32 (
|
|
|
|
; IN UINT64 Dividend,
|
|
|
|
; IN UINT32 Divisor,
|
|
|
|
; OUT UINT32 *Remainder
|
|
|
|
; );
|
|
|
|
;------------------------------------------------------------------------------
|
2006-04-22 00:54:32 +02:00
|
|
|
InternalMathDivRemU64x32 PROC
|
2007-01-10 07:57:04 +01:00
|
|
|
mov ecx, [esp + 12] ; ecx <- divisor
|
|
|
|
mov eax, [esp + 8] ; eax <- dividend[32..63]
|
2006-04-22 00:54:32 +02:00
|
|
|
xor edx, edx
|
2007-01-10 07:57:04 +01:00
|
|
|
div ecx ; eax <- quotient[32..63], edx <- remainder
|
2006-04-22 00:54:32 +02:00
|
|
|
push eax
|
2007-01-10 07:57:04 +01:00
|
|
|
mov eax, [esp + 8] ; eax <- dividend[0..31]
|
|
|
|
div ecx ; eax <- quotient[0..31]
|
|
|
|
mov ecx, [esp + 20] ; ecx <- Remainder
|
2006-07-21 10:47:38 +02:00
|
|
|
jecxz @F ; abandon remainder if Remainder == NULL
|
2006-04-22 00:54:32 +02:00
|
|
|
mov [ecx], edx
|
|
|
|
@@:
|
2007-01-10 07:57:04 +01:00
|
|
|
pop edx ; edx <- quotient[32..63]
|
2006-04-22 00:54:32 +02:00
|
|
|
ret
|
|
|
|
InternalMathDivRemU64x32 ENDP
|
|
|
|
|
|
|
|
END
|