2007-06-22 05:21:45 +02:00
|
|
|
/** @file
|
|
|
|
Math worker functions.
|
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-22 05:21:45 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "BaseLibInternals.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Divides a 64-bit signed integer by a 64-bit signed integer and generates a
|
|
|
|
64-bit signed result and a optional 64-bit signed remainder.
|
|
|
|
|
|
|
|
This function divides the 64-bit signed value Dividend by the 64-bit signed
|
|
|
|
value Divisor and generates a 64-bit signed quotient. If Remainder is not
|
|
|
|
NULL, then the 64-bit signed remainder is returned in Remainder. This
|
|
|
|
function returns the 64-bit signed quotient.
|
|
|
|
|
2008-12-01 15:06:25 +01:00
|
|
|
It is the caller's responsibility to not call this function with a Divisor of 0.
|
2018-06-27 15:11:33 +02:00
|
|
|
If Divisor is 0, then the quotient and remainder should be assumed to be
|
2008-11-25 04:19:49 +01:00
|
|
|
the largest negative integer.
|
|
|
|
|
2007-06-22 05:21:45 +02:00
|
|
|
If Divisor is 0, then ASSERT().
|
|
|
|
|
|
|
|
@param Dividend A 64-bit signed value.
|
|
|
|
@param Divisor A 64-bit signed value.
|
|
|
|
@param Remainder A pointer to a 64-bit signed value. This parameter is
|
|
|
|
optional and may be NULL.
|
|
|
|
|
|
|
|
@return Dividend / Divisor
|
|
|
|
|
|
|
|
**/
|
|
|
|
INT64
|
|
|
|
EFIAPI
|
|
|
|
DivS64x64Remainder (
|
2021-12-05 23:54:05 +01:00
|
|
|
IN INT64 Dividend,
|
|
|
|
IN INT64 Divisor,
|
|
|
|
OUT INT64 *Remainder OPTIONAL
|
2007-06-22 05:21:45 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
ASSERT (Divisor != 0);
|
|
|
|
return InternalMathDivRemS64x64 (Dividend, Divisor, Remainder);
|
|
|
|
}
|