Page MenuHomeFreeBSD

malloc: add a routine to find out usable size without allocating
ClosedPublic

Authored by mjg on Nov 5 2020, 4:14 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 8, 9:38 AM
Unknown Object (File)
Wed, Jan 8, 9:36 AM
Unknown Object (File)
Tue, Jan 7, 9:06 AM
Unknown Object (File)
Fri, Jan 3, 1:26 PM
Unknown Object (File)
Dec 13 2024, 5:53 PM
Unknown Object (File)
Dec 2 2024, 11:24 PM
Unknown Object (File)
Nov 22 2024, 12:59 PM
Unknown Object (File)
Nov 17 2024, 6:03 AM
Subscribers

Details

Summary

ZFS creates several zones, some of which unnecessarily duplicate zones provided by malloc.

The suggested routine can be used to avoid the problem. Sample user would be abd_chunk cache which defaults to 4096 but can be tuned in loader.conf

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 34637

Event Timeline

mjg requested review of this revision.Nov 5 2020, 4:14 AM
sys/kern/kern_malloc.c
1037

To me the name suggests that the return type should be uma_zone_t.

1042

The return type is (unsigned) size_t.

sys/kern/kern_malloc.c
1037

I don't care for the name, just suggest another one and I'll use it.

1042

Callers can check for -1 regardless. Alternatively, I can return errnos here and the actual size in a different argument, like so: error = func(size, &malloc_size);

sys/kern/kern_malloc.c
1034

"returns the number of bytes allocated for a request of the specified size"

1037

malloc_size() is my suggestion.

1042

Code analysis tools will raise warnings. Why not just return 0?

mjg marked 5 inline comments as done.
markj added inline comments.
sys/kern/kern_malloc.c
1044

No need for braces, or at least make it consistent with the if statement immediately following.

This revision is now accepted and ready to land.Nov 5 2020, 3:30 PM