/* * Copyright (c) 2011 Jakub Jermar * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include <genarch/efi.h> #include <arch/types.h> #include <stddef.h> void *efi_vendor_table_find(efi_system_table_t *st, efi_guid_t guid) { sysarg_t i; for (i = 0; i < st->conf_table_entries; i++) if ((st->conf_table[i].guid.low == guid.low) && (st->conf_table[i].guid.high == guid.high)) return st->conf_table[i].table; return NULL; } efi_status_t efi_get_memory_map(efi_system_table_t *st, sysarg_t *memory_map_size, efi_v1_memdesc_t **memory_map, sysarg_t *map_key, sysarg_t *descriptor_size, uint32_t *descriptor_version) { efi_status_t status; *memory_map_size = 8 * sizeof(**memory_map); do { /* Allocate space for the memory map. */ status = st->boot_services->allocate_pool(EFI_LOADER_DATA, *memory_map_size, (void **) memory_map); if (status != EFI_SUCCESS) return status; /* Try to obtain the map. */ status = st->boot_services->get_memory_map(memory_map_size, *memory_map, map_key, descriptor_size, descriptor_version); if (status == EFI_SUCCESS) return status; /* An error occurred, release the allocated memory. */ st->boot_services->free_pool(*memory_map); } while (status == EFI_BUFFER_TOO_SMALL); return status; }