Switch KM_SLEEP to KM_PUSHPAGE

In this particular instance the allocation occurred in the context
of sys_msync()->...->zpl_putpage() where we must be careful not to
initiate additional I/O.

Signed-off-by: Massimo Maggi <massimo@mmmm.it>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #1038
This commit is contained in:
Massimo Maggi 2012-10-12 00:55:42 +02:00 committed by Brian Behlendorf
parent c418410393
commit 6f53a6a229
1 changed files with 2 additions and 2 deletions

View File

@ -199,7 +199,7 @@ zfs_range_proxify(avl_tree_t *tree, rl_t *rl)
rl->r_cnt = 0; rl->r_cnt = 0;
/* create a proxy range lock */ /* create a proxy range lock */
proxy = kmem_alloc(sizeof (rl_t), KM_SLEEP); proxy = kmem_alloc(sizeof (rl_t), KM_PUSHPAGE);
proxy->r_off = rl->r_off; proxy->r_off = rl->r_off;
proxy->r_len = rl->r_len; proxy->r_len = rl->r_len;
proxy->r_cnt = 1; proxy->r_cnt = 1;
@ -228,7 +228,7 @@ zfs_range_split(avl_tree_t *tree, rl_t *rl, uint64_t off)
ASSERT(rl->r_read_wanted == B_FALSE); ASSERT(rl->r_read_wanted == B_FALSE);
/* create the rear proxy range lock */ /* create the rear proxy range lock */
rear = kmem_alloc(sizeof (rl_t), KM_SLEEP); rear = kmem_alloc(sizeof (rl_t), KM_PUSHPAGE);
rear->r_off = off; rear->r_off = off;
rear->r_len = rl->r_off + rl->r_len - off; rear->r_len = rl->r_off + rl->r_len - off;
rear->r_cnt = rl->r_cnt; rear->r_cnt = rl->r_cnt;