Skip to content

Commit

Permalink
lpc32xx: add lpc32xx-spl.bin boot image target
Browse files Browse the repository at this point in the history
Signed-off-by: Albert ARIBAUD (3ADEV) <[email protected]>
  • Loading branch information
3adev authored and albert-aribaud-u-boot committed Apr 10, 2015
1 parent 24d528e commit 39f520b
Show file tree
Hide file tree
Showing 4 changed files with 181 additions and 0 deletions.
1 change: 1 addition & 0 deletions common/image.c
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,7 @@ static const table_entry_t uimage_type[] = {
{ IH_TYPE_MXSIMAGE, "mxsimage", "Freescale MXS Boot Image",},
{ IH_TYPE_ATMELIMAGE, "atmelimage", "ATMEL ROM-Boot Image",},
{ IH_TYPE_X86_SETUP, "x86_setup", "x86 setup.bin", },
{ IH_TYPE_LPC32XXIMAGE, "lpc32xximage", "LPC32XX Boot Image", },
{ -1, "", "", },
};

Expand Down
1 change: 1 addition & 0 deletions include/image.h
Original file line number Diff line number Diff line change
Expand Up @@ -242,6 +242,7 @@ struct lmb;
#define IH_TYPE_ATMELIMAGE 18 /* ATMEL ROM bootable Image */
#define IH_TYPE_SOCFPGAIMAGE 19 /* Altera SOCFPGA Preloader */
#define IH_TYPE_X86_SETUP 20 /* x86 setup.bin Image */
#define IH_TYPE_LPC32XXIMAGE 21 /* x86 setup.bin Image */

/*
* Compression Types
Expand Down
1 change: 1 addition & 0 deletions tools/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ dumpimage-mkimage-objs := aisimage.o \
imximage.o \
kwbimage.o \
lib/md5.o \
lpc32xximage.o \
mxsimage.o \
omapimage.o \
os_support.o \
Expand Down
178 changes: 178 additions & 0 deletions tools/lpc32xximage.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,178 @@
/*
* Image manipulator for LPC32XX SoCs
*
* (C) Copyright 2015 DENX Software Engineering GmbH
* Written-by: Albert ARIBAUD <[email protected]>
*
* Derived from omapimage.c:
*
* (C) Copyright 2010
* Linaro LTD, www.linaro.org
* Author: John Rigby <[email protected]>
* Based on TI's signGP.c
*
* (C) Copyright 2009
* Stefano Babic, DENX Software Engineering, [email protected].
*
* (C) Copyright 2008
* Marvell Semiconductor <www.marvell.com>
* Written-by: Prafulla Wadaskar <[email protected]>
*
* SPDX-License-Identifier: GPL-2.0+
*/

#include "imagetool.h"
#include <compiler.h>
#include <image.h>

/*
* NAND page 0 boot header
*/

struct nand_page_0_boot_header {
uint32_t data[129];
uint32_t pad[383];
};

/*
* Default ICC (interface configuration data [sic]) if none specified
* in board config
*/

#ifndef LPC32XX_BOOT_ICR
#define LPC32XX_BOOT_ICR 0x00000096
#endif

/*
* Default boot NAND page size if none specified in board config
*/

#ifndef LPC32XX_BOOT_NAND_PAGESIZE
#define LPC32XX_BOOT_NAND_PAGESIZE 2048
#endif

/*
* Default boot NAND pages per sector if none specified in board config
*/

#ifndef LPC32XX_BOOT_NAND_PAGES_PER_SECTOR
#define LPC32XX_BOOT_NAND_PAGES_PER_SECTOR 64
#endif

/*
* Maximum size for boot code is 56K unless defined in board config
*/

#ifndef LPC32XX_BOOT_CODESIZE
#define LPC32XX_BOOT_CODESIZE (56*1024)
#endif

/* signature byte for a readable block */

#define LPC32XX_BOOT_BLOCK_OK 0xaa

static struct nand_page_0_boot_header lpc32xximage_header;

static int lpc32xximage_check_image_types(uint8_t type)
{
if (type == IH_TYPE_LPC32XXIMAGE)
return EXIT_SUCCESS;
return EXIT_FAILURE;
}

static int lpc32xximage_verify_header(unsigned char *ptr, int image_size,
struct image_tool_params *params)
{
struct nand_page_0_boot_header *hdr =
(struct nand_page_0_boot_header *)ptr;

/* turn image size from bytes to NAND pages, page 0 included */
int image_size_in_pages = ((image_size - 1)
/ LPC32XX_BOOT_NAND_PAGESIZE);

if (hdr->data[0] != (0xff & LPC32XX_BOOT_ICR))
return -1;
if (hdr->data[1] != (0xff & ~LPC32XX_BOOT_ICR))
return -1;
if (hdr->data[2] != (0xff & LPC32XX_BOOT_ICR))
return -1;
if (hdr->data[3] != (0xff & ~LPC32XX_BOOT_ICR))
return -1;
if (hdr->data[4] != (0xff & image_size_in_pages))
return -1;
if (hdr->data[5] != (0xff & ~image_size_in_pages))
return -1;
if (hdr->data[6] != (0xff & image_size_in_pages))
return -1;
if (hdr->data[7] != (0xff & ~image_size_in_pages))
return -1;
if (hdr->data[8] != (0xff & image_size_in_pages))
return -1;
if (hdr->data[9] != (0xff & ~image_size_in_pages))
return -1;
if (hdr->data[10] != (0xff & image_size_in_pages))
return -1;
if (hdr->data[11] != (0xff & ~image_size_in_pages))
return -1;
if (hdr->data[12] != LPC32XX_BOOT_BLOCK_OK)
return -1;
if (hdr->data[128] != LPC32XX_BOOT_BLOCK_OK)
return -1;
return 0;
}

static void print_hdr_byte(struct nand_page_0_boot_header *hdr, int ofs)
{
printf("header[%d] = %02x\n", ofs, hdr->data[ofs]);
}

static void lpc32xximage_print_header(const void *ptr)
{
struct nand_page_0_boot_header *hdr =
(struct nand_page_0_boot_header *)ptr;
int ofs;

for (ofs = 0; ofs <= 12; ofs++)
print_hdr_byte(hdr, ofs);
print_hdr_byte(hdr, 128);
}

static void lpc32xximage_set_header(void *ptr, struct stat *sbuf, int ifd,
struct image_tool_params *params)
{
struct nand_page_0_boot_header *hdr =
(struct nand_page_0_boot_header *)ptr;

/* turn image size from bytes to NAND pages, page 0 included */
int image_size_in_pages = ((sbuf->st_size
+ LPC32XX_BOOT_NAND_PAGESIZE - 1)
/ LPC32XX_BOOT_NAND_PAGESIZE);

/* fill header -- default byte value is 0x00, not 0xFF */
memset((void *)hdr, 0, sizeof(*hdr));
hdr->data[0] = (hdr->data[2] = 0xff & LPC32XX_BOOT_ICR);
hdr->data[1] = (hdr->data[3] = 0xff & ~LPC32XX_BOOT_ICR);
hdr->data[4] = (hdr->data[6] = (hdr->data[8]
= (hdr->data[10] = 0xff & image_size_in_pages)));
hdr->data[5] = (hdr->data[7] = (hdr->data[9]
= (hdr->data[11] = 0xff & ~image_size_in_pages)));
hdr->data[12] = (hdr->data[128] = LPC32XX_BOOT_BLOCK_OK);
}

/*
* lpc32xximage parameters
*/
U_BOOT_IMAGE_TYPE(
lpc32xximage,
"LPC32XX Boot Image",
sizeof(lpc32xximage_header),
(void *)&lpc32xximage_header,
NULL,
lpc32xximage_verify_header,
lpc32xximage_print_header,
lpc32xximage_set_header,
NULL,
lpc32xximage_check_image_types,
NULL,
NULL
);

0 comments on commit 39f520b

Please sign in to comment.