summaryrefslogtreecommitdiff
path: root/Core/MdePkg/Include/Library/SmmIoLib.h
diff options
context:
space:
mode:
authorGuo Mang <mang.guo@intel.com>2017-07-07 17:11:02 +0800
committerGuo Mang <mang.guo@intel.com>2017-07-12 11:24:59 +0800
commite5251a3139e6f3b2c4de5b7d53c77e6a030e84c1 (patch)
treeca35d12026b4839830dff6db51ef711b7b181ce5 /Core/MdePkg/Include/Library/SmmIoLib.h
parent47ab99051fae0fca283d0ff1c308e96accdb99ba (diff)
downloadedk2-platforms-e5251a3139e6f3b2c4de5b7d53c77e6a030e84c1.tar.xz
Move to new location
Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Guo Mang <mang.guo@intel.com>
Diffstat (limited to 'Core/MdePkg/Include/Library/SmmIoLib.h')
-rw-r--r--Core/MdePkg/Include/Library/SmmIoLib.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/Core/MdePkg/Include/Library/SmmIoLib.h b/Core/MdePkg/Include/Library/SmmIoLib.h
new file mode 100644
index 0000000000..7820f1ec10
--- /dev/null
+++ b/Core/MdePkg/Include/Library/SmmIoLib.h
@@ -0,0 +1,42 @@
+/** @file
+ Provides services for SMM IO Operation.
+
+ The SMM IO Library provides function for checking if IO resource is accessible inside of SMM.
+
+ Copyright (c) 2017, Intel Corporation. All rights reserved.<BR>
+ 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.
+
+**/
+
+#ifndef _SMM_IO_LIB_H_
+#define _SMM_IO_LIB_H_
+
+/**
+ This function check if the MMIO resource is valid per processor architecture and
+ valid per platform design.
+
+ @param BaseAddress The MMIO start address to be checked.
+ @param Length The MMIO length to be checked.
+ @param Owner A GUID representing the owner of the resource.
+ This GUID may be used by producer to correlate the device ownership of the resource.
+ NULL means no specific owner.
+
+ @retval TRUE This MMIO resource is valid per processor architecture and valid per platform design.
+ @retval FALSE This MMIO resource is not valid per processor architecture or valid per platform design.
+**/
+BOOLEAN
+EFIAPI
+SmmIsMmioValid (
+ IN EFI_PHYSICAL_ADDRESS BaseAddress,
+ IN UINT64 Length,
+ IN EFI_GUID *Owner OPTIONAL
+ );
+
+#endif
+