[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [XenPPC] PHDR link failure testcase



On Tue, Aug 15, 2006 at 07:46:53PM +0200, Segher Boessenkool wrote:

> That's how it's done, looks good.  I haven't checked the details
> though, look at the resulting image with readelf to check if
> everything is exactly as you want it to be ;-)

From: Tony Breeds <tony@xxxxxxxxxxxxxxxxxx>

This patch explicitly creates 3 program headers and maps the sections
into these sections.  Also adds section to PHDR mappings for .init.data
and __builtin_cmdline.

This avoids the:
        "Not enough room for program +headers (allocated 2, need 3)"
error when NR_CPUS becomes largish.

This has been booted on a JS20.

Signed-off-by: Tony Breeds <tony@xxxxxxxxxxxxxxxxxx>

---
diffstat:
 xen.lds.S |   16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

readelf -l xen/xen-syms:
Elf file type is EXEC (Executable file)
Entry point 0x400100
There are 3 program headers, starting at offset 64

Program Headers:
  Type           Offset             VirtAddr           PhysAddr
                 FileSiz            MemSiz              Flags  Align
  LOAD           0x0000000000000000 0x0000000000400000 0x0000000000400000
                 0x0000000000069788 0x0000000000069788  RWE    80
  LOAD           0x0000000000069800 0x0000000000469800 0x0000000000469800
                 0x0000000000253310 0x0000000000253310  RW     80
  LOAD           0x00000000002bcb80 0x00000000006c8000 0x00000000006c8000
                 0x000000000000a2e8 0x000000000001dc60  RW     80

 Section to Segment mapping:
  Segment Sections...
   00     .text .init.text .rodata __ex_table .init.data __builtin_cmdline 
   01     .data .setup.init .initcall.init .inithcall.text 
   02     .opd .got .bss 

---
diff -r 41827ce2cceb xen/arch/powerpc/xen.lds.S
--- a/xen/arch/powerpc/xen.lds.S        Mon Aug 14 19:22:16 2006 -0500
+++ b/xen/arch/powerpc/xen.lds.S        Wed Aug 16 11:36:03 2006 +1000
@@ -10,11 +10,17 @@ SEARCH_DIR("=/usr/local/lib64"); SEARCH_
 SEARCH_DIR("=/usr/local/lib64"); SEARCH_DIR("=/lib64"); 
SEARCH_DIR("=/usr/lib64"); SEARCH_DIR("=/usr/local/lib"); SEARCH_DIR("=/lib"); 
SEARCH_DIR("=/usr/lib");
 /* Do we need any of these for elf?
    __DYNAMIC = 0;    */
+PHDRS
+{
+  text  PT_LOAD FILEHDR PHDRS;
+  data  PT_LOAD;
+  extra PT_LOAD;
+}
 SECTIONS
 {
   /* Read-only sections, merged into text segment: */
   PROVIDE (__executable_start = 0x10000000); . = 0x10000000 + SIZEOF_HEADERS;
-  .interp         : { *(.interp) }
+  .interp         : { *(.interp) } :text
   .hash           : { *(.hash) }
   .dynsym         : { *(.dynsym) }
   .dynstr         : { *(.dynstr) }
@@ -101,11 +107,13 @@ SECTIONS
   PROVIDE (__fini_array_start = .);
   .fini_array     : { *(.fini_array) }
   PROVIDE (__fini_array_end = .);
+  .init.data : { *(.init.data) }
+  __builtin_cmdline : { *(__builtin_cmdline) }
   .data           :
   {
     *(.data .data.* .gnu.linkonce.d.*)
     SORT(CONSTRUCTORS)
-  }
+  } :data
 
   /* Xen addition */
 
@@ -121,7 +129,7 @@ SECTIONS
   __inithcall_end = .;
 
   __per_cpu_start = .;
-  .data.percpu : { *(.data.percpu) } :text
+  .data.percpu : { *(.data.percpu) }
   __per_cpu_data_end = .;
   . = __per_cpu_start + (NR_CPUS << PERCPU_SHIFT);
   . = ALIGN(STACK_SIZE);
@@ -129,7 +137,7 @@ SECTIONS
 
   /* end Xen addition */
 
-  .data1          : { *(.data1) }
+  .data1          : { *(.data1) } :extra
   .tdata         : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
   .tbss                  : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
   .eh_frame       : { KEEP (*(.eh_frame)) }

Yours Tony

   linux.conf.au       http://linux.conf.au/ || http://lca2007.linux.org.au/
   Jan 15-20 2007      The Australian Linux Technical Conference!


_______________________________________________
Xen-ppc-devel mailing list
Xen-ppc-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-ppc-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.