2020-09-30 17:12:29 +02:00

232 lines
6.1 KiB
ArmAsm
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// TITLE("EV4 Memory Operations")
//++
//
// Copyright (C) 1994,1995 Digital Equipment Corporation
//
// Module Name:
//
// ev4mem.s
//
// Abstract:
//
// This module implements EV4 memory operations that require assembly
// language.
//
// Environment:
//
// HAL, Kernel mode only.
//
//
//
//--
#include "ksalpha.h"
#define ZERO_BLOCK_SIZE (256)
#define ZERO_LOOPS (PAGE_SIZE/ZERO_BLOCK_SIZE)
//++
//
// VOID
// HalEV4ZeroPage (
// IN PVOID NewColor,
// IN PVOID OldColor,
// IN ULONG PageFrame
// )
//
// Routine Description:
//
// This function zeros a page of memory.
//
// Arguments:
//
// NewColor (a0) - Supplies the page aligned virtual address of the
// new color of the page that is zeroed.
//
// OldColor (a1) - Supplies the page aligned virtual address of the
// old color of the page that is zeroed.
//
// PageFrame (a2) - Supplies the page frame number of the page that
// is zeroed.
//
// Return Value:
//
// None.
//
//--
LEAF_ENTRY(HalZeroPage)
ldl t0, HalpIoArchitectureType
beq t0, HalpEV5ZeroPage
HalpEV4ZeroPage:
.set noreorder // hand scheduled
//
// Map the page via the 43-bit super-page on EV4.
//
ldiq t0, -0x4000 // 0xffff ffff ffff c000
sll a2, PAGE_SHIFT, t1 // physical address of page
sll t0, 28, t0 // 0xffff fc00 0000 0000
ldil t2, ZERO_LOOPS // set count of loops to run
bis t0, t1, t0 // set super-page enable + physical
bis zero, zero, zero // for branch alignment
//
// Zero the page in a loop, zeroing 256 bytes per iteration. This number
// was chosen to tradeoff loop overhead versus the overhead of fetching
// Icache blocks.
//
10:
stq zero, 0x00(t0) //
subl t2, 1, t2 // decrement the loop count
stq zero, 0x08(t0) //
stt f31, 0x10(t0) //
stq zero, 0x18(t0) //
stt f31, 0x20(t0) //
stq zero, 0x28(t0) //
stt f31, 0x30(t0) //
stq zero, 0x38(t0) //
stt f31, 0x40(t0) //
stq zero, 0x48(t0) //
stt f31, 0x50(t0) //
stq zero, 0x58(t0) //
stt f31, 0x60(t0) //
stq zero, 0x68(t0) //
stt f31, 0x70(t0) //
stq zero, 0x78(t0) //
stt f31, 0x80(t0) //
stq zero, 0x88(t0) //
stt f31, 0x90(t0) //
stq zero, 0x98(t0) //
stt f31, 0xa0(t0) //
stq zero, 0xa8(t0) //
stt f31, 0xb0(t0) //
bis t0, zero, t1 // copy base register
stq zero, 0xb8(t0) //
stq zero, 0xc0(t0) //
stt f31, 0xc8(t0) //
stq zero, 0xd0(t0) //
stt f31, 0xd8(t0) //
stq zero, 0xe0(t0) //
lda t0, 0x100(t0) // increment to next block
stq zero, 0xe8(t1) //
stt f31, 0xf0(t1) //
stt f31, 0xf8(t1) // use stt for dual issue with bne
bne t2, 10b // while count > 0
ret zero, (ra) // return
.set reorder //
HalpEV5ZeroPage:
.set noreorder // hand scheduled
//
// Map the page via the 43-bit super-page on EV5.
//
ldiq t0, -0x4000 // 0xffff ffff ffff c000
sll a2, PAGE_SHIFT, t1 // physical address of page
sll t0, 28, t0 // 0xffff fc00 0000 0000
ldil t2, ZERO_LOOPS // set count of loops to run
bis t0, t1, t0 // set super-page enable + physical
br zero, 10f // start the zeroing
//
// Zero the page in a loop, zeroing 256 bytes per iteration. This number
// was chosen to tradeoff loop overhead versus the overhead of fetching
// Icache blocks.
//
.align 4 // align as branch target
10:
stq zero, 0x00(t0) //
subl t2, 1, t2 // decrement the loop count
stq zero, 0x08(t0) //
stq zero, 0x10(t0) //
stq zero, 0x18(t0) //
stq zero, 0x20(t0) //
stq zero, 0x28(t0) //
stq zero, 0x30(t0) //
stq zero, 0x38(t0) //
stq zero, 0x40(t0) //
stq zero, 0x48(t0) //
stq zero, 0x50(t0) //
stq zero, 0x58(t0) //
stq zero, 0x60(t0) //
stq zero, 0x68(t0) //
stq zero, 0x70(t0) //
stq zero, 0x78(t0) //
stq zero, 0x80(t0) //
stq zero, 0x88(t0) //
stq zero, 0x90(t0) //
stq zero, 0x98(t0) //
stq zero, 0xa0(t0) //
stq zero, 0xa8(t0) //
stq zero, 0xb0(t0) //
stq zero, 0xb8(t0) //
bis t0, zero, t1 // copy base register
stq zero, 0xc0(t0) //
stq zero, 0xc8(t0) //
stq zero, 0xd0(t0) //
stq zero, 0xd8(t0) //
stq zero, 0xe0(t0) //
lda t0, 0x100(t0) // increment to next block
stq zero, 0xe8(t1) //
stq zero, 0xf0(t1) //
stq zero, 0xf8(t1) // use stt for dual issue with bne
bne t2, 10b // while count > 0
ret zero, (ra) // return
.set reorder //
.end HalZeroPage