1: /*
2: * SCCS id @(#)boot.s 1.2 (Berkeley) 9/6/82
3: */
4: #include "whoami.h"
5:
6: #ifdef UCB_AUTOBOOT
7: / The boot options and device are placed in the last SZFLAGS bytes
8: / at the end of core for the bootstrap.
9: ENDCORE= 160000 / end of core, mem. management off
10: SZFLAGS= 6 / size of boot flags
11: BOOTOPTS= 2 / location of options, bytes below ENDCORE
12: BOOTDEV= 4
13: CHECKWORD= 6
14:
15: reset= 5
16:
17: .globl _doboot, hardboot
18: .text
19: _doboot:
20: mov 4(sp),r4 / boot options
21: mov 2(sp),r3 / boot device
22:
23: #ifndef KERN_NONSEP
24: / If running separate I/D, need to turn off memory management.
25: / Call the routine unmap in low text, after setting up a jump
26: / in low data where the PC will be pointing.
27: .globl unmap
28: mov $137,*$unmap+2 / jmp *$hardboot
29: mov $hardboot,*$unmap+4
30: jmp unmap
31: / "return" from unmap will be to hardboot in data
32: .data
33: #else
34: / Reset to turn off memory management
35: reset
36: #endif
37:
38: / On power fail, hardboot is the entry point (map is already off)
39: / and the args are in r4, r3.
40:
41: hardboot:
42: mov r4, ENDCORE-BOOTOPTS
43: mov r3, ENDCORE-BOOTDEV
44: com r4 / if CHECKWORD == ~bootopts, flags are believed
45: mov r4, ENDCORE-CHECKWORD
46: 1:
47: reset
48:
49: / The remainder of the code is dependent on the boot device.
50: / If you have a bootstrap ROM, just jump to the correct entry.
51: / Otherwise, use a BOOT opcode, if available;
52: / if necessary, read in block 0 to location 0 "by hand".
53:
54: /
55: / Bootstrap for DIVA Comp/V controller without boot opcode
56: /
57: HPCSR= 176700 / Drive #0
58: HPDC= 176734 / Desired cylinder
59: HPBAE= 176750 / Bus extension address (RH70)
60: HPCS2= 176710 / Control/status register 2
61: READIT= 71
62: CSW= 177570 / Console switch display register
63:
64: 1:
65: bitb $200,*$HPCSR / wait for ready
66: beq 1b
67:
68: mov $0710,*$CSW / For debugging
69: mov $0,*$HPDC / Cylinder 0
70: mov $0,*$HPBAE / Bus extension address = 0
71: mov $HPCS2,r0
72: mov $0,-(r0) / HPCSR->hpda = 0 (desired address 0)
73: mov $0,-(r0) / HPCSR->hpba = 0 (buf address 0)
74: mov $177400,-(r0) / HPCSR->hpwc = -256 (one block)
75: mov $READIT,-(r0) / HPCSR->hpcs1 = HP_RCOM|HP_GO
76: mov $0711,*$CSW / For debugging
77:
78: 1:
79: bitb $200,*$HPCSR / wait for done
80: beq 1b
81: mov $0712,*$CSW / For debugging
82: jmp *$0
83:
84: / no return
85: #endif UCB_AUTOBOOT
Defined functions
_doboot
declared in line
17; defined in line
19; used 1 times
Defined variables
CSW
defined in line
62; used 3 times
HPBAE
defined in line
59; used 1 times
HPCS2
defined in line
60; used 1 times
HPCSR
defined in line
57; used 2 times
HPDC
defined in line
58; used 1 times
hardboot
declared in line
17; defined in line
41; used 2 times