[OE-core] [PATCH 1/1] binutils: Improve check for input file matching output file
Khem Raj
raj.khem at gmail.com
Fri Aug 17 00:30:05 UTC 2018
On 8/15/18 11:25 PM, Robert Yang wrote:
>
>
> On 08/16/2018 02:14 PM, Robert Yang wrote:
>> When the assembler reports that the input and output are the same,
>> report the
>> file names involved, in order to help debugging. Also do not equate
>> two files
>> are the same if the have the same inode value but reside on different
>> file
>> systems.
>>
>> Signed-off-by: Robert Yang <liezhi.yang at windriver.com>
>> ---
>> meta/recipes-devtools/binutils/binutils-2.31.inc | 1 +
>> ...check-for-input-file-matching-output-file.patch | 59
>> ++++++++++++++++++++++
>> 2 files changed, 60 insertions(+)
>> create mode 100644
>> meta/recipes-devtools/binutils/binutils/0017-improve-check-for-input-file-matching-output-file.patch
>>
>>
>> diff --git a/meta/recipes-devtools/binutils/binutils-2.31.inc
>> b/meta/recipes-devtools/binutils/binutils-2.31.inc
>> index 02d5bca..6603873 100644
>> --- a/meta/recipes-devtools/binutils/binutils-2.31.inc
>> +++ b/meta/recipes-devtools/binutils/binutils-2.31.inc
>> @@ -36,6 +36,7 @@ SRC_URI = "\
>> file://0014-Detect-64-bit-MIPS-targets.patch \
>> file://0015-sync-with-OE-libtool-changes.patch \
>> file://0016-add-i386pep-emulation-for-x86_64.patch \
>> +
>> file://0017-improve-check-for-input-file-matching-output-file.patch \
>> "
>> S = "${WORKDIR}/git"
>> diff --git
>> a/meta/recipes-devtools/binutils/binutils/0017-improve-check-for-input-file-matching-output-file.patch
>> b/meta/recipes-devtools/binutils/binutils/0017-improve-check-for-input-file-matching-output-file.patch
>>
>> new file mode 100644
>> index 0000000..6d8d8a3
>> --- /dev/null
>> +++
>> b/meta/recipes-devtools/binutils/binutils/0017-improve-check-for-input-file-matching-output-file.patch
>>
>> @@ -0,0 +1,59 @@
>> +From 2a50366ded329bfb39d387253450c9d5302c3503 Mon Sep 17 00:00:00 2001
>> +From: Robert Yang <liezhi.yang at windriver.com>
>> +Date: Tue, 14 Aug 2018 12:22:35 +0100
>> +Subject: [PATCH] as.c: Improve check for input file matching output
>> file.
>> +
>> +When the assembler reports that the input and output are the same,
>> report the
>> +file names involved, in order to help debugging. Also do not equate
>> two files
>> +are the same if the have the same inode value but reside on different
>> file
>> +systems.
>> +
>> +Upstream-Status: Backport
>> +
>> +Robert Yang <liezhi.yang at windriver.com>
>
> Sorry, here missed a SOB, I fixed it in the repo:
>
> Signed-off-by: Robert Yang <liezhi.yang at windriver.com>
patch is ok
>
> // Robert
>
>> +---
>> + gas/as.c | 27 ++++++++++++++++++++-------
>> + 2 files changed, 20 insertions(+), 7 deletions(-)
>> +
>> +diff --git a/gas/as.c b/gas/as.c
>> +index b2a908a..3105d06 100644
>> +--- a/gas/as.c
>> ++++ b/gas/as.c
>> +@@ -1259,14 +1259,27 @@ main (int argc, char ** argv)
>> + {
>> + struct stat sib;
>> +
>> +- if (stat (argv[i], &sib) == 0)
>> ++ /* Check that the input file and output file are different. */
>> ++ if (stat (argv[i], &sib) == 0
>> ++ && sib.st_ino == sob.st_ino
>> ++ /* POSIX emulating systems may support stat() but if the
>> ++ underlying file system does not support a file serial number
>> ++ of some kind then they will return 0 for the inode. So
>> ++ two files with an inode of 0 may not actually be the same.
>> ++ On real POSIX systems no ordinary file will ever have an
>> ++ inode of 0. */
>> ++ && sib.st_ino != 0
>> ++ /* Different files may have the same inode number if they
>> ++ reside on different devices, so check the st_dev field as
>> ++ well. */
>> ++ && sib.st_dev == sob.st_dev)
>> + {
>> +- if (sib.st_ino == sob.st_ino && sib.st_ino != 0)
>> +- {
>> +- /* Don't let as_fatal remove the output file! */
>> +- out_file_name = NULL;
>> +- as_fatal (_("The input and output files must be distinct"));
>> +- }
>> ++ const char *saved_out_file_name = out_file_name;
>> ++
>> ++ /* Don't let as_fatal remove the output file! */
>> ++ out_file_name = NULL;
>> ++ as_fatal (_("The input '%s' and output '%s' files are the
>> same"),
>> ++ argv[i], saved_out_file_name);
>> + }
>> + }
>> + }
>> +--
>> +2.7.4
>> +
>>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 195 bytes
Desc: OpenPGP digital signature
URL: <http://lists.openembedded.org/pipermail/openembedded-core/attachments/20180816/3a20f7b8/attachment-0002.sig>
More information about the Openembedded-core
mailing list