2018-06-27 15:11:33 +02:00
|
|
|
;------------------------------------------------------------------------------
|
2009-08-18 23:24:08 +02:00
|
|
|
;
|
2011-07-20 19:47:44 +02:00
|
|
|
; CpuSleep() for ARMv7
|
|
|
|
;
|
|
|
|
; ARMv6 versions was:
|
|
|
|
; MOV r0,#0
|
|
|
|
; MCR p15,0,r0,c7,c0,4 ;Wait for Interrupt instruction
|
|
|
|
;
|
|
|
|
; But this is a no-op on ARMv7
|
2009-08-18 23:24:08 +02:00
|
|
|
;
|
2018-06-27 15:11:33 +02:00
|
|
|
; Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2011-07-20 19:47:44 +02:00
|
|
|
; Portions copyright (c) 2008 - 2011, Apple Inc. All rights reserved.<BR>
|
2010-04-23 17:35:13 +02:00
|
|
|
; This program and the accompanying materials
|
2009-08-18 23:24:08 +02:00
|
|
|
; 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
|
2010-06-25 23:56:02 +02:00
|
|
|
; http://opensource.org/licenses/bsd-license.php.
|
2009-08-18 23:24:08 +02:00
|
|
|
;
|
|
|
|
; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
;
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
EXPORT CpuSleep
|
|
|
|
AREA cpu_sleep, CODE, READONLY
|
|
|
|
|
|
|
|
;/**
|
|
|
|
; Places the CPU in a sleep state until an interrupt is received.
|
|
|
|
;
|
|
|
|
; Places the CPU in a sleep state until an interrupt is received. If interrupts
|
|
|
|
; are disabled prior to calling this function, then the CPU will be placed in a
|
|
|
|
; sleep state indefinitely.
|
|
|
|
;
|
|
|
|
;**/
|
|
|
|
;VOID
|
|
|
|
;EFIAPI
|
|
|
|
;CpuSleep (
|
|
|
|
; VOID
|
|
|
|
; );
|
|
|
|
;
|
|
|
|
CpuSleep
|
2011-07-20 19:47:44 +02:00
|
|
|
WFI
|
2009-08-18 23:24:08 +02:00
|
|
|
BX LR
|
|
|
|
|
|
|
|
END
|