Page MenuHomeFreeBSD

sys: Add cpu_update_pcb hook
Needs ReviewPublic

Authored by jhb on Apr 22 2024, 11:37 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 15, 8:49 AM
Unknown Object (File)
Sun, Jan 12, 9:22 PM
Unknown Object (File)
Sun, Jan 12, 6:59 PM
Unknown Object (File)
Sun, Jan 12, 10:06 AM
Unknown Object (File)
Sun, Jan 12, 8:41 AM
Unknown Object (File)
Sun, Jan 12, 8:41 AM
Unknown Object (File)
Sun, Jan 12, 8:39 AM
Unknown Object (File)
Sun, Jan 12, 8:38 AM

Details

Summary

This MD function is invoked before dumping register set notes when
writing out a core dump to ensure that the PCB for a given thread is
up to date. This provides a centralized place to update the PCB with
values of the current thread for each arch rather than doing this work
in each register set's get method.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 57285
Build 54173: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Apr 22 2024, 11:37 PM

Right now the TLS register sets I added for arm64 and arm are missing the update in their get methods. It seems nicer to handle this in one place vs in each get method?

However, in theory this function should be something we use e.g. when copying pcb's for fork or creating threads, and in theory it should perhaps deal with fetching updated FPU registers as well. The latter tends to happen in fill_fpregs directly instead. The i386 change in particular is with an eye towards this possible longer term goal since pcb_gs isn't used in any get methods currently.

Related is that it would be nice to move more MD register sets (XSAVE, the PPC ones) over to using the regset stuff instead of elfNN_dump_thread. I know @andrew had an older patch set at some point to handle XSAVE. Would be nice to do XSAVE in a single place (sys/x86/x86/x86_ptrace.c or some such).

Could the purpose of the new cpu method expressed as "move CPU state to PCB/thread save location in preparation for ..."? I think a comment like that would be due.

In D44910#1024125, @kib wrote:

Could the purpose of the new cpu method expressed as "move CPU state to PCB/thread save location in preparation for ..."? I think a comment like that would be due.

Where would you want that comment to go? Next to its prototype in <sys/proc.h>?

In D44910#1026299, @jhb wrote:
In D44910#1024125, @kib wrote:

Could the purpose of the new cpu method expressed as "move CPU state to PCB/thread save location in preparation for ..."? I think a comment like that would be due.

Where would you want that comment to go? Next to its prototype in <sys/proc.h>?

Might be, near the method definition for one of the Tier-1 arch is enough.

Otherwise it would be a whole project to document all cpu_* methods in the header (but not a useless, just lot of typing and probably code reading).

Add comment describing the new hook

sys/amd64/amd64/vm_machdep.c
700

Is there ever a situation where you'd want to do something in this function on an architecture if this wasn't true? If not, would it make sense to push this to the few callers instead (and KASSERT here and/or implicitly use curthread?), or at least using an early return in every function?

sys/kern/imgact_elf.c
2418

Is it td or target_td?

Document in cpu_machdep(9)

sys/amd64/amd64/vm_machdep.c
700

I believe yes, see my comment for kern/imgact_elf.c.

sys/kern/imgact_elf.c
2418

Oh, yes, this should be target_td

Fix td passed for coredumps

sys/amd64/amd64/vm_machdep.c
700

On our current architectures I think it is always true that you can only have stale pcb values for the current thread. It might be ok to assume curthread for this API. One non-obvious thing for fork/cpu_copy_thread btw is that they can be called with the "old" thread being thread0 instead of curthread when creating new kprocs/kthreads.

This revision is now accepted and ready to land.Sat, Jan 4, 10:07 PM
jhb marked an inline comment as done.Tue, Jan 7, 3:55 PM

Push curthread check out to callers

This revision now requires review to proceed.Fri, Jan 10, 12:45 AM
share/man/man9/cpu_machdep.9
194 ↗(On Diff #149026)

May be add some text like this (with grammar fixed)

.Pp
Threads other than the current thread are stopped, and the state of the stopped thread must be fully saved into pcb by the MD code.

sys/kern/imgact_elf.c
2418

Then it is better to write target_td == td perhaps?

jhb marked 4 inline comments as done.Tue, Jan 14, 3:46 PM

Add a note about other threads being stopped

sys/amd64/amd64/vm_machdep.c
699

Should we not KASSERT(td == curthread); in all of these?

sys/amd64/amd64/vm_machdep.c
699

Possibly. We don't in other hooks like cpu_fetch_syscall_args, but I'm not opposed to adding that here.

This revision is now accepted and ready to land.Tue, Jan 14, 5:15 PM
This revision now requires review to proceed.Wed, Jan 15, 7:53 PM