NetBSD/sys/arch/arm26/stand/lib/riscoscalls.S

167 lines
3.7 KiB
ArmAsm
Raw Normal View History

/* $NetBSD: riscoscalls.S,v 1.4 2001/07/27 01:02:44 bjh21 Exp $ */
/*-
* Copyright (c) 2001 Ben Harris
* 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. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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>
#include <riscoscalls.h>
ENTRY(os_writec)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
2001-07-27 04:00:25 +04:00
swi OS_WriteC
ldmdb fp, {fp, sp, pc}
ENTRY(os_new_line)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_NewLine
ldmdb fp, {fp, sp, pc}
ENTRY(os_readc)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_ReadC
ldmdb fp, {fp, sp, pc}
ENTRY(xosargs_read)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r3, r2
swi OS_Args
ldmvsdb fp, {fp, sp, pc}
teq r3, #0
strne r2, [r3]
mov r0, #0
ldmdb fp, {fp, sp, pc}
ENTRY(xosargs_set)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_Args
movvc r0, #0
ldmdb fp, {fp, sp, pc}
ENTRY(xosgbpb_write)
mov ip, sp
stmfd sp!, {r4, fp, ip, lr, pc}
sub fp, ip, #4
mov ip, r3
mov r3, r2
mov r2, r1
mov r1, r0
mov r0, #OSGBPB_Write
swi XOS_GBPB
teq ip, #0
strne r3, [ip]
movvc r0, #0
ldmdb fp, {r4, fp, sp, pc}
ENTRY(xosgbpb_read)
mov ip, sp
stmfd sp!, {r4, fp, ip, lr, pc}
sub fp, ip, #4
mov ip, r3
mov r3, r2
mov r2, r1
mov r1, r0
mov r0, #OSGBPB_Read
swi XOS_GBPB
teq ip, #0
strne r3, [ip]
movvc r0, #0
ldmdb fp, {r4, fp, sp, pc}
ENTRY(xosfind_close)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r1, r0
mov r0, #OSFind_Close
swi XOS_Find
movvc r0, #0
ldmdb fp, {fp, sp, pc}
ENTRY(xosfind_open)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi XOS_Find
ldmvsdb fp, {fp, sp, pc}
teq r3, #0
strne r0, [r3]
mov r0, #0
ldmdb fp, {fp, sp, pc}
ENTRY(os_get_env)
mov ip, sp
stmfd sp!, {r4, fp, ip, lr, pc}
sub fp, ip, #4
mov r0, r3
mov r1, r4
swi OS_GetEnv
teq r3, #0
strne r1, [r3]
teq r4, #0
strne r2, [r4]
ldmdb fp, {r4, fp, sp, pc}
ENTRY(os_exit)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r2, r1
ldr r1, Labex
swi OS_Exit
ldmdb fp, {fp, sp, pc}
Labex:
.ascii "ABEX"
ENTRY(os_read_mem_map_info)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r2, r0
mov r3, r1
swi OS_ReadMemMapInfo
teq r2, #0
strne r0, [r2]
teq r3, #0
strne r1, [r3]
ldmdb fp, {fp, sp, pc}
ENTRY(os_read_mem_map_entries)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_ReadMemMapEntries
ldmdb fp, {fp, sp, pc}