tools: kwbimage: Add support for a new DATA_DELAY command
This command is supported only by v1 images and specifies a milliseconds delay after executing some set of DATA commands. The special string value SDRAM_SETUP instructs BootROM to setup SDRAM controller instead of executing delay. SDRAM_SETUP may be specified only once and after the last DATA command. Signed-off-by: Pali Rohár <pali@kernel.org> Reviewed-by: Marek Behún <marek.behun@nic.cz> Reviewed-by: Chris Packham <judge.packham@gmail.com> Reviewed-by: Stefan Roese <sr@denx.de> Tested-by: Chris Packham <judge.packham@gmail.com>
This commit is contained in:
@@ -104,6 +104,7 @@ enum image_cfg_type {
|
|||||||
IMAGE_CFG_NAND_PAGESZ,
|
IMAGE_CFG_NAND_PAGESZ,
|
||||||
IMAGE_CFG_BINARY,
|
IMAGE_CFG_BINARY,
|
||||||
IMAGE_CFG_DATA,
|
IMAGE_CFG_DATA,
|
||||||
|
IMAGE_CFG_DATA_DELAY,
|
||||||
IMAGE_CFG_BAUDRATE,
|
IMAGE_CFG_BAUDRATE,
|
||||||
IMAGE_CFG_DEBUG,
|
IMAGE_CFG_DEBUG,
|
||||||
IMAGE_CFG_KAK,
|
IMAGE_CFG_KAK,
|
||||||
@@ -131,6 +132,7 @@ static const char * const id_strs[] = {
|
|||||||
[IMAGE_CFG_NAND_PAGESZ] = "NAND_PAGE_SIZE",
|
[IMAGE_CFG_NAND_PAGESZ] = "NAND_PAGE_SIZE",
|
||||||
[IMAGE_CFG_BINARY] = "BINARY",
|
[IMAGE_CFG_BINARY] = "BINARY",
|
||||||
[IMAGE_CFG_DATA] = "DATA",
|
[IMAGE_CFG_DATA] = "DATA",
|
||||||
|
[IMAGE_CFG_DATA_DELAY] = "DATA_DELAY",
|
||||||
[IMAGE_CFG_BAUDRATE] = "BAUDRATE",
|
[IMAGE_CFG_BAUDRATE] = "BAUDRATE",
|
||||||
[IMAGE_CFG_DEBUG] = "DEBUG",
|
[IMAGE_CFG_DEBUG] = "DEBUG",
|
||||||
[IMAGE_CFG_KAK] = "KAK",
|
[IMAGE_CFG_KAK] = "KAK",
|
||||||
@@ -162,6 +164,7 @@ struct image_cfg_element {
|
|||||||
unsigned int nandeccmode;
|
unsigned int nandeccmode;
|
||||||
unsigned int nandpagesz;
|
unsigned int nandpagesz;
|
||||||
struct ext_hdr_v0_reg regdata;
|
struct ext_hdr_v0_reg regdata;
|
||||||
|
unsigned int regdata_delay;
|
||||||
unsigned int baudrate;
|
unsigned int baudrate;
|
||||||
unsigned int debug;
|
unsigned int debug;
|
||||||
const char *key_name;
|
const char *key_name;
|
||||||
@@ -1289,8 +1292,21 @@ static void *image_create_v1(size_t *imagesz, struct image_tool_params *params,
|
|||||||
register_set_hdr = (struct register_set_hdr_v1 *)cur;
|
register_set_hdr = (struct register_set_hdr_v1 *)cur;
|
||||||
for (cfgi = 0; cfgi < cfgn; cfgi++) {
|
for (cfgi = 0; cfgi < cfgn; cfgi++) {
|
||||||
e = &image_cfg[cfgi];
|
e = &image_cfg[cfgi];
|
||||||
if (e->type != IMAGE_CFG_DATA)
|
if (e->type != IMAGE_CFG_DATA &&
|
||||||
|
e->type != IMAGE_CFG_DATA_DELAY)
|
||||||
continue;
|
continue;
|
||||||
|
if (e->type == IMAGE_CFG_DATA_DELAY) {
|
||||||
|
size = sizeof(struct register_set_hdr_v1) + 8 * datai + 4;
|
||||||
|
register_set_hdr->headertype = OPT_HDR_V1_REGISTER_TYPE;
|
||||||
|
register_set_hdr->headersz_lsb = cpu_to_le16(size & 0xFFFF);
|
||||||
|
register_set_hdr->headersz_msb = size >> 16;
|
||||||
|
register_set_hdr->data[datai].last_entry.delay = e->regdata_delay;
|
||||||
|
cur += size;
|
||||||
|
*next_ext = 1;
|
||||||
|
next_ext = ®ister_set_hdr->data[datai].last_entry.next;
|
||||||
|
datai = 0;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
register_set_hdr->data[datai].entry.address =
|
register_set_hdr->data[datai].entry.address =
|
||||||
cpu_to_le32(e->regdata.raddr);
|
cpu_to_le32(e->regdata.raddr);
|
||||||
register_set_hdr->data[datai].entry.value =
|
register_set_hdr->data[datai].entry.value =
|
||||||
@@ -1429,6 +1445,12 @@ static int image_create_config_parse_oneline(char *line,
|
|||||||
el->regdata.raddr = strtoul(value1, NULL, 16);
|
el->regdata.raddr = strtoul(value1, NULL, 16);
|
||||||
el->regdata.rdata = strtoul(value2, NULL, 16);
|
el->regdata.rdata = strtoul(value2, NULL, 16);
|
||||||
break;
|
break;
|
||||||
|
case IMAGE_CFG_DATA_DELAY:
|
||||||
|
if (!strcmp(value1, "SDRAM_SETUP"))
|
||||||
|
el->regdata_delay = REGISTER_SET_HDR_OPT_DELAY_SDRAM_SETUP;
|
||||||
|
else
|
||||||
|
el->regdata_delay = REGISTER_SET_HDR_OPT_DELAY_MS(strtoul(value1, NULL, 10));
|
||||||
|
break;
|
||||||
case IMAGE_CFG_BAUDRATE:
|
case IMAGE_CFG_BAUDRATE:
|
||||||
el->baudrate = strtoul(value1, NULL, 10);
|
el->baudrate = strtoul(value1, NULL, 10);
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user