Page MenuHomeFreeBSD

Add OBJ_PG_DTOR flag to VM object
ClosedPublic

Authored by br on Jul 21 2017, 2:36 PM.
Tags
None
Referenced Files
F107934043: D11688.id32108.diff
Sun, Jan 19, 4:21 PM
Unknown Object (File)
Mon, Jan 13, 10:49 AM
Unknown Object (File)
Thu, Jan 2, 11:01 AM
Unknown Object (File)
Thu, Jan 2, 1:33 AM
Unknown Object (File)
Thu, Jan 2, 12:36 AM
Unknown Object (File)
Mon, Dec 30, 4:44 AM
Unknown Object (File)
Mon, Dec 30, 4:33 AM
Unknown Object (File)
Dec 20 2024, 10:39 PM
Subscribers
None

Details

Summary

Add OBJ_PG_DTOR flag to object allowing us to skip pages removal from object in vm_object_terminate() and to leave that for cdev_pg_dtor function.

This is required for Intel SGX support as we want to lookup pages in queue before removal.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

br edited the summary of this revision. (Show Details)

move out pages removal code to separate function to avoid code duplication

This revision is now accepted and ready to land.Aug 15 2017, 12:09 PM

I have no objections to this change. I'm just interested in hearing a little more about why it is needed. In your SGX driver are you essentially maintaining a private free page list for managing the pool of physical memory that backs enclaves?

In D11688#249549, @alc wrote:

I have no objections to this change. I'm just interested in hearing a little more about why it is needed. In your SGX driver are you essentially maintaining a private free page list for managing the pool of physical memory that backs enclaves?

Exactly. We have enclave's page cache (EPC) memory pool reserved by processor and we register it as fictitious range of physical memory. That EPC pool is encrypted and backs enclave's control information, enclave's code, stack, data, etc.
https://reviews.freebsd.org/D11113

In D11688#249553, @br wrote:
In D11688#249549, @alc wrote:

I have no objections to this change. I'm just interested in hearing a little more about why it is needed. In your SGX driver are you essentially maintaining a private free page list for managing the pool of physical memory that backs enclaves?

Exactly. We have enclave's page cache (EPC) memory pool reserved by processor and we register it as fictitious range of physical memory. That EPC pool is encrypted and backs enclave's control information, enclave's code, stack, data, etc.
https://reviews.freebsd.org/D11113

Ok, that helps. Because you are using OBJT_MGTDEVICE in the SGX driver, there is no list of fake pages, i.e., we don't maintain un_pager.devp.devp_pglist for that type of object.

This revision was automatically updated to reflect the committed changes.