Page MenuHomeFreeBSD

bus: Create dev_wired_cache
ClosedPublic

Authored by imp on Nov 1 2021, 7:18 PM.
Tags
None
Referenced Files
F107887070: D32783.diff
Sun, Jan 19, 1:02 AM
Unknown Object (File)
Tue, Jan 14, 10:26 AM
Unknown Object (File)
Sun, Dec 29, 10:18 AM
Unknown Object (File)
Dec 6 2024, 6:16 PM
Unknown Object (File)
Dec 3 2024, 11:18 PM
Unknown Object (File)
Nov 29 2024, 11:03 PM
Unknown Object (File)
Nov 28 2024, 6:37 AM
Unknown Object (File)
Nov 20 2024, 6:26 PM
Subscribers
None

Details

Summary

A simple cache to cache differnet locators to the same device.

Sponsored by: Netflix

Diff Detail

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

Event Timeline

imp requested review of this revision.Nov 1 2021, 7:18 PM
imp created this revision.
sys/kern/subr_bus.c
6085
6164
sys/kern/subr_bus.c
6121

You could simplify this a fair bit by just donating the allocated path pointer and then just malloc'ing the dln here. It does mean the fini routine above has to free dln->dln_path explicitly, but that seems like a lot simpler in implementation.

6150

You can make path a char * now that device_get_path returns that and then remove the need for the __DECONST below.

sys/kern/subr_bus.c
6121

That assumes that all the callers will have allocated this string and are cool with donating it. I don't think that's the case, especially for a cache miss. Then we'd have to pass back to the caller whether or not to free this thing.

6150

Sure.

sys/kern/subr_bus.c
6121

The only caller is the one call below that uses device_get_path which always has an allocated string (this is a static function, it's not one of the public APIs).

6168

This is the sole call, and path is always allocated.

Updating with these suggestions.

I also think that before I add FDT, I'll need to shift to creating a locator object and using it to make decisions rather than wiring different behaviors to string compares and stuff (noted here since all the other reviews are accept with reservations and I think this will address them in the future).

sys/kern/subr_bus.c
6121

The only caller is the one call below that uses device_get_path which always has an allocated string (this is a static function, it's not one of the public APIs).

You're correct. I was confusing this with a different interface. Those are great suggestions for improvement. Will roll them into next revision.

update per review + rebase

This revision was not accepted when it landed; it landed in state Needs Review.Mar 1 2022, 3:44 PM
This revision was automatically updated to reflect the committed changes.