Compare commits
4 Commits
26eb480343
...
v1.0.0-rc3
Author | SHA1 | Date | |
---|---|---|---|
ed6373473c | |||
80b5f5b1b3 | |||
4fab6ffd3a | |||
0ee19eaea4 |
@@ -135,7 +135,7 @@
|
|||||||
**patchelfcrc** -l -g word --start-magic=0x12345678 --end-magic=0x8754321 -p crc-32-mpeg -f bare -O .outputsection -S .text executable.elf
|
**patchelfcrc** -l -g word --start-magic=0x12345678 --end-magic=0x8754321 -p crc-32-mpeg -f bare -O .outputsection -S .text executable.elf
|
||||||
: Calculate the CRC over *.text* section and place the result in the *.outputsection* section.
|
: Calculate the CRC over *.text* section and place the result in the *.outputsection* section.
|
||||||
The output sections start and end are checked for the given magic numbers in order to assure correct memory layout.
|
The output sections start and end are checked for the given magic numbers in order to assure correct memory layout.
|
||||||
*CRC-32-MPEG* is used as CRC algorothm.
|
*CRC-32-MPEG* is used as CRC algorithm.
|
||||||
The memory is interpreted as *little endian* and the CRC calculation granularity is a 32 bit *word*.
|
The memory is interpreted as *little endian* and the CRC calculation granularity is a 32 bit *word*.
|
||||||
|
|
||||||
# BUGS
|
# BUGS
|
||||||
|
@@ -561,25 +561,24 @@ int elf_patch_compute_crc_over_section(elfpatch_handle_t *ep, const char *sectio
|
|||||||
/* Find section */
|
/* Find section */
|
||||||
sec = find_section_in_list(ep->sections, section);
|
sec = find_section_in_list(ep->sections, section);
|
||||||
if (!sec) {
|
if (!sec) {
|
||||||
print_err("Cannot find section %s\n", section);
|
print_err("Cannot find section '%s'\n", section);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
data = elf_getdata(sec->scn, NULL);
|
data = elf_getdata(sec->scn, NULL);
|
||||||
if (!data) {
|
if (!data) {
|
||||||
print_err("Error reading section data from %s: %s\n", section, elf_errmsg(-1));
|
print_err("Error reading section data from '%s': %s\n", section, elf_errmsg(-1));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
print_debug("Section data length: %lu\n", data->d_size);
|
|
||||||
if (!data->d_size) {
|
if (!data->d_size) {
|
||||||
print_err("Section %s contains no data.\n", section);
|
print_err("Section '%s' contains no data.\n", section);
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* NOBIT sections have a length but no data in the file. Abort in this case */
|
/* NOBIT sections have a length but no data in the file. Abort in this case */
|
||||||
if (!data->d_buf) {
|
if (!data->d_buf) {
|
||||||
print_err("Section %s does not contain loadable data.\n", section);
|
print_err("Section '%s' does not contain loadable data.\n", section);
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -593,7 +592,7 @@ int elf_patch_compute_crc_over_section(elfpatch_handle_t *ep, const char *sectio
|
|||||||
/* Check granularity vs size of section */
|
/* Check granularity vs size of section */
|
||||||
padding_count = (gran_in_bytes - data->d_size % gran_in_bytes) % gran_in_bytes;
|
padding_count = (gran_in_bytes - data->d_size % gran_in_bytes) % gran_in_bytes;
|
||||||
if (padding_count) {
|
if (padding_count) {
|
||||||
print_err("Section '%s' is not a multiple size of the given granularity. %u zero padding bytes will be added.\n",
|
print_warn("Section '%s' is not a multiple size of the given granularity. %u zero padding bytes will be added.\n",
|
||||||
section, padding_count);
|
section, padding_count);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -633,7 +632,7 @@ static size_t calculate_needed_space_for_crcs(enum crc_format format,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
needed_space = 0;
|
needed_space = 0;
|
||||||
print_err("Unsupported CRC output format\n");
|
print_err("Unsupported CRC output format.\n");
|
||||||
}
|
}
|
||||||
/* Add existing magic numbers to required space */
|
/* Add existing magic numbers to required space */
|
||||||
if (check_start_magic) {
|
if (check_start_magic) {
|
||||||
|
12
src/main.c
12
src/main.c
@@ -239,12 +239,11 @@ static void prepare_default_opts(struct command_line_options *opts)
|
|||||||
opts->output_section = NULL;
|
opts->output_section = NULL;
|
||||||
opts->export_xml = NULL;
|
opts->export_xml = NULL;
|
||||||
opts->import_xml = NULL;
|
opts->import_xml = NULL;
|
||||||
|
opts->force_nocolor = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_verbose_start_info(const struct command_line_options *cmd_opts)
|
static void print_verbose_start_info(const struct command_line_options *cmd_opts)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
SlList *list_iter;
|
|
||||||
const struct named_crc *predef_crc;
|
const struct named_crc *predef_crc;
|
||||||
|
|
||||||
print_debug("Start CRC patching\n");
|
print_debug("Start CRC patching\n");
|
||||||
@@ -278,11 +277,6 @@ static void print_verbose_start_info(const struct command_line_options *cmd_opts
|
|||||||
|
|
||||||
if (cmd_opts->import_xml)
|
if (cmd_opts->import_xml)
|
||||||
print_debug("Import CRCs from '%s'\n", cmd_opts->import_xml);
|
print_debug("Import CRCs from '%s'\n", cmd_opts->import_xml);
|
||||||
|
|
||||||
if (cmd_opts->section_list) {
|
|
||||||
for (list_iter = cmd_opts->section_list, i = 1; list_iter; list_iter = sl_list_next(list_iter), i++)
|
|
||||||
print_debug("Input section [%d]: \"%s\"\n", i, (const char *)list_iter->data);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void free_cmd_args(struct command_line_options *opts)
|
static void free_cmd_args(struct command_line_options *opts)
|
||||||
@@ -459,7 +453,7 @@ int main(int argc, char **argv)
|
|||||||
print_warn("--use-vma option only has an effect when exporting as struct output.\n");
|
print_warn("--use-vma option only has an effect when exporting as struct output.\n");
|
||||||
|
|
||||||
if (!cmd_opts.output_section && cmd_opts.export_xml == NULL)
|
if (!cmd_opts.output_section && cmd_opts.export_xml == NULL)
|
||||||
print_warn("No output section / XML export specified. Will continue but not create any output\n");
|
print_warn("No output section or XML export specified. Will continue but not create any output.\n");
|
||||||
|
|
||||||
/* Prepare libelf for use with the latest ELF version */
|
/* Prepare libelf for use with the latest ELF version */
|
||||||
elf_version(EV_CURRENT);
|
elf_version(EV_CURRENT);
|
||||||
@@ -501,7 +495,7 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
if (cmd_opts.export_xml) {
|
if (cmd_opts.export_xml) {
|
||||||
if (xml_write_crcs_to_file(cmd_opts.export_xml, crc_data)) {
|
if (xml_write_crcs_to_file(cmd_opts.export_xml, crc_data)) {
|
||||||
print_err("Error during XML generation\n");
|
print_err("Error during XML generation.\n");
|
||||||
ret = -3;
|
ret = -3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user