Page MenuHomeFreeBSD

vmm: Remove the per-vm cookie argument from vmmops taking a vcpu.
ClosedPublic

Authored by jhb on Oct 27 2022, 3:03 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 5 2024, 5:36 PM
Unknown Object (File)
Nov 24 2024, 8:46 PM
Unknown Object (File)
Nov 24 2024, 3:43 AM
Unknown Object (File)
Nov 23 2024, 3:08 AM
Unknown Object (File)
Nov 22 2024, 11:57 PM
Unknown Object (File)
Nov 21 2024, 3:46 PM
Unknown Object (File)
Nov 21 2024, 2:55 AM
Unknown Object (File)
Nov 19 2024, 5:52 AM

Details

Summary

This requires storing a reference the per-vm cookie in the
CPU-specific vCPU structure. Take advantage of this new field to
remove no-longer-needed function arguments in the CPU-specific
backends. In particular, stop passing the per-vm cookie to functions
that either don't use it or only use it for KTR traces.

Diff Detail

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

Event Timeline

corvink added inline comments.
sys/amd64/vmm/amd/svm.c
286

Why do we keep sc fore this function?

sys/amd64/vmm/amd/svm.c
286

At this stage in the patches sc is still used below to get to sc->vm for vm_set_tsc_offset. Later in the series it does get removed once VCPU_CTR1 and vm_set_tsc_offset no longer need it (D37162)

corvink added inline comments.
sys/amd64/vmm/amd/svm.c
286

A few lines below, you're removing sc from svm_set_intercept. VCPU_CTR3 is called there with vcpu->sc-vm. Many other functions get patched the same way here.

This revision is now accepted and ready to land.Nov 4 2022, 6:42 AM
sys/amd64/vmm/amd/svm.c
286

I think the strategy I followed was "remove the function arguments other than struct vcpu once all non-KTR-related bits stopped using it". So in this case it is about vm_set_tsc_offset and waiting until it changes. I mostly followed this strategy just to make it a series of changes vs one giant change. That said, it doesn't really matter when it changes within the series.