1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
/* $OpenBSD: prom_swpal.S,v 1.2 1996/07/29 23:01:44 niklas Exp $ */
/* $NetBSD: prom_swpal.S,v 1.2 1995/02/16 02:32:58 cgd Exp $ */
/*
* Copyright (c) 1994, 1995 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Keith Bostic
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
#include "../../include/asm.h"
#include "../../include/prom.h"
#include "../../include/rpb.h"
/* Offsets from base of HWRPB. */
#define RPB_SELFREF 0x00
#define RPB_SLOTSIZE 0x98
#define RPB_PERCPU_OFF 0xA0
/* Offsets in a boot PCB. */
#define PCB_KSP 0x00
#define PCB_PTBR 0x10
#define PCB_ASN 0x1c
#define PCB_FEN 0x28
/* Pal values. */
#define PAL_RESERVED 0 /* Reserved to Digital. */
#define PAL_VMS 1 /* VMS */
#define PAL_OSF 2 /* OSF */
/*
* PAL code switch routine.
*/
#define D_RA (7*8)
#define D_S0 (8*8)
#define D_S1 (9*8)
#define D_S2 (10*8)
#define D_S3 (11*8)
#define D_S4 (12*8)
#define D_S5 (13*8)
#define PALSW_FRAME_SIZE (14*8)
#define PALSW_REGS IM_RA|IM_S0|IM_S1|IM_S2|IM_S3|IM_S4|IM_S5
.comm ptbr_save 8
.text
.align 4
NESTED(switch_palcode, 0, PALSW_FRAME_SIZE, ra, PALSW_REGS, 0)
SETGP(pv)
/* ldgp gp, 0(pv)*/
lda sp, -PALSW_FRAME_SIZE(sp)
stq ra, D_RA(sp)
stq s0, D_S0(sp)
stq s1, D_S1(sp)
stq s2, D_S2(sp)
stq s3, D_S3(sp)
stq s4, D_S4(sp)
stq s5, D_S5(sp)
stq pv, 0(sp)
stq gp, 8(sp)
ldiq s0, HWRPB_ADDR /* s0 HWRPB_ADDR */
ldq s1, RPB_SLOTSIZE(s0)
call_pal PAL_VMS_mfpr_whami
mulq s1, v0, s1 /* s1 per_cpu offset from base */
ldq s2, RPB_PERCPU_OFF(s0)
addq s0, s2, s2
addq s2, s1, s2 /* s2 PCB (virtual) */
call_pal PAL_VMS_mfpr_ptbr
stq v0, PCB_PTBR(s2)
stq v0, ptbr_save /* save PTBR for the kernel */
stl zero, PCB_ASN(s2)
stq zero, PCB_FEN(s2)
stq sp, PCB_KSP(s2)
ldq t0, RPB_SELFREF(s0) /* HWRBP base (physical) */
ldq t1, RPB_PERCPU_OFF(s0)
addq t0, t1, t0
addq t0, s1, t0 /* PCB base (phys) */
stq t0, 16(sp)
call_pal PAL_VMS_mfpr_vptb
mov v0, a3
/* movi PAL_OSF, a0 */
CONST(PAL_OSF, a0)
lda a1, contin
ldq a2, 16(sp)
call_pal PAL_swppal /* a0, a1, a2, a3 */
contin: ldq pv, 0(sp)
ldq gp, 8(sp)
ldq ra, D_RA(sp)
ldq s0, D_S0(sp)
ldq s1, D_S1(sp)
ldq s2, D_S2(sp)
ldq s3, D_S3(sp)
ldq s4, D_S4(sp)
ldq s5, D_S5(sp)
lda sp, PALSW_FRAME_SIZE(sp)
RET
END(switch_palcode)
#undef D_RA
#undef D_S0
#undef D_S1
#undef D_S2
#undef D_S3
#undef D_S4
#undef D_S5
#undef PALSW_FRAME_SIZE
#undef PALSW_REGS
|