TianoCore EDK2 master
Loading...
Searching...
No Matches
ArmGicDParser.c File Reference

Go to the source code of this file.

Functions

STATIC EFI_STATUS EFIAPI GicDIntcNodeParser (IN CONST VOID *Fdt, IN INT32 GicIntcNode, IN CM_ARM_GICD_INFO *GicDInfo)
 
EFI_STATUS EFIAPI ArmGicDInfoParser (IN CONST FDT_HW_INFO_PARSER_HANDLE FdtParserHandle, IN INT32 FdtBranch)
 

Detailed Description

Arm Gic Distributor Parser.

Copyright (c) 2021, ARM Limited. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent

Reference(s):
  • linux/Documentation/devicetree/bindings/interrupt-controller/arm,gic.yaml
  • linux/Documentation/devicetree/bindings/interrupt-controller/arm,gic-v3.yaml

Definition in file ArmGicDParser.c.

Function Documentation

◆ ArmGicDInfoParser()

EFI_STATUS EFIAPI ArmGicDInfoParser ( IN CONST FDT_HW_INFO_PARSER_HANDLE  FdtParserHandle,
IN INT32  FdtBranch 
)

CM_ARM_GICD_INFO parser function.

This parser expects FdtBranch to be a Gic interrupt-controller node. At most one CmObj is created. The following structure is populated: typedef struct CmArmGicDInfo { UINT64 PhysicalBaseAddress; // {Populated} UINT32 SystemVectorBase; UINT8 GicVersion; // {Populated} } CM_ARM_GICD_INFO;

A parser parses a Device Tree to populate a specific CmObj type. None, one or many CmObj can be created by the parser. The created CmObj are then handed to the parser's caller through the HW_INFO_ADD_OBJECT interface. This can also be a dispatcher. I.e. a function that not parsing a Device Tree but calling other parsers.

Parameters
[in]FdtParserHandleA handle to the parser instance.
[in]FdtBranchWhen searching for DT node name, restrict the search to this Device Tree branch.
Return values
EFI_SUCCESSThe function completed successfully.
EFI_ABORTEDAn error occurred.
EFI_INVALID_PARAMETERInvalid parameter.
EFI_NOT_FOUNDNot found.
EFI_UNSUPPORTEDUnsupported.

Definition at line 113 of file ArmGicDParser.c.

◆ GicDIntcNodeParser()

STATIC EFI_STATUS EFIAPI GicDIntcNodeParser ( IN CONST VOID *  Fdt,
IN INT32  GicIntcNode,
IN CM_ARM_GICD_INFO GicDInfo 
)

Parse a Gic compatible interrupt-controller node, extracting GicD information.

This parser is valid for Gic v2 and v3.

Parameters
[in]FdtPointer to a Flattened Device Tree (Fdt).
[in]GicIntcNodeOffset of a Gic compatible interrupt-controller node.
[in]GicDInfoThe CM_ARM_GICD_INFO to populate.
Return values
EFI_SUCCESSThe function completed successfully.
EFI_ABORTEDAn error occurred.
EFI_INVALID_PARAMETERInvalid parameter.

Definition at line 35 of file ArmGicDParser.c.