-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unify arc_prune_async() code #15456
Unify arc_prune_async() code #15456
Conversation
There is no sense to have separate implementations for FreeBSD and Linux. Make Linux code shared as more functional and just register FreeBSD-specific prune callback with arc_add_prune_callback() API. Aside of code cleanup this should fix excessive pruning on FreeBSD: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274698 Signed-off-by: Alexander Motin <mav@FreeBSD.org> Sponsored by: iXsystems, Inc.
If you are trying to do clean ups I think first step is to remove obsolete compat for older FreeBSD versions, if present in affected code. 12.4 is EOLing later this year, 13.1 is already EOLed. 13.2 ships with 1302001, so any test for a value lower than that can be just whacked. |
@mjguzik ZFS release notes tell that all releases since 12.2-RELEASE are supported. It does not hurt much to keep it. Some day -- sure. |
This comment was marked as resolved.
This comment was marked as resolved.
@grahamperrin Sure, it could be merged into OpenZFS 2.2 branch and may be even 2.1, respectively FreeBSD 14 and may be 13.
I've never seen the problem myself, and it is not fatal, but I'll leave it to somebody who has workload triggering it to speak. IIRC 14.0 is in the last RC stages, so I am not eager to cause too much disruption unless there is something else. |
It's not fatal, but it's somewhat disruptive. If I'm running a CPU intensive workload, a user thread may be assigned to the CPU where arc_prune_task() is running, but then it never gets to run. The problem resolves itself when ULE's load balancer runs, but that can take a few seconds. It can cause my desktop to hang occasionally. It would be nice to have this in 14.0 but it's too late. I can take care of issuing an EN. |
There is no sense to have separate implementations for FreeBSD and Linux. Make Linux code shared as more functional and just register FreeBSD-specific prune callback with arc_add_prune_callback() API. Aside of code cleanup this should fix excessive pruning on FreeBSD: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274698 Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Mark Johnston <markj@FreeBSD.org> Signed-off-by: Alexander Motin <mav@FreeBSD.org> Sponsored by: iXsystems, Inc. Closes openzfs#15456
There is no sense to have separate implementations for FreeBSD and Linux. Make Linux code shared as more functional and just register FreeBSD-specific prune callback with arc_add_prune_callback() API. Aside of code cleanup this should fix excessive pruning on FreeBSD: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274698 Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Mark Johnston <markj@FreeBSD.org> Signed-off-by: Alexander Motin <mav@FreeBSD.org> Sponsored by: iXsystems, Inc. Closes openzfs#15456
@amotin shouldn't this be a candidate for zfs-2.1-release as well? |
There is no sense to have separate implementations for FreeBSD and Linux. Make Linux code shared as more functional and just register FreeBSD-specific prune callback with arc_add_prune_callback() API. Aside of code cleanup this should fix excessive pruning on FreeBSD: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274698 Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Mark Johnston <markj@FreeBSD.org> Signed-off-by: Alexander Motin <mav@FreeBSD.org> Sponsored by: iXsystems, Inc. Closes openzfs#15456
Excessive ARC pruning is still a very annoying problem in FreeBSD 13 (see https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=275594). @amotin Can this change be backported to OpenZFS 2.1.x? In the meantime, I'm planning to soon commit the simpler change: https://reviews.freebsd.org/D44170 to FreeBSD's copy, which alternatively could be committed to OpenZFS 2.1.x if you find it less disruptive than the one in this pull request. @mmatuska I assume you're going to continue to merge new releases from the OpenZFS 2.1.x branch to FreeBSD's stable/13, even if no new release is cut from the latter? Thanks. |
There is no sense to have separate implementations for FreeBSD and Linux. Make Linux code shared as more functional and just register FreeBSD-specific prune callback with arc_add_prune_callback() API.
Aside of code cleanup this should fix excessive pruning on FreeBSD:
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274698
Types of changes
Checklist:
Signed-off-by
.