summaryrefslogtreecommitdiff
path: root/examples/stubs.c
diff options
context:
space:
mode:
authorWolfgang Denk <wd@denx.de>2007-12-27 01:12:56 +0100
committerWolfgang Denk <wd@denx.de>2007-12-27 01:12:56 +0100
commit81b38be8631a0b809c97ab3d929f491373d7314f (patch)
tree0dd6444e2b602dcd06524f57c234b1f3b18ceb83 /examples/stubs.c
parentf77ac3d657e9b1d40012153e872a2118cca10a3d (diff)
parent29592ecba3b932b9b152bcec6c0c0806412db4a3 (diff)
downloadu-boot-imx-81b38be8631a0b809c97ab3d929f491373d7314f.zip
u-boot-imx-81b38be8631a0b809c97ab3d929f491373d7314f.tar.gz
u-boot-imx-81b38be8631a0b809c97ab3d929f491373d7314f.tar.bz2
Merge branch 'master' of git://www.denx.de/git/u-boot-sh
Conflicts: MAINTAINERS Signed-off-by: Wolfgang Denk <wd@denx.de>
Diffstat (limited to 'examples/stubs.c')
-rw-r--r--examples/stubs.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/examples/stubs.c b/examples/stubs.c
index 26df6e0..263dd8c 100644
--- a/examples/stubs.c
+++ b/examples/stubs.c
@@ -151,6 +151,22 @@ gd_t *global_data;
: \
: "i"(offsetof(gd_t, jt)), "i"(XF_ ##x) \
: "r8");
+#elif defined(CONFIG_SH)
+/*
+ * r13 holds the pointer to the global_data. r1 is a call clobbered.
+ */
+#define EXPORT_FUNC(x) \
+ asm volatile ( \
+ " .align 2\n" \
+ " .globl " #x "\n" \
+ #x ":\n" \
+ " mov r13, r1\n" \
+ " add %0, r1\n" \
+ " add %1, r1\n" \
+ " jmp @r1\n" \
+ " nop\n" \
+ " nop\n" \
+ : : "i"(offsetof(gd_t, jt)), "i"(XF_ ## x * sizeof(void *)) : "r1");
#else
#error stubs definition missing for this architecture
#endif