summaryrefslogtreecommitdiff
path: root/gnu-efi/apps/t6.c
diff options
context:
space:
mode:
authorSteve McIntyre <steve@einval.com>2021-03-23 23:49:46 +0000
committerSteve McIntyre <steve@einval.com>2021-03-23 23:49:46 +0000
commit1251a7ba86fc40a6aad8b4fecdbca2b61808d9fa (patch)
tree2125fda549aaca55cb49a48d54be77dec7fbf3df /gnu-efi/apps/t6.c
parent85b409232ce89b34626df9d72abedf5d4f5ccef6 (diff)
parent031e5cce385d3f96b1caa1d53495332a7eb03749 (diff)
downloadefi-boot-shim-debian/15.3-1.tar.gz
efi-boot-shim-debian/15.3-1.zip
Update upstream source from tag 'upstream/15.3'debian/15.3-1
Update to upstream version '15.3' with Debian dir 1b484f1c1ac270604a5a1451b34de4b0865c6211
Diffstat (limited to 'gnu-efi/apps/t6.c')
-rw-r--r--gnu-efi/apps/t6.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/gnu-efi/apps/t6.c b/gnu-efi/apps/t6.c
new file mode 100644
index 00000000..f95ea660
--- /dev/null
+++ b/gnu-efi/apps/t6.c
@@ -0,0 +1,43 @@
+#include <efi.h>
+#include <efilib.h>
+
+typedef EFI_STATUS (*foo_t)(EFI_HANDLE, EFI_GUID *, VOID **);
+typedef struct {
+ unsigned long addr;
+ unsigned long gp;
+} fdesc_t;
+
+EFI_LOADED_IMAGE my_loaded;
+
+EFI_STATUS
+efi_main (EFI_HANDLE image, EFI_SYSTEM_TABLE *systab)
+{
+ EFI_LOADED_IMAGE *loaded_image = NULL;
+#if 0
+ EFI_DEVICE_PATH *dev_path;
+#endif
+ EFI_STATUS status;
+
+ InitializeLib(image, systab);
+ status = uefi_call_wrapper(systab->BootServices->HandleProtocol,
+ 3,
+ image,
+ &LoadedImageProtocol,
+ (void **) &loaded_image);
+ if (EFI_ERROR(status)) {
+ Print(L"handleprotocol: %r\n", status);
+ }
+
+#if 0
+ BS->HandleProtocol(loaded_image->DeviceHandle, &DevicePathProtocol, (void **) &dev_path);
+
+ Print(L"Image device : %s\n", DevicePathToStr(dev_path));
+ Print(L"Image file : %s\n", DevicePathToStr(loaded_image->FilePath));
+#endif
+ Print(L"Image base : %lx\n", loaded_image->ImageBase);
+ Print(L"Image size : %lx\n", loaded_image->ImageSize);
+ Print(L"Load options size : %lx\n", loaded_image->LoadOptionsSize);
+ Print(L"Load options : %s\n", loaded_image->LoadOptions);
+
+ return EFI_SUCCESS;
+}