nalika / rpms / bash

Forked from rpms/bash 2 years ago
Clone

Blame SOURCES/bash-4.0-nobits.patch

b92f7d
diff -up bash-4.0/execute_cmd.c.nobits bash-4.0/execute_cmd.c
b92f7d
--- bash-4.0/execute_cmd.c.nobits	2009-08-11 11:53:38.000000000 +0200
b92f7d
+++ bash-4.0/execute_cmd.c	2009-08-14 16:18:18.000000000 +0200
b92f7d
@@ -4747,6 +4747,7 @@ shell_execve (command, args, env)
b92f7d
 	      && memcmp (sample, ELFMAG, SELFMAG) == 0)
b92f7d
 	    {
b92f7d
 	      off_t offset = -1;
b92f7d
+              int dynamic_nobits = 0;
b92f7d
 
b92f7d
 	      /* It is an ELF file.  Now determine whether it is dynamically
b92f7d
 		 linked and if yes, get the offset of the interpreter
b92f7d
@@ -4756,13 +4757,61 @@ shell_execve (command, args, env)
b92f7d
 		{
b92f7d
 		  Elf32_Ehdr ehdr;
b92f7d
 		  Elf32_Phdr *phdr;
b92f7d
-		  int nphdr;
b92f7d
+                  Elf32_Shdr *shdr;
b92f7d
+		  int nphdr, nshdr;
b92f7d
 
b92f7d
 		  /* We have to copy the data since the sample buffer
b92f7d
 		     might not be aligned correctly to be accessed as
b92f7d
 		     an Elf32_Ehdr struct.  */
b92f7d
 		  memcpy (&ehdr, sample, sizeof (Elf32_Ehdr));
b92f7d
 
b92f7d
+		  nshdr = ehdr.e_shnum;
b92f7d
+		  shdr = (Elf32_Shdr *) malloc (nshdr * ehdr.e_shentsize);
b92f7d
+                  
b92f7d
+		  if (shdr != NULL)
b92f7d
+		    {
b92f7d
+#ifdef HAVE_PREAD
b92f7d
+		      sample_len = pread (fd, shdr, nshdr * ehdr.e_shentsize,
b92f7d
+					  ehdr.e_shoff);
b92f7d
+#else
b92f7d
+		      if (lseek (fd, ehdr.e_shoff, SEEK_SET) != -1)
b92f7d
+			sample_len = read (fd, shdr,
b92f7d
+					   nshdr * ehdr.e_shentsize);
b92f7d
+		      else
b92f7d
+			sample_len = -1;
b92f7d
+#endif
b92f7d
+		      if (sample_len == nshdr * ehdr.e_shentsize)
b92f7d
+                        {
b92f7d
+                          char *strings = (char *) malloc (shdr[ehdr.e_shstrndx].sh_size);
b92f7d
+                          if (strings != NULL)
b92f7d
+                            {
b92f7d
+#ifdef HAVE_PREAD
b92f7d
+		              sample_len = pread (fd, strings,
b92f7d
+                                             shdr[ehdr.e_shstrndx].sh_size,
b92f7d
+					     shdr[ehdr.e_shstrndx].sh_offset);
b92f7d
+#else
b92f7d
+		              if (lseek (fd, shdr[ehdr.e_shstrndx].sh_offset,
b92f7d
+                                         SEEK_SET) != -1)
b92f7d
+			        sample_len = read (fd, strings,
b92f7d
+			  		       shdr[ehdr.e_shstrndx].sh_size);
b92f7d
+		              else
b92f7d
+			        sample_len = -1;
b92f7d
+#endif
b92f7d
+                              if (sample_len == shdr[ehdr.e_shstrndx].sh_size)
b92f7d
+			        while (nshdr-- > 0)
b92f7d
+                                  if (strcmp (strings + shdr[nshdr].sh_name,
b92f7d
+                                              ".interp") == 0 &&
b92f7d
+                                      shdr[nshdr].sh_type == SHT_NOBITS)
b92f7d
+                                    {
b92f7d
+                                      dynamic_nobits++;
b92f7d
+                                      break;
b92f7d
+                                    }
b92f7d
+                              free (strings);
b92f7d
+                            }
b92f7d
+                        }
b92f7d
+		      free (shdr);
b92f7d
+		    }
b92f7d
+
b92f7d
 		  nphdr = ehdr.e_phnum;
b92f7d
 		  phdr = (Elf32_Phdr *) malloc (nphdr * ehdr.e_phentsize);
b92f7d
 		  if (phdr != NULL)
b92f7d
@@ -4792,13 +4841,60 @@ shell_execve (command, args, env)
b92f7d
 		{
b92f7d
 		  Elf64_Ehdr ehdr;
b92f7d
 		  Elf64_Phdr *phdr;
b92f7d
-		  int nphdr;
b92f7d
+                  Elf64_Shdr *shdr;
b92f7d
+		  int nphdr, nshdr;
b92f7d
 
b92f7d
 		  /* We have to copy the data since the sample buffer
b92f7d
 		     might not be aligned correctly to be accessed as
b92f7d
 		     an Elf64_Ehdr struct.  */
b92f7d
 		  memcpy (&ehdr, sample, sizeof (Elf64_Ehdr));
b92f7d
 
b92f7d
+		  nshdr = ehdr.e_shnum;
b92f7d
+		  shdr = (Elf64_Shdr *) malloc (nshdr * ehdr.e_shentsize);
b92f7d
+		  if (shdr != NULL)
b92f7d
+		    {
b92f7d
+#ifdef HAVE_PREAD
b92f7d
+		      sample_len = pread (fd, shdr, nshdr * ehdr.e_shentsize,
b92f7d
+					  ehdr.e_shoff);
b92f7d
+#else
b92f7d
+		      if (lseek (fd, ehdr.e_shoff, SEEK_SET) != -1)
b92f7d
+			sample_len = read (fd, shdr,
b92f7d
+					   nshdr * ehdr.e_shentsize);
b92f7d
+		      else
b92f7d
+			sample_len = -1;
b92f7d
+#endif
b92f7d
+		      if (sample_len == nshdr * ehdr.e_shentsize)
b92f7d
+                        {
b92f7d
+                          char *strings = (char *) malloc (shdr[ehdr.e_shstrndx].sh_size);
b92f7d
+                          if (strings != NULL)
b92f7d
+                            {
b92f7d
+#ifdef HAVE_PREAD
b92f7d
+		              sample_len = pread (fd, strings,
b92f7d
+                                             shdr[ehdr.e_shstrndx].sh_size,
b92f7d
+					     shdr[ehdr.e_shstrndx].sh_offset);
b92f7d
+#else
b92f7d
+		              if (lseek (fd, shdr[ehdr.e_shstrndx].sh_offset,
b92f7d
+                                         SEEK_SET) != -1)
b92f7d
+			        sample_len = read (fd, strings,
b92f7d
+			  		       shdr[ehdr.e_shstrndx].sh_size);
b92f7d
+		              else
b92f7d
+			        sample_len = -1;
b92f7d
+#endif
b92f7d
+                              if (sample_len == shdr[ehdr.e_shstrndx].sh_size)
b92f7d
+			        while (nshdr-- > 0)
b92f7d
+                                  if (strcmp (strings + shdr[nshdr].sh_name,
b92f7d
+                                              ".interp") == 0 &&
b92f7d
+                                      shdr[nshdr].sh_type == SHT_NOBITS)
b92f7d
+                                    {
b92f7d
+                                      dynamic_nobits++;
b92f7d
+                                      break;
b92f7d
+                                    }
b92f7d
+                              free (strings);
b92f7d
+                            }
b92f7d
+                        }
b92f7d
+		      free (shdr);
b92f7d
+		    }
b92f7d
+
b92f7d
 		  nphdr = ehdr.e_phnum;
b92f7d
 		  phdr = (Elf64_Phdr *) malloc (nphdr * ehdr.e_phentsize);
b92f7d
 		  if (phdr != NULL)
b92f7d
@@ -4858,8 +4954,15 @@ shell_execve (command, args, env)
b92f7d
 		    {
b92f7d
 		      close (fd);
b92f7d
 		      errno = i;
b92f7d
-		      sys_error ("%s: %s: bad ELF interpreter", command,
b92f7d
-				 interp);
b92f7d
+                      if (dynamic_nobits > 0)
b92f7d
+                        {
b92f7d
+                          sys_error ("%s: bad ELF interpreter", command);
b92f7d
+                        }
b92f7d
+                      else
b92f7d
+                        {
b92f7d
+		          sys_error ("%s: %s: bad ELF interpreter", command,
b92f7d
+				     interp);
b92f7d
+                        }
b92f7d
 		      free (interp);
b92f7d
 		      return (EX_NOEXEC);
b92f7d
 		    }