Details
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
No Lint Coverage - Unit
No Test Coverage
Event Timeline
I've tested this on 8.x already with your other changes backported. Have not yet built a HEAD kernel with this applied. It's also at github/bsdjhb/freebsd/domain_sysctl
Konstantin, adding you to see what you think. I'm not sure exactly yet what we will end up with in HEAD as the final solution, but this data is useful for sysadmins at my current work in practice.
This has the same issue I reported when the bus_get_domain() was discussed; returning a vm domain may carry no sense. That said, now the thing becomes exposed to usermode and starts being part of the ABI.
I just realized that BUS_GET_DOMAIN commit mis-handled the DMARs. As I understand the wiring of calls, it results in ENOENT/no domain for them. I should fix this.
Do you have an alternate suggestion? I'm fine with marking bus_get_domain() as "XXX experimental, may be removed", etc. However, we need something here.
Should we rename PCPU_GET(domain) as well then? (These are inherently the same thing in ACPI/x86 which is the only model we currently have to test/build in/design for. I'm a bit hesitant to add abstractions that only exist in hardware FreeBSD will never run on)
Should we rename PCPU_GET(domain) as well then? (These are inherently the same thing in ACPI/x86 which is the only model we currently have to test/build in/design for. I'm a bit hesitant to add abstractions that only exist in hardware FreeBSD will never run on)
In-kernel names are somewhat easier, since there is no ABI-stability cost on changing them.
I do not mean non-x86 hardware when I am talking about vm domains not being same as bios/proximity domains. My concern are (not yet committed, but already used) patches which split bios vm domains into smaller chunks, in particular, to get sharding on page queue locks.
Ok. If you want I can just leave out the sysctl for now. I have other more proximate uses for 'bus_get_domain' in HEAD.
I do not mean non-x86 hardware when I am talking about vm domains not being same as bios/proximity domains. My concern are (not yet committed, but already used) patches which split bios vm domains into smaller chunks, in particular, to get sharding on page queue locks.
As I said before, just call those shards something else besides "domain". "domain" has a well-known context in terms of computer memory: NUMA domains. It would be confusing to overload the "domain" term in the VM system to mean anything else.
Well, no. Commit it.
I do not mean non-x86 hardware when I am talking about vm domains not being same as bios/proximity domains. My concern are (not yet committed, but already used) patches which split bios vm domains into smaller chunks, in particular, to get sharding on page queue locks.
As I said before, just call those shards something else besides "domain". "domain" has a well-known context in terms of computer memory: NUMA domains. It would be confusing to overload the "domain" term in the VM system to mean anything else.
They are already called vm_domain. See vm/vm_page.h. I will rename them when the patches are to be revived.