Implemented first use of API-experimental burn_drive_info_forget() in cdrskin signal handler
This commit is contained in:
parent
085d025bd4
commit
fcaba35881
@ -51,6 +51,63 @@ void burn_drive_free_all(void)
|
|||||||
memset(drive_array, 0, sizeof(drive_array));
|
memset(drive_array, 0, sizeof(drive_array));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ts A60822 */
|
||||||
|
int burn_drive_is_open(struct burn_drive *d)
|
||||||
|
{
|
||||||
|
/* a bit more detailed case distinction than needed */
|
||||||
|
if (d->fd == -1337)
|
||||||
|
return 0;
|
||||||
|
if (d->fd < 0)
|
||||||
|
return 0;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ts A60906 */
|
||||||
|
int burn_drive_force_idle(struct burn_drive *d)
|
||||||
|
{
|
||||||
|
d->busy = BURN_DRIVE_IDLE;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ts A60906 */
|
||||||
|
int burn_drive_is_released(struct burn_drive *d)
|
||||||
|
{
|
||||||
|
return !!d->released;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ts A60906 */
|
||||||
|
/** Inquires drive status in respect to degree of app usage.
|
||||||
|
@param return -2 = drive is forgotten
|
||||||
|
-1 = drive is closed (i.e. released explicitely)
|
||||||
|
0 = drive is open, not grabbed (after scan, before 1st grab)
|
||||||
|
1 = drive is grabbed but BURN_DRIVE_IDLE
|
||||||
|
10 = drive is grabbing (BURN_DRIVE_GRABBING)
|
||||||
|
100 = drive is busy in cancelable state
|
||||||
|
1000 = drive is in non-cancelable state
|
||||||
|
Expect a monotonous sequence of usage severity to emerge in future.
|
||||||
|
*/
|
||||||
|
int burn_drive_is_occupied(struct burn_drive *d)
|
||||||
|
{
|
||||||
|
if(d->global_index < 0)
|
||||||
|
return -2;
|
||||||
|
if(!burn_drive_is_open(d))
|
||||||
|
return -1;
|
||||||
|
if(d->busy == BURN_DRIVE_GRABBING)
|
||||||
|
return 10;
|
||||||
|
if(d->released)
|
||||||
|
return 0;
|
||||||
|
if(d->busy == BURN_DRIVE_IDLE)
|
||||||
|
return 1;
|
||||||
|
if(d->busy == BURN_DRIVE_READING || d->busy == BURN_DRIVE_WRITING)
|
||||||
|
return 50;
|
||||||
|
return 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
void drive_read_lead_in(int dnum)
|
void drive_read_lead_in(int dnum)
|
||||||
{
|
{
|
||||||
@ -145,7 +202,10 @@ void burn_drive_release(struct burn_drive *d, int le)
|
|||||||
{
|
{
|
||||||
if (d->released)
|
if (d->released)
|
||||||
burn_print(1, "second release on drive!\n");
|
burn_print(1, "second release on drive!\n");
|
||||||
assert(!d->busy);
|
|
||||||
|
/* ts A60906: one should not assume BURN_DRIVE_IDLE == 0 */
|
||||||
|
assert(d->busy == BURN_DRIVE_IDLE);
|
||||||
|
|
||||||
d->unlock(d);
|
d->unlock(d);
|
||||||
if (le)
|
if (le)
|
||||||
d->eject(d);
|
d->eject(d);
|
||||||
@ -404,7 +464,26 @@ void burn_drive_info_free(struct burn_drive_info drive_infos[])
|
|||||||
/* Experimental API call */
|
/* Experimental API call */
|
||||||
int burn_drive_info_forget(struct burn_drive_info *info, int force)
|
int burn_drive_info_forget(struct burn_drive_info *info, int force)
|
||||||
{
|
{
|
||||||
burn_drive_free(info->drive);
|
int occup;
|
||||||
|
struct burn_drive *d;
|
||||||
|
|
||||||
|
d = info->drive;
|
||||||
|
occup = burn_drive_is_occupied(d);
|
||||||
|
if(occup <= -2)
|
||||||
|
return 2;
|
||||||
|
if(occup > 0)
|
||||||
|
if(force < 1)
|
||||||
|
return 0;
|
||||||
|
if(occup > 10)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* >>> do any drive calming here */;
|
||||||
|
|
||||||
|
|
||||||
|
burn_drive_force_idle(d);
|
||||||
|
if(occup > 0 && !burn_drive_is_released(d))
|
||||||
|
burn_drive_release(d,0);
|
||||||
|
burn_drive_free(d);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -484,17 +563,6 @@ int burn_drive_is_banned(char *device_address)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ts A60822 */
|
|
||||||
int burn_drive_is_open(struct burn_drive *d)
|
|
||||||
{
|
|
||||||
/* a bit more detailed case distinction than needed */
|
|
||||||
if (d->fd == -1337)
|
|
||||||
return 0;
|
|
||||||
if (d->fd < 0)
|
|
||||||
return 0;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ts A60823 */
|
/* ts A60823 */
|
||||||
/** Aquire a drive with known persistent address.
|
/** Aquire a drive with known persistent address.
|
||||||
*/
|
*/
|
||||||
|
@ -552,12 +552,13 @@ int burn_drive_scan(struct burn_drive_info *drive_infos[],
|
|||||||
@param drive_info pointer to a single element out of the array
|
@param drive_info pointer to a single element out of the array
|
||||||
obtained from burn_drive_scan() : &(drive_infos[driveno])
|
obtained from burn_drive_scan() : &(drive_infos[driveno])
|
||||||
@param force controls degree of permissible drive usage at the moment this
|
@param force controls degree of permissible drive usage at the moment this
|
||||||
function is called and amount of automatically provided drive
|
function is called, and the amount of automatically provided
|
||||||
shutdown :
|
drive shutdown :
|
||||||
0= drive must be ungrabbed and BURN_DRIVE_IDLE
|
0= drive must be ungrabbed and BURN_DRIVE_IDLE
|
||||||
1= try to release drive resp. accept BURN_DRIVE_GRABBING
|
1= try to release drive resp. accept BURN_DRIVE_GRABBING
|
||||||
Use these two only. Further values are to be defined.
|
Use these two only. Further values are to be defined.
|
||||||
@return 1 on success, <=0 on failure
|
@return 1 on success, 2 if drive was already forgotten,
|
||||||
|
0 if not permissible, <0 on other failures,
|
||||||
*/
|
*/
|
||||||
int burn_drive_info_forget(struct burn_drive_info *drive_info, int force);
|
int burn_drive_info_forget(struct burn_drive_info *drive_info, int force);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user