代码拉取完成,页面将自动刷新
#include <stdlib.h>
#include <string.h>
#include "io_u_queue.h"
#include "smalloc.h"
bool io_u_qinit(struct io_u_queue *q, unsigned int nr, bool shared)
{
if (shared)
q->io_us = smalloc(nr * sizeof(struct io_u *));
else
q->io_us = calloc(nr, sizeof(struct io_u *));
if (!q->io_us)
return false;
q->nr = 0;
q->max = nr;
return true;
}
void io_u_qexit(struct io_u_queue *q, bool shared)
{
if (shared)
sfree(q->io_us);
else
free(q->io_us);
}
bool io_u_rinit(struct io_u_ring *ring, unsigned int nr)
{
ring->max = nr + 1;
if (ring->max & (ring->max - 1)) {
ring->max--;
ring->max |= ring->max >> 1;
ring->max |= ring->max >> 2;
ring->max |= ring->max >> 4;
ring->max |= ring->max >> 8;
ring->max |= ring->max >> 16;
ring->max++;
}
ring->ring = calloc(ring->max, sizeof(struct io_u *));
if (!ring->ring)
return false;
ring->head = ring->tail = 0;
return true;
}
void io_u_rexit(struct io_u_ring *ring)
{
free(ring->ring);
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。