Page MenuHomeFreeBSD

Pull vm_object_scan_all_shadowed out of vm_object_backing_scan
ClosedPublic

Authored by cem on Dec 1 2015, 6:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 1 2024, 6:58 PM
Unknown Object (File)
Sep 26 2024, 6:56 PM
Unknown Object (File)
Sep 26 2024, 12:14 AM
Unknown Object (File)
Sep 24 2024, 5:22 AM
Unknown Object (File)
Sep 18 2024, 1:42 AM
Unknown Object (File)
Sep 16 2024, 11:24 PM
Unknown Object (File)
Sep 13 2024, 4:52 AM
Unknown Object (File)
Sep 9 2024, 3:55 AM
Subscribers

Details

Summary

These two functions were largely unrelated, they just used the same same
loop logic to walk through a backing object's memq. Pull out the
all_shadowed test as its own function and eliminate
OBSC_TEST_ALL_SHADOWED. Rename vm_object_backing_scan to
vm_object_collapse_scan.

No functional change.

Sponsored by: EMC / Isilon Storage Division

Diff Detail

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

Event Timeline

cem retitled this revision from to Pull vm_object_scan_all_shadowed out of vm_object_backing_scan.
cem updated this object.
cem edited the test plan for this revision. (Show Details)
cem added reviewers: kib, alc.

Overall, I like the change.

sys/vm/vm_object.c
1471

This comment is rather useless in the short function which consists only of the loop.

1472–1488

for (p = TAILQ_FIRST(); p != NULL; p = TAILQ_NEXT(p, listq)) {

1474

Remove.

1474

I do not quite understand the reason for the second paragraph in the comment. I suspect it can be removed, we do not do collapse when backing object is not splittable.

1494–1495

I do not think that the 'busy' comment is relevant for the shadow scan. It has some significance for the collapse, where we unlock objects.

1502

Remove.

1515

Remove.

sys/vm/vm_object.c
1471

It was useless before, too :). Again, I haven't (yet) changed the comments at all.

1472–1488

Sure.

1474

Sure; I did not change the comments at all yet.

1494–1495

It came from the if (op & OBSC_TEST_ALL_SHADOWED) { block, and I did not change the comments.

cem edited edge metadata.

Make changes suggested by kib@.

cem marked 7 inline comments as done.Dec 2 2015, 6:19 PM
sys/vm/vm_object.c
1463–1464

The index calculation can be postponed after the check for the backing_object type, otherwise it is useless.

1470

This comment would describe the real bug, where we silently destroy the user data by ignoring allocated swap in the backing object. But it is not since besides the result of the function, we also test for the resident_page_count value in vm_object_collapse(). Might be, this comment should say something about the usage.

1475

I think we could use vm_page_find_least(backing_object, backing_offset_index) as the start page there and in the collapse() ? This could be left to the next change.

1526–1527

Might be, simultaneously rewrite this loop in the for() form. I think it is more concise and easier to grasp from the short look.

cem marked 2 inline comments as done.

Address 2nd round CR feedback.

sys/vm/vm_object.c
1470

I don't know this area well enough to rewriting comments. I'm happy with the small change to split the routine in two logical pieces.

1475

Next change.

kib edited edge metadata.
This revision is now accepted and ready to land.Dec 3 2015, 5:17 PM
This revision was automatically updated to reflect the committed changes.