Page MenuHomeFreeBSD

pmap_change_attr: Only fixup DMAP for DMAPed ranges
ClosedPublic

Authored by cem on Oct 29 2015, 6:31 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Dec 26, 4:13 AM
Unknown Object (File)
Nov 28 2024, 7:26 PM
Unknown Object (File)
Nov 28 2024, 7:25 PM
Unknown Object (File)
Sep 16 2024, 11:55 AM
Unknown Object (File)
Aug 24 2024, 5:32 PM
Unknown Object (File)
Aug 22 2024, 8:57 PM
Unknown Object (File)
Aug 22 2024, 8:57 PM
Unknown Object (File)
Aug 22 2024, 8:56 PM
Subscribers

Details

Summary

pmap_change_attr must change the memory type of both the requested KVA
and the corresponding DMAP mappings (if such mappings exist), to satisfy
an Intel requirement that two or more mappings to the same physical
pages must have the same memory type.

However, not all kernel mapped pages have corresponding DMAP mappings --
for example, 64-bit BARs. Skip fixing up the DMAP for out-of-bounds
addresses.

Submitted by: Steve Wahl <steve_wahl@dell.com>
Sponsored by: Dell Compellent

Test Plan

I re-enabled the pmap_change_attr() of a non-DMAP 64-bit BAR in the ntb_hw(4)
driver. The call succeeds without error and without crashing.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 971
Build 971: arc lint + arc unit

Event Timeline

cem retitled this revision from to pmap_change_attr: Only fixup DMAP for DMAPed ranges.
cem updated this object.
cem edited the test plan for this revision. (Show Details)
cem added reviewers: alc, jhb, markj, kib.
jhb edited edge metadata.

alc@ also approved this in e-mail, so he can be listed in Reviewed by as well.

This revision is now accepted and ready to land.Oct 29 2015, 6:56 PM
This revision was automatically updated to reflect the committed changes.
head/sys/amd64/amd64/pmap.c
6546 ↗(On Diff #9803)

I don't claim to fully understand this code, but should this PG_PS_FRAME be PG_FRAME instead?

I noticed this while merging from FreeBSD into our tree. Ours has PG_FRAME here.

head/sys/amd64/amd64/pmap.c
6546 ↗(On Diff #9803)

Yeah, I think you're right. This is the !PG_PS case and the code below references PG_FRAME. The constants are similar, but not identical, so this check is ignoring some valid PTEs below, but near to, the dmaplimit.

head/sys/amd64/amd64/pmap.c
6546 ↗(On Diff #9803)

I think that fix to replace PG_PS_FRAME with PG_FRAME is valid.

Note that the current code does not ignore, but erronously processes some ptes which are for pages after dmaplimit, if ever this range becomes demoted. This should result in assertion from PHYS_TO_DMAP(), at least.

Please commit the fix. Also, I think that pa_end == (*pde & PG_PS_FRAME) case might be wrong as well, after the fix.

Yes, PG_PS_FRAME should be replaced by PG_FRAME here. Please commit that change.

Kostik, I didn't understand your last comment. Can you please elaborate?

In D4030#222841, @alc wrote:

Kostik, I didn't understand your last comment. Can you please elaborate?

I looked at the wrong if() branch in my editor, sorry.