Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/x68k/x68k Move the startup routine to the beginning...
details: https://anonhg.NetBSD.org/src/rev/678ef3715bc3
branches: trunk
changeset: 326501:678ef3715bc3
user: tsutsui <tsutsui%NetBSD.org@localhost>
date: Fri Jan 31 18:24:03 2014 +0000
description:
Move the startup routine to the beginning of the source as other m68k ports.
No particular comments on port-x68k@.
diffstat:
sys/arch/x68k/x68k/locore.s | 546 ++++++++++++++++++++++----------------------
1 files changed, 273 insertions(+), 273 deletions(-)
diffs (truncated from 567 to 300 lines):
diff -r 2dc0cf0b49ac -r 678ef3715bc3 sys/arch/x68k/x68k/locore.s
--- a/sys/arch/x68k/x68k/locore.s Fri Jan 31 18:17:27 2014 +0000
+++ b/sys/arch/x68k/x68k/locore.s Fri Jan 31 18:24:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: locore.s,v 1.111 2013/10/27 02:06:06 tsutsui Exp $ */
+/* $NetBSD: locore.s,v 1.112 2014/01/31 18:24:03 tsutsui Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -82,6 +82,278 @@
/* NOTREACHED */
/*
+ * Macro to relocate a symbol, used before MMU is enabled.
+ */
+#define _RELOC(var, ar) \
+ lea var,ar; \
+ addl %a5,ar
+
+#define RELOC(var, ar) _RELOC(_C_LABEL(var), ar)
+#define ASRELOC(var, ar) _RELOC(_ASM_LABEL(var), ar)
+
+/*
+ * Initialization
+ *
+ * A4 contains the address of the end of the symtab
+ * A5 contains physical load point from boot
+ * VBR contains zero from ROM. Exceptions will continue to vector
+ * through ROM until MMU is turned on at which time they will vector
+ * through our table (vectors.s).
+ */
+BSS(lowram,4)
+BSS(esym,4)
+
+GLOBAL(_verspad)
+ .word 0
+GLOBAL(boot_version)
+ .word X68K_BOOTIF_VERS
+
+ASENTRY_NOPROFILE(start)
+ movw #PSL_HIGHIPL,%sr | no interrupts
+
+ addql #4,%sp
+ movel %sp@+,%a5 | firstpa
+ movel %sp@+,%d5 | fphysize -- last page
+ movel %sp@,%a4 | esym
+
+ RELOC(vectab,%a0) | set Vector Base Register temporaly
+ movc %a0,%vbr
+
+#if 0 /* XXX this should be done by the boot loader */
+ RELOC(edata, %a0) | clear out BSS
+ movl #_C_LABEL(end)-4,%d0 | (must be <= 256 kB)
+ subl #_C_LABEL(edata),%d0
+ lsrl #2,%d0
+1: clrl %a0@+
+ dbra %d0,1b
+#endif
+
+ ASRELOC(tmpstk, %a0)
+ movl %a0,%sp | give ourselves a temporary stack
+ RELOC(esym, %a0)
+#if 1
+ movl %a4,%a0@ | store end of symbol table
+#else
+ clrl %a0@ | no symbol table, yet
+#endif
+ RELOC(lowram, %a0)
+ movl %a5,%a0@ | store start of physical memory
+
+ movl #CACHE_OFF,%d0
+ movc %d0,%cacr | clear and disable on-chip cache(s)
+
+/* determine our CPU/MMU combo - check for all regardless of kernel config */
+ movl #0x200,%d0 | data freeze bit
+ movc %d0,%cacr | only exists on 68030
+ movc %cacr,%d0 | read it back
+ tstl %d0 | zero?
+ jeq Lnot68030 | yes, we have 68020/68040/68060
+ jra Lstart1 | no, we have 68030
+Lnot68030:
+ bset #31,%d0 | data cache enable bit
+ movc %d0,%cacr | only exists on 68040/68060
+ movc %cacr,%d0 | read it back
+ tstl %d0 | zero?
+ jeq Lis68020 | yes, we have 68020
+ moveq #0,%d0 | now turn it back off
+ movec %d0,%cacr | before we access any data
+ .word 0xf4d8 | cinva bc - invalidate caches XXX
+ bset #30,%d0 | data cache no allocate mode bit
+ movc %d0,%cacr | only exists on 68060
+ movc %cacr,%d0 | read it back
+ tstl %d0 | zero?
+ jeq Lis68040 | yes, we have 68040
+ RELOC(mmutype, %a0) | no, we have 68060
+ movl #MMU_68040,%a0@ | with a 68040 compatible MMU
+ RELOC(cputype, %a0)
+ movl #CPU_68060,%a0@ | and a 68060 CPU
+ jra Lstart1
+Lis68040:
+ RELOC(mmutype, %a0)
+ movl #MMU_68040,%a0@ | with a 68040 MMU
+ RELOC(cputype, %a0)
+ movl #CPU_68040,%a0@ | and a 68040 CPU
+ jra Lstart1
+Lis68020:
+ RELOC(mmutype, %a0)
+ movl #MMU_68851,%a0@ | we have PMMU
+ RELOC(cputype, %a0)
+ movl #CPU_68020,%a0@ | and a 68020 CPU
+
+Lstart1:
+/* initialize source/destination control registers for movs */
+ moveq #FC_USERD,%d0 | user space
+ movc %d0,%sfc | as source
+ movc %d0,%dfc | and destination of transfers
+/* initialize memory sizes (for pmap_bootstrap) */
+ movl %d5,%d1 | last page
+ moveq #PGSHIFT,%d2
+ lsrl %d2,%d1 | convert to page (click) number
+ RELOC(maxmem, %a0)
+ movl %d1,%a0@ | save as maxmem
+ movl %a5,%d0 | lowram value from ROM via boot
+ lsrl %d2,%d0 | convert to page number
+ subl %d0,%d1 | compute amount of RAM present
+ RELOC(physmem, %a0)
+ movl %d1,%a0@ | and physmem
+/* configure kernel and lwp0 VA space so we can get going */
+#if NKSYMS || defined(DDB) || defined(LKM)
+ RELOC(esym,%a0) | end of static kernel test/data/syms
+ movl %a0@,%d5
+ jne Lstart2
+#endif
+ movl #_C_LABEL(end),%d5 | end of static kernel text/data
+Lstart2:
+ RELOC(setmemrange,%a0) | call setmemrange()
+ jbsr %a0@ | to probe all memory regions
+ addl #PAGE_SIZE-1,%d5
+ andl #PG_FRAME,%d5 | round to a page
+ movl %d5,%a4
+ addl %a5,%a4 | convert to PA
+ pea %a5@ | firstpa
+ pea %a4@ | nextpa
+ RELOC(pmap_bootstrap,%a0)
+ jbsr %a0@ | pmap_bootstrap(firstpa, nextpa)
+ addql #8,%sp
+
+/*
+ * Prepare to enable MMU.
+ * Since the kernel is mapped logical == physical, we just turn it on.
+ */
+ RELOC(Sysseg_pa, %a0) | system segment table addr
+ movl %a0@,%d1 | read value (a PA)
+ RELOC(mmutype, %a0)
+ cmpl #MMU_68040,%a0@ | 68040?
+ jne Lmotommu1 | no, skip
+ .long 0x4e7b1807 | movc d1,srp
+ jra Lstploaddone
+Lmotommu1:
+ RELOC(protorp, %a0)
+ movl #0x80000202,%a0@ | nolimit + share global + 4 byte PTEs
+ movl %d1,%a0@(4) | + segtable address
+ pmove %a0@,%srp | load the supervisor root pointer
+ movl #0x80000002,%a0@ | reinit upper half for CRP loads
+Lstploaddone:
+ RELOC(mmutype, %a0)
+ cmpl #MMU_68040,%a0@ | 68040?
+ jne Lmotommu2 | no, skip
+#include "opt_jupiter.h"
+#ifdef JUPITER
+ /* JUPITER-X: set system register "SUPER" bit */
+ movl #0x0200a240,%d0 | translate DRAM area transparently
+ .long 0x4e7b0006 | movc d0,dtt0
+ lea 0x00c00000,%a0 | a0: graphic VRAM
+ lea 0x02c00000,%a1 | a1: graphic VRAM ( not JUPITER-X )
+ | DRAM ( JUPITER-X )
+ movw %a0@,%d0
+ movw %d0,%d1
+ notw %d1
+ movw %d1,%a1@
+ movw %d0,%a0@
+ cmpw %a1@,%d1 | JUPITER-X?
+ jne Ljupiterdone | no, skip
+ movl #0x0100a240,%d0 | to access system register
+ .long 0x4e7b0006 | movc d0,dtt0
+ movb #0x01,0x01800003 | set "SUPER" bit
+Ljupiterdone:
+#endif /* JUPITER */
+ moveq #0,%d0 | ensure TT regs are disabled
+ .long 0x4e7b0004 | movc d0,itt0
+ .long 0x4e7b0005 | movc d0,itt1
+ .long 0x4e7b0006 | movc d0,dtt0
+ .long 0x4e7b0007 | movc d0,dtt1
+ .word 0xf4d8 | cinva bc
+ .word 0xf518 | pflusha
+#if PGSHIFT == 13
+ movl #0xc000,%d0
+#else
+ movl #0x8000,%d0
+#endif
+ .long 0x4e7b0003 | movc d0,tc
+#ifdef M68060
+ RELOC(cputype, %a0)
+ cmpl #CPU_68060,%a0@ | 68060?
+ jne Lnot060cache
+ movl #1,%d0
+ .long 0x4e7b0808 | movcl d0,pcr
+ movl #0xa0808000,%d0
+ movc %d0,%cacr | enable store buffer, both caches
+ jmp Lenab1
+Lnot060cache:
+#endif
+ movl #0x80008000,%d0
+ movc %d0,%cacr | turn on both caches
+ jmp Lenab1
+Lmotommu2:
+ pflusha
+#if PGSHIFT == 13
+ movl #0x82d08b00,%sp@- | value to load TC with
+#else
+ movl #0x82c0aa00,%sp@- | value to load TC with
+#endif
+ pmove %sp@,%tc | load it
+
+/*
+ * Should be running mapped from this point on
+ */
+Lenab1:
+/* set vector base in virtual address */
+ movl #_C_LABEL(vectab),%d0 | set Vector Base Register
+ movc %d0,%vbr
+ lea _ASM_LABEL(tmpstk),%sp | temporary stack
+/* call final pmap setup */
+ jbsr _C_LABEL(pmap_bootstrap_finalize)
+/* set kernel stack, user SP */
+ movl _C_LABEL(lwp0uarea),%a1 | grab lwp0 uarea
+ lea %a1@(USPACE-4),%sp | set kernel stack to end of area
+ movl #USRSTACK-4,%a2
+ movl %a2,%usp | init user SP
+
+/* detect FPU type */
+ jbsr _C_LABEL(fpu_probe)
+ movl %d0,_C_LABEL(fputype)
+ tstl _C_LABEL(fputype) | Have an FPU?
+ jeq Lenab2 | No, skip.
+ clrl %a1@(PCB_FPCTX) | ensure null FP context
+ movl %a1,%sp@-
+ jbsr _C_LABEL(m68881_restore) | restore it (does not kill a1)
+ addql #4,%sp
+Lenab2:
+ cmpl #MMU_68040,_C_LABEL(mmutype) | 68040?
+ jeq Ltbia040 | yes, cache already on
+ pflusha
+ tstl _C_LABEL(mmutype)
+ jpl Lenab3 | 68851 implies no d-cache
+ movl #CACHE_ON,%d0
+ movc %d0,%cacr | clear cache(s)
+ jra Lenab3
+Ltbia040:
+ .word 0xf518
+Lenab3:
+/* final setup for C code */
+ movl %d7,_C_LABEL(boothowto) | save reboot flags
+ movl %d6,_C_LABEL(bootdev) | and boot device
+ jbsr _C_LABEL(x68k_init) | additional pre-main initialization
+
+/*
+ * Create a fake exception frame so that cpu_lwp_fork() can copy it.
+ * main() nevers returns; we exit to user mode from a forked process
+ * later on.
+ */
+ clrw %sp@- | vector offset/frame type
+ clrl %sp@- | PC - filled in by "execve"
+ movw #PSL_USER,%sp@- | in user mode
+ clrl %sp@- | stack adjust count and padding
+ lea %sp@(-64),%sp | construct space for D0-D7/A0-A7
+ lea _C_LABEL(lwp0),%a0 | save pointer to frame
+ movl %sp,%a0@(L_MD_REGS) | in lwp0.p_md.md_regs
+
+ jra _C_LABEL(main) | main()
+
+ PANIC("main() returned") | Yow! Main returned!
+ /* NOTREACHED */
+
+/*
* Trap/interrupt vector routines
*/
#include <m68k/m68k/trap_subr.s>
@@ -655,278 +927,6 @@
rte | real return
/*
- * Macro to relocate a symbol, used before MMU is enabled.
- */
-#define _RELOC(var, ar) \
- lea var,ar; \
- addl %a5,ar
-
-#define RELOC(var, ar) _RELOC(_C_LABEL(var), ar)
-#define ASRELOC(var, ar) _RELOC(_ASM_LABEL(var), ar)
Home |
Main Index |
Thread Index |
Old Index