2 Protocol to describe overrides required to support non-standard SDHCI
5 Copyright (c) 2017 - 2018, Linaro, Ltd. All rights reserved.<BR>
7 This program and the accompanying materials
8 are licensed and made available under the terms and conditions of the BSD License
9 which accompanies this distribution. The full text of the license may be found at
10 http://opensource.org/licenses/bsd-license.php
12 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
17 #ifndef __SD_MMC_OVERRIDE_H__
18 #define __SD_MMC_OVERRIDE_H__
20 #include <Protocol/SdMmcPassThru.h>
22 #define EDKII_SD_MMC_OVERRIDE_PROTOCOL_GUID \
23 { 0xeaf9e3c1, 0xc9cd, 0x46db, { 0xa5, 0xe5, 0x5a, 0x12, 0x4c, 0x83, 0x23, 0x23 } }
25 #define EDKII_SD_MMC_OVERRIDE_PROTOCOL_VERSION 0x1
27 typedef struct _EDKII_SD_MMC_OVERRIDE EDKII_SD_MMC_OVERRIDE
;
32 EdkiiSdMmcInitHostPre
,
33 EdkiiSdMmcInitHostPost
,
34 } EDKII_SD_MMC_PHASE_TYPE
;
38 Override function for SDHCI capability bits
40 @param[in] ControllerHandle The EFI_HANDLE of the controller.
41 @param[in] Slot The 0 based slot index.
42 @param[in,out] SdMmcHcSlotCapability The SDHCI capability structure.
44 @retval EFI_SUCCESS The override function completed successfully.
45 @retval EFI_NOT_FOUND The specified controller or slot does not exist.
46 @retval EFI_INVALID_PARAMETER SdMmcHcSlotCapability is NULL
51 (EFIAPI
* EDKII_SD_MMC_CAPABILITY
) (
52 IN EFI_HANDLE ControllerHandle
,
54 IN OUT VOID
*SdMmcHcSlotCapability
59 Override function for SDHCI controller operations
61 @param[in] ControllerHandle The EFI_HANDLE of the controller.
62 @param[in] Slot The 0 based slot index.
63 @param[in] PhaseType The type of operation and whether the
64 hook is invoked right before (pre) or
66 @param[in,out] PhaseData The pointer to a phase-specific data.
68 @retval EFI_SUCCESS The override function completed successfully.
69 @retval EFI_NOT_FOUND The specified controller or slot does not exist.
70 @retval EFI_INVALID_PARAMETER PhaseType is invalid
75 (EFIAPI
* EDKII_SD_MMC_NOTIFY_PHASE
) (
76 IN EFI_HANDLE ControllerHandle
,
78 IN EDKII_SD_MMC_PHASE_TYPE PhaseType
,
79 IN OUT VOID
*PhaseData
82 struct _EDKII_SD_MMC_OVERRIDE
{
84 // Protocol version of this implementation
88 // Callback to override SD/MMC host controller capability bits
90 EDKII_SD_MMC_CAPABILITY Capability
;
92 // Callback to invoke SD/MMC override hooks
94 EDKII_SD_MMC_NOTIFY_PHASE NotifyPhase
;
97 extern EFI_GUID gEdkiiSdMmcOverrideProtocolGuid
;