mirror of
https://github.com/u-boot/u-boot.git
synced 2025-05-08 10:39:08 +00:00
tools: moved code common to all image tools to a separated module.
In order to avoid duplicating code and keep only one point of modification, the functions, structs and defines useful for "dumpimage" were moved from "mkimage" to a common module called "imagetool". This modification also weakens the coupling between image types (FIT, IMX, MXS, and so on) and image tools (mkimage and dumpimage). Any tool may initialize the "imagetool" through register_image_tool() function, while the image types register themselves within an image tool using the register_image_type() function: +---------------+ +------| fit_image | +--------------+ +-----------+ | +---------------+ | mkimage |--------> | | <-----+ +--------------+ | | +---------------+ | imagetool | <------------| imximage | +--------------+ | | +---------------+ | dumpimage |--------> | | <-----+ +--------------+ +-----------+ | +---------------+ +------| default_image | +---------------+ register_image_tool() register_image_type() Also, the struct "mkimage_params" was renamed to "image_tool_params" to make clear its general purpose. Signed-off-by: Guilherme Maciel Ferreira <guilherme.maciel.ferreira@gmail.com> Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
f1cc458cf3
commit
f86ed6a8d5
14 changed files with 276 additions and 191 deletions
|
@ -14,7 +14,7 @@
|
|||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include "mkimage.h"
|
||||
#include "imagetool.h"
|
||||
#include <image.h>
|
||||
#include "omapimage.h"
|
||||
|
||||
|
@ -69,7 +69,7 @@ static int valid_gph_load_addr(uint32_t load_addr)
|
|||
}
|
||||
|
||||
static int omapimage_verify_header(unsigned char *ptr, int image_size,
|
||||
struct mkimage_params *params)
|
||||
struct image_tool_params *params)
|
||||
{
|
||||
struct ch_toc *toc = (struct ch_toc *)ptr;
|
||||
struct gp_header *gph = (struct gp_header *)(ptr+OMAP_CH_HDR_SIZE);
|
||||
|
@ -188,7 +188,7 @@ static int toc_offset(void *hdr, void *member)
|
|||
}
|
||||
|
||||
static void omapimage_set_header(void *ptr, struct stat *sbuf, int ifd,
|
||||
struct mkimage_params *params)
|
||||
struct image_tool_params *params)
|
||||
{
|
||||
struct ch_toc *toc = (struct ch_toc *)ptr;
|
||||
struct ch_settings *chs = (struct ch_settings *)
|
||||
|
@ -224,7 +224,7 @@ static void omapimage_set_header(void *ptr, struct stat *sbuf, int ifd,
|
|||
}
|
||||
}
|
||||
|
||||
int omapimage_check_params(struct mkimage_params *params)
|
||||
int omapimage_check_params(struct image_tool_params *params)
|
||||
{
|
||||
return (params->dflag && (params->fflag || params->lflag)) ||
|
||||
(params->fflag && (params->dflag || params->lflag)) ||
|
||||
|
@ -247,5 +247,5 @@ static struct image_type_params omapimage_params = {
|
|||
|
||||
void init_omap_image_type(void)
|
||||
{
|
||||
mkimage_register(&omapimage_params);
|
||||
register_image_type(&omapimage_params);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue