revert r315852 which introduced zio_buf_alloc_nowait for use in vdev_queue_aggregate
I think that the change is still good, but reconciling it with a planned merge of the ARC buf data scatter-ization is a bit more tedious than I can handle. MFC after: 17 days
This commit is contained in:
parent
d6609e6a12
commit
42ce346fcc
@ -555,7 +555,6 @@ extern zio_t *zio_unique_parent(zio_t *cio);
|
|||||||
extern void zio_add_child(zio_t *pio, zio_t *cio);
|
extern void zio_add_child(zio_t *pio, zio_t *cio);
|
||||||
|
|
||||||
extern void *zio_buf_alloc(size_t size);
|
extern void *zio_buf_alloc(size_t size);
|
||||||
extern void *zio_buf_alloc_nowait(size_t size);
|
|
||||||
extern void zio_buf_free(void *buf, size_t size);
|
extern void zio_buf_free(void *buf, size_t size);
|
||||||
extern void *zio_data_buf_alloc(size_t size);
|
extern void *zio_data_buf_alloc(size_t size);
|
||||||
extern void zio_data_buf_free(void *buf, size_t size);
|
extern void zio_data_buf_free(void *buf, size_t size);
|
||||||
|
@ -647,7 +647,6 @@ static zio_t *
|
|||||||
vdev_queue_aggregate(vdev_queue_t *vq, zio_t *zio)
|
vdev_queue_aggregate(vdev_queue_t *vq, zio_t *zio)
|
||||||
{
|
{
|
||||||
zio_t *first, *last, *aio, *dio, *mandatory, *nio;
|
zio_t *first, *last, *aio, *dio, *mandatory, *nio;
|
||||||
void *abuf;
|
|
||||||
uint64_t maxgap = 0;
|
uint64_t maxgap = 0;
|
||||||
uint64_t size;
|
uint64_t size;
|
||||||
boolean_t stretch;
|
boolean_t stretch;
|
||||||
@ -766,12 +765,8 @@ vdev_queue_aggregate(vdev_queue_t *vq, zio_t *zio)
|
|||||||
size = IO_SPAN(first, last);
|
size = IO_SPAN(first, last);
|
||||||
ASSERT3U(size, <=, SPA_MAXBLOCKSIZE);
|
ASSERT3U(size, <=, SPA_MAXBLOCKSIZE);
|
||||||
|
|
||||||
abuf = zio_buf_alloc_nowait(size);
|
|
||||||
if (abuf == NULL)
|
|
||||||
return (NULL);
|
|
||||||
|
|
||||||
aio = zio_vdev_delegated_io(first->io_vd, first->io_offset,
|
aio = zio_vdev_delegated_io(first->io_vd, first->io_offset,
|
||||||
abuf, size, first->io_type, zio->io_priority,
|
zio_buf_alloc(size), size, first->io_type, zio->io_priority,
|
||||||
flags | ZIO_FLAG_DONT_CACHE | ZIO_FLAG_DONT_QUEUE,
|
flags | ZIO_FLAG_DONT_CACHE | ZIO_FLAG_DONT_QUEUE,
|
||||||
vdev_queue_agg_io_done, NULL);
|
vdev_queue_agg_io_done, NULL);
|
||||||
aio->io_timestamp = first->io_timestamp;
|
aio->io_timestamp = first->io_timestamp;
|
||||||
|
@ -272,33 +272,18 @@ zio_fini(void)
|
|||||||
* useful to inspect ZFS metadata, but if possible, we should avoid keeping
|
* useful to inspect ZFS metadata, but if possible, we should avoid keeping
|
||||||
* excess / transient data in-core during a crashdump.
|
* excess / transient data in-core during a crashdump.
|
||||||
*/
|
*/
|
||||||
static void *
|
void *
|
||||||
zio_buf_alloc_impl(size_t size, boolean_t canwait)
|
zio_buf_alloc(size_t size)
|
||||||
{
|
{
|
||||||
size_t c = (size - 1) >> SPA_MINBLOCKSHIFT;
|
size_t c = (size - 1) >> SPA_MINBLOCKSHIFT;
|
||||||
int flags = zio_exclude_metadata ? KM_NODEBUG : 0;
|
int flags = zio_exclude_metadata ? KM_NODEBUG : 0;
|
||||||
|
|
||||||
VERIFY3U(c, <, SPA_MAXBLOCKSIZE >> SPA_MINBLOCKSHIFT);
|
VERIFY3U(c, <, SPA_MAXBLOCKSIZE >> SPA_MINBLOCKSHIFT);
|
||||||
|
|
||||||
if (zio_use_uma) {
|
if (zio_use_uma)
|
||||||
return (kmem_cache_alloc(zio_buf_cache[c],
|
return (kmem_cache_alloc(zio_buf_cache[c], KM_PUSHPAGE));
|
||||||
canwait ? KM_PUSHPAGE : KM_NOSLEEP));
|
else
|
||||||
} else {
|
return (kmem_alloc(size, KM_SLEEP|flags));
|
||||||
return (kmem_alloc(size,
|
|
||||||
(canwait ? KM_SLEEP : KM_NOSLEEP) | flags));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void *
|
|
||||||
zio_buf_alloc(size_t size)
|
|
||||||
{
|
|
||||||
return (zio_buf_alloc_impl(size, B_TRUE));
|
|
||||||
}
|
|
||||||
|
|
||||||
void *
|
|
||||||
zio_buf_alloc_nowait(size_t size)
|
|
||||||
{
|
|
||||||
return (zio_buf_alloc_impl(size, B_FALSE));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user