2010-08-26 22:49:16 +04:00
|
|
|
/*
|
|
|
|
* CDDL HEADER START
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the terms of the
|
|
|
|
* Common Development and Distribution License, Version 1.0 only
|
|
|
|
* (the "License"). You may not use this file except in compliance
|
|
|
|
* with the License.
|
|
|
|
*
|
|
|
|
* You can obtain a copy of the license at * usr/src/OPENSOLARIS.LICENSE
|
|
|
|
* or http://www.opensolaris.org/os/licensing.
|
|
|
|
* See the License for the specific language governing permissions
|
|
|
|
* and limitations under the License.
|
|
|
|
*
|
|
|
|
* When distributing Covered Code, include this CDDL HEADER in each
|
|
|
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
|
|
|
* If applicable, add the following below this CDDL HEADER, with the
|
|
|
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
|
|
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
|
|
|
*
|
|
|
|
* CDDL HEADER END
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* Copyright 2004 Sun Microsystems, Inc. All rights reserved.
|
|
|
|
* Use is subject to license terms.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/nvpair.h>
|
|
|
|
#include <sys/kmem.h>
|
|
|
|
|
|
|
|
static void *
|
|
|
|
nv_alloc_sleep_spl(nv_alloc_t *nva, size_t size)
|
|
|
|
{
|
2014-12-03 22:56:32 +03:00
|
|
|
return (kmem_alloc(size, KM_SLEEP));
|
2010-08-26 22:49:16 +04:00
|
|
|
}
|
|
|
|
|
2013-06-18 21:15:33 +04:00
|
|
|
static void *
|
|
|
|
nv_alloc_pushpage_spl(nv_alloc_t *nva, size_t size)
|
|
|
|
{
|
2014-12-03 22:56:32 +03:00
|
|
|
return (kmem_alloc(size, KM_PUSHPAGE));
|
2013-06-18 21:15:33 +04:00
|
|
|
}
|
|
|
|
|
2010-08-26 22:49:16 +04:00
|
|
|
static void *
|
|
|
|
nv_alloc_nosleep_spl(nv_alloc_t *nva, size_t size)
|
|
|
|
{
|
|
|
|
return (kmem_alloc(size, KM_NOSLEEP));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
nv_free_spl(nv_alloc_t *nva, void *buf, size_t size)
|
|
|
|
{
|
|
|
|
kmem_free(buf, size);
|
|
|
|
}
|
|
|
|
|
|
|
|
const nv_alloc_ops_t spl_sleep_ops_def = {
|
2013-11-01 23:26:11 +04:00
|
|
|
NULL, /* nv_ao_init() */
|
|
|
|
NULL, /* nv_ao_fini() */
|
|
|
|
nv_alloc_sleep_spl, /* nv_ao_alloc() */
|
|
|
|
nv_free_spl, /* nv_ao_free() */
|
|
|
|
NULL /* nv_ao_reset() */
|
2010-08-26 22:49:16 +04:00
|
|
|
};
|
|
|
|
|
2013-06-18 21:15:33 +04:00
|
|
|
const nv_alloc_ops_t spl_pushpage_ops_def = {
|
2013-11-01 23:26:11 +04:00
|
|
|
NULL, /* nv_ao_init() */
|
|
|
|
NULL, /* nv_ao_fini() */
|
|
|
|
nv_alloc_pushpage_spl, /* nv_ao_alloc() */
|
|
|
|
nv_free_spl, /* nv_ao_free() */
|
|
|
|
NULL /* nv_ao_reset() */
|
2013-06-18 21:15:33 +04:00
|
|
|
};
|
|
|
|
|
2010-08-26 22:49:16 +04:00
|
|
|
const nv_alloc_ops_t spl_nosleep_ops_def = {
|
2013-11-01 23:26:11 +04:00
|
|
|
NULL, /* nv_ao_init() */
|
|
|
|
NULL, /* nv_ao_fini() */
|
|
|
|
nv_alloc_nosleep_spl, /* nv_ao_alloc() */
|
|
|
|
nv_free_spl, /* nv_ao_free() */
|
|
|
|
NULL /* nv_ao_reset() */
|
2010-08-26 22:49:16 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
nv_alloc_t nv_alloc_sleep_def = {
|
|
|
|
&spl_sleep_ops_def,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2013-06-18 21:15:33 +04:00
|
|
|
nv_alloc_t nv_alloc_pushpage_def = {
|
|
|
|
&spl_pushpage_ops_def,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2010-08-26 22:49:16 +04:00
|
|
|
nv_alloc_t nv_alloc_nosleep_def = {
|
|
|
|
&spl_nosleep_ops_def,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
|
|
|
nv_alloc_t *nv_alloc_sleep = &nv_alloc_sleep_def;
|
2013-06-18 21:15:33 +04:00
|
|
|
nv_alloc_t *nv_alloc_pushpage = &nv_alloc_pushpage_def;
|
2010-08-26 22:49:16 +04:00
|
|
|
nv_alloc_t *nv_alloc_nosleep = &nv_alloc_nosleep_def;
|