ctr_firmware/trunk/bootrom/build/libraries/mi/common/mi_exclusive.c
nakasima 83bec6addb スピンロックライブラリ追加。
git-svn-id: file:///Volumes/Transfer/gigaleak_20231201/2020-09-30%20-%20paladin.7z/paladin/ctr_firmware@165 b871894f-2f95-9b40-918c-086798483c85
2009-01-13 07:03:40 +00:00

64 lines
2.1 KiB
C

/*---------------------------------------------------------------------------*
Project: CtrBrom - MI
File: mi_exclusive.c
Copyright 2009 Nintendo. All rights reserved.
These coded instructions, statements, and computer programs contain
proprietary information of Nintendo of America Inc. and/or Nintendo
Company Ltd., and are protected by Federal copyright law. They may
not be disclosed to third parties or copied or duplicated in any form,
in whole or in part, without the prior written consent of Nintendo.
$Date:: $
$Rev$
$Author$
*---------------------------------------------------------------------------*/
#include <brom/mi/exclusive.h>
// miSwap* will be used for control common resource exclusively among processers
// or modules. Beside, it's used for realization spin lock system.
//
// notice: you cannot access main memory by byte unless via cache.
// so, use miSwapByte generally for accessing main memory ,not miSwapWord.
//---- This code will be compiled in ARM-Mode
#include <brom/code32.h>
/*---------------------------------------------------------------------------*
Name: miSwapByte
Description: swap data and memory
Arguments: setData data to swap
destp memory address to swap
Returns: swapped memory data
*---------------------------------------------------------------------------*/
asm u8 miSwapByte( register u32 setData, register vu8* destp )
{
swpb r0, r0, [r1]
bx lr
}
/*---------------------------------------------------------------------------*
Name: miSwapWord
Description: swap data and memory
Arguments: setData data to swap
destp memory address to swap
Returns: swapped memory data
*---------------------------------------------------------------------------*/
asm u32 miSwapWord( register u32 setData, register vu32* destp )
{
swp r0, r0, [r1]
bx lr
}
//---- end limitation of ARM-Mode
#include <brom/codereset.h>