; $NetBSD: arm_sa1100_asm.asm,v 1.2 2019/12/15 16:48:25 tsutsui Exp $
;
; Copyright (c) 2001 The NetBSD Foundation, Inc.
; All rights reserved.
;
; This code is derived from software contributed to The NetBSD Foundation
; by UCHIYAMA Yasushi.
;
; 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.
;
; THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
;
;
;armasm.exe $(InputPath)
;arm.obj
;
AREA |.text|, CODE, PIC
; FlatJump_sa1100 (kaddr_t bootinfo, kaddr_t pvec, kaddr_t stack
; kaddr_t jump)
; bootinfo boot information block address.
; pvec page vector of kernel.
; stack physical address of stack
; jump physical address of boot function
; *** MMU and pipeline behavier are SA-1100 specific. ***
EXPORT |FlatJump_sa1100|
|FlatJump_sa1100| PROC
; disable interrupt
mrs r4, cpsr
orr r4, r4, #0xc0
msr cpsr, r4
; disable MMU, I/D-Cache, Writebuffer.
; interrupt vector address is 0xffff0000
; 32bit exception handler/address range.
ldr r4, [pc, #24]
; Disable WB/Cache/MMU
mcr p15, 0, r4, c1, c0, 0
; Invalidate I/D-cache.
mcr p15, 0, r4, c7, c7, 0 ; Fetch translated fetch
; Invalidate TLB entries.
mcr p15, 0, r4, c8, c7, 0 ; Fetch translated decode
; jump to kernel entry physical address.
mov pc, r3 ; Fetch translated execute
; NOTREACHED
nop ; Fetch nontranslated cache access
nop ; Fetch nontranslated writeback
mov pc, lr ; Fetch nontranslated
DCD 0x00002030
ENDP ; |FlatJump_sa1100|
;
; UART test
;
; boot_func (uint32_t mapaddr, uint32_t bootinfo, uint32_t flags)
;
EXPORT |boot_func_sa1100|
|boot_func_sa1100| PROC
nop ; Cop15 hazard
nop ; Cop15 hazard
nop ; Cop15 hazard
mov sp, r2 ; set bootloader stack
; mov r4, r0
; mov r5, r1
; bl colorbar
; mov r0, r4
; mov r1, r5
bl boot_sa1100
nop ; NOTREACHED
nop
ENDP ; |boot_func_sa1100|
EXPORT |colorbar|
|colorbar| PROC
stmfd sp!, {r4-r7, lr}
adr r4, |$FBADDR|
ldr r4, [r4]
mov r7, #8
add r0, r0, r7
|color_loop|
mov r6, r0
and r6, r6, #7
orr r6, r6, r6, LSL #8
orr r6, r6, r6, LSL #16
add r5, r4, #0x9600
|fb_loop|
str r6, [r4], #4
cmp r4, r5
blt |fb_loop|
subs r7, r7, #1
bne |color_loop|
ldmfd sp!, {r4-r7, pc}
|$FBADDR|
DCD 0xc0003000 ; use WindowsCE default.
ENDP ; |colorbar|
EXPORT |boot_sa1100|
|boot_sa1100| PROC
;
; UART test code
;
; ; print boot_info address (r0) and page_vector start address (r1).
; mov r4, r0
; mov r5, r1
; mov r0, #'I'
; bl btputc
; mov r0, r4
; bl hexdump
; mov r0, #'P'
; bl btputc
; mov r0, r5
; bl hexdump
; mov r7, r4
; mov r2, r5 ; start
mov r7, r0 ; if enabled above debug print, remove this.
mov r2, r1 ; if enabled above debug print, remove this.
|page_loop|
mvn r0, #0 ; ~0
cmp r2, r0
beq |page_end| ; if (next == ~0) goto page_end
mov r1, r2 ; p = next
ldr r2, [r1] ; next
ldr r3, [r1, #4] ; src
ldr r4, [r1, #8] ; dst
ldr r5, [r1, #12] ; sz
cmp r3, r0
add r6, r4, r5 ; end address
bne |page_memcpy4| ; if (src != ~0) goto page_memcpy4
mov r0, #0
|page_memset| ; memset (dst, 0, sz) uncached.
str r0, [r4], #4
cmp r4, r6
blt |page_memset|
b |page_loop|
|page_memcpy4| ; memcpy (dst, src, sz) uncached.
ldr r0, [r3], #4
ldr r5, [r3], #4
str r0, [r4], #4
cmp r4, r6
strlt r5, [r4], #4
cmplt r4, r6
blt |page_memcpy4|
b |page_loop|
|page_end|
;
; jump to kernel
;
; mov r0, #'E'
; bl btputc
; ldr r0, [r7]
; bl hexdump
; ldr r0, [r7]
; ldr r0, [r0]
; bl hexdump
; set stack pointer
mov r5, #4096
add r6, r6, #8192
sub r5, r5, #1
bic sp, r6, r5
; set bootargs
ldr r4, [r7]
ldr r0, [r7, #4]
ldr r1, [r7, #8]
ldr r2, [r7, #12]
mov pc, r4
; NOTREACHED
|infinite_loop|
nop
nop
nop
nop
nop
b |infinite_loop|
ENDP ; |boot|
|btputc| PROC
adr r1, |$UARTTXBSY|
ldr r1, [r1]
|btputc_busy|
ldr r2, [r1]
and r2, r2, #1
cmp r2, #1
beq |btputc_busy|
adr r1, |$UARTTXADR|
ldr r1, [r1]
str r0, [r1]
mov pc, lr
ENDP ;|btputc|
|hexdump| PROC
stmfd sp!, {r4-r5, lr}
mov r4, r0
mov r0, #0x30
bl btputc
mov r0, #0x78
bl btputc
mov r0, r4
; Transmit register address
adr r1, |$UARTTXADR|
ldr r1, [r1]
; Transmit busy register address
adr r2, |$UARTTXBSY|
ldr r2, [r2]
mov r5, #8
|hex_loop|
mov r3, r0, LSR #28
cmp r3, #9
addgt r3, r3, #0x41 - 10
addle r3, r3, #0x30
|hex_busyloop|
ldr r4, [r2]
and r4, r4, #1
cmp r4, #1
beq |hex_busyloop|
str r3, [r1]
mov r0, r0, LSL #4
subs r5, r5, #1
bne |hex_loop|
mov r0, #0x0d
bl btputc
mov r0, #0x0a
bl btputc
ldmfd sp!, {r4-r5, pc}
ENDP ;|hexdump|
|$UARTTXADR|
DCD 0x80050014
|$UARTTXBSY|
DCD 0x80050020
EXPORT |boot_func_end_sa1100| [ DATA ]
|boot_func_end_sa1100| DCD 0x0
END