4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
28 /* All Rights Reserved */
30 #include <sys/types.h>
31 #include <sys/t_lock.h>
32 #include <sys/param.h>
34 #include <sys/debug.h>
35 #include <sys/inline.h>
38 #include <sys/regset.h>
39 #include <sys/privregs.h>
40 #include <sys/sysmacros.h>
41 #include <sys/systm.h>
43 #include <sys/vnode.h>
47 #include <sys/signal.h>
49 #include <sys/cpuvar.h>
51 #include <sys/fault.h>
52 #include <sys/syscall.h>
53 #include <sys/procfs.h>
54 #include <sys/cmn_err.h>
55 #include <sys/stack.h>
56 #include <sys/debugreg.h>
57 #include <sys/copyops.h>
61 #include <sys/vmparam.h>
63 #include <sys/archsystm.h>
64 #include <sys/vmsystm.h>
68 #include <vm/seg_kmem.h>
69 #include <vm/seg_kp.h>
72 #include <sys/sysi86.h>
74 #include <fs/proc/prdata.h>
76 int prnwatch
= 10000; /* maximum number of watched areas */
79 * Force a thread into the kernel if it is not already there.
80 * This is a no-op on uniprocessors.
84 prpokethread(kthread_t
*t
)
86 if (t
->t_state
== TS_ONPROC
&& t
->t_cpu
!= CPU
)
87 poke_cpu(t
->t_cpu
->cpu_id
);
91 * Return general registers.
94 prgetprregs(klwp_t
*lwp
, prgregset_t prp
)
96 ASSERT(MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
102 * Set general registers.
103 * (Note: This can be an alias to setgregs().)
106 prsetprregs(klwp_t
*lwp
, prgregset_t prp
, int initial
)
108 if (initial
) /* set initial values */
109 lwptoregs(lwp
)->r_ps
= PSL_USER
;
110 (void) setgregs(lwp
, prp
);
113 #ifdef _SYSCALL32_IMPL
116 * Convert prgregset32 to native prgregset
119 prgregset_32ton(klwp_t
*lwp
, prgregset32_t src
, prgregset_t dst
)
121 struct regs
*rp
= lwptoregs(lwp
);
123 dst
[REG_GSBASE
] = lwp
->lwp_pcb
.pcb_gsbase
;
124 dst
[REG_FSBASE
] = lwp
->lwp_pcb
.pcb_fsbase
;
126 dst
[REG_DS
] = (uint16_t)src
[DS
];
127 dst
[REG_ES
] = (uint16_t)src
[ES
];
129 dst
[REG_GS
] = (uint16_t)src
[GS
];
130 dst
[REG_FS
] = (uint16_t)src
[FS
];
131 dst
[REG_SS
] = (uint16_t)src
[SS
];
132 dst
[REG_RSP
] = (uint32_t)src
[UESP
];
134 (rp
->r_ps
& ~PSL_USERMASK
) | (src
[EFL
] & PSL_USERMASK
);
135 dst
[REG_CS
] = (uint16_t)src
[CS
];
136 dst
[REG_RIP
] = (uint32_t)src
[EIP
];
137 dst
[REG_ERR
] = (uint32_t)src
[ERR
];
138 dst
[REG_TRAPNO
] = (uint32_t)src
[TRAPNO
];
139 dst
[REG_RAX
] = (uint32_t)src
[EAX
];
140 dst
[REG_RCX
] = (uint32_t)src
[ECX
];
141 dst
[REG_RDX
] = (uint32_t)src
[EDX
];
142 dst
[REG_RBX
] = (uint32_t)src
[EBX
];
143 dst
[REG_RBP
] = (uint32_t)src
[EBP
];
144 dst
[REG_RSI
] = (uint32_t)src
[ESI
];
145 dst
[REG_RDI
] = (uint32_t)src
[EDI
];
146 dst
[REG_R8
] = dst
[REG_R9
] = dst
[REG_R10
] = dst
[REG_R11
] =
147 dst
[REG_R12
] = dst
[REG_R13
] = dst
[REG_R14
] = dst
[REG_R15
] = 0;
151 * Return 32-bit general registers
154 prgetprregs32(klwp_t
*lwp
, prgregset32_t prp
)
156 ASSERT(MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
157 getgregs32(lwp
, prp
);
160 #endif /* _SYSCALL32_IMPL */
163 * Get the syscall return values for the lwp.
166 prgetrvals(klwp_t
*lwp
, long *rval1
, long *rval2
)
168 struct regs
*r
= lwptoregs(lwp
);
172 if (lwp
->lwp_eosys
== JUSTRETURN
) {
175 } else if (lwp_getdatamodel(lwp
) != DATAMODEL_NATIVE
) {
177 * XX64 Not sure we -really- need to do this, because the
178 * syscall return already masks off the bottom values ..?
180 *rval1
= r
->r_r0
& (uint32_t)0xffffffffu
;
181 *rval2
= r
->r_r1
& (uint32_t)0xffffffffu
;
190 * Does the system support floating-point, either through hardware
191 * or by trapping and emulating floating-point machine instructions?
198 return (fp_kind
!= FP_NO
);
202 * Get floating-point registers.
205 prgetprfpregs(klwp_t
*lwp
, prfpregset_t
*pfp
)
207 bzero(pfp
, sizeof (prfpregset_t
));
211 #if defined(_SYSCALL32_IMPL)
213 prgetprfpregs32(klwp_t
*lwp
, prfpregset32_t
*pfp
)
215 bzero(pfp
, sizeof (*pfp
));
216 getfpregs32(lwp
, pfp
);
218 #endif /* _SYSCALL32_IMPL */
221 * Set floating-point registers.
222 * (Note: This can be an alias to setfpregs().)
225 prsetprfpregs(klwp_t
*lwp
, prfpregset_t
*pfp
)
230 #if defined(_SYSCALL32_IMPL)
232 prsetprfpregs32(klwp_t
*lwp
, prfpregset32_t
*pfp
)
234 setfpregs32(lwp
, pfp
);
236 #endif /* _SYSCALL32_IMPL */
239 * Does the system support extra register state?
249 * Get the size of the extra registers.
253 prgetprxregsize(proc_t
*p
)
259 * Get extra registers.
263 prgetprxregs(klwp_t
*lwp
, caddr_t prx
)
265 /* no extra registers */
269 * Set extra registers.
273 prsetprxregs(klwp_t
*lwp
, caddr_t prx
)
275 /* no extra registers */
279 * Return the base (lower limit) of the process stack.
282 prgetstackbase(proc_t
*p
)
284 return (p
->p_usrstack
- p
->p_stksize
);
288 * Return the "addr" field for pr_addr in prpsinfo_t.
289 * This is a vestige of the past, so whatever we return is OK.
292 prgetpsaddr(proc_t
*p
)
298 * Arrange to single-step the lwp.
301 prstep(klwp_t
*lwp
, int watchstep
)
303 ASSERT(MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
306 * flag LWP so that its r_efl trace bit (PS_T) will be set on
307 * next return to usermode.
309 lwp
->lwp_pcb
.pcb_flags
|= REQUEST_STEP
;
310 lwp
->lwp_pcb
.pcb_flags
&= ~REQUEST_NOSTEP
;
313 lwp
->lwp_pcb
.pcb_flags
|= WATCH_STEP
;
315 lwp
->lwp_pcb
.pcb_flags
|= NORMAL_STEP
;
317 aston(lwptot(lwp
)); /* let trap() set PS_T in rp->r_efl */
324 prnostep(klwp_t
*lwp
)
326 ASSERT(ttolwp(curthread
) == lwp
||
327 MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
330 * flag LWP so that its r_efl trace bit (PS_T) will be cleared on
331 * next return to usermode.
333 lwp
->lwp_pcb
.pcb_flags
|= REQUEST_NOSTEP
;
335 lwp
->lwp_pcb
.pcb_flags
&=
336 ~(REQUEST_STEP
|NORMAL_STEP
|WATCH_STEP
|DEBUG_PENDING
);
338 aston(lwptot(lwp
)); /* let trap() clear PS_T in rp->r_efl */
342 * Return non-zero if a single-step is in effect.
345 prisstep(klwp_t
*lwp
)
347 ASSERT(MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
349 return ((lwp
->lwp_pcb
.pcb_flags
&
350 (NORMAL_STEP
|WATCH_STEP
|DEBUG_PENDING
)) != 0);
354 * Set the PC to the specified virtual address.
357 prsvaddr(klwp_t
*lwp
, caddr_t vaddr
)
359 struct regs
*r
= lwptoregs(lwp
);
361 ASSERT(MUTEX_NOT_HELD(&lwptoproc(lwp
)->p_lock
));
363 r
->r_pc
= (uintptr_t)vaddr
;
367 * Map address "addr" in address space "as" into a kernel virtual address.
368 * The memory is guaranteed to be resident and locked down.
371 prmapin(struct as
*as
, caddr_t addr
, int writing
)
378 * XXX - Because of past mistakes, we have bits being returned
379 * by getpfnum that are actually the page type bits of the pte.
380 * When the object we are trying to map is a memory page with
381 * a page structure everything is ok and we can use the optimal
382 * method, ppmapin. Otherwise, we have to do something special.
384 pfnum
= hat_getpfnum(as
->a_hat
, addr
);
385 if (pf_is_memory(pfnum
)) {
386 pp
= page_numtopp_nolock(pfnum
);
388 ASSERT(PAGE_LOCKED(pp
));
389 kaddr
= ppmapin(pp
, writing
?
390 (PROT_READ
| PROT_WRITE
) : PROT_READ
, (caddr_t
)-1);
391 return (kaddr
+ ((uintptr_t)addr
& PAGEOFFSET
));
396 * Oh well, we didn't have a page struct for the object we were
397 * trying to map in; ppmapin doesn't handle devices, but allocating a
398 * heap address allows ppmapout to free virtual space when done.
400 kaddr
= vmem_alloc(heap_arena
, PAGESIZE
, VM_SLEEP
);
402 hat_devload(kas
.a_hat
, kaddr
, MMU_PAGESIZE
, pfnum
,
403 writing
? (PROT_READ
| PROT_WRITE
) : PROT_READ
, 0);
405 return (kaddr
+ ((uintptr_t)addr
& PAGEOFFSET
));
409 * Unmap address "addr" in address space "as"; inverse of prmapin().
413 prmapout(struct as
*as
, caddr_t addr
, caddr_t vaddr
, int writing
)
415 extern void ppmapout(caddr_t
);
417 vaddr
= (caddr_t
)((uintptr_t)vaddr
& PAGEMASK
);
422 * Make sure the lwp is in an orderly state
423 * for inspection by a debugger through /proc.
425 * This needs to be called only once while the current thread remains in the
426 * kernel and needs to be called while holding no resources (mutex locks, etc).
428 * As a hedge against these conditions, if prstop() is called repeatedly
429 * before prunstop() is called, it does nothing and just returns.
431 * prunstop() must be called before the thread returns to user level.
435 prstop(int why
, int what
)
437 klwp_t
*lwp
= ttolwp(curthread
);
438 struct regs
*r
= lwptoregs(lwp
);
440 if (lwp
->lwp_pcb
.pcb_flags
& PRSTOP_CALLED
)
444 * Make sure we don't deadlock on a recursive call
445 * to prstop(). stop() tests the lwp_nostop flag.
447 ASSERT(lwp
->lwp_nostop
== 0);
450 if (copyin_nowatch((caddr_t
)r
->r_pc
, &lwp
->lwp_pcb
.pcb_instr
,
451 sizeof (lwp
->lwp_pcb
.pcb_instr
)) == 0)
452 lwp
->lwp_pcb
.pcb_flags
|= INSTR_VALID
;
454 lwp
->lwp_pcb
.pcb_flags
&= ~INSTR_VALID
;
455 lwp
->lwp_pcb
.pcb_instr
= 0;
458 (void) save_syscall_args();
459 ASSERT(lwp
->lwp_nostop
== 1);
462 lwp
->lwp_pcb
.pcb_flags
|= PRSTOP_CALLED
;
463 aston(curthread
); /* so prunstop() will be called */
467 * Inform prstop() that it should do its work again
468 * the next time it is called.
473 ttolwp(curthread
)->lwp_pcb
.pcb_flags
&= ~PRSTOP_CALLED
;
477 * Fetch the user-level instruction on which the lwp is stopped.
478 * It was saved by the lwp itself, in prstop().
479 * Return non-zero if the instruction is valid.
482 prfetchinstr(klwp_t
*lwp
, ulong_t
*ip
)
484 *ip
= (ulong_t
)(instr_t
)lwp
->lwp_pcb
.pcb_instr
;
485 return (lwp
->lwp_pcb
.pcb_flags
& INSTR_VALID
);
489 * Called from trap() when a load or store instruction
490 * falls in a watched page but is not a watchpoint.
491 * We emulate the instruction in the kernel.
495 pr_watch_emul(struct regs
*rp
, caddr_t addr
, enum seg_rw rw
)
500 char *badaddr
= (caddr_t
)(-1);
503 /* prevent recursive calls to pr_watch_emul() */
504 ASSERT(!(curthread
->t_flag
& T_WATCHPT
));
505 curthread
->t_flag
|= T_WATCHPT
;
507 watch_disable_addr(addr
, 8, rw
);
508 res
= do_unaligned(rp
, &badaddr
);
509 watch_enable_addr(addr
, 8, rw
);
511 curthread
->t_flag
&= ~T_WATCHPT
;
512 if (res
== SIMU_SUCCESS
) {
521 * Return the number of active entries in the local descriptor table.
529 ASSERT(MUTEX_HELD(&p
->p_ldtlock
));
532 * Currently 64 bit processes cannot have private LDTs.
534 ASSERT(p
->p_model
!= DATAMODEL_LP64
|| p
->p_ldt
== NULL
);
536 if (p
->p_ldt
== NULL
)
539 limit
= p
->p_ldtlimit
;
540 ASSERT(limit
>= 0 && limit
< MAXNLDT
);
543 * Count all present user descriptors.
545 for (i
= LDT_UDBASE
, udp
= &p
->p_ldt
[i
]; i
<= limit
; i
++, udp
++)
546 if (udp
->usd_type
!= 0 || udp
->usd_dpl
!= 0 || udp
->usd_p
!= 0)
552 * Fetch the active entries from the local descriptor table.
555 prgetldt(proc_t
*p
, struct ssd
*ssd
)
560 ASSERT(MUTEX_HELD(&p
->p_ldtlock
));
562 if (p
->p_ldt
== NULL
)
565 limit
= p
->p_ldtlimit
;
566 ASSERT(limit
>= 0 && limit
< MAXNLDT
);
569 * All present user descriptors.
571 for (i
= LDT_UDBASE
, udp
= &p
->p_ldt
[i
]; i
<= limit
; i
++, udp
++)
572 if (udp
->usd_type
!= 0 || udp
->usd_dpl
!= 0 ||
574 usd_to_ssd(udp
, ssd
++, SEL_LDT(i
));