我正在研究nvme-cli的测试工具(用c编写,可以在linux上运行)。
我有兴趣用't'个线程重复nvme命令'r'次。
以下代码重复执行命令以及线程,但问题是并行执行时间与串行执行相比非常高。
根据我的观察,原因是调用ioctl()
系统调用
err = nvme_identify(fd, 0, 1, data);
,nvme_identify()
来电ioctl()
。
我可以知道ioctl()
是否阻止nvme?
我也可以通过线程减少执行时间(解决方案)吗?
int repeat_cmd(int fd, void *data, int nsid,int cmd, int rc, int flags,
struct repeatfields *rf, int threadcount)
{
pthread_t tid[threadcount];
int err, i=0,j=0;
struct my_struct1 my_struct[threadcount];
switch(cmd){
case 1 :
for (j=0; j <threadcount; j++)
{
my_struct[j].fd = fd;
my_struct[j].data = data;
my_struct[j].flags = flags;
my_struct[j].rf = *rf;
my_struct[j].rcount = rc/threadcount;
pthread_create(&tid[j], NULL, ThreadFun_id_ctrl, (void*)&my_struct[i]);
}
for (j=0; j <threadcount; j++)
pthread_join(tid[j], NULL);
break;
}
线程功能如下:
void *ThreadFun_id_ctrl(void *val)
{
int err,j;
struct my_struct1 *my_struct = (struct my_struct1 *)val;
int fd = my_struct->fd;
void *data = my_struct->data;
struct repeatfields rf = my_struct->rf;
int flags = my_struct->flags;
int rcount = my_struct->rcount;
printf("Printing count = %d\n",rcount);
for (j=0; j <rcount; j++)
{
err = nvme_identify(fd, 0, 1, data);
if (!err) {
if (rf.fmt == BINARY)
d_raw((unsigned char *)&rf.ctrl, sizeof(rf.ctrl));
else if (rf.fmt == JSON)
json_nvme_id_ctrl(data, flags, 0);
else {
printf("NVME Identify Controller:\n");
__show_nvme_id_ctrl(data, flags, 0);
}
}
else if (err > 0){
fprintf(stderr, "NVMe Status:%s(%x)\n",
nvme_status_to_string(err), err);
}
else
perror("identify controller");
printf("Printing from Thread id = %d\n",syscall(SYS_gettid));
}
return NULL;