summaryrefslogtreecommitdiffstats
path: root/libgloss/rl78/gcrt0.S
diff options
context:
space:
mode:
Diffstat (limited to 'libgloss/rl78/gcrt0.S')
-rw-r--r--libgloss/rl78/gcrt0.S58
1 files changed, 58 insertions, 0 deletions
diff --git a/libgloss/rl78/gcrt0.S b/libgloss/rl78/gcrt0.S
new file mode 100644
index 000000000..a75614f89
--- /dev/null
+++ b/libgloss/rl78/gcrt0.S
@@ -0,0 +1,58 @@
+/* Copyright (c) 2011 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. */
+
+#define PROFILE_SUPPORT 1
+
+#include "crt0.S"
+
+ .global __mcount
+ .type __mcount, @function
+__mcount:
+ ;; When a function is compiled for profiling, gcc creates code
+ ;; like this at the start of each profiled function:
+ ;;
+ ;; .global <func_name>
+ ;; <func_name>:
+ ;; bsr __mcount
+ ;; <...function's prologue...>
+ ;; <...function's body...>
+ ;;
+ ;; We must save all of the argument registers, extract the
+ ;; address of <func_name>, call _mcount_internal to do the
+ ;; real work and then restore the argument registers before
+ ;; returning.
+
+ movw ax, [sp]
+ push ax
+ call !!__mcount_internal
+ pop ax
+ ret
+
+ .size __mcount, . - __mcount