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

Subversion Repositories open8_urisc

[/] [open8_urisc/] [trunk/] [gnu/] [binutils/] [ld/] [testsuite/] [ld-sh/] [sh64/] [shdl-1.s] - Rev 106

Compare with Previous | Blame | View Log

! Test inter-file DataLabel support.
!
! We need to test symbols that are:
! * Global, defined in this file, with/without/both-with-without datalabel
!   references.
! * The above in combinations where the reference is/is not from within
!   the same section.  The implementation is currently indifferent to that
!   fact, but it seems likely to be something that can change.
! * Extern with/without/both-with-without datalabel-qualified references.
! * The above with reference from same *and* other file.
! * The above in combinations for where the symbol is/is not a
!   STO_SH5_ISA32-marked symbol.
 
! There will be omissions and overlap in combinations.  Add spotted
! omissions with complementary tests in other files.
 
	.text
	.mode SHmedia
 
! For good measure, we start with a nop to get a non-zero offset within
! the .text section.
 
	.global start
start:
	nop
 
! Referenced from the same file, same section, is ISA32, only referenced
! with datalabel qualifier.
	.global foo
foo:
	nop
	movi (datalabel foo + 8) & 65535,r30
 
! Referenced from same file, same section, both with and without
! datalabel qualifier, is ISA32.
	.global fooboth
fooboth:
	nop
	movi (datalabel fooboth + 16) & 65535,r40
	movi (fooboth + 12) & 65535,r40
 
! Same as above, but in different order.
	.global fooboth2
fooboth2:
	nop
	movi (fooboth2 + 12) & 65535,r40
	movi (datalabel fooboth2 + 16) & 65535,r40
 
! Referenced from this file and another, same section, is ISA32.
	.global foowithout
foowithout:
	nop
	movi (foowithout + 24) & 65535,r30
 
! Same as above, different section than definition.
 
	.global foo_other
foo_other:
	nop
	.global foo_otherboth
foo_otherboth:
	nop
	.global foo_otherboth2
foo_otherboth2:
	nop
	.global foo_otherwithout
foo_otherwithout:
	nop
 
	.section .rodata
	.long datalabel foo_other + 4
	.long datalabel foo_otherboth + 40
	.long foo_otherboth + 24
	.long foo_otherboth2 + 24
	.long datalabel foo_otherboth2 + 40
	.long foo_otherwithout
 
	.text
 
! Same as above, mixing references from same and other section.
	.global foo_mix
foo_mix:
	nop
	movi (datalabel foo_mix + 8) & 65535,r30
	.global foo_mix2
foo_mix2:
	nop
	movi (foo_mix2 + 8) & 65535,r30
	.global foo_mixboth
foo_mixboth:
	nop
	movi (datalabel foo_mixboth + 80) & 65535,r30
	movi (foo_mixboth + 80) & 65535,r30
	.global foo_mixboth2
foo_mixboth2:
	nop
	movi (foo_mixboth2 + 64) & 65535,r30
	movi (datalabel foo_mixboth2 + 64) & 65535,r30
	.global foo_mixwithout
foo_mixwithout:
	nop
	movi (foo_mixwithout + 42) & 65535,r30
	.global foo_mixwithout2
foo_mixwithout2:
	nop
	movi (foo_mixwithout2 + 24) & 65535,r30
 
	.section .rodata
	.long foo_mix + 4
	.long datalabel foo_mix2 + 48
	.long datalabel foo_mixboth + 400
	.long foo_mixboth + 420
	.long foo_mixboth2 + 248
	.long datalabel foo_mixboth2 + 240
	.long foo_mixwithout
 
! Same as above, referencing symbol in other file (reference only from
! this to other file).
 
	.text
	nop
	movi (datalabel bar + 8) & 65535,r30
 
	movi (datalabel barboth + 16) & 65535,r40
	movi (barboth + 12) & 65535,r40
 
	movi (barboth2 + 12) & 65535,r40
	movi (datalabel barboth2 + 16) & 65535,r40
 
	movi (barwithout + 24) & 65535,r30
 
	.section .rodata
	.long datalabel bar_other + 4
	.long datalabel bar_otherboth + 40
	.long bar_otherboth + 24
	.long bar_otherboth2 + 24
	.long datalabel bar_otherboth2 + 40
	.long bar_otherwithout
 
	.text
	movi (datalabel bar_mix + 8) & 65535,r30
	movi (bar_mix2 + 8) & 65535,r30
	movi (datalabel bar_mixboth + 80) & 65535,r30
	movi (bar_mixboth + 80) & 65535,r30
	movi (bar_mixboth2 + 64) & 65535,r30
	movi (datalabel bar_mixboth2 + 64) & 65535,r30
	movi (bar_mixwithout + 42) & 65535,r30
	movi (bar_mixwithout2 + 24) & 65535,r30
 
	.section .rodata
	.long bar_mix + 4
	.long datalabel bar_mix2 + 48
	.long datalabel bar_mixboth + 400
	.long bar_mixboth + 420
	.long bar_mixboth2 + 248
	.long datalabel bar_mixboth2 + 240
	.long bar_mixwithout
 
! Same as above, referencing symbol in other file *and* within that file.
 
	.text
	movi (datalabel baz + 8) & 65535,r30
 
	movi (datalabel bazboth + 16) & 65535,r40
	movi (bazboth + 12) & 65535,r40
 
	movi (bazboth2 + 12) & 65535,r40
	movi (datalabel bazboth2 + 16) & 65535,r40
 
	movi (bazwithout + 24) & 65535,r30
 
	.section .rodata
	.long datalabel baz_other + 4
	.long datalabel baz_otherboth + 40
	.long baz_otherboth + 24
	.long baz_otherboth2 + 24
	.long datalabel baz_otherboth2 + 40
	.long baz_otherwithout
 
	.text
	movi (datalabel baz_mix + 8) & 65535,r30
	movi (baz_mix2 + 8) & 65535,r30
	movi (datalabel baz_mixboth + 80) & 65535,r30
	movi (baz_mixboth + 80) & 65535,r30
	movi (baz_mixboth2 + 64) & 65535,r30
	movi (datalabel baz_mixboth2 + 64) & 65535,r30
	movi (baz_mixwithout + 42) & 65535,r30
	movi (baz_mixwithout2 + 24) & 65535,r30
 
	.section .rodata
	.long baz_mix + 4
	.long datalabel baz_mix2 + 48
	.long datalabel baz_mixboth + 400
	.long baz_mixboth + 420
	.long baz_mixboth2 + 248
	.long datalabel baz_mixboth2 + 240
	.long baz_mixwithout
 
! Same as all of the above, but where the symbol is not an ISA32 one.
 
	.data
	.global dfoo
dfoo:
	.long 0
	.long (datalabel dfoo + 8)
 
	.global dfooboth
dfooboth:
	.long 0
	.long (datalabel dfooboth + 16)
	.long (dfooboth + 12)
 
	.global dfooboth2
dfooboth2:
	.long 0
	.long (dfooboth2 + 12)
	.long (datalabel dfooboth2 + 16)
 
	.global dfoowithout
dfoowithout:
	.long 0
	.long (dfoowithout + 24)
 
	.global dfoo_other
dfoo_other:
	.long 0
	.global dfoo_otherboth
dfoo_otherboth:
	.long 0
	.global dfoo_otherboth2
dfoo_otherboth2:
	.long 0
	.global dfoo_otherwithout
dfoo_otherwithout:
	.long 0
 
	.section .rodata
	.long datalabel dfoo_other + 4
	.long datalabel dfoo_otherboth + 40
	.long dfoo_otherboth + 24
	.long dfoo_otherboth2 + 24
	.long datalabel dfoo_otherboth2 + 40
	.long dfoo_otherwithout
 
	.data
 
! Same as above, mixing references from same and other section.
	.global dfoo_mix
dfoo_mix:
	.long 0
	.long (datalabel dfoo_mix + 8)
	.global dfoo_mix2
dfoo_mix2:
	.long 0
	.long (dfoo_mix2 + 8)
	.global dfoo_mixboth
dfoo_mixboth:
	.long 0
	.long (datalabel dfoo_mixboth + 80)
	.long (dfoo_mixboth + 80)
	.global dfoo_mixboth2
dfoo_mixboth2:
	.long 0
	.long (dfoo_mixboth2 + 64)
	.long (datalabel dfoo_mixboth2 + 64)
	.global dfoo_mixwithout
dfoo_mixwithout:
	.long 0
	.long (dfoo_mixwithout + 42)
	.global dfoo_mixwithout2
dfoo_mixwithout2:
	.long 0
	.long (dfoo_mixwithout2 + 24)
 
	.section .rodata
	.long dfoo_mix + 4
	.long datalabel dfoo_mix2 + 48
	.long datalabel dfoo_mixboth + 400
	.long dfoo_mixboth + 420
	.long dfoo_mixboth2 + 248
	.long datalabel dfoo_mixboth2 + 240
	.long dfoo_mixwithout
 
! Same as above, referencing symbol in other file (reference only from
! this to other file).
 
	.text
	movi (datalabel dbarboth + 16) & 65535,r40
	movi (dbarboth + 12) & 65535,r40
	movi (dbarboth2 + 12) & 65535,r40
	movi (datalabel dbarboth2 + 16) & 65535,r40
	movi (dbarwithout + 24) & 65535,r30
 
	.data
	.long (datalabel dbar + 8)
	.long datalabel dbar_other + 4
	.long datalabel dbar_otherboth + 40
	.long dbar_otherboth + 24
	.long dbar_otherboth2 + 24
	.long datalabel dbar_otherboth2 + 40
	.long dbar_otherwithout
 
	.text
	movi (datalabel dbar_mix + 8) & 65535,r30
	movi (dbar_mix2 + 8) & 65535,r30
	movi (datalabel dbar_mixboth + 80) & 65535,r30
	movi (dbar_mixboth + 80) & 65535,r30
	movi (dbar_mixboth2 + 64) & 65535,r30
	movi (datalabel dbar_mixboth2 + 64) & 65535,r30
	movi (dbar_mixwithout + 42) & 65535,r30
	movi (dbar_mixwithout2 + 24) & 65535,r30
 
	.data
	.long dbar_mix + 4
	.long datalabel dbar_mix2 + 48
	.long datalabel dbar_mixboth + 400
	.long dbar_mixboth + 420
	.long dbar_mixboth2 + 248
	.long datalabel dbar_mixboth2 + 240
	.long dbar_mixwithout
 
! Same as above, referencing symbol in other file *and* within that file.
 
	.text
	movi (datalabel dbazboth + 16) & 65535,r40
	movi (dbazboth + 12) & 65535,r40
 
	movi (dbazboth2 + 12) & 65535,r40
	movi (datalabel dbazboth2 + 16) & 65535,r40
 
	movi (dbazwithout + 24) & 65535,r30
 
	.data
	.long (datalabel dbaz + 8)
	.long datalabel dbaz_other + 4
	.long datalabel dbaz_otherboth + 40
	.long dbaz_otherboth + 24
	.long dbaz_otherboth2 + 24
	.long datalabel dbaz_otherboth2 + 40
	.long dbaz_otherwithout
 
	.text
	movi (datalabel dbaz_mix + 8) & 65535,r30
	movi (dbaz_mix2 + 8) & 65535,r30
	movi (datalabel dbaz_mixboth + 80) & 65535,r30
	movi (dbaz_mixboth + 80) & 65535,r30
	movi (dbaz_mixboth2 + 64) & 65535,r30
	movi (datalabel dbaz_mixboth2 + 64) & 65535,r30
	movi (dbaz_mixwithout + 42) & 65535,r30
	movi (dbaz_mixwithout2 + 24) & 65535,r30
 
	.data
	.long dbaz_mix + 4
	.long datalabel dbaz_mix2 + 48
	.long datalabel dbaz_mixboth + 400
	.long dbaz_mixboth + 420
	.long dbaz_mixboth2 + 248
	.long datalabel dbaz_mixboth2 + 240
	.long dbaz_mixwithout
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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