aboutsummaryrefslogtreecommitdiffstats
path: root/Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c
diff options
context:
space:
mode:
authorKonstantin Aladyshev <aladyshev22@gmail.com>2021-06-25 15:41:56 +0300
committerKonstantin Aladyshev <aladyshev22@gmail.com>2021-06-25 15:41:56 +0300
commit2bcd42f531b1b5eed139aef990ab85cfd420fe1b (patch)
tree0d332ff10c7694dc1e5d3d8d0727b5c7230a36fb /Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c
parent2e291ad1adea28c1462f2a39bff8091935e0ef9d (diff)
downloadUEFI-Lessons-2bcd42f531b1b5eed139aef990ab85cfd420fe1b.tar.gz
UEFI-Lessons-2bcd42f531b1b5eed139aef990ab85cfd420fe1b.tar.bz2
UEFI-Lessons-2bcd42f531b1b5eed139aef990ab85cfd420fe1b.zip
Add lesson 18
Diffstat (limited to 'Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c')
-rw-r--r--Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c b/Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c
new file mode 100644
index 0000000..c45570e
--- /dev/null
+++ b/Lesson_18/UefiLessonsPkg/ImageInfo/ImageInfo.c
@@ -0,0 +1,44 @@
+#include <Library/UefiBootServicesTableLib.h>
+#include <Library/UefiLib.h>
+
+#include <Protocol/LoadedImage.h>
+#include <Library/DevicePathLib.h>
+
+EFI_STATUS
+EFIAPI
+UefiMain (
+ IN EFI_HANDLE ImageHandle,
+ IN EFI_SYSTEM_TABLE *SystemTable
+ )
+{
+ EFI_STATUS Status;
+ EFI_LOADED_IMAGE_PROTOCOL* LoadedImage;
+
+ Status = gBS->HandleProtocol(
+ ImageHandle,
+ &gEfiLoadedImageProtocolGuid,
+ (VOID **) &LoadedImage
+ );
+
+ if (Status == EFI_SUCCESS) {
+ EFI_DEVICE_PATH_PROTOCOL* DevicePath;
+
+ Status = gBS->HandleProtocol(
+ ImageHandle,
+ &gEfiLoadedImageDevicePathProtocolGuid,
+ (VOID**) &DevicePath
+ );
+
+ if (Status == EFI_SUCCESS) {
+ Print(L"Image device: %s\n", ConvertDevicePathToText(DevicePath, FALSE, TRUE));
+ Print(L"Image file: %s\n", ConvertDevicePathToText(LoadedImage->FilePath, FALSE, TRUE)); // EFI_DEVICE_PATH_PROTOCOL *FilePath
+ Print(L"Image Base: %X\n", LoadedImage->ImageBase);
+ Print(L"Image Size: %X\n", LoadedImage->ImageSize);
+ } else {
+ Print(L"Can't get EFI_LOADED_IMAGE_PROTOCOL, Status=%r\n", Status);
+ }
+ } else {
+ Print(L"Can't get EFI_DEVICE_PATH_PROTOCOL, Status=%r\n", Status);
+ }
+ return EFI_SUCCESS;
+}