GNU LD Script to catch C++ group / dynsym Sections











up vote
0
down vote

favorite












I'm maintaining a tool which can convert ELF32 relocatables to RDOFF2 format.

For this process to work I need to pre-link the input files currently using the ld-script shown below:



OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
OUTPUT_ARCH(i386)
FORCE_COMMON_ALLOCATION

SECTIONS {
.text : {
/* collect .init / .fini sections */

PROVIDE_HIDDEN(__init_start = .);
KEEP (*(.init))
PROVIDE_HIDDEN(__init_end = .);

PROVIDE_HIDDEN(__fini_start = .);
KEEP (*(.fini))
PROVIDE_HIDDEN(__fini_end = .);

/* .text and .rodata */

*(.text .text.* .gnu.linkonce.t.*)
*(.rodata .rodata.* .gnu.linkonce.r.*)
*(.rodata1)


/* .init- / .fini_arrays */

PROVIDE_HIDDEN (__preinit_array_start = .);
KEEP (*(.preinit_array))
PROVIDE_HIDDEN (__preinit_array_end = .);

PROVIDE_HIDDEN (__init_array_start = .);
KEEP (*(SORT(.init_array.*)))
KEEP (*(.init_array))
PROVIDE_HIDDEN (__init_array_end = .);

PROVIDE_HIDDEN (__fini_array_start = .);
KEEP (*(SORT(.fini_array.*)))
KEEP (*(.fini_array))
PROVIDE_HIDDEN (__fini_array_end = .);
}
.data : {
*(.data .data.* .gnu.linkonce.d.*)
*(.data1)

SORT(CONSTRUCTORS)

/* c++ ctors / dtors and exception tables */

PROVIDE_HIDDEN (__gcc_except_table_start = .);
*(.gcc_except_table .gcc_except_table.*)
PROVIDE_HIDDEN (__gcc_except_table_end = .);

PROVIDE_HIDDEN (__eh_frame_start = .);
*(.eh_frame_hdr)
*(.eh_frame)
PROVIDE_HIDDEN (__eh_frame_end = .);

PROVIDE_HIDDEN (__ctors_array_start = .);
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
PROVIDE_HIDDEN (__ctors_array_end = .);

PROVIDE_HIDDEN (__dtors_array_start = .);
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
PROVIDE_HIDDEN (__dtors_array_end = .);
}
.bss : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)

. = ALIGN(. != 0 ? 32 / 8 : 1);
}
/DISCARD/ : {
*(.note.GNU-stack)
*(.gnu_debuglink)
}
}


The goal is to reduce the input file to contain only .text, .data, .bss, .strtab, .symtab and .shstrtab sections.



While the curren version works fine with C code it breaks for C++ as g++ / ld seem to generate sections of type SHT_DYNSYM named after some of my C++ symbols.



My question: How would one modify the provided linker script to catch those stray symbols?



Here is my example source:



/* compile with g++ -c cxx_hello.cc */
/* generic sys write provided by syswrite_$arch.S */
void _syscall_write(int fd, const char *msg, unsigned len);

void syscall_write(int fd, const char *msg, unsigned len)
{
_syscall_write(fd, msg, len);
}

class HelloBase
{
public:
HelloBase() { syscall_write(1, "::HelloBase()n", 14); i = 42; };
~HelloBase() { syscall_write(1, "::~HelloBase()n", 15); };
int res(void) { return i; }
protected:
void sayHi(void) { syscall_write(1, "Hello", 5); };
private:
int i;
};

class HelloDeriv : public HelloBase
{
public:
HelloDeriv() { syscall_write(1, "::HelloDeriv()n", 15); }
~HelloDeriv() { syscall_write(1, "::~HelloDeriv()n", 16); }

void greet(void) { this->sayHi(); syscall_write(1, ", World!n", 9); }
};

int
_main(void)
{
HelloDeriv hello;

hello.greet();
return hello.res();
}


The output of objdump -h (only interesting sections):



cxx_hello.o:     file format elf32-i386

Sections:
Idx Name Size VMA LMA File off Algn
0 _ZN9HelloBase3resEv 00000008 00000000 00000000 00000034 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

1 _ZN9HelloBaseC2Ev 00000008 00000000 00000000 0000003c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

2 _ZN9HelloBaseD2Ev 00000008 00000000 00000000 00000044 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

3 _ZN10HelloDerivC1Ev 00000008 00000000 00000000 0000004c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

4 _ZN9HelloBase5sayHiEv 00000008 00000000 00000000 00000054 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

5 _ZN10HelloDeriv5greetEv 00000008 00000000 00000000 0000005c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

6 _ZN10HelloDerivD1Ev 00000008 00000000 00000000 00000064 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

7 .text 00000000 00000000 00000000 0000006c 2**2
CONTENTS, ALLOC, LOAD, READONLY, CODE

8 .data 00000000 00000000 00000000 0000006c 2**2

CONTENTS, ALLOC, LOAD, DATA
9 .bss 00000000 00000000 00000000 0000006c 2**2
ALLOC


The same file with readelf -S



There are 37 section headers, starting at offset 0x59c:

Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 0] NULL 00000000 000000 000000 00 0 0 0
[ 1] .group GROUP 00000000 000034 000008 04 35 26 4
[ 2] .group GROUP 00000000 00003c 000008 04 35 30 4
[ 3] .group GROUP 00000000 000044 000008 04 35 31 4
[ 4] .group GROUP 00000000 00004c 000008 04 35 33 4
[ 5] .group GROUP 00000000 000054 000008 04 35 34 4
[ 6] .group GROUP 00000000 00005c 000008 04 35 35 4
[ 7] .group GROUP 00000000 000064 000008 04 35 36 4
[ 8] .text PROGBITS 00000000 00006c 000000 00 AX 0 0 4
[ 9] .data PROGBITS 00000000 00006c 000000 00 WA 0 0 4
[10] .bss NOBITS 00000000 00006c 000000 00 WA 0 0 4









share|improve this question
























  • Further investigations (even the the linker sources..) didn't reveal any news :(
    – Shirkrin
    Oct 28 '09 at 16:11










  • I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
    – Shirkrin
    Nov 23 '11 at 13:38















up vote
0
down vote

favorite












I'm maintaining a tool which can convert ELF32 relocatables to RDOFF2 format.

For this process to work I need to pre-link the input files currently using the ld-script shown below:



OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
OUTPUT_ARCH(i386)
FORCE_COMMON_ALLOCATION

SECTIONS {
.text : {
/* collect .init / .fini sections */

PROVIDE_HIDDEN(__init_start = .);
KEEP (*(.init))
PROVIDE_HIDDEN(__init_end = .);

PROVIDE_HIDDEN(__fini_start = .);
KEEP (*(.fini))
PROVIDE_HIDDEN(__fini_end = .);

/* .text and .rodata */

*(.text .text.* .gnu.linkonce.t.*)
*(.rodata .rodata.* .gnu.linkonce.r.*)
*(.rodata1)


/* .init- / .fini_arrays */

PROVIDE_HIDDEN (__preinit_array_start = .);
KEEP (*(.preinit_array))
PROVIDE_HIDDEN (__preinit_array_end = .);

PROVIDE_HIDDEN (__init_array_start = .);
KEEP (*(SORT(.init_array.*)))
KEEP (*(.init_array))
PROVIDE_HIDDEN (__init_array_end = .);

PROVIDE_HIDDEN (__fini_array_start = .);
KEEP (*(SORT(.fini_array.*)))
KEEP (*(.fini_array))
PROVIDE_HIDDEN (__fini_array_end = .);
}
.data : {
*(.data .data.* .gnu.linkonce.d.*)
*(.data1)

SORT(CONSTRUCTORS)

/* c++ ctors / dtors and exception tables */

PROVIDE_HIDDEN (__gcc_except_table_start = .);
*(.gcc_except_table .gcc_except_table.*)
PROVIDE_HIDDEN (__gcc_except_table_end = .);

PROVIDE_HIDDEN (__eh_frame_start = .);
*(.eh_frame_hdr)
*(.eh_frame)
PROVIDE_HIDDEN (__eh_frame_end = .);

PROVIDE_HIDDEN (__ctors_array_start = .);
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
PROVIDE_HIDDEN (__ctors_array_end = .);

PROVIDE_HIDDEN (__dtors_array_start = .);
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
PROVIDE_HIDDEN (__dtors_array_end = .);
}
.bss : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)

. = ALIGN(. != 0 ? 32 / 8 : 1);
}
/DISCARD/ : {
*(.note.GNU-stack)
*(.gnu_debuglink)
}
}


The goal is to reduce the input file to contain only .text, .data, .bss, .strtab, .symtab and .shstrtab sections.



While the curren version works fine with C code it breaks for C++ as g++ / ld seem to generate sections of type SHT_DYNSYM named after some of my C++ symbols.



My question: How would one modify the provided linker script to catch those stray symbols?



Here is my example source:



/* compile with g++ -c cxx_hello.cc */
/* generic sys write provided by syswrite_$arch.S */
void _syscall_write(int fd, const char *msg, unsigned len);

void syscall_write(int fd, const char *msg, unsigned len)
{
_syscall_write(fd, msg, len);
}

class HelloBase
{
public:
HelloBase() { syscall_write(1, "::HelloBase()n", 14); i = 42; };
~HelloBase() { syscall_write(1, "::~HelloBase()n", 15); };
int res(void) { return i; }
protected:
void sayHi(void) { syscall_write(1, "Hello", 5); };
private:
int i;
};

class HelloDeriv : public HelloBase
{
public:
HelloDeriv() { syscall_write(1, "::HelloDeriv()n", 15); }
~HelloDeriv() { syscall_write(1, "::~HelloDeriv()n", 16); }

void greet(void) { this->sayHi(); syscall_write(1, ", World!n", 9); }
};

int
_main(void)
{
HelloDeriv hello;

hello.greet();
return hello.res();
}


The output of objdump -h (only interesting sections):



cxx_hello.o:     file format elf32-i386

Sections:
Idx Name Size VMA LMA File off Algn
0 _ZN9HelloBase3resEv 00000008 00000000 00000000 00000034 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

1 _ZN9HelloBaseC2Ev 00000008 00000000 00000000 0000003c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

2 _ZN9HelloBaseD2Ev 00000008 00000000 00000000 00000044 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

3 _ZN10HelloDerivC1Ev 00000008 00000000 00000000 0000004c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

4 _ZN9HelloBase5sayHiEv 00000008 00000000 00000000 00000054 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

5 _ZN10HelloDeriv5greetEv 00000008 00000000 00000000 0000005c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

6 _ZN10HelloDerivD1Ev 00000008 00000000 00000000 00000064 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

7 .text 00000000 00000000 00000000 0000006c 2**2
CONTENTS, ALLOC, LOAD, READONLY, CODE

8 .data 00000000 00000000 00000000 0000006c 2**2

CONTENTS, ALLOC, LOAD, DATA
9 .bss 00000000 00000000 00000000 0000006c 2**2
ALLOC


The same file with readelf -S



There are 37 section headers, starting at offset 0x59c:

Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 0] NULL 00000000 000000 000000 00 0 0 0
[ 1] .group GROUP 00000000 000034 000008 04 35 26 4
[ 2] .group GROUP 00000000 00003c 000008 04 35 30 4
[ 3] .group GROUP 00000000 000044 000008 04 35 31 4
[ 4] .group GROUP 00000000 00004c 000008 04 35 33 4
[ 5] .group GROUP 00000000 000054 000008 04 35 34 4
[ 6] .group GROUP 00000000 00005c 000008 04 35 35 4
[ 7] .group GROUP 00000000 000064 000008 04 35 36 4
[ 8] .text PROGBITS 00000000 00006c 000000 00 AX 0 0 4
[ 9] .data PROGBITS 00000000 00006c 000000 00 WA 0 0 4
[10] .bss NOBITS 00000000 00006c 000000 00 WA 0 0 4









share|improve this question
























  • Further investigations (even the the linker sources..) didn't reveal any news :(
    – Shirkrin
    Oct 28 '09 at 16:11










  • I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
    – Shirkrin
    Nov 23 '11 at 13:38













up vote
0
down vote

favorite









up vote
0
down vote

favorite











I'm maintaining a tool which can convert ELF32 relocatables to RDOFF2 format.

For this process to work I need to pre-link the input files currently using the ld-script shown below:



OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
OUTPUT_ARCH(i386)
FORCE_COMMON_ALLOCATION

SECTIONS {
.text : {
/* collect .init / .fini sections */

PROVIDE_HIDDEN(__init_start = .);
KEEP (*(.init))
PROVIDE_HIDDEN(__init_end = .);

PROVIDE_HIDDEN(__fini_start = .);
KEEP (*(.fini))
PROVIDE_HIDDEN(__fini_end = .);

/* .text and .rodata */

*(.text .text.* .gnu.linkonce.t.*)
*(.rodata .rodata.* .gnu.linkonce.r.*)
*(.rodata1)


/* .init- / .fini_arrays */

PROVIDE_HIDDEN (__preinit_array_start = .);
KEEP (*(.preinit_array))
PROVIDE_HIDDEN (__preinit_array_end = .);

PROVIDE_HIDDEN (__init_array_start = .);
KEEP (*(SORT(.init_array.*)))
KEEP (*(.init_array))
PROVIDE_HIDDEN (__init_array_end = .);

PROVIDE_HIDDEN (__fini_array_start = .);
KEEP (*(SORT(.fini_array.*)))
KEEP (*(.fini_array))
PROVIDE_HIDDEN (__fini_array_end = .);
}
.data : {
*(.data .data.* .gnu.linkonce.d.*)
*(.data1)

SORT(CONSTRUCTORS)

/* c++ ctors / dtors and exception tables */

PROVIDE_HIDDEN (__gcc_except_table_start = .);
*(.gcc_except_table .gcc_except_table.*)
PROVIDE_HIDDEN (__gcc_except_table_end = .);

PROVIDE_HIDDEN (__eh_frame_start = .);
*(.eh_frame_hdr)
*(.eh_frame)
PROVIDE_HIDDEN (__eh_frame_end = .);

PROVIDE_HIDDEN (__ctors_array_start = .);
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
PROVIDE_HIDDEN (__ctors_array_end = .);

PROVIDE_HIDDEN (__dtors_array_start = .);
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
PROVIDE_HIDDEN (__dtors_array_end = .);
}
.bss : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)

. = ALIGN(. != 0 ? 32 / 8 : 1);
}
/DISCARD/ : {
*(.note.GNU-stack)
*(.gnu_debuglink)
}
}


The goal is to reduce the input file to contain only .text, .data, .bss, .strtab, .symtab and .shstrtab sections.



While the curren version works fine with C code it breaks for C++ as g++ / ld seem to generate sections of type SHT_DYNSYM named after some of my C++ symbols.



My question: How would one modify the provided linker script to catch those stray symbols?



Here is my example source:



/* compile with g++ -c cxx_hello.cc */
/* generic sys write provided by syswrite_$arch.S */
void _syscall_write(int fd, const char *msg, unsigned len);

void syscall_write(int fd, const char *msg, unsigned len)
{
_syscall_write(fd, msg, len);
}

class HelloBase
{
public:
HelloBase() { syscall_write(1, "::HelloBase()n", 14); i = 42; };
~HelloBase() { syscall_write(1, "::~HelloBase()n", 15); };
int res(void) { return i; }
protected:
void sayHi(void) { syscall_write(1, "Hello", 5); };
private:
int i;
};

class HelloDeriv : public HelloBase
{
public:
HelloDeriv() { syscall_write(1, "::HelloDeriv()n", 15); }
~HelloDeriv() { syscall_write(1, "::~HelloDeriv()n", 16); }

void greet(void) { this->sayHi(); syscall_write(1, ", World!n", 9); }
};

int
_main(void)
{
HelloDeriv hello;

hello.greet();
return hello.res();
}


The output of objdump -h (only interesting sections):



cxx_hello.o:     file format elf32-i386

Sections:
Idx Name Size VMA LMA File off Algn
0 _ZN9HelloBase3resEv 00000008 00000000 00000000 00000034 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

1 _ZN9HelloBaseC2Ev 00000008 00000000 00000000 0000003c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

2 _ZN9HelloBaseD2Ev 00000008 00000000 00000000 00000044 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

3 _ZN10HelloDerivC1Ev 00000008 00000000 00000000 0000004c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

4 _ZN9HelloBase5sayHiEv 00000008 00000000 00000000 00000054 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

5 _ZN10HelloDeriv5greetEv 00000008 00000000 00000000 0000005c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

6 _ZN10HelloDerivD1Ev 00000008 00000000 00000000 00000064 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

7 .text 00000000 00000000 00000000 0000006c 2**2
CONTENTS, ALLOC, LOAD, READONLY, CODE

8 .data 00000000 00000000 00000000 0000006c 2**2

CONTENTS, ALLOC, LOAD, DATA
9 .bss 00000000 00000000 00000000 0000006c 2**2
ALLOC


The same file with readelf -S



There are 37 section headers, starting at offset 0x59c:

Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 0] NULL 00000000 000000 000000 00 0 0 0
[ 1] .group GROUP 00000000 000034 000008 04 35 26 4
[ 2] .group GROUP 00000000 00003c 000008 04 35 30 4
[ 3] .group GROUP 00000000 000044 000008 04 35 31 4
[ 4] .group GROUP 00000000 00004c 000008 04 35 33 4
[ 5] .group GROUP 00000000 000054 000008 04 35 34 4
[ 6] .group GROUP 00000000 00005c 000008 04 35 35 4
[ 7] .group GROUP 00000000 000064 000008 04 35 36 4
[ 8] .text PROGBITS 00000000 00006c 000000 00 AX 0 0 4
[ 9] .data PROGBITS 00000000 00006c 000000 00 WA 0 0 4
[10] .bss NOBITS 00000000 00006c 000000 00 WA 0 0 4









share|improve this question















I'm maintaining a tool which can convert ELF32 relocatables to RDOFF2 format.

For this process to work I need to pre-link the input files currently using the ld-script shown below:



OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
OUTPUT_ARCH(i386)
FORCE_COMMON_ALLOCATION

SECTIONS {
.text : {
/* collect .init / .fini sections */

PROVIDE_HIDDEN(__init_start = .);
KEEP (*(.init))
PROVIDE_HIDDEN(__init_end = .);

PROVIDE_HIDDEN(__fini_start = .);
KEEP (*(.fini))
PROVIDE_HIDDEN(__fini_end = .);

/* .text and .rodata */

*(.text .text.* .gnu.linkonce.t.*)
*(.rodata .rodata.* .gnu.linkonce.r.*)
*(.rodata1)


/* .init- / .fini_arrays */

PROVIDE_HIDDEN (__preinit_array_start = .);
KEEP (*(.preinit_array))
PROVIDE_HIDDEN (__preinit_array_end = .);

PROVIDE_HIDDEN (__init_array_start = .);
KEEP (*(SORT(.init_array.*)))
KEEP (*(.init_array))
PROVIDE_HIDDEN (__init_array_end = .);

PROVIDE_HIDDEN (__fini_array_start = .);
KEEP (*(SORT(.fini_array.*)))
KEEP (*(.fini_array))
PROVIDE_HIDDEN (__fini_array_end = .);
}
.data : {
*(.data .data.* .gnu.linkonce.d.*)
*(.data1)

SORT(CONSTRUCTORS)

/* c++ ctors / dtors and exception tables */

PROVIDE_HIDDEN (__gcc_except_table_start = .);
*(.gcc_except_table .gcc_except_table.*)
PROVIDE_HIDDEN (__gcc_except_table_end = .);

PROVIDE_HIDDEN (__eh_frame_start = .);
*(.eh_frame_hdr)
*(.eh_frame)
PROVIDE_HIDDEN (__eh_frame_end = .);

PROVIDE_HIDDEN (__ctors_array_start = .);
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
PROVIDE_HIDDEN (__ctors_array_end = .);

PROVIDE_HIDDEN (__dtors_array_start = .);
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
PROVIDE_HIDDEN (__dtors_array_end = .);
}
.bss : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)

. = ALIGN(. != 0 ? 32 / 8 : 1);
}
/DISCARD/ : {
*(.note.GNU-stack)
*(.gnu_debuglink)
}
}


The goal is to reduce the input file to contain only .text, .data, .bss, .strtab, .symtab and .shstrtab sections.



While the curren version works fine with C code it breaks for C++ as g++ / ld seem to generate sections of type SHT_DYNSYM named after some of my C++ symbols.



My question: How would one modify the provided linker script to catch those stray symbols?



Here is my example source:



/* compile with g++ -c cxx_hello.cc */
/* generic sys write provided by syswrite_$arch.S */
void _syscall_write(int fd, const char *msg, unsigned len);

void syscall_write(int fd, const char *msg, unsigned len)
{
_syscall_write(fd, msg, len);
}

class HelloBase
{
public:
HelloBase() { syscall_write(1, "::HelloBase()n", 14); i = 42; };
~HelloBase() { syscall_write(1, "::~HelloBase()n", 15); };
int res(void) { return i; }
protected:
void sayHi(void) { syscall_write(1, "Hello", 5); };
private:
int i;
};

class HelloDeriv : public HelloBase
{
public:
HelloDeriv() { syscall_write(1, "::HelloDeriv()n", 15); }
~HelloDeriv() { syscall_write(1, "::~HelloDeriv()n", 16); }

void greet(void) { this->sayHi(); syscall_write(1, ", World!n", 9); }
};

int
_main(void)
{
HelloDeriv hello;

hello.greet();
return hello.res();
}


The output of objdump -h (only interesting sections):



cxx_hello.o:     file format elf32-i386

Sections:
Idx Name Size VMA LMA File off Algn
0 _ZN9HelloBase3resEv 00000008 00000000 00000000 00000034 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

1 _ZN9HelloBaseC2Ev 00000008 00000000 00000000 0000003c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

2 _ZN9HelloBaseD2Ev 00000008 00000000 00000000 00000044 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

3 _ZN10HelloDerivC1Ev 00000008 00000000 00000000 0000004c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

4 _ZN9HelloBase5sayHiEv 00000008 00000000 00000000 00000054 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

5 _ZN10HelloDeriv5greetEv 00000008 00000000 00000000 0000005c 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

6 _ZN10HelloDerivD1Ev 00000008 00000000 00000000 00000064 2**2
CONTENTS, READONLY, EXCLUDE, GROUP, LINK_ONCE_DISCARD

7 .text 00000000 00000000 00000000 0000006c 2**2
CONTENTS, ALLOC, LOAD, READONLY, CODE

8 .data 00000000 00000000 00000000 0000006c 2**2

CONTENTS, ALLOC, LOAD, DATA
9 .bss 00000000 00000000 00000000 0000006c 2**2
ALLOC


The same file with readelf -S



There are 37 section headers, starting at offset 0x59c:

Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 0] NULL 00000000 000000 000000 00 0 0 0
[ 1] .group GROUP 00000000 000034 000008 04 35 26 4
[ 2] .group GROUP 00000000 00003c 000008 04 35 30 4
[ 3] .group GROUP 00000000 000044 000008 04 35 31 4
[ 4] .group GROUP 00000000 00004c 000008 04 35 33 4
[ 5] .group GROUP 00000000 000054 000008 04 35 34 4
[ 6] .group GROUP 00000000 00005c 000008 04 35 35 4
[ 7] .group GROUP 00000000 000064 000008 04 35 36 4
[ 8] .text PROGBITS 00000000 00006c 000000 00 AX 0 0 4
[ 9] .data PROGBITS 00000000 00006c 000000 00 WA 0 0 4
[10] .bss NOBITS 00000000 00006c 000000 00 WA 0 0 4






c++ c linker elf low-level






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 17 at 8:56









yugr

6,73221339




6,73221339










asked Sep 11 '09 at 13:31









Shirkrin

3,29512031




3,29512031












  • Further investigations (even the the linker sources..) didn't reveal any news :(
    – Shirkrin
    Oct 28 '09 at 16:11










  • I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
    – Shirkrin
    Nov 23 '11 at 13:38


















  • Further investigations (even the the linker sources..) didn't reveal any news :(
    – Shirkrin
    Oct 28 '09 at 16:11










  • I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
    – Shirkrin
    Nov 23 '11 at 13:38
















Further investigations (even the the linker sources..) didn't reveal any news :(
– Shirkrin
Oct 28 '09 at 16:11




Further investigations (even the the linker sources..) didn't reveal any news :(
– Shirkrin
Oct 28 '09 at 16:11












I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
– Shirkrin
Nov 23 '11 at 13:38




I'm voting to close this question (answering it myself feels foolish..). Recent gcc versions changed the linking behavior and exposed different dynsym sections.. I don't think someone will be able to answer this.
– Shirkrin
Nov 23 '11 at 13:38












1 Answer
1






active

oldest

votes

















up vote
0
down vote













Well, I have a quite simple sugestion, so simple it may not work...



Accordingly to:



http://ftp.gnu.org/old-gnu/Manuals/ld-2.9.1/html_node/ld_19.html



You can specify just the name of a file (.o) for all its sections to be captured.



And you can use wildcards.



Could it be that a line with just a * would capture all remaining sections? Like this:



.bss  : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
*
}





share|improve this answer





















  • Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
    – Shirkrin
    Nov 23 '10 at 10:18











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














 

draft saved


draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f1410887%2fgnu-ld-script-to-catch-c-group-dynsym-sections%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes








up vote
0
down vote













Well, I have a quite simple sugestion, so simple it may not work...



Accordingly to:



http://ftp.gnu.org/old-gnu/Manuals/ld-2.9.1/html_node/ld_19.html



You can specify just the name of a file (.o) for all its sections to be captured.



And you can use wildcards.



Could it be that a line with just a * would capture all remaining sections? Like this:



.bss  : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
*
}





share|improve this answer





















  • Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
    – Shirkrin
    Nov 23 '10 at 10:18















up vote
0
down vote













Well, I have a quite simple sugestion, so simple it may not work...



Accordingly to:



http://ftp.gnu.org/old-gnu/Manuals/ld-2.9.1/html_node/ld_19.html



You can specify just the name of a file (.o) for all its sections to be captured.



And you can use wildcards.



Could it be that a line with just a * would capture all remaining sections? Like this:



.bss  : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
*
}





share|improve this answer





















  • Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
    – Shirkrin
    Nov 23 '10 at 10:18













up vote
0
down vote










up vote
0
down vote









Well, I have a quite simple sugestion, so simple it may not work...



Accordingly to:



http://ftp.gnu.org/old-gnu/Manuals/ld-2.9.1/html_node/ld_19.html



You can specify just the name of a file (.o) for all its sections to be captured.



And you can use wildcards.



Could it be that a line with just a * would capture all remaining sections? Like this:



.bss  : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
*
}





share|improve this answer












Well, I have a quite simple sugestion, so simple it may not work...



Accordingly to:



http://ftp.gnu.org/old-gnu/Manuals/ld-2.9.1/html_node/ld_19.html



You can specify just the name of a file (.o) for all its sections to be captured.



And you can use wildcards.



Could it be that a line with just a * would capture all remaining sections? Like this:



.bss  : {
*(.dynbss)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
*
}






share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 22 '10 at 14:26









jcristovao

349112




349112












  • Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
    – Shirkrin
    Nov 23 '10 at 10:18


















  • Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
    – Shirkrin
    Nov 23 '10 at 10:18
















Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
– Shirkrin
Nov 23 '10 at 10:18




Sorry but this seems to be broken in "recent" versions (I'm using ld 2.20.1).
– Shirkrin
Nov 23 '10 at 10:18


















 

draft saved


draft discarded



















































 


draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f1410887%2fgnu-ld-script-to-catch-c-group-dynsym-sections%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

"Incorrect syntax near the keyword 'ON'. (on update cascade, on delete cascade,)

Alcedinidae

RAC Tourist Trophy