aboutsummaryrefslogtreecommitdiff
path: root/libgloss/m68hc11
diff options
context:
space:
mode:
authorJeff Johnston <jjohnstn@redhat.com>2004-03-04 00:35:03 +0000
committerJeff Johnston <jjohnstn@redhat.com>2004-03-04 00:35:03 +0000
commit13a47bd66a97e146afef8b6f92bbbefbbf956a1b (patch)
treef429a981b00040535be11e6c913c11d770b1c918 /libgloss/m68hc11
parente299c7addc3ec7f20162a54740dc06cae2a71389 (diff)
downloadnewlib-13a47bd66a97e146afef8b6f92bbbefbbf956a1b.zip
newlib-13a47bd66a97e146afef8b6f92bbbefbbf956a1b.tar.gz
newlib-13a47bd66a97e146afef8b6f92bbbefbbf956a1b.tar.bz2
2004-03-03 Stephane Carrez <stcarrez@nerim.fr>
* m68hc11/sci-inout.S: Supports -mlong-calls. * m68hc11/sim-valid-m68hc11.ld (.tramp): New section for trampolines. (.text): Mark the .installN and .finiN section with KEEP. (.vectors): Likewise for .vectors. (.gcc_except_table): New section. * m68hc11/sim-valid-m68hc12.ld (.tramp): New section for trampolines. (.text): Mark the .installN and .finiN section with KEEP. (.vectors): Likewise for .vectors. (.gcc_except_table): New section.
Diffstat (limited to 'libgloss/m68hc11')
-rw-r--r--libgloss/m68hc11/sci-inout.S29
-rw-r--r--libgloss/m68hc11/sim-valid-m68hc11.ld48
-rw-r--r--libgloss/m68hc11/sim-valid-m68hc12.ld48
3 files changed, 70 insertions, 55 deletions
diff --git a/libgloss/m68hc11/sci-inout.S b/libgloss/m68hc11/sci-inout.S
index 070fd7d..a8675d2 100644
--- a/libgloss/m68hc11/sci-inout.S
+++ b/libgloss/m68hc11/sci-inout.S
@@ -1,5 +1,5 @@
/* M68HC11/M68HC12 serial line operations
- * Copyright (C) 1999, 2001 Stephane Carrez (stcarrez@nerim.fr)
+ * Copyright (C) 1999, 2001, 2003, 2004 Stephane Carrez (stcarrez@nerim.fr)
*
* The authors hereby grant permission to use, copy, modify, distribute,
* and license this software and its documentation for any purpose, provided
@@ -12,6 +12,25 @@
* they apply.
*/
+#ifdef __HAVE_SHORT_INT__
+ .mode mshort
+#else
+ .mode mlong
+#endif
+
+#if defined(__USE_RTC__)
+ .macro ret
+#if defined(mc68hc12)
+ rtc
+#else
+ jmp __return_32
+#endif
+ .endm
+#else
+ .macro ret
+ rts
+ .endm
+#endif
#ifdef mc68hc12
SC0CR1 = 0xC2
SC0CR2 = 0xC3
@@ -39,7 +58,7 @@ L1:
ldab SC0CR2,x
orab #0x8
stab SC0CR2,x
- rts
+ ret
.sect .text
.globl inbyte
@@ -52,7 +71,7 @@ inbyte:
bita #0x20
beq inbyte
ldab SC0CR2,x
- rts
+ ret
.globl _sci_init
.sect .text
@@ -99,7 +118,7 @@ L1:
ldab SCCR2,x
orab #0x8
stab SCCR2,x
- rts
+ ret
.sect .text
.globl inbyte
@@ -112,7 +131,7 @@ inbyte:
bita #0x20
beq inbyte
ldab SCDR,x
- rts
+ ret
.globl _sci_init
.sect .text
diff --git a/libgloss/m68hc11/sim-valid-m68hc11.ld b/libgloss/m68hc11/sim-valid-m68hc11.ld
index 86b336e..904b8d6 100644
--- a/libgloss/m68hc11/sim-valid-m68hc11.ld
+++ b/libgloss/m68hc11/sim-valid-m68hc11.ld
@@ -146,15 +146,21 @@ SECTIONS
{
*(.init)
} =0
+ /* Put trampolines at beginning of text at 0x4400 so that they
+ are not in memory bank window. */
+ .tramp :
+ {
+ *(.tramp)
+ } > text
.text :
{
/* Put startup code at beginning so that _start keeps same address. */
/* Startup code. */
- *(.install0) /* Section should setup the stack pointer. */
- *(.install1) /* Place holder for applications. */
- *(.install2) /* Optional installation of data sections in RAM. */
- *(.install3) /* Place holder for applications. */
- *(.install4) /* Section that calls the main. */
+ KEEP (*(.install0)) /* Section should setup the stack pointer. */
+ KEEP (*(.install1)) /* Place holder for applications. */
+ KEEP (*(.install2)) /* Optional installation of data sections in RAM. */
+ KEEP (*(.install3)) /* Place holder for applications. */
+ KEEP (*(.install4)) /* Section that calls the main. */
*(.init)
*(.text)
*(.text.*)
@@ -162,11 +168,11 @@ SECTIONS
*(.gnu.warning)
*(.gnu.linkonce.t.*)
/* Finish code. */
- *(.fini0) /* Beginning of finish code (_exit symbol). */
- *(.fini1) /* Place holder for applications. */
- *(.fini2) /* C++ destructors. */
- *(.fini3) /* Place holder for applications. */
- *(.fini4) /* Runtime exit. */
+ KEEP (*(.fini0)) /* Beginning of finish code (_exit symbol). */
+ KEEP (*(.fini1)) /* Place holder for applications. */
+ KEEP (*(.fini2)) /* C++ destructors. */
+ KEEP (*(.fini3)) /* Place holder for applications. */
+ KEEP (*(.fini4)) /* Runtime exit. */
_etext = .;
PROVIDE (etext = .);
} > text
@@ -174,6 +180,10 @@ SECTIONS
{
*(.eh_frame)
} > text
+ .gcc_except_table :
+ {
+ *(.gcc_except_table)
+ } > text
.rodata :
{
*(.rodata)
@@ -188,25 +198,13 @@ SECTIONS
.ctors :
{
PROVIDE (__CTOR_LIST__ = .);
- *(.ctors)
- /* We don't want to include the .ctor section from
- from the crtend.o file until after the sorted ctors.
- The .ctor section from the crtend file contains the
- end of ctors marker and it must be last
- KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
- KEEP (*(SORT(.ctors.*)))
- KEEP (*(.ctors)) */
+ KEEP (*(.ctors))
PROVIDE(__CTOR_END__ = .);
} > text
.dtors :
{
PROVIDE(__DTOR_LIST__ = .);
- *(.dtors)
- /*
- KEEP (*crtbegin.o(.dtors))
- KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
- KEEP (*(SORT(.dtors.*)))
- KEEP (*(.dtors)) */
+ KEEP (*(.dtors))
PROVIDE(__DTOR_END__ = .);
} > text
/* Start of the data section image in ROM. */
@@ -274,7 +272,7 @@ SECTIONS
PROVIDE (_vectors_addr = DEFINED (vectors_addr) ? vectors_addr : 0xffc0);
.vectors DEFINED (vectors_addr) ? vectors_addr : 0xffc0 :
{
- *(.vectors)
+ KEEP (*(.vectors))
}
/* Stabs debugging sections. */
.stab 0 : { *(.stab) }
diff --git a/libgloss/m68hc11/sim-valid-m68hc12.ld b/libgloss/m68hc11/sim-valid-m68hc12.ld
index 6b15ed2..17dea1d 100644
--- a/libgloss/m68hc11/sim-valid-m68hc12.ld
+++ b/libgloss/m68hc11/sim-valid-m68hc12.ld
@@ -145,15 +145,21 @@ SECTIONS
{
*(.init)
} =0
+ /* Put trampolines at beginning of text at 0x4400 so that they
+ are not in memory bank window. */
+ .tramp :
+ {
+ *(.tramp)
+ } > text
.text :
{
/* Put startup code at beginning so that _start keeps same address. */
/* Startup code. */
- *(.install0) /* Section should setup the stack pointer. */
- *(.install1) /* Place holder for applications. */
- *(.install2) /* Optional installation of data sections in RAM. */
- *(.install3) /* Place holder for applications. */
- *(.install4) /* Section that calls the main. */
+ KEEP (*(.install0)) /* Section should setup the stack pointer. */
+ KEEP (*(.install1)) /* Place holder for applications. */
+ KEEP (*(.install2)) /* Optional installation of data sections in RAM. */
+ KEEP (*(.install3)) /* Place holder for applications. */
+ KEEP (*(.install4)) /* Section that calls the main. */
*(.init)
*(.text)
*(.text.*)
@@ -161,11 +167,11 @@ SECTIONS
*(.gnu.warning)
*(.gnu.linkonce.t.*)
/* Finish code. */
- *(.fini0) /* Beginning of finish code (_exit symbol). */
- *(.fini1) /* Place holder for applications. */
- *(.fini2) /* C++ destructors. */
- *(.fini3) /* Place holder for applications. */
- *(.fini4) /* Runtime exit. */
+ KEEP (*(.fini0)) /* Beginning of finish code (_exit symbol). */
+ KEEP (*(.fini1)) /* Place holder for applications. */
+ KEEP (*(.fini2)) /* C++ destructors. */
+ KEEP (*(.fini3)) /* Place holder for applications. */
+ KEEP (*(.fini4)) /* Runtime exit. */
_etext = .;
PROVIDE (etext = .);
} > text
@@ -173,6 +179,10 @@ SECTIONS
{
*(.eh_frame)
} > text
+ .gcc_except_table :
+ {
+ *(.gcc_except_table)
+ } > text
.rodata :
{
*(.rodata)
@@ -187,25 +197,13 @@ SECTIONS
.ctors :
{
PROVIDE (__CTOR_LIST__ = .);
- *(.ctors)
- /* We don't want to include the .ctor section from
- from the crtend.o file until after the sorted ctors.
- The .ctor section from the crtend file contains the
- end of ctors marker and it must be last
- KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
- KEEP (*(SORT(.ctors.*)))
- KEEP (*(.ctors)) */
+ KEEP (*(.ctors))
PROVIDE(__CTOR_END__ = .);
} > text
.dtors :
{
PROVIDE(__DTOR_LIST__ = .);
- *(.dtors)
- /*
- KEEP (*crtbegin.o(.dtors))
- KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
- KEEP (*(SORT(.dtors.*)))
- KEEP (*(.dtors)) */
+ KEEP (*(.dtors))
PROVIDE(__DTOR_END__ = .);
} > text
/* Start of the data section image in ROM. */
@@ -274,7 +272,7 @@ SECTIONS
PROVIDE (_vectors_addr = DEFINED (vectors_addr) ? vectors_addr : 0xffc0);
.vectors DEFINED (vectors_addr) ? vectors_addr : 0xffc0 :
{
- *(.vectors)
+ KEEP (*(.vectors))
}
/* Stabs debugging sections. */
.stab 0 : { *(.stab) }