mirror of
https://xff.cz/git/u-boot/
synced 2025-09-02 09:12:08 +02:00
Add support for 64-bit MIPS to examples/standalone
Signed-off-by: Stanislav Galabov <sgalabov@gmail.com>
This commit is contained in:
committed by
Daniel Schwierzeck
parent
78757d52c8
commit
4a48cfc4e5
@@ -65,6 +65,23 @@ gd_t *global_data;
|
|||||||
: : "i"(offsetof(gd_t, jt)), "i"(FO(x)) : "ip");
|
: : "i"(offsetof(gd_t, jt)), "i"(FO(x)) : "ip");
|
||||||
#endif
|
#endif
|
||||||
#elif defined(CONFIG_MIPS)
|
#elif defined(CONFIG_MIPS)
|
||||||
|
#ifdef CONFIG_CPU_MIPS64
|
||||||
|
/*
|
||||||
|
* k0 ($26) holds the pointer to the global_data; t9 ($25) is a call-
|
||||||
|
* clobbered register that is also used to set gp ($26). Note that the
|
||||||
|
* jr instruction also executes the instruction immediately following
|
||||||
|
* it; however, GCC/mips generates an additional `nop' after each asm
|
||||||
|
* statement
|
||||||
|
*/
|
||||||
|
#define EXPORT_FUNC(f, a, x, ...) \
|
||||||
|
asm volatile ( \
|
||||||
|
" .globl " #x "\n" \
|
||||||
|
#x ":\n" \
|
||||||
|
" ld $25, %0($26)\n" \
|
||||||
|
" ld $25, %1($25)\n" \
|
||||||
|
" jr $25\n" \
|
||||||
|
: : "i"(offsetof(gd_t, jt)), "i"(FO(x)) : "t9");
|
||||||
|
#else
|
||||||
/*
|
/*
|
||||||
* k0 ($26) holds the pointer to the global_data; t9 ($25) is a call-
|
* k0 ($26) holds the pointer to the global_data; t9 ($25) is a call-
|
||||||
* clobbered register that is also used to set gp ($26). Note that the
|
* clobbered register that is also used to set gp ($26). Note that the
|
||||||
@@ -80,6 +97,7 @@ gd_t *global_data;
|
|||||||
" lw $25, %1($25)\n" \
|
" lw $25, %1($25)\n" \
|
||||||
" jr $25\n" \
|
" jr $25\n" \
|
||||||
: : "i"(offsetof(gd_t, jt)), "i"(FO(x)) : "t9");
|
: : "i"(offsetof(gd_t, jt)), "i"(FO(x)) : "t9");
|
||||||
|
#endif
|
||||||
#elif defined(CONFIG_NIOS2)
|
#elif defined(CONFIG_NIOS2)
|
||||||
/*
|
/*
|
||||||
* gp holds the pointer to the global_data, r8 is call-clobbered
|
* gp holds the pointer to the global_data, r8 is call-clobbered
|
||||||
|
Reference in New Issue
Block a user