From: Nick Clifton Date: Tue, 4 Jan 2005 15:47:38 +0000 (+0000) Subject: PR binutils/630 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=8b626bcf2c36015a4488c30775d524c0c3be4b19;p=binutils-gdb.git PR binutils/630 * nlmconv.c (main): Only store the basename of the output filename in the module table. --- diff --git a/binutils/ChangeLog b/binutils/ChangeLog index ad750ebfc2e..755b5e7da32 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,9 @@ +2005-01-04 Armin Diehl + + PR binutils/630 + * nlmconv.c (main): Only store the basename of the output filename + in the module table. + 2005-01-04 H.J. Lu BZ 615 diff --git a/binutils/nlmconv.c b/binutils/nlmconv.c index 9b5e4c8ead7..1bbd22a8870 100644 --- a/binutils/nlmconv.c +++ b/binutils/nlmconv.c @@ -1057,18 +1057,24 @@ main (int argc, char **argv) sharedhdr.exitProcedureOffset; free (data); } - len = strlen (output_file); - if (len > NLM_MODULE_NAME_SIZE - 2) - len = NLM_MODULE_NAME_SIZE - 2; - nlm_fixed_header (outbfd)->moduleName[0] = len; - - strncpy (nlm_fixed_header (outbfd)->moduleName + 1, output_file, - NLM_MODULE_NAME_SIZE - 2); - nlm_fixed_header (outbfd)->moduleName[NLM_MODULE_NAME_SIZE - 1] = '\0'; - for (modname = nlm_fixed_header (outbfd)->moduleName; - *modname != '\0'; - modname++) - *modname = TOUPPER (*modname); + + { + const int max_len = NLM_MODULE_NAME_SIZE - 2; + const char * filename = lbasename (output_file); + + len = strlen (filename); + if (len > max_len) + len = max_len; + nlm_fixed_header (outbfd)->moduleName[0] = len; + + strncpy (nlm_fixed_header (outbfd)->moduleName + 1, filename, max_len); + nlm_fixed_header (outbfd)->moduleName[max_len + 1] = '\0'; + + for (modname = nlm_fixed_header (outbfd)->moduleName; + *modname != '\0'; + modname++) + *modname = TOUPPER (*modname); + } strncpy (nlm_variable_header (outbfd)->oldThreadName, " LONG", NLM_OLD_THREAD_NAME_LENGTH);