Search
lxdream.org :: lxdream/test/sh4/tlb.s
lxdream 0.9.1
released Jun 29
Download Now
filename test/sh4/tlb.s
changeset 555:309c97260912
next1065:bc1cc0c54917
author nkeynes
date Tue Jan 01 04:32:01 2008 +0000 (16 years ago)
branchlxdream-mmu
permissions -rw-r--r--
last change Add initial TLB tests
file annotate diff log raw
nkeynes@555
     1
.section .text
nkeynes@555
     2
.include "sh4/inc.s"
nkeynes@555
     3
!
nkeynes@555
     4
! Test for correct UTLB operation.
nkeynes@555
     5
! 
nkeynes@555
     6
! Note we don't test triggering a TLB multiple-hit exception - it's a reset
nkeynes@555
     7
! rather than a regular exception.
nkeynes@555
     8
nkeynes@555
     9
.global _test_tlb
nkeynes@555
    10
_test_tlb:
nkeynes@555
    11
	start_test
nkeynes@555
    12
nkeynes@555
    13
! Turn on AT, and flush the current TLB (if any)
nkeynes@555
    14
! Initialize to SV=0, SQMD=0, URB=URC=LRUI=0
nkeynes@555
    15
	mov.l test_tlb_mmucr, r0
nkeynes@555
    16
	mov #5, r1
nkeynes@555
    17
	mov.l r1, @r0
nkeynes@555
    18
	
nkeynes@555
    19
! Privileged mode tests first (much easier)
nkeynes@555
    20
	add #1, r12
nkeynes@555
    21
	mov.l test_tlb1_pteh, r1
nkeynes@555
    22
	mov.l test_tlb_pteh, r2
nkeynes@555
    23
	mov.l r1, @r2
nkeynes@555
    24
	mov.l test_tlb1_ptel, r1
nkeynes@555
    25
	mov.l test_tlb_ptel, r2
nkeynes@555
    26
	mov.l r1, @r2
nkeynes@555
    27
	ldtlb
nkeynes@555
    28
nkeynes@555
    29
! Simple read
nkeynes@555
    30
	mov.l test_tlb1_direct, r3
nkeynes@555
    31
	mov #42, r2
nkeynes@555
    32
	mov.l r2, @r3
nkeynes@555
    33
	mov.l test_tlb1_mmu, r0
nkeynes@555
    34
	mov.l @r0, r1
nkeynes@555
    35
	cmp/eq r1, r2
nkeynes@555
    36
	bt test_tlb_2
nkeynes@555
    37
	fail test_tlb_str_k
nkeynes@555
    38
	bra test_tlb_2
nkeynes@555
    39
	nop
nkeynes@555
    40
test_tlb1_pteh:
nkeynes@555
    41
	.long 0x12345012
nkeynes@555
    42
test_tlb1_ptel:
nkeynes@555
    43
	.long 0x005F8120
nkeynes@555
    44
nkeynes@555
    45
test_tlb_2:		
nkeynes@555
    46
	! Trigger an initial-page-write exception
nkeynes@555
    47
	add #1, r12
nkeynes@555
    48
	expect_exc 0x00000080
nkeynes@555
    49
	mov.l test_tlb1_mmu, r0
nkeynes@555
    50
test_tlb2_exc:	
nkeynes@555
    51
	mov.l r0, @r0
nkeynes@555
    52
	assert_tlb_exc_caught test_tlb_str_k test_tlb2_exc test_tlb1_mmu
nkeynes@555
    53
nkeynes@555
    54
test_tlb_3:
nkeynes@555
    55
	! Trigger a missing page read exception by invalidation
nkeynes@555
    56
	add #1, r12
nkeynes@555
    57
	mov.l test_tlb3_addr, r1
nkeynes@555
    58
	mov.l test_tlb3_data, r2
nkeynes@555
    59
	mov.l r2, @r1
nkeynes@555
    60
nkeynes@555
    61
	expect_exc 0x00000040
nkeynes@555
    62
	mov.l test_tlb1_mmu, r0
nkeynes@555
    63
test_tlb3_exc:
nkeynes@555
    64
	mov.l @r0, r2
nkeynes@555
    65
	assert_tlb_exc_caught test_tlb_str_k, test_tlb3_exc, test_tlb1_mmu
nkeynes@555
    66
	bra test_tlb_4
nkeynes@555
    67
	nop
nkeynes@555
    68
	
nkeynes@555
    69
test_tlb3_addr:
nkeynes@555
    70
	.long 0xF6000F80
nkeynes@555
    71
test_tlb3_data:
nkeynes@555
    72
	.long 0x12345212
nkeynes@555
    73
nkeynes@555
    74
test_tlb_4:
nkeynes@555
    75
	! Test missing page write exception on the same page
nkeynes@555
    76
	add #1, r12
nkeynes@555
    77
	expect_exc 0x00000060
nkeynes@555
    78
	mov.l test_tlb1_mmu, r0
nkeynes@555
    79
test_tlb4_exc:
nkeynes@555
    80
	mov.l r2, @r0
nkeynes@555
    81
	assert_tlb_exc_caught test_tlb_str_k, test_tlb4_exc, test_tlb1_mmu
nkeynes@555
    82
	
nkeynes@555
    83
test_tlb_5: ! Test initial write exception
nkeynes@555
    84
	add #1, r12
nkeynes@555
    85
nkeynes@555
    86
	mov.l test_tlb5_addr, r1
nkeynes@555
    87
	mov.l test_tlb5_data, r2
nkeynes@555
    88
	mov.l r2, @r1
nkeynes@555
    89
	
nkeynes@555
    90
	expect_exc 0x00000080
nkeynes@555
    91
	mov.l test_tlb1_mmu, r0
nkeynes@555
    92
	mov #63, r3
nkeynes@555
    93
test_tlb5_exc:
nkeynes@555
    94
	mov.l r3, @r0
nkeynes@555
    95
	assert_tlb_exc_caught test_tlb_str_k, test_tlb5_exc, test_tlb1_mmu
nkeynes@555
    96
	mov.l test_tlb1_direct, r3
nkeynes@555
    97
	mov.l @r3, r4
nkeynes@555
    98
	mov #42, r2
nkeynes@555
    99
	cmp/eq r2, r4
nkeynes@555
   100
	bf test_tlb5_fail
nkeynes@555
   101
	mov.l test_tlb1_mmu, r0
nkeynes@555
   102
	mov.l @r0, r3
nkeynes@555
   103
	cmp/eq r2, r3
nkeynes@555
   104
	bt test_tlb_6
nkeynes@555
   105
test_tlb5_fail:
nkeynes@555
   106
	fail test_tlb_str_k
nkeynes@555
   107
nkeynes@555
   108
test_tlb5_addr:
nkeynes@555
   109
	.long 0xF6000F80
nkeynes@555
   110
test_tlb5_data:
nkeynes@555
   111
	.long 0x12345112
nkeynes@555
   112
nkeynes@555
   113
test_tlb_6:! Test successful write.
nkeynes@555
   114
	add #1, r12
nkeynes@555
   115
nkeynes@555
   116
	mov.l test_tlb6_addr, r1
nkeynes@555
   117
	mov.l test_tlb6_data, r2
nkeynes@555
   118
	mov.l r2, @r1
nkeynes@555
   119
nkeynes@555
   120
	mov.l test_tlb1_mmu, r0
nkeynes@555
   121
	mov #77, r3
nkeynes@555
   122
	mov.l r3, @r0
nkeynes@555
   123
	mov.l test_tlb1_direct, r1
nkeynes@555
   124
	mov.l @r1, r2
nkeynes@555
   125
	cmp/eq r2, r3
nkeynes@555
   126
	bt test_tlb_7
nkeynes@555
   127
	fail test_tlb_str_k
nkeynes@555
   128
	bra test_tlb_7
nkeynes@555
   129
	nop
nkeynes@555
   130
nkeynes@555
   131
test_tlb_7:	
nkeynes@555
   132
	bra test_tlb_end
nkeynes@555
   133
	nop
nkeynes@555
   134
nkeynes@555
   135
test_tlb6_addr:
nkeynes@555
   136
	.long 0xF6000F80
nkeynes@555
   137
test_tlb6_data:
nkeynes@555
   138
	.long 0x12345312
nkeynes@555
   139
nkeynes@555
   140
			
nkeynes@555
   141
test_tlb1_mmu:
nkeynes@555
   142
	.long 0x12345040
nkeynes@555
   143
test_tlb1_direct:
nkeynes@555
   144
	.long 0xA05F8040  ! Display border colour
nkeynes@555
   145
nkeynes@555
   146
test_tlb_end:
nkeynes@555
   147
	xor r0, r0
nkeynes@555
   148
	mov.l test_tlb_mmucr, r1
nkeynes@555
   149
	mov.l r0, @r1
nkeynes@555
   150
	
nkeynes@555
   151
	end_test test_tlb_str_k
nkeynes@555
   152
nkeynes@555
   153
test_tlb_mmucr:
nkeynes@555
   154
	.long 0xFF000010
nkeynes@555
   155
test_tlb_pteh:
nkeynes@555
   156
	.long 0xFF000000
nkeynes@555
   157
test_tlb_ptel:
nkeynes@555
   158
	.long 0xFF000004
nkeynes@555
   159
test_tlb_tea:
nkeynes@555
   160
	.long 0xFF00000C
nkeynes@555
   161
test_tlb_str:
nkeynes@555
   162
	.string "TLB"
nkeynes@555
   163
.align 4
nkeynes@555
   164
test_tlb_str_k:
nkeynes@555
   165
	.long test_tlb_str
.