Allow 16M send/recv blocks

Fix an off by one error introduced by fcff0f3 which triggers an
assertion when 16M blocks are used with send/recv.  This fix was
intentionally not folder in to the Illumos commit so it can be
easily cherry-picked by upstream.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
This commit is contained in:
Brian Behlendorf 2016-01-08 19:21:56 -05:00
parent fcff0f35bd
commit e9e3d31d2c

View File

@ -69,7 +69,7 @@ void
bqueue_enqueue(bqueue_t *q, void *data, uint64_t item_size) bqueue_enqueue(bqueue_t *q, void *data, uint64_t item_size)
{ {
ASSERT3U(item_size, >, 0); ASSERT3U(item_size, >, 0);
ASSERT3U(item_size, <, q->bq_maxsize); ASSERT3U(item_size, <=, q->bq_maxsize);
mutex_enter(&q->bq_lock); mutex_enter(&q->bq_lock);
obj2node(q, data)->bqn_size = item_size; obj2node(q, data)->bqn_size = item_size;
while (q->bq_size + item_size > q->bq_maxsize) { while (q->bq_size + item_size > q->bq_maxsize) {