/* * Flattened Image Tree loader. * * Copyright (c) 2016 Imagination Technologies * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, see . */ #ifndef HW_LOADER_FIT_H #define HW_LOADER_FIT_H #include "exec/hwaddr.h" struct fit_loader_match { const char *compatible; const void *data; }; struct fit_loader { const struct fit_loader_match *matches; hwaddr (*addr_to_phys)(void *opaque, uint64_t addr); void *(*fdt_filter)(void *opaque, const void *fdt, const void *match_data, hwaddr *load_addr); const void *(*kernel_filter)(void *opaque, const void *kernel, hwaddr *load_addr, hwaddr *entry_addr); }; /** * load_fit: load a FIT format image * @ldr: structure defining board specific properties and hooks * @filename: image to load * @pfdt: pointer to update with address of FDT blob * @opaque: opaque value passed back to the hook functions in @ldr * Returns: 0 on success, or a negative errno on failure * * @pfdt is used to tell the caller about the FDT blob. On return, it * has been set to point to the FDT blob, and it is now the caller's * responsibility to free that memory with g_free(). Usually the caller * will want to pass in &machine->fdt here, to record the FDT blob for * the dumpdtb option and QMP/HMP commands. */ int load_fit(const struct fit_loader *ldr, const char *filename, void **pfdt, void *opaque); #endif /* HW_LOADER_FIT_H */