NetBSD/sys/arch/acorn26/stand/lib/riscoscalls.S
bjh21 1de4f40a8a Rename NetBSD/arm26 to NetBSD/acorn26, so that the two Acorn/ARM ports have
matching names.  This commit might include some private hacks that have been
lurking in my tree a while.  They're all harmless, and this reduces the number
of gratuitous diffs I have to deal with.
2002-03-24 15:45:29 +00:00

241 lines
5.0 KiB
ArmAsm

/* $NetBSD: riscoscalls.S,v 1.1 2002/03/24 15:47:27 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
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(os_byte)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_Byte
teq r3, #0
strne r1, [r3]
ldr r3, [fp, #4]
teq r3, #0
strne r2, [r3]
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_int_off)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_IntOff
ldmdb fp, {fp, sp, pc}
ENTRY(os_enter_os)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_EnterOS
ldmdb fp, {fp, sp, pc}
ENTRY(xosfscontrol_shutdown)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r0, #OSFSControl_Shutdown
swi XOS_FSControl
movvc r0, #0
ldmdb fp, {fp, sp, pc}
ENTRY(service_pre_reset)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r1, #Service_PreReset
swi OS_ServiceCall
ldmdb fp, {fp, sp, pc}
ENTRY(os_read_vdu_variables)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi OS_ReadVduVariables
ldmdb fp, {fp, sp, pc}
ENTRY(xos_swi_number_from_string)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
mov r2, r1
mov r1, r0
swi XOS_SWINumberFromString
ldmvsdb fp, {fp, sp, pc}
str r0, [r2]
mov r0, #0
ldmdb fp, {fp, sp, pc}
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}
ENTRY(xcache_control)
mov ip, sp
stmfd sp!, {fp, ip, lr, pc}
sub fp, ip, #4
swi XCache_Control
ldmvsdb fp, {fp, sp, pc}
teq r2, #0
strne r0, [r2]
mov r0, #0
ldmdb fp, {fp, sp, pc}