2011-09-23 00:59:52 +02:00
|
|
|
/** @file
|
|
|
|
*
|
2012-05-02 21:48:00 +02:00
|
|
|
* Copyright (c) 2011-2012, ARM Limited. All rights reserved.
|
2011-09-23 00:59:52 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
#include <Library/IoLib.h>
|
|
|
|
#include <Library/ArmGicLib.h>
|
2012-03-26 12:46:25 +02:00
|
|
|
#include <Library/PcdLib.h>
|
2011-09-23 00:59:52 +02:00
|
|
|
|
2012-05-02 21:48:00 +02:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
ArmGicGetMaxNumInterrupts (
|
|
|
|
IN INTN GicDistributorBase
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return 32 * ((MmioRead32 (GicDistributorBase + ARM_GIC_ICDICTR) & 0x1F) + 1);
|
|
|
|
}
|
|
|
|
|
2011-09-23 00:59:52 +02:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
ArmGicSendSgiTo (
|
|
|
|
IN INTN GicDistributorBase,
|
|
|
|
IN INTN TargetListFilter,
|
2012-05-02 22:08:03 +02:00
|
|
|
IN INTN CPUTargetList,
|
|
|
|
IN INTN SgiId
|
2011-09-23 00:59:52 +02:00
|
|
|
)
|
|
|
|
{
|
2012-05-02 22:08:03 +02:00
|
|
|
MmioWrite32 (GicDistributorBase + ARM_GIC_ICDSGIR, ((TargetListFilter & 0x3) << 24) | ((CPUTargetList & 0xFF) << 16) | SgiId);
|
2011-09-23 00:59:52 +02:00
|
|
|
}
|
|
|
|
|
2012-05-02 22:09:16 +02:00
|
|
|
RETURN_STATUS
|
2011-09-23 00:59:52 +02:00
|
|
|
EFIAPI
|
2012-05-02 22:09:16 +02:00
|
|
|
ArmGicAcknowledgeInterrupt (
|
|
|
|
IN UINTN GicDistributorBase,
|
|
|
|
IN UINTN GicInterruptInterfaceBase,
|
|
|
|
OUT UINTN *CoreId,
|
|
|
|
OUT UINTN *InterruptId
|
2011-09-23 00:59:52 +02:00
|
|
|
)
|
|
|
|
{
|
2012-05-02 22:09:16 +02:00
|
|
|
UINT32 Interrupt;
|
2011-09-23 00:59:52 +02:00
|
|
|
|
2012-05-02 22:09:16 +02:00
|
|
|
// Read the Interrupt Acknowledge Register
|
|
|
|
Interrupt = MmioRead32 (GicInterruptInterfaceBase + ARM_GIC_ICCIAR);
|
2011-09-23 00:59:52 +02:00
|
|
|
|
2012-05-02 22:09:16 +02:00
|
|
|
// Check if it is a valid interrupt ID
|
|
|
|
if ((Interrupt & 0x3FF) < ArmGicGetMaxNumInterrupts (GicDistributorBase)) {
|
|
|
|
// Got a valid SGI number hence signal End of Interrupt by writing to ICCEOIR
|
|
|
|
MmioWrite32 (GicInterruptInterfaceBase + ARM_GIC_ICCEIOR, Interrupt);
|
2011-09-23 00:59:52 +02:00
|
|
|
|
2012-05-02 22:09:16 +02:00
|
|
|
if (CoreId) {
|
|
|
|
*CoreId = (Interrupt >> 10) & 0x7;
|
|
|
|
}
|
|
|
|
if (InterruptId) {
|
|
|
|
*InterruptId = Interrupt & 0x3FF;
|
|
|
|
}
|
|
|
|
return RETURN_SUCCESS;
|
2011-09-23 00:59:52 +02:00
|
|
|
} else {
|
2012-05-02 22:09:16 +02:00
|
|
|
return RETURN_INVALID_PARAMETER;
|
2011-09-23 00:59:52 +02:00
|
|
|
}
|
|
|
|
}
|