New API call burn_lookup_device_link()
This commit is contained in:
parent
b798f3b6e6
commit
57185dc9e7
@ -1 +1 @@
|
|||||||
#define Cdrskin_timestamP "2011.07.15.081325"
|
#define Cdrskin_timestamP "2011.07.28.191202"
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
|
||||||
/* ts A61007 */
|
/* ts A61007 */
|
||||||
/* #include <a ssert.h> */
|
/* #include <a ssert.h> */
|
||||||
@ -2045,6 +2046,7 @@ int burn_drive_convert_fs_adr_sub(char *path, char adr[], int *rec_count)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
/** 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. */
|
||||||
int burn_drive_convert_fs_adr(char *path, char adr[])
|
int burn_drive_convert_fs_adr(char *path, char adr[])
|
||||||
@ -2056,6 +2058,88 @@ int burn_drive_convert_fs_adr(char *path, char adr[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int burn_lookup_device_link(char *dev_adr, char link_adr[],
|
||||||
|
char *dir_adr, char **ranks, int rank_count, int flag)
|
||||||
|
{
|
||||||
|
DIR *dirpt= NULL;
|
||||||
|
struct dirent *entry;
|
||||||
|
struct stat link_stbuf;
|
||||||
|
char *adr= NULL, *namept, *sys_adr= NULL;
|
||||||
|
int ret, name_rank, found_rank= 0x7fffffff, dirlen, i, rec_count = 0;
|
||||||
|
static char default_ranks_data[][8] =
|
||||||
|
{"dvdrw", "cdrw", "dvd", "cdrom", "cd"};
|
||||||
|
char *default_ranks[5];
|
||||||
|
|
||||||
|
link_adr[0] = 0;
|
||||||
|
if (ranks == NULL) {
|
||||||
|
for (i = 0; i < 5; i++)
|
||||||
|
default_ranks[i] = default_ranks_data[i];
|
||||||
|
ranks = default_ranks;
|
||||||
|
rank_count= 5;
|
||||||
|
}
|
||||||
|
dirlen= strlen(dir_adr) + 1;
|
||||||
|
if (strlen(dir_adr) + 1 >= BURN_DRIVE_ADR_LEN) {
|
||||||
|
|
||||||
|
/* >>> Issue warning about oversized directory address */;
|
||||||
|
|
||||||
|
{ret = 0; goto ex;}
|
||||||
|
}
|
||||||
|
BURN_ALLOC_MEM(adr, char, BURN_DRIVE_ADR_LEN);
|
||||||
|
BURN_ALLOC_MEM(sys_adr, char, BURN_DRIVE_ADR_LEN);
|
||||||
|
|
||||||
|
dirpt = opendir(dir_adr);
|
||||||
|
if (dirpt == NULL)
|
||||||
|
{ret = 0; goto ex;}
|
||||||
|
strcpy(adr, dir_adr);
|
||||||
|
strcat(adr, "/");
|
||||||
|
namept = adr + strlen(dir_adr) + 1;
|
||||||
|
while(1) {
|
||||||
|
entry = readdir(dirpt);
|
||||||
|
if(entry == NULL)
|
||||||
|
break;
|
||||||
|
if (strlen(entry->d_name) + dirlen >= BURN_DRIVE_ADR_LEN)
|
||||||
|
continue;
|
||||||
|
strcpy(namept, entry->d_name);
|
||||||
|
if(lstat(adr, &link_stbuf) == -1)
|
||||||
|
continue;
|
||||||
|
if((link_stbuf.st_mode & S_IFMT) != S_IFLNK)
|
||||||
|
continue;
|
||||||
|
/* Determine rank and omit uninteresting ones */
|
||||||
|
for(name_rank= 0; name_rank < rank_count; name_rank++)
|
||||||
|
if(strncmp(namept, ranks[name_rank],
|
||||||
|
strlen(ranks[name_rank])) == 0)
|
||||||
|
break;
|
||||||
|
/* we look for lowest rank */
|
||||||
|
if(name_rank >= rank_count ||
|
||||||
|
name_rank > found_rank ||
|
||||||
|
(name_rank == found_rank &&
|
||||||
|
strcmp(namept, link_adr + dirlen) >= 0))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* Does name point to the same device as dev_adr ? */
|
||||||
|
ret= burn_drive_resolve_link(adr, sys_adr, &rec_count, 2);
|
||||||
|
if(ret < 0)
|
||||||
|
goto ex;
|
||||||
|
if(ret == 0)
|
||||||
|
continue;
|
||||||
|
if(strcmp(dev_adr, sys_adr) == 0) {
|
||||||
|
strcpy(link_adr, adr);
|
||||||
|
found_rank= name_rank;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ret= 2;
|
||||||
|
if(found_rank < 0x7fffffff)
|
||||||
|
ret= 1;
|
||||||
|
ex:;
|
||||||
|
if(dirpt != NULL)
|
||||||
|
closedir(dirpt);
|
||||||
|
BURN_FREE_MEM(adr);
|
||||||
|
BURN_FREE_MEM(sys_adr);
|
||||||
|
return(ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/** A pacifier function suitable for burn_abort.
|
/** A pacifier function suitable for burn_abort.
|
||||||
@param handle If not NULL, a pointer to a text suitable for printf("%s")
|
@param handle If not NULL, a pointer to a text suitable for printf("%s")
|
||||||
*/
|
*/
|
||||||
|
@ -1059,6 +1059,39 @@ int burn_drive_convert_fs_adr(char *path, char adr[]);
|
|||||||
int burn_drive_convert_scsi_adr(int bus_no, int host_no, int channel_no,
|
int burn_drive_convert_scsi_adr(int bus_no, int host_no, int channel_no,
|
||||||
int target_no, int lun_no, char adr[]);
|
int target_no, int lun_no, char adr[]);
|
||||||
|
|
||||||
|
/* ts B10728 */
|
||||||
|
/** Try to convert a given persistent drive address into the address of a
|
||||||
|
symbolic link that points to this drive address.
|
||||||
|
Modern GNU/Linux systems may shuffle drive addresses from boot to boot.
|
||||||
|
The udev daemon is supposed to create links which always point to the
|
||||||
|
same drive, regardless of its system address.
|
||||||
|
This call tries to find such links.
|
||||||
|
@param dev_adr Should contain a drive address as returned by
|
||||||
|
burn_drive_scan().
|
||||||
|
@param link_adr An application provided array of at least
|
||||||
|
BURN_DRIVE_ADR_LEN characters size. The found link
|
||||||
|
address gets copied to it.
|
||||||
|
@param dir_adr The address of the directory where to look for links.
|
||||||
|
Normally: "/dev"
|
||||||
|
@param templ An array of pointers to name templates, which
|
||||||
|
links have to match. A symbolic link in dir_adr matches
|
||||||
|
a name template if it begins by that text. E.g.
|
||||||
|
link address "/dev/dvdrw1" matches template "dvdrw".
|
||||||
|
If templ is NULL, then the default array gets used:
|
||||||
|
{"dvdrw", "cdrw", "dvd", "cdrom", "cd"}
|
||||||
|
If several links would match, then a link will win,
|
||||||
|
which matches the template with the lowest array index.
|
||||||
|
Among these candidates, the one with the lowest strcmp()
|
||||||
|
rank will be chosen as link_adr.
|
||||||
|
@param num_templ Number of array elements in templ.
|
||||||
|
@param flag Bitfield for control purposes. Unused yet. Submit 0.
|
||||||
|
@return <0 severe error, 0 failed to search, 2 nothing found
|
||||||
|
1 success, link_adr is valid
|
||||||
|
@since 1.1.2
|
||||||
|
*/
|
||||||
|
int burn_lookup_device_link(char *dev_adr, char link_adr[],
|
||||||
|
char *dir_adr, char **templ, int num_templ, int flag);
|
||||||
|
|
||||||
/* ts A60923 - A61005 */
|
/* ts A60923 - A61005 */
|
||||||
/** Try to obtain bus,host,channel,target,lun from path. If there is an SCSI
|
/** Try to obtain bus,host,channel,target,lun from path. If there is an SCSI
|
||||||
address at all, then this call should succeed with a persistent
|
address at all, then this call should succeed with a persistent
|
||||||
@ -3064,6 +3097,8 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
|
|||||||
3= stdio-drive, sequential, write-only
|
3= stdio-drive, sequential, write-only
|
||||||
4= stdio-drive, random access, read-only
|
4= stdio-drive, random access, read-only
|
||||||
(only if enabled by burn_allow_drive_role_4())
|
(only if enabled by burn_allow_drive_role_4())
|
||||||
|
5= stdio-drive, random access, write-only
|
||||||
|
(only if enabled by burn_allow_drive_role_4())
|
||||||
@since 0.4.0
|
@since 0.4.0
|
||||||
*/
|
*/
|
||||||
int burn_drive_get_drive_role(struct burn_drive *d);
|
int burn_drive_get_drive_role(struct burn_drive *d);
|
||||||
|
@ -81,6 +81,7 @@ burn_guess_manufacturer;
|
|||||||
burn_initialize;
|
burn_initialize;
|
||||||
burn_is_aborting;
|
burn_is_aborting;
|
||||||
burn_lba_to_msf;
|
burn_lba_to_msf;
|
||||||
|
burn_lookup_device_link;
|
||||||
burn_msf_to_lba;
|
burn_msf_to_lba;
|
||||||
burn_msf_to_sectors;
|
burn_msf_to_sectors;
|
||||||
burn_msgs_obtain;
|
burn_msgs_obtain;
|
||||||
|
Loading…
Reference in New Issue
Block a user