2002-07-11 18:23:04 +04:00
|
|
|
/* $NetBSD: _setjmp.S,v 1.3 2002/07/11 14:23:05 scw Exp $ */
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright 2002 Wasabi Systems, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Written by Steve C. Woodford for Wasabi Systems, Inc.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. 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.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed for the NetBSD Project by
|
|
|
|
* Wasabi Systems, Inc.
|
|
|
|
* 4. The name of Wasabi Systems, Inc. may not be used to endorse
|
|
|
|
* or promote products derived from this software without specific prior
|
|
|
|
* written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``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 WASABI SYSTEMS, INC
|
|
|
|
* 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 <machine/asm.h>
|
2002-07-10 15:05:19 +04:00
|
|
|
#include <machine/setjmp.h>
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
|
|
|
|
/*
|
2002-07-11 18:23:04 +04:00
|
|
|
* C library -- setjmp, longjmp
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
*
|
2002-07-11 18:23:04 +04:00
|
|
|
* longjmp(a,v)
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
* will generate a "return(v)" from
|
|
|
|
* the last call to
|
2002-07-11 18:23:04 +04:00
|
|
|
* setjmp(a)
|
|
|
|
* by restoring registers from the stack.
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
* The previous signal state is NOT restored.
|
|
|
|
*/
|
|
|
|
|
|
|
|
ENTRY_NOPROFILE(_setjmp)
|
2002-07-11 18:23:04 +04:00
|
|
|
/* Save callee-saved register */
|
|
|
|
getcon usr, r1
|
|
|
|
st.q r2, _JB_R10, r10
|
|
|
|
st.q r2, _JB_R11, r11
|
|
|
|
st.q r2, _JB_R12, r12
|
|
|
|
st.q r2, _JB_R13, r13
|
|
|
|
st.q r2, _JB_R14, r14
|
|
|
|
st.q r2, _JB_R15, r15
|
|
|
|
st.q r2, _JB_R18, r18
|
|
|
|
LDUC32(0xBADBABE5, r0)
|
|
|
|
st.q r2, _JB_R24, r0 /* sigcontext magic number */
|
|
|
|
st.q r2, _JB_R26, r26
|
|
|
|
st.q r2, _JB_R27, r27
|
|
|
|
st.q r2, _JB_R28, r28
|
|
|
|
st.q r2, _JB_R29, r29
|
|
|
|
st.q r2, _JB_R30, r30
|
|
|
|
st.q r2, _JB_R31, r31
|
|
|
|
st.q r2, _JB_R32, r32
|
|
|
|
st.q r2, _JB_R33, r33
|
|
|
|
st.q r2, _JB_R34, r34
|
|
|
|
st.q r2, _JB_R35, r35
|
|
|
|
st.q r2, _JB_R44, r44
|
|
|
|
st.q r2, _JB_R45, r45
|
|
|
|
st.q r2, _JB_R46, r46
|
|
|
|
st.q r2, _JB_R47, r47
|
|
|
|
st.q r2, _JB_R48, r48
|
|
|
|
st.q r2, _JB_R49, r49
|
|
|
|
st.q r2, _JB_R50, r50
|
|
|
|
st.q r2, _JB_R51, r51
|
|
|
|
st.q r2, _JB_R52, r52
|
|
|
|
st.q r2, _JB_R53, r53
|
|
|
|
st.q r2, _JB_R54, r54
|
|
|
|
st.q r2, _JB_R55, r55
|
|
|
|
st.q r2, _JB_R56, r56
|
|
|
|
st.q r2, _JB_R57, r57
|
|
|
|
st.q r2, _JB_R58, r58
|
|
|
|
st.q r2, _JB_R59, r59
|
|
|
|
movi 1, r0
|
|
|
|
st.q r2, _JB_TR0, r0 /* Ensure caller-saved copies of */
|
|
|
|
st.q r2, _JB_TR1, r0 /* branch-target registers have valid */
|
|
|
|
st.q r2, _JB_TR2, r0 /* (albeit, pointing to nothing) */
|
|
|
|
st.q r2, _JB_TR3, r0 /* SHmedia addresses. */
|
|
|
|
st.q r2, _JB_TR4, r0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
gettr tr5, r0
|
2002-07-11 18:23:04 +04:00
|
|
|
st.q r2, _JB_TR5, r0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
gettr tr6, r0
|
2002-07-11 18:23:04 +04:00
|
|
|
st.q r2, _JB_TR6, r0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
gettr tr7, r0
|
2002-07-11 18:23:04 +04:00
|
|
|
st.q r2, _JB_TR7, r0
|
|
|
|
pta/u 1f, tr0
|
|
|
|
shlri r1, 8, r3
|
|
|
|
andi r3, 0xff, r3
|
|
|
|
movi 0, r0 /* Assume not saved */
|
|
|
|
beq/u r3, r63, tr0 /* Jump if no FP regs used */
|
|
|
|
movi -3329, r0 /* Mask for FP regs saved/used */
|
|
|
|
and r1, r0, r1 /* Update USR */
|
|
|
|
fst.d r2, _JB_DR12, dr12 /* Quicker to save all callee-saved */
|
|
|
|
fst.d r2, _JB_DR14, dr14 /* than check USR bits */
|
|
|
|
fst.d r2, _JB_DR36, dr36
|
|
|
|
fst.d r2, _JB_DR38, dr38
|
|
|
|
fst.d r2, _JB_DR40, dr40
|
|
|
|
fst.d r2, _JB_DR42, dr42
|
|
|
|
fst.d r2, _JB_DR44, dr44
|
|
|
|
fst.d r2, _JB_DR46, dr46
|
|
|
|
fst.d r2, _JB_DR48, dr48
|
|
|
|
fst.d r2, _JB_DR50, dr50
|
|
|
|
fst.d r2, _JB_DR52, dr52
|
|
|
|
fst.d r2, _JB_DR54, dr54
|
|
|
|
fst.d r2, _JB_DR56, dr56
|
|
|
|
fst.d r2, _JB_DR58, dr58
|
|
|
|
fst.d r2, _JB_DR60, dr60
|
|
|
|
fst.d r2, _JB_DR62, dr62
|
|
|
|
fgetscr fr0
|
|
|
|
fst.d r2, _JB_FPSCR, dr0
|
|
|
|
movi 3, r0 /* Regs saved/used */
|
|
|
|
1: st.l r2, _JB_SIGFPSTATE, r0
|
|
|
|
st.q r2, _JB_USR, r1
|
|
|
|
ptabs/l r18, tr0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
movi 0, r2
|
|
|
|
blink tr0, r63
|
|
|
|
|
|
|
|
|
|
|
|
ENTRY_NOPROFILE(_longjmp)
|
2002-07-11 18:23:04 +04:00
|
|
|
pta/u Lbotch, tr0
|
|
|
|
ld.q r2, _JB_R24, r0 /* Check if jmp_buf was saved by a */
|
|
|
|
LDUC32(0xBADBABE5, r1) /* call to _setjmp, above */
|
|
|
|
bne/u r0, r1, tr0 /* Punt if not */
|
|
|
|
cmpeq r3, r63, r3 /* Ensure a non-zero return value */
|
|
|
|
|
|
|
|
/* Restore callee-saved register */
|
|
|
|
ld.q r2, _JB_R10, r10
|
|
|
|
ld.q r2, _JB_R11, r11
|
|
|
|
ld.q r2, _JB_R12, r12
|
|
|
|
ld.q r2, _JB_R13, r13
|
|
|
|
ld.q r2, _JB_R14, r14
|
|
|
|
ld.q r2, _JB_R15, r15
|
|
|
|
ld.q r2, _JB_R18, r18
|
|
|
|
ld.q r2, _JB_R26, r26
|
|
|
|
ld.q r2, _JB_R27, r27
|
|
|
|
ld.q r2, _JB_R28, r28
|
|
|
|
ld.q r2, _JB_R29, r29
|
|
|
|
ld.q r2, _JB_R30, r30
|
|
|
|
ld.q r2, _JB_R31, r31
|
|
|
|
ld.q r2, _JB_R32, r32
|
|
|
|
ld.q r2, _JB_R33, r33
|
|
|
|
ld.q r2, _JB_R34, r34
|
|
|
|
ld.q r2, _JB_R35, r35
|
|
|
|
ld.q r2, _JB_R44, r44
|
|
|
|
ld.q r2, _JB_R45, r45
|
|
|
|
ld.q r2, _JB_R46, r46
|
|
|
|
ld.q r2, _JB_R47, r47
|
|
|
|
ld.q r2, _JB_R48, r48
|
|
|
|
ld.q r2, _JB_R49, r49
|
|
|
|
ld.q r2, _JB_R50, r50
|
|
|
|
ld.q r2, _JB_R51, r51
|
|
|
|
ld.q r2, _JB_R52, r52
|
|
|
|
ld.q r2, _JB_R53, r53
|
|
|
|
ld.q r2, _JB_R54, r54
|
|
|
|
ld.q r2, _JB_R55, r55
|
|
|
|
ld.q r2, _JB_R56, r56
|
|
|
|
ld.q r2, _JB_R57, r57
|
|
|
|
ld.q r2, _JB_R58, r58
|
|
|
|
ld.q r2, _JB_R59, r59
|
|
|
|
ld.q r2, _JB_TR5, r0 /* Could take an IADDERR exception */
|
|
|
|
ptabs/u r0, tr5 /* here if the jmp_buf is corrupt... */
|
|
|
|
ld.q r2, _JB_TR6, r0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
ptabs/u r0, tr6
|
2002-07-11 18:23:04 +04:00
|
|
|
ld.q r2, _JB_TR7, r0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
ptabs/u r0, tr7
|
2002-07-11 18:23:04 +04:00
|
|
|
ld.l r2, _JB_SIGFPSTATE, r0 /* Were any FP regs saved? */
|
|
|
|
pta/u 1f, tr0
|
|
|
|
andi r0, 3, r0
|
|
|
|
beq/u r0, r63, tr0 /* Skip if not. */
|
|
|
|
fld.d r2, _JB_DR12, dr12 /* Quicker to save all callee-saved */
|
|
|
|
fld.d r2, _JB_DR14, dr14 /* than check USR bits */
|
|
|
|
fld.d r2, _JB_DR36, dr36
|
|
|
|
fld.d r2, _JB_DR38, dr38
|
|
|
|
fld.d r2, _JB_DR40, dr40
|
|
|
|
fld.d r2, _JB_DR42, dr42
|
|
|
|
fld.d r2, _JB_DR44, dr44
|
|
|
|
fld.d r2, _JB_DR46, dr46
|
|
|
|
fld.d r2, _JB_DR48, dr48
|
|
|
|
fld.d r2, _JB_DR50, dr50
|
|
|
|
fld.d r2, _JB_DR52, dr52
|
|
|
|
fld.d r2, _JB_DR54, dr54
|
|
|
|
fld.d r2, _JB_DR56, dr56
|
|
|
|
fld.d r2, _JB_DR58, dr58
|
|
|
|
fld.d r2, _JB_DR60, dr60
|
|
|
|
fld.d r2, _JB_DR62, dr62
|
|
|
|
fld.d r2, _JB_FPSCR, dr0
|
|
|
|
fputscr fr0
|
|
|
|
1: ld.q r2, _JB_USR, r1
|
|
|
|
putcon r1, usr
|
|
|
|
or r3, r63, r2 /* Fix up return value */
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
ptabs/l r18, tr0
|
2002-07-11 18:23:04 +04:00
|
|
|
blink tr0, r63
|
|
|
|
|
|
|
|
Lbotch: pta/l _C_LABEL(longjmperror), tr0
|
|
|
|
blink tr0, r18
|
|
|
|
pta/l _C_LABEL(abort), tr0
|
NetBSD, meet the SH-5 cpu.
SH-5, meet NetBSD.
Let's hope this is the start of a long and fruitful relationship. :-)
This code, funded by Wasabi Systems, adds initial support for the
Hitachi SuperH(tm) SH-5 cpu architecture to NetBSD.
At the present time, NetBSD/evbsh5 only runs on a SH-5 core simulator
which has no simulated devices other than a simple console. However, it
is good enough to get to the "root device: " prompt.
Device driver support for Real SH-5 Hardware is in place, particularly for
supporting the up-coming Cayman evaluation board, and should be quite
easy to get running when the hardware is available.
There is no in-tree toolchain for this port at this time. Gcc-current has
rudimentary SH-5 support but it is known to be buggy. A working toolchain
was obtained from SuperH to facilitate this port. Gcc-current will be
fixed in due course.
The SH-5 architecture is fully 64-bit capable, although NetBSD/evbsh5 has
currently only been tested in 32-bit mode. It is bi-endian, via a boot-
time option and it also has an "SHcompact" mode in which it will execute
SH-[34] user-land instructions.
For more information on the SH-5, see www.superh.com. Suffice to say it
is *not* just another respin of the SH-[34].
2002-07-05 17:31:28 +04:00
|
|
|
blink tr0, r63
|