Page MenuHomeFreeBSD

nvdimm(4): Only expose namespaces for accessible data SPAs
ClosedPublic

Authored by scottph on Oct 11 2019, 10:27 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 1, 4:45 PM
Unknown Object (File)
Tue, Dec 31, 7:22 PM
Unknown Object (File)
Mon, Dec 30, 7:57 PM
Unknown Object (File)
Sun, Dec 29, 7:52 PM
Unknown Object (File)
Sat, Dec 28, 8:22 PM
Unknown Object (File)
Fri, Dec 27, 2:02 PM
Unknown Object (File)
Nov 23 2024, 12:02 AM
Unknown Object (File)
Oct 28 2024, 12:32 AM
Subscribers

Details

Summary

Apply the same user accessible filter to namespaces as is applied
to full-SPA devices. Also, explicitly filter out control region
SPAs which don't expose the nvdimm data area.

MFC after: 1 week
Sponsored by: Intel Corporation

Diff Detail

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

Event Timeline

sys/dev/nvdimm/nvdimm_spa.c
164 ↗(On Diff #63170)

Why the loop? Why not just a single line that's return? I'm guessing there is a field we need to check

sys/dev/nvdimm/nvdimm_spa.c
164 ↗(On Diff #63170)

SPA_TYPE_UNKNOWN = 127,
is outside the bounds of the array. How about:

return (spa_type >= 0 && spa_type < nitems(nvdimm_SPA_uuid_list) ? nvdimm_SPA_uuid_list[spa_type].u_usr_acc : false);

Do Control Region SPAs have namespaces? I'm still fairly new to NFIT.

sys/dev/nvdimm/nvdimm_spa.c
164 ↗(On Diff #63170)

I like the suggestion and the proposal. I'm not sure it needs to be a one-liner but I'm on-board with the bounds check approach. I'd probably spell it more like:

if ((int)spa_type < 0 || spa_type >= nitems(nvdimm_SPA_uuid_list))
    return (false);
return (nvdimm_SPA_uuid_list[spa_type].u_usr_acc);

But it doesn't really matter to me how it's formatted.

In D21987#480367, @cem wrote:

Do Control Region SPAs have namespaces? I'm still fairly new to NFIT.

No, namespaces should only apply to areas where there's a mapping to the dimm physical addresses, which I believe is never the case with a control region. Which leads me to think that this check is necessary (don't show namespaces for regions that we also hide) but not sufficient on its own.

scottph retitled this revision from nvdimm(4): Don't expose namespaces for inaccessible SPAs to nvdimm(4): Only expose namespaces for accessible data SPAs.
scottph edited the summary of this revision. (Show Details)
scottph marked 2 inline comments as done.
This revision is now accepted and ready to land.Nov 12 2019, 1:05 AM