mirror of
https://github.com/acidanthera/audk.git
synced 2025-10-24 16:53:47 +02:00
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@3 6f19259b-4bc3-4df7-8a09-765794883524
83 lines
1.8 KiB
C
83 lines
1.8 KiB
C
/*++
|
|
|
|
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:
|
|
|
|
Stall.c
|
|
|
|
Abstract:
|
|
|
|
Tiano Miscellaneous Services Stall service implementation
|
|
|
|
--*/
|
|
|
|
//
|
|
// Include statements
|
|
//
|
|
|
|
#include <DxeMain.h>
|
|
|
|
|
|
EFI_STATUS
|
|
EFIAPI
|
|
CoreStall (
|
|
IN UINTN Microseconds
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Introduces a fine-grained stall.
|
|
|
|
Arguments:
|
|
|
|
Microseconds The number of microseconds to stall execution
|
|
|
|
Returns:
|
|
|
|
EFI_SUCCESS - Execution was stalled for at least the requested amount
|
|
of microseconds.
|
|
|
|
EFI_NOT_AVAILABLE_YET - gMetronome is not available yet
|
|
|
|
--*/
|
|
{
|
|
UINT32 Counter;
|
|
UINT32 Remainder;
|
|
|
|
if (gMetronome == NULL) {
|
|
return EFI_NOT_AVAILABLE_YET;
|
|
}
|
|
|
|
//
|
|
// Calculate the number of ticks by dividing the number of microseconds by
|
|
// the TickPeriod.
|
|
// Calcullation is based on 100ns unit.
|
|
//
|
|
Counter = (UINT32) DivU64x32Remainder (
|
|
Microseconds * 10,
|
|
gMetronome->TickPeriod,
|
|
&Remainder
|
|
);
|
|
|
|
//
|
|
// Call WaitForTick for Counter + 1 ticks to try to guarantee Counter tick
|
|
// periods, thus attempting to ensure Microseconds of stall time.
|
|
//
|
|
if (Remainder != 0) {
|
|
Counter++;
|
|
}
|
|
|
|
gMetronome->WaitForTick (gMetronome, Counter);
|
|
|
|
return EFI_SUCCESS;
|
|
}
|