From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1521) id E00863858404; Tue, 2 Jan 2024 04:36:29 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org E00863858404 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1704170189; bh=5TuzunesNvUzwzojsAEShbgcdmYHWbsD/CnQIJw8ylE=; h=From:To:Subject:Date:From; b=lhqdghvSZXD9HDIPIVqtLWwyINYhy4SLDokmXyQFCqm8wv51zIbdO65hrFUb5JTKE 4ag3p58eNI1XDdV3XhI0BtcD0Qq7g4rTrKarLqb98/GAT8ISbT/cEns0DkDUCBKy3u gH0BHu5rTEApoOv0Cf+wEHenc7tXjlxapVsxabSY= Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable From: Michael Frysinger To: newlib-cvs@sourceware.org Subject: [newlib-cygwin/users/vapier/wip] libgloss: msp430: split up crt0.S source X-Act-Checkin: newlib-cygwin X-Git-Author: Mike Frysinger X-Git-Refname: refs/heads/users/vapier/wip X-Git-Oldrev: 466514c02077e4f05b3590fbc8f920105098d8ef X-Git-Newrev: ef9cbcad29aaf4732d52ce4f13d228ae335d0013 Message-Id: <20240102043629.E00863858404@sourceware.org> Date: Tue, 2 Jan 2024 04:36:29 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=3Dnewlib-cygwin.git;h=3Def9cbcad29a= af4732d52ce4f13d228ae335d0013 commit ef9cbcad29aaf4732d52ce4f13d228ae335d0013 Author: Mike Frysinger Date: Tue Dec 26 22:01:30 2023 -0500 libgloss: msp430: split up crt0.S source =20 The build system compiles crt0.S many times to produce independent object files by defining different -DLxxx symbols for each. This complicates the build, and has led to some bugs in the source and build (see the previous cleanup commits in here). The crt_bss.S file has also been duplicated with crt0.S leading to confusion as to which one is the "real" one. The only reason to keep them in one file is to make management of the section numbers when calling START_CRT_FUNC a little easier, but that seems trivial to check with a quick grep across all the files. =20 Considering how complicated the build is now, and the bugs we've had as a result, split the crt0.S file up into multiple source files so we don't have to compile it multiple times. This will also simplify merging it into the top-level Makefile. Diff: --- libgloss/msp430/Makefile.in | 7 +- libgloss/msp430/crt0.S | 192 +---------------------------= ---- libgloss/msp430/crt_bss.S | 24 ++-- libgloss/msp430/crt_callexit.S | 39 +++++++ libgloss/msp430/crt_high_bss.S | 51 +++++++++ libgloss/msp430/crt_init.S | 46 ++++++++ libgloss/msp430/crt_main.S | 40 +++++++ libgloss/msp430/crt_move_highdata.S | 71 ++++++++++++ libgloss/msp430/crt_movedata.S | 50 +++++++++ libgloss/msp430/crt_run_array.S | 48 ++++++++ libgloss/msp430/crt_run_fini_array.S | 43 +++++++ libgloss/msp430/crt_run_init_array.S | 43 +++++++ libgloss/msp430/crt_run_preinit_array.S | 43 +++++++ libgloss/msp430/memmodel.h | 14 ++- 14 files changed, 499 insertions(+), 212 deletions(-) diff --git a/libgloss/msp430/Makefile.in b/libgloss/msp430/Makefile.in index c5d70ff7d..ccf94dc16 100644 --- a/libgloss/msp430/Makefile.in +++ b/libgloss/msp430/Makefile.in @@ -78,8 +78,6 @@ NOSYS_OBJS =3D ciosyscalls.o \ unlink.o \ sbrk.o =20 -# Each crt_*.o is built from crt0.S using -DL*. crt0.o is built from -# crt0.s with -DL0 via the default rule below. CRT_OBJS =3D \ crt_bss.o \ crt_high_bss.o \ @@ -98,12 +96,9 @@ CRT_OBJS =3D \ =20 all: $(CRT) $(SIM_BSP) $(LIB_NOSYS) $(LIB_CRT) copy_scripts_to_objdir =20 -crt_%.o : crt0.S - $(CC) -DL$* -Wa,-gdwarf2 -Wa,-I$(srcdir) $(CFLAGS_FOR_TARGET) $(INCLUDES)= $(CFLAGS) -c $< -o $@ - # Override .S.o rule to pass assembler debugging flags .S.o: - $(CC) -DL0 -Wa,-gdwarf2 -Wa,-I$(srcdir) $(CFLAGS_FOR_TARGET) $(INCLUDES) = $(CFLAGS) -c $< + $(CC) -Wa,-gdwarf2 -Wa,-I$(srcdir) $(CFLAGS_FOR_TARGET) $(INCLUDES) $(CFL= AGS) -c $< =20 $(SIM_BSP): $(SIM_OBJS) $(AR) $(ARFLAGS) $@ $? diff --git a/libgloss/msp430/crt0.S b/libgloss/msp430/crt0.S index c0b258f50..affc2c9a8 100644 --- a/libgloss/msp430/crt0.S +++ b/libgloss/msp430/crt0.S @@ -13,13 +13,6 @@ =20 #include "memmodel.h" =20 -;; The linker links all .crt_* sections in asciibetical order at the -;; same place. So, the four digits in .crt_NNNN_xxx name created by -;; the START_CRT_FUNC macro determine the link order, so, keep them -;; in sequential order here. The first two digits are set here, the -;; second two allow users to insert code between code fragments here. - -#if L0 .section ".resetvec", "a" __msp430_resetvec_hook: .word __crt0_start @@ -56,9 +49,8 @@ START_CRT_FUNC 0000 start mov_ #__stack, R1 =20 END_CRT_FUNC start -#endif =20 -;; The CRT functions below will only be present in the final linked +;; The CRT functions will only be present in the final linked ;; executable if the assembler decides they are needed. The assembler will ;; only define the symbol necessary to prevent them being garbage collected ;; by the linker if the file being assembled has a specific section, @@ -67,185 +59,3 @@ END_CRT_FUNC start ;; if it detects that main() has an epilogue. For example, if main() has a ;; while(1) loop at the end, GCC will not generate an epilogue (since it w= on't ;; return) and __crt0_call_exit won't be included. - -#if Lbss -;; This function is responsible for initializing the contents of the -;; .bss section. - -START_CRT_FUNC 0100 init_bss - - mov_ #__bssstart, R12 - clr.w R13 - mov_ #__bsssize, R14 -#ifdef __MSP430X_LARGE__ - clr.w R15 ; We assume that __bsssize is never > 64K -#endif - call_ #memset - -END_CRT_FUNC init_bss -#endif /* Lbss */ - - -#ifdef __MSP430X_LARGE__ -#if Lhigh_bss -;; This function is responsible for initializing the contents of the -;; .upper.bss section. - -START_CRT_FUNC 0200 init_highbss -=09 - mov_ #__high_bssstart, R12 - mov.w #0, R13 - mov_ #__high_bsssize, R14 - ;; If __high_bsssize is zero then skip the call to memset. - ;; This can happen if all of the bss data was placed into .either.bss. - cmp.w #0, R14 - jeq 1f - call_ #memset -1: -END_CRT_FUNC init_highbss -#endif /* Lhigh_bss */ -#endif /* __MSP430X_LARGE__ */ - - -#if Lmovedata -;; This function is responsible for copying the -;; contents of the .data section from its load address (in ROM) to -;; its run-time address (in RAM). - -START_CRT_FUNC 0300 movedata - - mov_ #__datastart, R12 - mov_ #__romdatastart, R13 - - ;; memmove and memcpy do not currently work when src =3D=3D dst - cmp_ R12, R13 - jeq 1f - - mov_ #__romdatacopysize, R14 - - call_ #memmove -1: -END_CRT_FUNC movedata -#endif /* Lmovedata */ - - -#ifdef __MSP430X_LARGE__ -#if Lmove_highdata -;; This function is responsible for making sure that the -;; contents of the .upper.data section have their correct startup values. -;; If a copy of the .upper.data section is stored in ROM then this means -;; copying the contents into HIFRAM. If a copy of .upper.data is stored i= n a -;; shadow section in HIFRAM then this means copying from the shadow section -;; into the real section. - -START_CRT_FUNC 0400 move_highdata - ;; __rom_highdatacopysize may be zero. Test this first because - ;; its value may come from the weak definitions above and we do - ;; not want to access the memory at address 0 pointed to by the - ;; weak definition of __upper_data_init. - mov.w #__rom_highdatacopysize, R14 - cmp.w #0, R14 - jeq 3f - - /* Test our status word. */ - cmpx.w #0, &__upper_data_init - jeq 1f - /* Status word is non-zero - copy from shadow into upper. */ - mov_ #__high_datastart, R12 - mov_ #__rom_highdatastart, R13 - jmp 2f - -1: /* Status word is zero. Copy from upper to shadow and change status wo= rd. */ - movx.w #1, &__upper_data_init - mov_ #__rom_highdatastart, R12 - mov_ #__high_datastart, R13 - -2: ;; __rom_highdatacopysize may be zero. memmove should cope. - mov.w #__rom_highdatacopysize, R14 - - call_ #memmove -3: -END_CRT_FUNC move_highdata -#endif /* Lmove_highdata */ -#endif /* __MSP430X_LARGE__ */ - -#if Lrun_preinit_array -;; This function is responsible for setting up the arguments -;; required for __crt0_run_array, to run the functions in .preinit_array. -START_CRT_FUNC 0500 run_preinit_array - - mov_ #__preinit_array_start, R4 - mov_ #__preinit_array_end, R5 - mov_ #PTRsz, R6 - call_ #__crt0_run_array - -END_CRT_FUNC run_preinit_array -#endif /* Lrun_preinit_array */ - -#if Lrun_init_array -;; This function is responsible for setting up the arguments -;; required for __crt0_run_array, to run the functions in .init_array. -START_CRT_FUNC 0600 run_init_array - - mov_ #__init_array_start, R4 - mov_ #__init_array_end, R5 - mov_ #PTRsz, R6 - call_ #__crt0_run_array - -END_CRT_FUNC run_init_array -#endif /* Lrun_init_array */ - - -#if Lmain -;; This function is always included and calls main(). - -START_CRT_FUNC 0800 call_main - - clr.w R12 ; Set argc =3D=3D 0 - call_ #main - -END_CRT_FUNC call_main -#endif /* Lmain */ - -#if Lcallexit -;; This function is responsible for calling exit once main has finished. - -START_CRT_FUNC 0900 call_exit - - call_ #_exit - -END_CRT_FUNC call_exit -#endif /* Lcallexit */ - -;---------------------------------------- - -#if Lrun_fini_array -;; This function is responsible for setting up the arguments -;; required for __crt0_run_array, to run the functions in .fini_array. -START_CRT_FUNC 1000 run_fini_array - - mov_ #__fini_array_start, R4 - mov_ #__fini_array_end, R5 - mov_ #-PTRsz, R6 - call_ #__crt0_run_array - -END_CRT_FUNC run_fini_array -#endif /* Lrun_fini_array */ - -#if Lrun_array -;; Note - this section is only included in the startup code of the applica= tion -;; if it is needed by one of the above run_*_array functions. -START_CRT_FUNC 1100 run_array - - cmp_ R4, R5 - jeq _msp430_run_done - mov_ @R4, R7 - add_ R6, R4 - call_ R7 - br_ #__crt0_run_array - -END_CRT_FUNC run_array - -_msp430_run_done: - ret_ -#endif /* Lrun_array */ diff --git a/libgloss/msp430/crt_bss.S b/libgloss/msp430/crt_bss.S index 27ab2efeb..e83ea9845 100644 --- a/libgloss/msp430/crt_bss.S +++ b/libgloss/msp430/crt_bss.S @@ -1,19 +1,19 @@ -/* Copyright (c) 2012-2013 Red Hat Incorporated. +/* Copyright (c) 2012-2015 Red Hat Incorporated. All rights reserved. =20 Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions - are met:=20 + are met: =20 - Redistributions of source code must retain the above copyright=20 + Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. =20 Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. =20 - The name of Red Hat Incorporated may not be used to endorse=20 - or promote products derived from this software without specific=20 + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific prior written permission. =20 This software is provided by the copyright holders and contributors @@ -30,15 +30,17 @@ =20 #include "memmodel.h" =20 - .section ".crt_bss", "ax", @progbits +;; This function is responsible for initializing the contents of the +;; .bss section. + +START_CRT_FUNC 0100 init_bss =20 - .global __crt0_init_bss -__crt0_init_bss:=09 -=09 mov_ #__bssstart, R12 clr.w R13 - mov.w #__bsssize, R14 + mov_ #__bsssize, R14 #ifdef __MSP430X_LARGE__ - clr.w R15 ; We assume that __bsssize is never > 64M + clr.w R15 ; We assume that __bsssize is never > 64K #endif call_ #memset + +END_CRT_FUNC init_bss diff --git a/libgloss/msp430/crt_callexit.S b/libgloss/msp430/crt_callexit.S new file mode 100644 index 000000000..86a8ca63f --- /dev/null +++ b/libgloss/msp430/crt_callexit.S @@ -0,0 +1,39 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for calling exit once main has finished. + +START_CRT_FUNC 0900 call_exit + + call_ #_exit + +END_CRT_FUNC call_exit diff --git a/libgloss/msp430/crt_high_bss.S b/libgloss/msp430/crt_high_bss.S new file mode 100644 index 000000000..462c7aecb --- /dev/null +++ b/libgloss/msp430/crt_high_bss.S @@ -0,0 +1,51 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#ifdef __MSP430X_LARGE__ + +#include "memmodel.h" + +;; This function is responsible for initializing the contents of the +;; .upper.bss section. + +START_CRT_FUNC 0200 init_highbss + + mov_ #__high_bssstart, R12 + mov.w #0, R13 + mov_ #__high_bsssize, R14 + ;; If __high_bsssize is zero then skip the call to memset. + ;; This can happen if all of the bss data was placed into .either.bss. + cmp.w #0, R14 + jeq 1f + call_ #memset +1: +END_CRT_FUNC init_highbss + +#endif /* __MSP430X_LARGE__ */ diff --git a/libgloss/msp430/crt_init.S b/libgloss/msp430/crt_init.S new file mode 100644 index 000000000..e83ea9845 --- /dev/null +++ b/libgloss/msp430/crt_init.S @@ -0,0 +1,46 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for initializing the contents of the +;; .bss section. + +START_CRT_FUNC 0100 init_bss + + mov_ #__bssstart, R12 + clr.w R13 + mov_ #__bsssize, R14 +#ifdef __MSP430X_LARGE__ + clr.w R15 ; We assume that __bsssize is never > 64K +#endif + call_ #memset + +END_CRT_FUNC init_bss diff --git a/libgloss/msp430/crt_main.S b/libgloss/msp430/crt_main.S new file mode 100644 index 000000000..ee2094cf3 --- /dev/null +++ b/libgloss/msp430/crt_main.S @@ -0,0 +1,40 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is always included and calls main(). + +START_CRT_FUNC 0800 call_main + + clr.w R12 ; Set argc =3D=3D 0 + call_ #main + +END_CRT_FUNC call_main diff --git a/libgloss/msp430/crt_move_highdata.S b/libgloss/msp430/crt_move= _highdata.S new file mode 100644 index 000000000..b96954962 --- /dev/null +++ b/libgloss/msp430/crt_move_highdata.S @@ -0,0 +1,71 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#ifdef __MSP430X_LARGE__ + +#include "memmodel.h" + +;; This function is responsible for making sure that the +;; contents of the .upper.data section have their correct startup values. +;; If a copy of the .upper.data section is stored in ROM then this means +;; copying the contents into HIFRAM. If a copy of .upper.data is stored i= n a +;; shadow section in HIFRAM then this means copying from the shadow section +;; into the real section. + +START_CRT_FUNC 0400 move_highdata + ;; __rom_highdatacopysize may be zero. Test this first because + ;; its value may come from the weak definitions above and we do + ;; not want to access the memory at address 0 pointed to by the + ;; weak definition of __upper_data_init. + mov.w #__rom_highdatacopysize, R14 + cmp.w #0, R14 + jeq 3f + + /* Test our status word. */ + cmpx.w #0, &__upper_data_init + jeq 1f + /* Status word is non-zero - copy from shadow into upper. */ + mov_ #__high_datastart, R12 + mov_ #__rom_highdatastart, R13 + jmp 2f + +1: /* Status word is zero. Copy from upper to shadow and change status wo= rd. */ + movx.w #1, &__upper_data_init + mov_ #__rom_highdatastart, R12 + mov_ #__high_datastart, R13 + +2: ;; __rom_highdatacopysize may be zero. memmove should cope. + mov.w #__rom_highdatacopysize, R14 + + call_ #memmove +3: +END_CRT_FUNC move_highdata + +#endif /* __MSP430X_LARGE__ */ diff --git a/libgloss/msp430/crt_movedata.S b/libgloss/msp430/crt_movedata.S new file mode 100644 index 000000000..de0f51990 --- /dev/null +++ b/libgloss/msp430/crt_movedata.S @@ -0,0 +1,50 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for copying the +;; contents of the .data section from its load address (in ROM) to +;; its run-time address (in RAM). + +START_CRT_FUNC 0300 movedata + + mov_ #__datastart, R12 + mov_ #__romdatastart, R13 + + ;; memmove and memcpy do not currently work when src =3D=3D dst + cmp_ R12, R13 + jeq 1f + + mov_ #__romdatacopysize, R14 + + call_ #memmove +1: +END_CRT_FUNC movedata diff --git a/libgloss/msp430/crt_run_array.S b/libgloss/msp430/crt_run_arra= y.S new file mode 100644 index 000000000..6f9bf07a5 --- /dev/null +++ b/libgloss/msp430/crt_run_array.S @@ -0,0 +1,48 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; Note - this section is only included in the startup code of the applica= tion +;; if it is needed by one of the above run_*_array functions. + +START_CRT_FUNC 1100 run_array + + cmp_ R4, R5 + jeq _msp430_run_done + mov_ @R4, R7 + add_ R6, R4 + call_ R7 + br_ #__crt0_run_array + +END_CRT_FUNC run_array + +_msp430_run_done: + ret_ diff --git a/libgloss/msp430/crt_run_fini_array.S b/libgloss/msp430/crt_run= _fini_array.S new file mode 100644 index 000000000..c68b1e3e0 --- /dev/null +++ b/libgloss/msp430/crt_run_fini_array.S @@ -0,0 +1,43 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for setting up the arguments +;; required for __crt0_run_array, to run the functions in .fini_array. + +START_CRT_FUNC 1000 run_fini_array + + mov_ #__fini_array_start, R4 + mov_ #__fini_array_end, R5 + mov_ #-PTRsz, R6 + call_ #__crt0_run_array + +END_CRT_FUNC run_fini_array diff --git a/libgloss/msp430/crt_run_init_array.S b/libgloss/msp430/crt_run= _init_array.S new file mode 100644 index 000000000..002507532 --- /dev/null +++ b/libgloss/msp430/crt_run_init_array.S @@ -0,0 +1,43 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for setting up the arguments +;; required for __crt0_run_array, to run the functions in .init_array. + +START_CRT_FUNC 0600 run_init_array + + mov_ #__init_array_start, R4 + mov_ #__init_array_end, R5 + mov_ #PTRsz, R6 + call_ #__crt0_run_array + +END_CRT_FUNC run_init_array diff --git a/libgloss/msp430/crt_run_preinit_array.S b/libgloss/msp430/crt_= run_preinit_array.S new file mode 100644 index 000000000..db2e09ef5 --- /dev/null +++ b/libgloss/msp430/crt_run_preinit_array.S @@ -0,0 +1,43 @@ +/* Copyright (c) 2012-2015 Red Hat Incorporated. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + The name of Red Hat Incorporated may not be used to endorse + or promote products derived from this software without specific + prior written permission. + + This software is provided by the copyright holders and contributors + "AS IS" and any express or implied warranties, including, but not + limited to, the implied warranties of merchantability and fitness for + a particular purpose are disclaimed. In no event shall Red Hat + incorporated be liable for any direct, indirect, incidental, special, + exemplary, or consequential damages (including, but not limited to, + procurement of substitute goods or services; loss of use, data, or + profits; or business interruption) however caused and on any theory of + liability, whether in contract, strict liability, or tort (including + negligence or otherwise) arising in any way out of the use of this + software, even if advised of the possibility of such damage. */ + +#include "memmodel.h" + +;; This function is responsible for setting up the arguments +;; required for __crt0_run_array, to run the functions in .preinit_array. + +START_CRT_FUNC 0500 run_preinit_array + + mov_ #__preinit_array_start, R4 + mov_ #__preinit_array_end, R5 + mov_ #PTRsz, R6 + call_ #__crt0_run_array + +END_CRT_FUNC run_preinit_array diff --git a/libgloss/msp430/memmodel.h b/libgloss/msp430/memmodel.h index a481460c6..9fba60190 100644 --- a/libgloss/msp430/memmodel.h +++ b/libgloss/msp430/memmodel.h @@ -40,10 +40,16 @@ #endif =20 /* Start a function in its own named and numbered section, so that it - can be subject to linker garbage collection. The numbers are used - to enforce link-time ordering of the sections. Note - the construction - of the symbol names is critical - they need to match the unresolved - symbol references created by the compiler and assembler. */ + can be subject to linker garbage collection. + + The linker links all .crt_* sections in asciibetical order at the same = place. + So, the four digits in .crt_NNNN_xxx name are used to enforce link-time + ordering of the sections. Make sure to keep them in sequential order. = The + first two digits are set in the files, the second two allow users to in= sert + code between our standard code fragments. + + Note - the construction of the symbol names is critical - they need to = match + the unresolved symbol references created by the compiler and assembler.= */ .macro START_CRT_FUNC number name=20 .section .crt_\number\name,"ax",@progbits .global __crt0_\name