We don't need our own architecture macros; the standard ones will do. This patch also fixes some __x86_64__ tests to be USE_RELA tests instead, because they're not actually x86_64-specific. I've cleaned up architecture-specific code slightly so where possible all the code corresponding to a particular architecture is together. This patch also fixes a bug in LP64 DT_PLTGOT handling, which should be an error rather than falling through into DT_DEBUG! There was another #ifdef bug where we'd only report unexpected DT_ entries on MIPS. Change-Id: Id1d04e372611f641c1aa278a18e379f28af9eaf5
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (C) 2012 The Android Open Source Project
 | 
						|
 * All rights reserved.
 | 
						|
 *
 | 
						|
 * Redistribution and use in source and binary forms, with or without
 | 
						|
 * modification, are permitted provided that the following conditions
 | 
						|
 * are met:
 | 
						|
 *  * Redistributions of source code must retain the above copyright
 | 
						|
 *    notice, this list of conditions and the following disclaimer.
 | 
						|
 *  * Redistributions in binary form must reproduce the above copyright
 | 
						|
 *    notice, this list of conditions and the following disclaimer in
 | 
						|
 *    the documentation and/or other materials provided with the
 | 
						|
 *    distribution.
 | 
						|
 *
 | 
						|
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 | 
						|
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | 
						|
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 | 
						|
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 | 
						|
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 | 
						|
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 | 
						|
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
 | 
						|
 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
 | 
						|
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 | 
						|
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 | 
						|
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 | 
						|
 * SUCH DAMAGE.
 | 
						|
 */
 | 
						|
#ifndef LINKER_PHDR_H
 | 
						|
#define LINKER_PHDR_H
 | 
						|
 | 
						|
/* Declarations related to the ELF program header table and segments.
 | 
						|
 *
 | 
						|
 * The design goal is to provide an API that is as close as possible
 | 
						|
 * to the ELF spec, and does not depend on linker-specific data
 | 
						|
 * structures (e.g. the exact layout of struct soinfo).
 | 
						|
 */
 | 
						|
 | 
						|
#include "linker.h"
 | 
						|
 | 
						|
class ElfReader {
 | 
						|
 public:
 | 
						|
  ElfReader(const char* name, int fd);
 | 
						|
  ~ElfReader();
 | 
						|
 | 
						|
  bool Load();
 | 
						|
 | 
						|
  size_t phdr_count() { return phdr_num_; }
 | 
						|
  Elf_Addr load_start() { return reinterpret_cast<Elf_Addr>(load_start_); }
 | 
						|
  size_t load_size() { return load_size_; }
 | 
						|
  Elf_Addr load_bias() { return load_bias_; }
 | 
						|
  const Elf_Phdr* loaded_phdr() { return loaded_phdr_; }
 | 
						|
 | 
						|
 private:
 | 
						|
  bool ReadElfHeader();
 | 
						|
  bool VerifyElfHeader();
 | 
						|
  bool ReadProgramHeader();
 | 
						|
  bool ReserveAddressSpace();
 | 
						|
  bool LoadSegments();
 | 
						|
  bool FindPhdr();
 | 
						|
  bool CheckPhdr(Elf_Addr);
 | 
						|
 | 
						|
  const char* name_;
 | 
						|
  int fd_;
 | 
						|
 | 
						|
  Elf_Ehdr header_;
 | 
						|
  size_t phdr_num_;
 | 
						|
 | 
						|
  void* phdr_mmap_;
 | 
						|
  Elf_Phdr* phdr_table_;
 | 
						|
  Elf_Addr phdr_size_;
 | 
						|
 | 
						|
  // First page of reserved address space.
 | 
						|
  void* load_start_;
 | 
						|
  // Size in bytes of reserved address space.
 | 
						|
  size_t load_size_;
 | 
						|
  // Load bias.
 | 
						|
  Elf_Addr load_bias_;
 | 
						|
 | 
						|
  // Loaded phdr.
 | 
						|
  const Elf_Phdr* loaded_phdr_;
 | 
						|
};
 | 
						|
 | 
						|
size_t phdr_table_get_load_size(const Elf_Phdr* phdr_table, size_t phdr_count,
 | 
						|
                                Elf_Addr* min_vaddr = NULL, Elf_Addr* max_vaddr = NULL);
 | 
						|
 | 
						|
int phdr_table_protect_segments(const Elf_Phdr* phdr_table, size_t phdr_count, Elf_Addr load_bias);
 | 
						|
 | 
						|
int phdr_table_unprotect_segments(const Elf_Phdr* phdr_table, size_t phdr_count, Elf_Addr load_bias);
 | 
						|
 | 
						|
int phdr_table_protect_gnu_relro(const Elf_Phdr* phdr_table, size_t phdr_count, Elf_Addr load_bias);
 | 
						|
 | 
						|
 | 
						|
#if defined(__arm__)
 | 
						|
int phdr_table_get_arm_exidx(const Elf_Phdr* phdr_table, size_t phdr_count, Elf_Addr load_bias,
 | 
						|
                             Elf_Addr** arm_exidx, unsigned* arm_exidix_count);
 | 
						|
#endif
 | 
						|
 | 
						|
void phdr_table_get_dynamic_section(const Elf_Phdr* phdr_table, size_t phdr_count,
 | 
						|
                                    Elf_Addr load_bias,
 | 
						|
                                    Elf_Dyn** dynamic, size_t* dynamic_count, Elf_Word* dynamic_flags);
 | 
						|
 | 
						|
#endif /* LINKER_PHDR_H */
 |