aboutsummaryrefslogtreecommitdiffstats
path: root/Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c
diff options
context:
space:
mode:
authorKonstantin Aladyshev <aladyshev22@gmail.com>2021-06-24 14:43:14 +0300
committerKonstantin Aladyshev <aladyshev22@gmail.com>2021-06-24 14:43:14 +0300
commit9d89eecb980b52ef61c1374f0661d2591c51cf8a (patch)
tree5269d75869fb7ca74fa925322d953a167d1c8284 /Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c
parent35b4c9ce3baf2894601d9ed9334e7af51c35fe81 (diff)
downloadUEFI-Lessons-9d89eecb980b52ef61c1374f0661d2591c51cf8a.tar.gz
UEFI-Lessons-9d89eecb980b52ef61c1374f0661d2591c51cf8a.tar.bz2
UEFI-Lessons-9d89eecb980b52ef61c1374f0661d2591c51cf8a.zip
Add lesson 16
Diffstat (limited to 'Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c')
-rw-r--r--Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c b/Lesson_16/UefiLessonsPkg/ImageInfo/ImageInfo.c
new file mode 100644
index 0000000..c45570e
--- /dev/null
+++ b/Lesson_16/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;
+}