Implemented finding matching /dev/sgN from /dev/srM or /dev/scdK
This commit is contained in:
parent
d0d0af1ba5
commit
b67c555b30
@ -724,7 +724,7 @@ int burn_drive_find_devno(dev_t devno, char adr[])
|
|||||||
if(strlen(fname) >= BURN_DRIVE_ADR_LEN)
|
if(strlen(fname) >= BURN_DRIVE_ADR_LEN)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
fprintf(stderr,"libburn experimental: burn_drive_find_devno( 0x%llX ) found %s\n", (long long) devno, fname);
|
fprintf(stderr,"libburn experimental: burn_drive_find_devno( 0x%lX ) found %s\n", (long) devno, fname);
|
||||||
|
|
||||||
strcpy(adr, fname);
|
strcpy(adr, fname);
|
||||||
return 1;
|
return 1;
|
||||||
@ -732,6 +732,52 @@ fprintf(stderr,"libburn experimental: burn_drive_find_devno( 0x%llX ) found %s\n
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ts A60922 ticket 33 */
|
||||||
|
/* Try to find an enumerated address with the same host,channel,target,lun
|
||||||
|
as path */
|
||||||
|
int burn_drive_find_scsi_adr(char *path, char adr[])
|
||||||
|
{
|
||||||
|
char fname[4096];
|
||||||
|
int i, ret = 0, first = 1;
|
||||||
|
int host_no, channel_no, target_no, lun_no;
|
||||||
|
int i_host_no, i_channel_no, i_target_no, i_lun_no;
|
||||||
|
|
||||||
|
ret = sg_obtain_scsi_adr(path, &host_no, &channel_no, &target_no,
|
||||||
|
&lun_no);
|
||||||
|
if(ret <= 0) {
|
||||||
|
|
||||||
|
fprintf(stderr,"libburn experimental: sg_obtain_scsi_adr( %s ) returns %d\n", path, ret);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(stderr,"libburn experimental: burn_drive_find_scsi_adr( %s ) : %d,%d,%d,%d\n", path, host_no, channel_no, target_no, lun_no);
|
||||||
|
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
ret= sg_give_next_adr(&i, fname, sizeof(fname), first);
|
||||||
|
if(ret <= 0)
|
||||||
|
break;
|
||||||
|
first = 0;
|
||||||
|
ret = sg_obtain_scsi_adr(fname, &i_host_no, &i_channel_no,
|
||||||
|
&i_target_no, &i_lun_no);
|
||||||
|
if(ret == -1)
|
||||||
|
continue;
|
||||||
|
if(i_host_no != host_no || i_channel_no != channel_no ||
|
||||||
|
i_target_no != target_no || i_lun_no != lun_no)
|
||||||
|
continue;
|
||||||
|
if(strlen(fname) >= BURN_DRIVE_ADR_LEN)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
fprintf(stderr,"libburn experimental: burn_drive_find_scsi_adr( %s ) found %s\n", path, fname);
|
||||||
|
|
||||||
|
strcpy(adr, fname);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ts A60922 ticket 33 */
|
/* ts A60922 ticket 33 */
|
||||||
/** Try to convert a given existing filesystem address into a persistent drive
|
/** Try to convert a given existing filesystem address into a persistent drive
|
||||||
address. */
|
address. */
|
||||||
@ -768,11 +814,9 @@ fprintf(stderr,"libburn experimental: lstat( %s ) returns -1\n",path);
|
|||||||
ret = burn_drive_find_devno(stbuf.st_rdev, adr);
|
ret = burn_drive_find_devno(stbuf.st_rdev, adr);
|
||||||
if(ret > 0)
|
if(ret > 0)
|
||||||
return 1;
|
return 1;
|
||||||
|
ret = burn_drive_find_scsi_adr(path, adr);
|
||||||
/* >>> if SCSI device :
|
if(ret > 0)
|
||||||
try to find enumerated device with same Bus,Target,Lun
|
return 1;
|
||||||
*/;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr,"libburn experimental: Nothing found for %s \n",path);
|
fprintf(stderr,"libburn experimental: Nothing found for %s \n",path);
|
||||||
|
34
libburn/sg.c
34
libburn/sg.c
@ -248,6 +248,9 @@ void sg_enumerate(void)
|
|||||||
close(fd);
|
close(fd);
|
||||||
if (sid.scsi_type != TYPE_ROM)
|
if (sid.scsi_type != TYPE_ROM)
|
||||||
continue;
|
continue;
|
||||||
|
/* <<< ts A60922 (use SCSI_IOCTL_GET_IDLUN on block devices)
|
||||||
|
fprintf(stderr,"libburn experimental: SCSI triple: %d,%d,%d\n",sid.host_no,sid.scsi_id,sid.lun);
|
||||||
|
*/
|
||||||
|
|
||||||
enumerate_common(fname);
|
enumerate_common(fname);
|
||||||
}
|
}
|
||||||
@ -556,3 +559,34 @@ enum response scsi_error(struct burn_drive *d, unsigned char *sense,
|
|||||||
burn_print(1, "key:0x%x, asc:0x%x, ascq:0x%x\n", key, asc, ascq);
|
burn_print(1, "key:0x%x, asc:0x%x, ascq:0x%x\n", key, asc, ascq);
|
||||||
return FAIL;
|
return FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ts A60922 */
|
||||||
|
/** Try to obtain SCSI address parameters.
|
||||||
|
@return 1 is success , 0 is failure
|
||||||
|
*/
|
||||||
|
int sg_obtain_scsi_adr(char *path, int *host_no, int *channel_no,
|
||||||
|
int *target_no, int *lun_no)
|
||||||
|
{
|
||||||
|
int fd, ret;
|
||||||
|
struct my_scsi_idlun {
|
||||||
|
int x;
|
||||||
|
int host_unique_id;
|
||||||
|
};
|
||||||
|
struct my_scsi_idlun idlun;
|
||||||
|
|
||||||
|
fd = open(path, O_RDONLY | O_NONBLOCK);
|
||||||
|
if(fd < 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* http://www.tldp.org/HOWTO/SCSI-Generic-HOWTO/scsi_g_idlun.html */
|
||||||
|
ret= ioctl(fd, SCSI_IOCTL_GET_IDLUN, &idlun);
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
if(ret == -1)
|
||||||
|
return(0);
|
||||||
|
*host_no= (idlun.x>>24)&255;
|
||||||
|
*channel_no= (idlun.x>>16)&255;
|
||||||
|
*target_no= (idlun.x)&255;
|
||||||
|
*lun_no= (idlun.x>>8)&255;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
@ -12,6 +12,8 @@ enum response
|
|||||||
/* ts A60922 ticket 33 */
|
/* ts A60922 ticket 33 */
|
||||||
int sg_give_next_adr(int *idx, char adr[], int adr_size, int initialize);
|
int sg_give_next_adr(int *idx, char adr[], int adr_size, int initialize);
|
||||||
int sg_is_enumerable_adr(char *adr);
|
int sg_is_enumerable_adr(char *adr);
|
||||||
|
int sg_obtain_scsi_adr(char *path, int *host_no, int *channel_no,
|
||||||
|
int *target_no, int *lun_no);
|
||||||
|
|
||||||
void sg_enumerate(void);
|
void sg_enumerate(void);
|
||||||
void ata_enumerate(void);
|
void ata_enumerate(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user