1 // testfile.cc -- Dummy ELF objects for testing purposes.
2 
3 // Copyright (C) 2006-2014 Free Software Foundation, Inc.
4 // Written by Ian Lance Taylor <iant@google.com>.
5 
6 // This file is part of gold.
7 
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 3 of the License, or
11 // (at your option) any later version.
12 
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 // GNU General Public License for more details.
17 
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the Free Software
20 // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21 // MA 02110-1301, USA.
22 
23 #include "gold.h"
24 
25 #include "target.h"
26 #include "target-select.h"
27 
28 #include "test.h"
29 #include "testfile.h"
30 
31 namespace gold_testsuite
32 {
33 
34 using namespace gold;
35 
36 // A Target used for testing purposes.
37 
38 template<int size, bool big_endian>
39 class Target_test : public Sized_target<size, big_endian>
40 {
41  public:
Target_test()42   Target_test()
43     : Sized_target<size, big_endian>(&test_target_info)
44   { }
45 
46   void
gc_process_relocs(Symbol_table *,Layout *,Sized_relobj_file<size,big_endian> *,unsigned int,unsigned int,const unsigned char *,size_t,Output_section *,bool,size_t,const unsigned char *)47   gc_process_relocs(Symbol_table*, Layout*,
48 		    Sized_relobj_file<size, big_endian>*,
49 		    unsigned int, unsigned int, const unsigned char*, size_t,
50 		    Output_section*, bool, size_t, const unsigned char*)
51   { ERROR("call to Target_test::gc_process_relocs"); }
52 
53   void
scan_relocs(Symbol_table *,Layout *,Sized_relobj_file<size,big_endian> *,unsigned int,unsigned int,const unsigned char *,size_t,Output_section *,bool,size_t,const unsigned char *)54   scan_relocs(Symbol_table*, Layout*, Sized_relobj_file<size, big_endian>*,
55 	      unsigned int, unsigned int, const unsigned char*, size_t,
56 	      Output_section*, bool, size_t, const unsigned char*)
57   { ERROR("call to Target_test::scan_relocs"); }
58 
59   void
relocate_section(const Relocate_info<size,big_endian> *,unsigned int,const unsigned char *,size_t,Output_section *,bool,unsigned char *,typename elfcpp::Elf_types<size>::Elf_Addr,section_size_type,const Reloc_symbol_changes *)60   relocate_section(const Relocate_info<size, big_endian>*, unsigned int,
61 		   const unsigned char*, size_t, Output_section*, bool,
62 		   unsigned char*, typename elfcpp::Elf_types<size>::Elf_Addr,
63 		   section_size_type, const Reloc_symbol_changes*)
64   { ERROR("call to Target_test::relocate_section"); }
65 
66   void
scan_relocatable_relocs(Symbol_table *,Layout *,Sized_relobj_file<size,big_endian> *,unsigned int,unsigned int,const unsigned char *,size_t,Output_section *,bool,size_t,const unsigned char *,Relocatable_relocs *)67   scan_relocatable_relocs(Symbol_table*, Layout*,
68 			  Sized_relobj_file<size, big_endian>*, unsigned int,
69 			  unsigned int, const unsigned char*,
70 			  size_t, Output_section*, bool, size_t,
71 			  const unsigned char*, Relocatable_relocs*)
72   { ERROR("call to Target_test::scan_relocatable_relocs"); }
73 
74   void
relocate_relocs(const Relocate_info<size,big_endian> *,unsigned int,const unsigned char *,size_t,Output_section *,typename elfcpp::Elf_types<size>::Elf_Off,const Relocatable_relocs *,unsigned char *,typename elfcpp::Elf_types<size>::Elf_Addr,section_size_type,unsigned char *,section_size_type)75   relocate_relocs(const Relocate_info<size, big_endian>*,
76 		  unsigned int, const unsigned char*, size_t,
77 		  Output_section*, typename elfcpp::Elf_types<size>::Elf_Off,
78                   const Relocatable_relocs*, unsigned char*,
79 		  typename elfcpp::Elf_types<size>::Elf_Addr,
80 		  section_size_type, unsigned char*,
81 		  section_size_type)
82   { ERROR("call to Target_test::relocate_relocs"); }
83 
84   static const Target::Target_info test_target_info;
85 };
86 
87 template<int size, bool big_endian>
88 const Target::Target_info Target_test<size, big_endian>::test_target_info =
89 {
90   size,					// size
91   big_endian,				// is_big_endian
92   static_cast<elfcpp::EM>(0xffff),	// machine_code
93   false,				// has_make_symbol
94   false,				// has_resolve
95   false,				// has_code_fill
96   false,				// is_default_stack_executable
97   false,				// can_icf_inline_merge_sections
98   '\0',					// wrap_char
99   "/dummy",				// dynamic_linker
100   0x08000000,				// default_text_segment_address
101   0x1000,				// abi_pagesize
102   0x1000,				// common_pagesize
103   false,                                // isolate_execinstr
104   0,                                    // rosegment_gap
105   elfcpp::SHN_UNDEF,			// small_common_shndx
106   elfcpp::SHN_UNDEF,			// large_common_shndx
107   0,					// small_common_section_flags
108   0,					// large_common_section_flags
109   NULL,					// attributes_section
110   NULL,					// attributes_vendor
111   "_start"		// entry_symbol_name
112 };
113 
114 // The test targets.
115 
116 #ifdef HAVE_TARGET_32_LITTLE
117 Target_test<32, false> target_test_32_little;
118 #endif
119 
120 #ifdef HAVE_TARGET_32_BIG
121 Target_test<32, true> target_test_32_big;
122 #endif
123 
124 #ifdef HAVE_TARGET_64_LITTLE
125 Target_test<64, false> target_test_64_little;
126 #endif
127 
128 #ifdef HAVE_TARGET_64_BIG
129 Target_test<64, true> target_test_64_big;
130 #endif
131 
132 // A pointer to the test targets.  This is used in CHECKs.
133 
134 #ifdef HAVE_TARGET_32_LITTLE
135 Target* target_test_pointer_32_little = &target_test_32_little;
136 #endif
137 
138 #ifdef HAVE_TARGET_32_BIG
139 Target* target_test_pointer_32_big = &target_test_32_big;
140 #endif
141 
142 #ifdef HAVE_TARGET_64_LITTLE
143 Target* target_test_pointer_64_little = &target_test_64_little;
144 #endif
145 
146 #ifdef HAVE_TARGET_64_BIG
147 Target* target_test_pointer_64_big = &target_test_64_big;
148 #endif
149 
150 // Select the test targets.
151 
152 template<int size, bool big_endian>
153 class Target_selector_test : public Target_selector
154 {
155  public:
Target_selector_test()156   Target_selector_test()
157     : Target_selector(0xffff, size, big_endian, NULL, NULL)
158   { }
159 
160   virtual Target*
do_instantiate_target()161   do_instantiate_target()
162   {
163     gold_unreachable();
164     return NULL;
165   }
166 
167   virtual Target*
do_recognize(Input_file *,off_t,int,int,int)168   do_recognize(Input_file*, off_t, int, int, int)
169   {
170     if (size == 32)
171       {
172 	if (!big_endian)
173 	  {
174 #ifdef HAVE_TARGET_32_LITTLE
175 	    return &target_test_32_little;
176 #endif
177 	  }
178 	else
179 	  {
180 #ifdef HAVE_TARGET_32_BIG
181 	    return &target_test_32_big;
182 #endif
183 	  }
184       }
185     else
186       {
187 	if (!big_endian)
188 	  {
189 #ifdef HAVE_TARGET_64_LITTLE
190 	    return &target_test_64_little;
191 #endif
192 	  }
193 	else
194 	  {
195 #ifdef HAVE_TARGET_64_BIG
196 	    return &target_test_64_big;
197 #endif
198 	  }
199       }
200 
201     return NULL;
202   }
203 
204   virtual Target*
do_recognize_by_name(const char *)205   do_recognize_by_name(const char*)
206   { return NULL; }
207 
208   virtual void
do_supported_names(std::vector<const char * > *)209   do_supported_names(std::vector<const char*>*)
210   { }
211 };
212 
213 // Register the test target selectors.  These don't need to be
214 // conditionally compiled, as they will return NULL if there is no
215 // support for them.
216 
217 Target_selector_test<32, false> target_selector_test_32_little;
218 Target_selector_test<32, true> target_selector_test_32_big;
219 Target_selector_test<64, false> target_selector_test_64_little;
220 Target_selector_test<64, true> target_selector_test_64_big;
221 
222 // A simple ELF object with one empty section, named ".test" and one
223 // globally visible symbol named "test".
224 
225 const unsigned char test_file_1_32_little[] =
226 {
227   // Ehdr
228   // EI_MAG[0-3]
229   0x7f, 'E', 'L', 'F',
230   // EI_CLASS: 32 bit.
231   1,
232   // EI_DATA: little endian
233   1,
234   // EI_VERSION
235   1,
236   // EI_OSABI
237   0,
238   // EI_ABIVERSION
239   0,
240   // EI_PAD
241   0, 0, 0, 0, 0, 0, 0,
242   // e_type: ET_REL
243   1, 0,
244   // e_machine: a magic value used for testing.
245   0xff, 0xff,
246   // e_version
247   1, 0, 0, 0,
248   // e_entry
249   0, 0, 0, 0,
250   // e_phoff
251   0, 0, 0, 0,
252   // e_shoff: starts right after file header
253   52, 0, 0, 0,
254   // e_flags
255   0, 0, 0, 0,
256   // e_ehsize
257   52, 0,
258   // e_phentsize
259   32, 0,
260   // e_phnum
261   0, 0,
262   // e_shentsize
263   40, 0,
264   // e_shnum: dummy, .test, .symtab, .strtab, .shstrtab
265   5, 0,
266   // e_shstrndx
267   4, 0,
268 
269   // Offset 52
270   // Shdr 0: dummy entry
271   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
272   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
273   0, 0, 0, 0, 0, 0, 0, 0,
274 
275   // Offset 92
276   // Shdr 1: .test
277   // sh_name: after initial null
278   1, 0, 0, 0,
279   // sh_type: SHT_PROGBITS
280   1, 0, 0, 0,
281   // sh_flags: SHF_ALLOC
282   2, 0, 0, 0,
283   // sh_addr
284   0, 0, 0, 0,
285   // sh_offset: after file header + 5 section headers
286   252, 0, 0, 0,
287   // sh_size
288   0, 0, 0, 0,
289   // sh_link
290   0, 0, 0, 0,
291   // sh_info
292   0, 0, 0, 0,
293   // sh_addralign
294   1, 0, 0, 0,
295   // sh_entsize
296   0, 0, 0, 0,
297 
298   // Offset 132
299   // Shdr 2: .symtab
300   // sh_name: 1 null byte + ".test\0"
301   7, 0, 0, 0,
302   // sh_type: SHT_SYMTAB
303   2, 0, 0, 0,
304   // sh_flags
305   0, 0, 0, 0,
306   // sh_addr
307   0, 0, 0, 0,
308   // sh_offset: after file header + 5 section headers + empty section
309   252, 0, 0, 0,
310   // sh_size: two symbols: dummy symbol + test symbol
311   32, 0, 0, 0,
312   // sh_link: to .strtab
313   3, 0, 0, 0,
314   // sh_info: one local symbol, the dummy symbol
315   1, 0, 0, 0,
316   // sh_addralign
317   4, 0, 0, 0,
318   // sh_entsize: size of symbol
319   16, 0, 0, 0,
320 
321   // Offset 172
322   // Shdr 3: .strtab
323   // sh_name: 1 null byte + ".test\0" + ".symtab\0"
324   15, 0, 0, 0,
325   // sh_type: SHT_STRTAB
326   3, 0, 0, 0,
327   // sh_flags
328   0, 0, 0, 0,
329   // sh_addr
330   0, 0, 0, 0,
331   // sh_offset: after .symtab section.  284 == 0x11c
332   0x1c, 0x1, 0, 0,
333   // sh_size: 1 null byte + "test\0"
334   6, 0, 0, 0,
335   // sh_link
336   0, 0, 0, 0,
337   // sh_info
338   0, 0, 0, 0,
339   // sh_addralign
340   1, 0, 0, 0,
341   // sh_entsize
342   0, 0, 0, 0,
343 
344   // Offset 212
345   // Shdr 4: .shstrtab
346   // sh_name: 1 null byte + ".test\0" + ".symtab\0" + ".strtab\0"
347   23, 0, 0, 0,
348   // sh_type: SHT_STRTAB
349   3, 0, 0, 0,
350   // sh_flags
351   0, 0, 0, 0,
352   // sh_addr
353   0, 0, 0, 0,
354   // sh_offset: after .strtab section.  290 == 0x122
355   0x22, 0x1, 0, 0,
356   // sh_size: all section names
357   33, 0, 0, 0,
358   // sh_link
359   0, 0, 0, 0,
360   // sh_info
361   0, 0, 0, 0,
362   // sh_addralign
363   1, 0, 0, 0,
364   // sh_entsize
365   0, 0, 0, 0,
366 
367   // Offset 252
368   // Contents of .symtab section
369   // Symbol 0
370   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
371 
372   // Offset 268
373   // Symbol 1
374   // st_name
375   1, 0, 0, 0,
376   // st_value
377   0, 0, 0, 0,
378   // st_size
379   0, 0, 0, 0,
380   // st_info: STT_NOTYPE, STB_GLOBAL
381   0x10,
382   // st_other
383   0,
384   // st_shndx: In .test
385   1, 0,
386 
387   // Offset 284
388   // Contents of .strtab section
389   '\0',
390   't', 'e', 's', 't', '\0',
391 
392   // Offset 290
393   // Contents of .shstrtab section
394   '\0',
395   '.', 't', 'e', 's', 't', '\0',
396   '.', 's', 'y', 'm', 't', 'a', 'b', '\0',
397   '.', 's', 't', 'r', 't', 'a', 'b', '\0',
398   '.', 's', 'h', 's', 't', 'r', 't', 'a', 'b', '\0'
399 };
400 
401 const unsigned int test_file_1_size_32_little = sizeof test_file_1_32_little;
402 
403 // 32-bit big-endian version of test_file_1_32_little.
404 
405 const unsigned char test_file_1_32_big[] =
406 {
407   // Ehdr
408   // EI_MAG[0-3]
409   0x7f, 'E', 'L', 'F',
410   // EI_CLASS: 32 bit.
411   1,
412   // EI_DATA: big endian
413   2,
414   // EI_VERSION
415   1,
416   // EI_OSABI
417   0,
418   // EI_ABIVERSION
419   0,
420   // EI_PAD
421   0, 0, 0, 0, 0, 0, 0,
422   // e_type: ET_REL
423   0, 1,
424   // e_machine: a magic value used for testing.
425   0xff, 0xff,
426   // e_version
427   0, 0, 0, 1,
428   // e_entry
429   0, 0, 0, 0,
430   // e_phoff
431   0, 0, 0, 0,
432   // e_shoff: starts right after file header
433   0, 0, 0, 52,
434   // e_flags
435   0, 0, 0, 0,
436   // e_ehsize
437   0, 52,
438   // e_phentsize
439   0, 32,
440   // e_phnum
441   0, 0,
442   // e_shentsize
443   0, 40,
444   // e_shnum: dummy, .test, .symtab, .strtab, .shstrtab
445   0, 5,
446   // e_shstrndx
447   0, 4,
448 
449   // Offset 52
450   // Shdr 0: dummy entry
451   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
452   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
453   0, 0, 0, 0, 0, 0, 0, 0,
454 
455   // Offset 92
456   // Shdr 1: .test
457   // sh_name: after initial null
458   0, 0, 0, 1,
459   // sh_type: SHT_PROGBITS
460   0, 0, 0, 1,
461   // sh_flags: SHF_ALLOC
462   0, 0, 0, 2,
463   // sh_addr
464   0, 0, 0, 0,
465   // sh_offset: after file header + 5 section headers
466   0, 0, 0, 252,
467   // sh_size
468   0, 0, 0, 0,
469   // sh_link
470   0, 0, 0, 0,
471   // sh_info
472   0, 0, 0, 0,
473   // sh_addralign
474   0, 0, 0, 1,
475   // sh_entsize
476   0, 0, 0, 0,
477 
478   // Offset 132
479   // Shdr 2: .symtab
480   // sh_name: 1 null byte + ".test\0"
481   0, 0, 0, 7,
482   // sh_type: SHT_SYMTAB
483   0, 0, 0, 2,
484   // sh_flags
485   0, 0, 0, 0,
486   // sh_addr
487   0, 0, 0, 0,
488   // sh_offset: after file header + 5 section headers + empty section
489   0, 0, 0, 252,
490   // sh_size: two symbols: dummy symbol + test symbol
491   0, 0, 0, 32,
492   // sh_link: to .strtab
493   0, 0, 0, 3,
494   // sh_info: one local symbol, the dummy symbol
495   0, 0, 0, 1,
496   // sh_addralign
497   0, 0, 0, 4,
498   // sh_entsize: size of symbol
499   0, 0, 0, 16,
500 
501   // Offset 172
502   // Shdr 3: .strtab
503   // sh_name: 1 null byte + ".test\0" + ".symtab\0"
504   0, 0, 0, 15,
505   // sh_type: SHT_STRTAB
506   0, 0, 0, 3,
507   // sh_flags
508   0, 0, 0, 0,
509   // sh_addr
510   0, 0, 0, 0,
511   // sh_offset: after .symtab section.  284 == 0x11c
512   0, 0, 0x1, 0x1c,
513   // sh_size: 1 null byte + "test\0"
514   0, 0, 0, 6,
515   // sh_link
516   0, 0, 0, 0,
517   // sh_info
518   0, 0, 0, 0,
519   // sh_addralign
520   0, 0, 0, 1,
521   // sh_entsize
522   0, 0, 0, 0,
523 
524   // Offset 212
525   // Shdr 4: .shstrtab
526   // sh_name: 1 null byte + ".test\0" + ".symtab\0" + ".strtab\0"
527   0, 0, 0, 23,
528   // sh_type: SHT_STRTAB
529   0, 0, 0, 3,
530   // sh_flags
531   0, 0, 0, 0,
532   // sh_addr
533   0, 0, 0, 0,
534   // sh_offset: after .strtab section.  290 == 0x122
535   0, 0, 0x1, 0x22,
536   // sh_size: all section names
537   0, 0, 0, 33,
538   // sh_link
539   0, 0, 0, 0,
540   // sh_info
541   0, 0, 0, 0,
542   // sh_addralign
543   0, 0, 0, 1,
544   // sh_entsize
545   0, 0, 0, 0,
546 
547   // Offset 252
548   // Contents of .symtab section
549   // Symbol 0
550   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
551 
552   // Offset 268
553   // Symbol 1
554   // st_name
555   0, 0, 0, 1,
556   // st_value
557   0, 0, 0, 0,
558   // st_size
559   0, 0, 0, 0,
560   // st_info: STT_NOTYPE, STB_GLOBAL
561   0x10,
562   // st_other
563   0,
564   // st_shndx: In .test
565   0, 1,
566 
567   // Offset 284
568   // Contents of .strtab section
569   '\0',
570   't', 'e', 's', 't', '\0',
571 
572   // Offset 290
573   // Contents of .shstrtab section
574   '\0',
575   '.', 't', 'e', 's', 't', '\0',
576   '.', 's', 'y', 'm', 't', 'a', 'b', '\0',
577   '.', 's', 't', 'r', 't', 'a', 'b', '\0',
578   '.', 's', 'h', 's', 't', 'r', 't', 'a', 'b', '\0'
579 };
580 
581 const unsigned int test_file_1_size_32_big = sizeof test_file_1_32_big;
582 
583 // 64-bit little-endian version of test_file_1_32_little.
584 
585 const unsigned char test_file_1_64_little[] =
586 {
587   // Ehdr
588   // EI_MAG[0-3]
589   0x7f, 'E', 'L', 'F',
590   // EI_CLASS: 64 bit.
591   2,
592   // EI_DATA: little endian
593   1,
594   // EI_VERSION
595   1,
596   // EI_OSABI
597   0,
598   // EI_ABIVERSION
599   0,
600   // EI_PAD
601   0, 0, 0, 0, 0, 0, 0,
602   // e_type: ET_REL
603   1, 0,
604   // e_machine: a magic value used for testing.
605   0xff, 0xff,
606   // e_version
607   1, 0, 0, 0,
608   // e_entry
609   0, 0, 0, 0, 0, 0, 0, 0,
610   // e_phoff
611   0, 0, 0, 0, 0, 0, 0, 0,
612   // e_shoff: starts right after file header
613   64, 0, 0, 0, 0, 0, 0, 0,
614   // e_flags
615   0, 0, 0, 0,
616   // e_ehsize
617   64, 0,
618   // e_phentsize
619   56, 0,
620   // e_phnum
621   0, 0,
622   // e_shentsize
623   64, 0,
624   // e_shnum: dummy, .test, .symtab, .strtab, .shstrtab
625   5, 0,
626   // e_shstrndx
627   4, 0,
628 
629   // Offset 64
630   // Shdr 0: dummy entry
631   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
632   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
633   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
634   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
635 
636   // Offset 128
637   // Shdr 1: .test
638   // sh_name: after initial null
639   1, 0, 0, 0,
640   // sh_type: SHT_PROGBITS
641   1, 0, 0, 0,
642   // sh_flags: SHF_ALLOC
643   2, 0, 0, 0, 0, 0, 0, 0,
644   // sh_addr
645   0, 0, 0, 0, 0, 0, 0, 0,
646   // sh_offset: after file header + 5 section headers.  384 == 0x180.
647   0x80, 0x1, 0, 0, 0, 0, 0, 0,
648   // sh_size
649   0, 0, 0, 0, 0, 0, 0, 0,
650   // sh_link
651   0, 0, 0, 0,
652   // sh_info
653   0, 0, 0, 0,
654   // sh_addralign
655   1, 0, 0, 0, 0, 0, 0, 0,
656   // sh_entsize
657   0, 0, 0, 0, 0, 0, 0, 0,
658 
659   // Offset 192
660   // Shdr 2: .symtab
661   // sh_name: 1 null byte + ".test\0"
662   7, 0, 0, 0,
663   // sh_type: SHT_SYMTAB
664   2, 0, 0, 0,
665   // sh_flags
666   0, 0, 0, 0, 0, 0, 0, 0,
667   // sh_addr
668   0, 0, 0, 0, 0, 0, 0, 0,
669   // sh_offset: after file header + 5 section headers + empty section
670   // 384 == 0x180.
671   0x80, 0x1, 0, 0, 0, 0, 0, 0,
672   // sh_size: two symbols: dummy symbol + test symbol
673   48, 0, 0, 0, 0, 0, 0, 0,
674   // sh_link: to .strtab
675   3, 0, 0, 0,
676   // sh_info: one local symbol, the dummy symbol
677   1, 0, 0, 0,
678   // sh_addralign
679   8, 0, 0, 0, 0, 0, 0, 0,
680   // sh_entsize: size of symbol
681   24, 0, 0, 0, 0, 0, 0, 0,
682 
683   // Offset 256
684   // Shdr 3: .strtab
685   // sh_name: 1 null byte + ".test\0" + ".symtab\0"
686   15, 0, 0, 0,
687   // sh_type: SHT_STRTAB
688   3, 0, 0, 0,
689   // sh_flags
690   0, 0, 0, 0, 0, 0, 0, 0,
691   // sh_addr
692   0, 0, 0, 0, 0, 0, 0, 0,
693   // sh_offset: after .symtab section.  432 == 0x1b0
694   0xb0, 0x1, 0, 0, 0, 0, 0, 0,
695   // sh_size: 1 null byte + "test\0"
696   6, 0, 0, 0, 0, 0, 0, 0,
697   // sh_link
698   0, 0, 0, 0,
699   // sh_info
700   0, 0, 0, 0,
701   // sh_addralign
702   1, 0, 0, 0, 0, 0, 0, 0,
703   // sh_entsize
704   0, 0, 0, 0, 0, 0, 0, 0,
705 
706   // Offset 320
707   // Shdr 4: .shstrtab
708   // sh_name: 1 null byte + ".test\0" + ".symtab\0" + ".strtab\0"
709   23, 0, 0, 0,
710   // sh_type: SHT_STRTAB
711   3, 0, 0, 0,
712   // sh_flags
713   0, 0, 0, 0, 0, 0, 0, 0,
714   // sh_addr
715   0, 0, 0, 0, 0, 0, 0, 0,
716   // sh_offset: after .strtab section.  438 == 0x1b6
717   0xb6, 0x1, 0, 0, 0, 0, 0, 0,
718   // sh_size: all section names
719   33, 0, 0, 0, 0, 0, 0, 0,
720   // sh_link
721   0, 0, 0, 0,
722   // sh_info
723   0, 0, 0, 0,
724   // sh_addralign
725   1, 0, 0, 0, 0, 0, 0, 0,
726   // sh_entsize
727   0, 0, 0, 0, 0, 0, 0, 0,
728 
729   // Offset 384
730   // Contents of .symtab section
731   // Symbol 0
732   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
733   0, 0, 0, 0, 0, 0, 0, 0,
734 
735   // Offset 408
736   // Symbol 1
737   // st_name
738   1, 0, 0, 0,
739   // st_info: STT_NOTYPE, STB_GLOBAL
740   0x10,
741   // st_other
742   0,
743   // st_shndx: In .test
744   1, 0,
745   // st_value
746   0, 0, 0, 0, 0, 0, 0, 0,
747   // st_size
748   0, 0, 0, 0, 0, 0, 0, 0,
749 
750   // Offset 432
751   // Contents of .strtab section
752   '\0',
753   't', 'e', 's', 't', '\0',
754 
755   // Offset 438
756   // Contents of .shstrtab section
757   '\0',
758   '.', 't', 'e', 's', 't', '\0',
759   '.', 's', 'y', 'm', 't', 'a', 'b', '\0',
760   '.', 's', 't', 'r', 't', 'a', 'b', '\0',
761   '.', 's', 'h', 's', 't', 'r', 't', 'a', 'b', '\0'
762 };
763 
764 const unsigned int test_file_1_size_64_little = sizeof test_file_1_64_little;
765 
766 // 64-bit big-endian version of test_file_1_32_little.
767 
768 const unsigned char test_file_1_64_big[] =
769 {
770   // Ehdr
771   // EI_MAG[0-3]
772   0x7f, 'E', 'L', 'F',
773   // EI_CLASS: 64 bit.
774   2,
775   // EI_DATA: big endian
776   2,
777   // EI_VERSION
778   1,
779   // EI_OSABI
780   0,
781   // EI_ABIVERSION
782   0,
783   // EI_PAD
784   0, 0, 0, 0, 0, 0, 0,
785   // e_type: ET_REL
786   0, 1,
787   // e_machine: a magic value used for testing.
788   0xff, 0xff,
789   // e_version
790   0, 0, 0, 1,
791   // e_entry
792   0, 0, 0, 0, 0, 0, 0, 0,
793   // e_phoff
794   0, 0, 0, 0, 0, 0, 0, 0,
795   // e_shoff: starts right after file header
796   0, 0, 0, 0, 0, 0, 0, 64,
797   // e_flags
798   0, 0, 0, 0,
799   // e_ehsize
800   0, 64,
801   // e_phentsize
802   0, 56,
803   // e_phnum
804   0, 0,
805   // e_shentsize
806   0, 64,
807   // e_shnum: dummy, .test, .symtab, .strtab, .shstrtab
808   0, 5,
809   // e_shstrndx
810   0, 4,
811 
812   // Offset 64
813   // Shdr 0: dummy entry
814   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
815   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
816   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
817   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
818 
819   // Offset 128
820   // Shdr 1: .test
821   // sh_name: after initial null
822   0, 0, 0, 1,
823   // sh_type: SHT_PROGBITS
824   0, 0, 0, 1,
825   // sh_flags: SHF_ALLOC
826   0, 0, 0, 0, 0, 0, 0, 2,
827   // sh_addr
828   0, 0, 0, 0, 0, 0, 0, 0,
829   // sh_offset: after file header + 5 section headers.  384 == 0x180.
830   0, 0, 0, 0, 0, 0, 0x1, 0x80,
831   // sh_size
832   0, 0, 0, 0, 0, 0, 0, 0,
833   // sh_link
834   0, 0, 0, 0,
835   // sh_info
836   0, 0, 0, 0,
837   // sh_addralign
838   0, 0, 0, 0, 0, 0, 0, 1,
839   // sh_entsize
840   0, 0, 0, 0, 0, 0, 0, 0,
841 
842   // Offset 192
843   // Shdr 2: .symtab
844   // sh_name: 1 null byte + ".test\0"
845   0, 0, 0, 7,
846   // sh_type: SHT_SYMTAB
847   0, 0, 0, 2,
848   // sh_flags
849   0, 0, 0, 0, 0, 0, 0, 0,
850   // sh_addr
851   0, 0, 0, 0, 0, 0, 0, 0,
852   // sh_offset: after file header + 5 section headers + empty section
853   // 384 == 0x180.
854   0, 0, 0, 0, 0, 0, 0x1, 0x80,
855   // sh_size: two symbols: dummy symbol + test symbol
856   0, 0, 0, 0, 0, 0, 0, 48,
857   // sh_link: to .strtab
858   0, 0, 0, 3,
859   // sh_info: one local symbol, the dummy symbol
860   0, 0, 0, 1,
861   // sh_addralign
862   0, 0, 0, 0, 0, 0, 0, 8,
863   // sh_entsize: size of symbol
864   0, 0, 0, 0, 0, 0, 0, 24,
865 
866   // Offset 256
867   // Shdr 3: .strtab
868   // sh_name: 1 null byte + ".test\0" + ".symtab\0"
869   0, 0, 0, 15,
870   // sh_type: SHT_STRTAB
871   0, 0, 0, 3,
872   // sh_flags
873   0, 0, 0, 0, 0, 0, 0, 0,
874   // sh_addr
875   0, 0, 0, 0, 0, 0, 0, 0,
876   // sh_offset: after .symtab section.  432 == 0x1b0
877   0, 0, 0, 0, 0, 0, 0x1, 0xb0,
878   // sh_size: 1 null byte + "test\0"
879   0, 0, 0, 0, 0, 0, 0, 6,
880   // sh_link
881   0, 0, 0, 0,
882   // sh_info
883   0, 0, 0, 0,
884   // sh_addralign
885   0, 0, 0, 0, 0, 0, 0, 1,
886   // sh_entsize
887   0, 0, 0, 0, 0, 0, 0, 0,
888 
889   // Offset 320
890   // Shdr 4: .shstrtab
891   // sh_name: 1 null byte + ".test\0" + ".symtab\0" + ".strtab\0"
892   0, 0, 0, 23,
893   // sh_type: SHT_STRTAB
894   0, 0, 0, 3,
895   // sh_flags
896   0, 0, 0, 0, 0, 0, 0, 0,
897   // sh_addr
898   0, 0, 0, 0, 0, 0, 0, 0,
899   // sh_offset: after .strtab section.  438 == 0x1b6
900   0, 0, 0, 0, 0, 0, 0x1, 0xb6,
901   // sh_size: all section names
902   0, 0, 0, 0, 0, 0, 0, 33,
903   // sh_link
904   0, 0, 0, 0,
905   // sh_info
906   0, 0, 0, 0,
907   // sh_addralign
908   0, 0, 0, 0, 0, 0, 0, 1,
909   // sh_entsize
910   0, 0, 0, 0, 0, 0, 0, 0,
911 
912   // Offset 384
913   // Contents of .symtab section
914   // Symbol 0
915   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
916   0, 0, 0, 0, 0, 0, 0, 0,
917 
918   // Offset 408
919   // Symbol 1
920   // st_name
921   0, 0, 0, 1,
922   // st_info: STT_NOTYPE, STB_GLOBAL
923   0x10,
924   // st_other
925   0,
926   // st_shndx: In .test
927   0, 1,
928   // st_value
929   0, 0, 0, 0, 0, 0, 0, 0,
930   // st_size
931   0, 0, 0, 0, 0, 0, 0, 0,
932 
933   // Offset 432
934   // Contents of .strtab section
935   '\0',
936   't', 'e', 's', 't', '\0',
937 
938   // Offset 438
939   // Contents of .shstrtab section
940   '\0',
941   '.', 't', 'e', 's', 't', '\0',
942   '.', 's', 'y', 'm', 't', 'a', 'b', '\0',
943   '.', 's', 't', 'r', 't', 'a', 'b', '\0',
944   '.', 's', 'h', 's', 't', 'r', 't', 'a', 'b', '\0'
945 };
946 
947 const unsigned int test_file_1_size_64_big = sizeof test_file_1_64_big;
948 
949 } // End namespace gold_testsuite.
950