mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-14 04:00:31 +03:00
Add hdr_recl() reclaim callback
Originally removed because it wasn't required under Linux. However, there may still be some utility in signaling the arc reclaim thread under Linux via reclaim. This should already have happened by other means but it's not harmless and reduces another point of divergence with upstream. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Issue #3533
This commit is contained in:
parent
728d6ae91e
commit
8c8af9d807
@ -1054,6 +1054,22 @@ buf_dest(void *vbuf, void *unused)
|
|||||||
arc_space_return(sizeof (arc_buf_t), ARC_SPACE_HDRS);
|
arc_space_return(sizeof (arc_buf_t), ARC_SPACE_HDRS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Reclaim callback -- invoked when memory is low.
|
||||||
|
*/
|
||||||
|
/* ARGSUSED */
|
||||||
|
static void
|
||||||
|
hdr_recl(void *unused)
|
||||||
|
{
|
||||||
|
dprintf("hdr_recl called\n");
|
||||||
|
/*
|
||||||
|
* umem calls the reclaim func when we destroy the buf cache,
|
||||||
|
* which is after we do arc_fini().
|
||||||
|
*/
|
||||||
|
if (!arc_dead)
|
||||||
|
cv_signal(&arc_reclaim_thread_cv);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
buf_init(void)
|
buf_init(void)
|
||||||
{
|
{
|
||||||
@ -1089,9 +1105,9 @@ retry:
|
|||||||
}
|
}
|
||||||
|
|
||||||
hdr_full_cache = kmem_cache_create("arc_buf_hdr_t_full", HDR_FULL_SIZE,
|
hdr_full_cache = kmem_cache_create("arc_buf_hdr_t_full", HDR_FULL_SIZE,
|
||||||
0, hdr_full_cons, hdr_full_dest, NULL, NULL, NULL, 0);
|
0, hdr_full_cons, hdr_full_dest, hdr_recl, NULL, NULL, 0);
|
||||||
hdr_l2only_cache = kmem_cache_create("arc_buf_hdr_t_l2only",
|
hdr_l2only_cache = kmem_cache_create("arc_buf_hdr_t_l2only",
|
||||||
HDR_L2ONLY_SIZE, 0, hdr_l2only_cons, hdr_l2only_dest, NULL,
|
HDR_L2ONLY_SIZE, 0, hdr_l2only_cons, hdr_l2only_dest, hdr_recl,
|
||||||
NULL, NULL, 0);
|
NULL, NULL, 0);
|
||||||
buf_cache = kmem_cache_create("arc_buf_t", sizeof (arc_buf_t),
|
buf_cache = kmem_cache_create("arc_buf_t", sizeof (arc_buf_t),
|
||||||
0, buf_cons, buf_dest, NULL, NULL, NULL, 0);
|
0, buf_cons, buf_dest, NULL, NULL, NULL, 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user