mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 18:52:45 +01:00
152 lines
3.8 KiB
ArmAsm
152 lines
3.8 KiB
ArmAsm
|
/*
|
||
|
* Copyright 2016, Imagination Technologies Limited and/or its
|
||
|
* affiliated group companies.
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* 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. Neither the name of the copyright holder nor the names of its
|
||
|
* contributors may 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 THE COPYRIGHT HOLDER OR CONTRIBUTORS 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.
|
||
|
*/
|
||
|
|
||
|
|
||
|
/* ************ PLEASE READ ME !!!! ****************
|
||
|
|
||
|
This file is missing from $MIPS_ELF_ROOT/share/mips/hal
|
||
|
|
||
|
Future toolchain versions will have this file included and this local copy will
|
||
|
be no longer needed.
|
||
|
|
||
|
Note the above copyright/license is 3 Clause BSD and as such is compatible with LGPLv2.1
|
||
|
as such we grant licensing this file under LGPLv2.1 (See the file LICENSE in the top level
|
||
|
directory for more details) as well.
|
||
|
|
||
|
Thanks for reading.
|
||
|
*/
|
||
|
|
||
|
.set nomips16
|
||
|
#include <mips/asm.h>
|
||
|
#include <mips/regdef.h>
|
||
|
#include <mips/m32c0.h>
|
||
|
#include <mips/hal.h>
|
||
|
#include <mips/endian.h>
|
||
|
|
||
|
#
|
||
|
# FUNCTION: _dsp_save
|
||
|
#
|
||
|
# DESCRIPTION: save the DSP context.
|
||
|
#
|
||
|
# RETURNS: int
|
||
|
#
|
||
|
# 0: No context saved
|
||
|
# CTX_*: Type of conext stored
|
||
|
#
|
||
|
LEAF(_dsp_save)
|
||
|
PTR_S zero, LINKCTX_NEXT(a0)
|
||
|
move v0, zero
|
||
|
|
||
|
# Test for DSP support
|
||
|
mfc0 t0, C0_CONFIG3
|
||
|
ext t0, t0, CFG3_DSPP_SHIFT, 1
|
||
|
beqz t0, 1f
|
||
|
|
||
|
# Test for DSP enabled
|
||
|
mfc0 t0, C0_STATUS
|
||
|
ext t0, t0, SR_MX_SHIFT, 1
|
||
|
beqz t0, 1f
|
||
|
|
||
|
lui v0, %hi(LINKCTX_TYPE_DSP)
|
||
|
addiu v0, v0, %lo(LINKCTX_TYPE_DSP)
|
||
|
.set push
|
||
|
.set dsp
|
||
|
rddsp t1
|
||
|
mfhi t2, $ac1
|
||
|
mflo t3, $ac1
|
||
|
mfhi t4, $ac2
|
||
|
mflo t5, $ac2
|
||
|
mfhi t6, $ac3
|
||
|
mflo t7, $ac3
|
||
|
.set pop
|
||
|
sw t1, DSPCTX_DSPC(a0)
|
||
|
sw t2, DSPCTX_HI1(a0)
|
||
|
sw t3, DSPCTX_LO1(a0)
|
||
|
sw t4, DSPCTX_HI2(a0)
|
||
|
sw t5, DSPCTX_LO2(a0)
|
||
|
sw t6, DSPCTX_HI3(a0)
|
||
|
sw t7, DSPCTX_LO3(a0)
|
||
|
REG_S v0, LINKCTX_ID(a0)
|
||
|
1:
|
||
|
jr ra
|
||
|
END(_dsp_save)
|
||
|
|
||
|
#
|
||
|
# FUNCTION: _dsp_load
|
||
|
#
|
||
|
# DESCRIPTION: load the DSP context.
|
||
|
#
|
||
|
# RETURNS: int
|
||
|
#
|
||
|
# 0: Unrecognised context
|
||
|
# CTX_*: Type of context restored
|
||
|
#
|
||
|
LEAF(_dsp_load)
|
||
|
REG_L v0, LINKCTX_ID(a0)
|
||
|
lui v1, %hi(LINKCTX_TYPE_DSP)
|
||
|
addiu v1, v1, %lo(LINKCTX_TYPE_DSP)
|
||
|
bne v0,v1,1f
|
||
|
|
||
|
# Test for DSP support
|
||
|
mfc0 t0, C0_CONFIG3
|
||
|
ext t0, t0, CFG3_DSPP_SHIFT, 1
|
||
|
beqz t0, 1f
|
||
|
|
||
|
# Force on DSP
|
||
|
di t3
|
||
|
ehb
|
||
|
or t3, t3, SR_MX
|
||
|
mtc0 t3, C0_STATUS
|
||
|
ehb
|
||
|
|
||
|
lw t1, DSPCTX_DSPC(a0)
|
||
|
lw t2, DSPCTX_HI1(a0)
|
||
|
lw t3, DSPCTX_LO1(a0)
|
||
|
lw t4, DSPCTX_HI2(a0)
|
||
|
lw t5, DSPCTX_LO2(a0)
|
||
|
lw t6, DSPCTX_HI3(a0)
|
||
|
lw t7, DSPCTX_LO3(a0)
|
||
|
.set push
|
||
|
.set dsp
|
||
|
wrdsp t1
|
||
|
mthi t2, $ac1
|
||
|
mtlo t3, $ac1
|
||
|
mthi t4, $ac2
|
||
|
mtlo t5, $ac2
|
||
|
mthi t6, $ac3
|
||
|
mtlo t7, $ac3
|
||
|
.set pop
|
||
|
jr ra
|
||
|
1:
|
||
|
# Don't recognise this context, fail
|
||
|
move v0, zero
|
||
|
jr ra
|
||
|
END(_dsp_load)
|