Page MenuHomeFreeBSD

Ensure that imports into per-domain arenas are aligned.
ClosedPublic

Authored by markj on Sep 19 2018, 8:03 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 12, 1:34 PM
Unknown Object (File)
Sat, Jan 11, 3:55 PM
Unknown Object (File)
Dec 25 2024, 8:56 AM
Unknown Object (File)
Dec 25 2024, 8:49 AM
Unknown Object (File)
Dec 25 2024, 8:38 AM
Unknown Object (File)
Dec 24 2024, 8:22 PM
Unknown Object (File)
Nov 25 2024, 9:20 PM
Unknown Object (File)
Nov 1 2024, 7:56 PM
Subscribers

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

markj marked an inline comment as done.
markj added inline comments.
sys/vm/vm_kern.c
750 ↗(On Diff #48240)

I can't remember the purpose of this global arena. Why can't the per-domain rwx arenas import directly from kernel_arena?

sys/vm/vm_kern.c
750 ↗(On Diff #48240)

I believe this is a consequence of r338318. I.e. it was used before that rev.

This revision is now accepted and ready to land.Sep 19 2018, 9:41 PM
alc added inline comments.
sys/vm/vm_kern.c
702 ↗(On Diff #48240)

Replace kernel_rwx_alloc by kva_domain_import.

750 ↗(On Diff #48240)

The additional "use" before r338318 was essentially that of a flag. If the arena passed to kmem_free() wasn't the global kernel arena, then the per-domain rwx arena was selected. No operation was actually performed on the global rwx arena in kmem_free(). In other words, even before r338318 the per-domain rwx arenas could have imported directly from the global kernel arena.

I see no reason not to eliminate the global rwx arena.

Remove the unused global rwx arena.

This revision now requires review to proceed.Sep 20 2018, 3:10 PM
markj marked an inline comment as done.

Fix the function name in a KASSERT.

This revision is now accepted and ready to land.Sep 20 2018, 3:35 PM
alc added inline comments.
sys/vm/vm_kern.c
695 ↗(On Diff #48268)

How about adding some detail here. That the size of the returned KVA will be a multiple of KVA_QUANTUM, and the returned KVA will start at an address that is a multiple of KVA_QUANTUM. Also, there is nothing in the comments here that explains why we do this.

  • Add some comments.
  • Make the per-domain rwx arenas import directly from kernel_arena instead of the per-domain "standard" kernel arenas.
This revision now requires review to proceed.Sep 20 2018, 5:08 PM
This revision is now accepted and ready to land.Sep 20 2018, 5:25 PM

Here is some food for thought. We might be better of if we used the per-domain arenas differently. Suppose that the import function allocated the physical memory and mapped it. Further, suppose that we had a release function, and that function actually unmapped and freed physical memory. The benefits being: (1) we wouldn't have to wait for full population to trigger promotion, and (2) uma_reclaim() wouldn't trigger demotions (and hopefully later repromotions).

This revision was automatically updated to reflect the committed changes.
In D17249#367826, @alc wrote:

Here is some food for thought. We might be better of if we used the per-domain arenas differently. Suppose that the import function allocated the physical memory and mapped it. Further, suppose that we had a release function, and that function actually unmapped and freed physical memory. The benefits being: (1) we wouldn't have to wait for full population to trigger promotion, and (2) uma_reclaim() wouldn't trigger demotions (and hopefully later repromotions).

That's a cool idea. My main concern would be fragmentation, but kmem_* already use M_BESTFIT and we can at least easily measure the amount of physical memory wasted using vmem_size().

In D17249#367826, @alc wrote:

Here is some food for thought. We might be better of if we used the per-domain arenas differently. Suppose that the import function allocated the physical memory and mapped it. Further, suppose that we had a release function, and that function actually unmapped and freed physical memory. The benefits being: (1) we wouldn't have to wait for full population to trigger promotion, and (2) uma_reclaim() wouldn't trigger demotions (and hopefully later repromotions).

That's a cool idea. My main concern would be fragmentation, but kmem_* already use M_BESTFIT and we can at least easily measure the amount of physical memory wasted using vmem_size().

Switching the vmem free lists to FIFO instead of LIFO should further reduce fragmentation at the cost of making the arena structure larger.