OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [binutils-2.18.50/] [ld/] [testsuite/] [ld-elfvers/] [vers1.c] - Rev 816

Compare with Previous | Blame | View Log

/*
 * Basic test of versioning.  The idea with this is that we define
 * a bunch of definitions of the same symbol, and we can theoretically
 * then link applications against varying sets of these.
 */
const char * show_bar1 = "asdf";
const char * show_bar2 = "asdf";
 
extern int new2_foo();
extern int bar33();
 
int
bar()
{
	return 3;
}
 
/*
 * The 'hide' prefix is something so that we can automatically search the
 * symbol table and verify that none of these symbols were actually exported.
 */
int
hide_original_foo()
{
	return 1+bar();
 
}
 
int
hide_old_foo()
{
	return 10+bar();
 
}
 
int
hide_old_foo1()
{
	return 100+bar();
 
}
 
int
hide_new_foo()
{
	return 1000+bar();
 
}
 
__asm__(".symver hide_original_foo,show_foo@");
__asm__(".symver hide_old_foo,show_foo@VERS_1.1");
__asm__(".symver hide_old_foo1,show_foo@VERS_1.2");
__asm__(".symver hide_new_foo,show_foo@@VERS_2.0");
 
 
 
#ifdef DO_TEST10
/* In test 10, we try and define a non-existant version node.  The linker
 * should catch this and complain. */
int
hide_new_bogus_foo()
{
	return 1000+bar();
 
}
__asm__(".symver hide_new_bogus_foo,show_foo@VERS_2.2");
#endif
 
 
 
 
#ifdef DO_TEST11
/*
 * This test is designed to catch a couple of syntactic errors.  The assembler
 * should complain about both of the directives below.
 */
void
xyzzz()
{
  new2_foo();
  bar33();
}
 
__asm__(".symver new2_foo,fooVERS_2.0");
__asm__(".symver bar33,bar@@VERS_2.0");
#endif
 
#ifdef DO_TEST12
/*
 * This test is designed to catch a couple of syntactic errors.  The assembler
 * should complain about both of the directives below.
 */
void
xyzzz()
{
  new2_foo();
  bar33();
}
 
__asm__(".symver bar33,bar@@VERS_2.0");
#endif
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.