[OE-core] [PATCH 1/1] binutils: Improve check for input file matching output file

Robert Yang liezhi.yang at windriver.com
Thu Aug 16 06:25:34 UTC 2018



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>

// 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
> +
> 



More information about the Openembedded-core mailing list