SBC: Add support for WRITESAME16 and add simple tests using it to unmap blocks from a thin provisioned lun
This commit is contained in:
26
lib/sync.c
26
lib/sync.c
@@ -387,6 +387,32 @@ iscsi_writesame10_sync(struct iscsi_context *iscsi, int lun,
|
||||
return state.task;
|
||||
}
|
||||
|
||||
struct scsi_task *
|
||||
iscsi_writesame16_sync(struct iscsi_context *iscsi, int lun,
|
||||
unsigned char *data, uint32_t datalen,
|
||||
uint64_t lba, uint32_t num_blocks,
|
||||
int anchor, int unmap, int pbdata, int lbdata,
|
||||
int wrprotect, int group)
|
||||
{
|
||||
struct iscsi_sync_state state;
|
||||
|
||||
memset(&state, 0, sizeof(state));
|
||||
|
||||
if (iscsi_writesame16_task(iscsi, lun, data, datalen,
|
||||
lba, num_blocks,
|
||||
anchor, unmap, pbdata, lbdata,
|
||||
wrprotect, group,
|
||||
scsi_sync_cb, &state) == NULL) {
|
||||
iscsi_set_error(iscsi,
|
||||
"Failed to send WRITESAME16 command");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
event_loop(iscsi, &state);
|
||||
|
||||
return state.task;
|
||||
}
|
||||
|
||||
struct scsi_task *
|
||||
iscsi_unmap_sync(struct iscsi_context *iscsi, int lun, int anchor, int group,
|
||||
struct unmap_list *list, int list_len)
|
||||
|
||||
Reference in New Issue
Block a user