1 /** @file
2   Math worker functions.
3 
4   Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
5   This program and the accompanying materials
6   are licensed and made available under the terms and conditions of the BSD License
7   which accompanies this distribution.  The full text of the license may be found at
8   http://opensource.org/licenses/bsd-license.php.
9 
10   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
12 
13 **/
14 
15 
16 
17 
18 #include "BaseLibInternals.h"
19 
20 /**
21   Divides a 64-bit signed integer by a 64-bit signed integer and generates a
22   64-bit signed result and a optional 64-bit signed remainder.
23 
24   This function divides the 64-bit signed value Dividend by the 64-bit signed
25   value Divisor and generates a 64-bit signed quotient. If Remainder is not
26   NULL, then the 64-bit signed remainder is returned in Remainder. This
27   function returns the 64-bit signed quotient.
28 
29   It is the caller's responsibility to not call this function with a Divisor of 0.
30   If Divisor is 0, then the quotient and remainder should be assumed to be
31   the largest negative integer.
32 
33   If Divisor is 0, then ASSERT().
34 
35   @param  Dividend  A 64-bit signed value.
36   @param  Divisor   A 64-bit signed value.
37   @param  Remainder A pointer to a 64-bit signed value. This parameter is
38                     optional and may be NULL.
39 
40   @return Dividend / Divisor
41 
42 **/
43 INT64
44 EFIAPI
DivS64x64Remainder(IN INT64 Dividend,IN INT64 Divisor,OUT INT64 * Remainder OPTIONAL)45 DivS64x64Remainder (
46   IN      INT64                     Dividend,
47   IN      INT64                     Divisor,
48   OUT     INT64                     *Remainder  OPTIONAL
49   )
50 {
51   ASSERT (Divisor != 0);
52   return InternalMathDivRemS64x64 (Dividend, Divisor, Remainder);
53 }
54