Provisory introduction of drive role 5, random access write-only

This commit is contained in:
Thomas Schmitt 2011-03-18 09:33:54 +00:00
parent 998fcdbefa
commit af41742516
7 changed files with 130 additions and 28 deletions

View File

@ -1 +1 @@
#define Cdrskin_timestamP "2011.03.18.093128" #define Cdrskin_timestamP "2011.03.18.093410"

View File

@ -392,7 +392,7 @@ void burn_disc_erase(struct burn_drive *drive, int fast)
drive->status != BURN_DISC_APPENDABLE && drive->status != BURN_DISC_APPENDABLE &&
drive->status != BURN_DISC_BLANK) drive->status != BURN_DISC_BLANK)
|| ||
(drive->drive_role != 1) (drive->drive_role != 1 && drive->drive_role != 5)
) { ) {
libdax_msgs_submit(libdax_messenger, drive->global_index, libdax_msgs_submit(libdax_messenger, drive->global_index,
0x00020130, 0x00020130,

View File

@ -78,6 +78,7 @@ int burn_setup_drive(struct burn_drive *d, char *fname)
d->status = BURN_DISC_UNREADY; d->status = BURN_DISC_UNREADY;
d->do_stream_recording = 0; d->do_stream_recording = 0;
d->stream_recording_start= 0; d->stream_recording_start= 0;
d->role_5_nwa = 0;
return 1; return 1;
} }
@ -312,8 +313,9 @@ int burn_drive_inquire_media(struct burn_drive *d)
int burn_drive_grab(struct burn_drive *d, int le) int burn_drive_grab(struct burn_drive *d, int le)
{ {
int errcode; int errcode;
/* ts A61125 - A61202 */ /* ts A61125 - B10314 */
int ret, sose; int ret, sose, stat_ret = -1;
struct stat stbuf;
if (!d->released) { if (!d->released) {
burn_print(1, "can't grab - already grabbed\n"); burn_print(1, "can't grab - already grabbed\n");
@ -321,9 +323,24 @@ int burn_drive_grab(struct burn_drive *d, int le)
} }
if(d->drive_role != 1) { if(d->drive_role != 1) {
d->released = 0; d->released = 0;
d->current_profile = 0xffff;
if (d->devname[0])
stat_ret = stat(d->devname, &stbuf);
if(d->drive_role == 2 || d->drive_role == 3) { if(d->drive_role == 2 || d->drive_role == 3) {
d->status = BURN_DISC_BLANK; d->status = BURN_DISC_BLANK;
d->current_profile = 0xffff; } else if(d->drive_role == 4) {
if (d->media_read_capacity > 0)
d->status = BURN_DISC_FULL;
else
d->status = BURN_DISC_EMPTY;
} else if(d->drive_role == 5) {
if (stat_ret != -1 && S_ISREG(stbuf.st_mode) &&
stbuf.st_size > 0) {
d->status = BURN_DISC_APPENDABLE;
d->role_5_nwa = stbuf.st_size / 2048 +
!!(stbuf.st_size % 2049);
} else
d->status = BURN_DISC_BLANK;
} else { } else {
d->status = BURN_DISC_EMPTY; d->status = BURN_DISC_EMPTY;
d->current_profile = 0; d->current_profile = 0;
@ -620,13 +637,29 @@ void burn_wait_all(void)
void burn_disc_erase_sync(struct burn_drive *d, int fast) void burn_disc_erase_sync(struct burn_drive *d, int fast)
{ {
/* ts A60924 : libburn/message.c gets obsoleted int ret;
burn_message_clear_queue();
*/
burn_print(1, "erasing drive %s %s\n", d->idata->vendor, burn_print(1, "erasing drive %s %s\n", d->idata->vendor,
d->idata->product); d->idata->product);
if (d->drive_role == 5) { /* Random access write-only drive */
ret = truncate(d->devname, (off_t) 0);
if (ret == -1) {
libdax_msgs_submit(libdax_messenger, -1,
0x00020182,
LIBDAX_MSGS_SEV_FAILURE, LIBDAX_MSGS_PRIO_HIGH,
"Cannot truncate disk file for pseudo blanking",
0, 0);
return;
}
d->role_5_nwa = 0;
d->cancel = 0;
d->status = BURN_DISC_BLANK;
d->busy = BURN_DRIVE_IDLE;
d->progress.sector = 0x10000;
return;
}
d->cancel = 0; d->cancel = 0;
#ifdef Libburn_reset_progress_asynC #ifdef Libburn_reset_progress_asynC
@ -1365,6 +1398,7 @@ int burn_drive__fd_from_special_adr(char *adr)
} }
/* @param flag bit0= accept read-only files and return 2 in this case /* @param flag bit0= accept read-only files and return 2 in this case
bit1= accept write-only files and return 3 in this case
*/ */
static int burn_drive__is_rdwr(char *fname, int *stat_ret, static int burn_drive__is_rdwr(char *fname, int *stat_ret,
struct stat *stbuf_ret, struct stat *stbuf_ret,
@ -1405,6 +1439,9 @@ fprintf(stderr, "LIBBURN_DEBUG: burn_drive__is_rdwr: getfl_ret = %lX , O_RDWR =
if ((flag & 1) && getfl_ret != -1 && if ((flag & 1) && getfl_ret != -1 &&
(getfl_ret & mask) == O_RDONLY) (getfl_ret & mask) == O_RDONLY)
is_rdwr = 2; is_rdwr = 2;
if ((flag & 2) && getfl_ret != -1 &&
(getfl_ret & mask) == O_WRONLY)
is_rdwr = 3;
} }
if (stat_ret != NULL) if (stat_ret != NULL)
*stat_ret = st_ret; *stat_ret = st_ret;
@ -1439,7 +1476,7 @@ static int burn_role_by_access(char *fname, int flag)
fd = open(fname, O_WRONLY | O_LARGEFILE); fd = open(fname, O_WRONLY | O_LARGEFILE);
if (fd != -1) { if (fd != -1) {
close(fd); close(fd);
return 3; return 5;
} }
if (flag & 1) if (flag & 1)
return 0; return 0;
@ -1450,8 +1487,8 @@ static int burn_role_by_access(char *fname, int flag)
/* ts A70903 : Implements adquiration of pseudo drives */ /* ts A70903 : Implements adquiration of pseudo drives */
int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname) int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname)
{ {
int ret = -1, role = 0; int ret = -1, role = 0, fd;
int is_rdwr = 0, stat_ret; int is_rdwr = 0, stat_ret = -1;
/* divided by 512 it needs to fit into a signed long integer */ /* divided by 512 it needs to fit into a signed long integer */
off_t size = ((off_t) (512 * 1024 * 1024 - 1) * (off_t) 2048); off_t size = ((off_t) (512 * 1024 * 1024 - 1) * (off_t) 2048);
off_t read_size = -1; off_t read_size = -1;
@ -1459,8 +1496,9 @@ int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname)
struct stat stbuf; struct stat stbuf;
if (fname[0] != 0) { if (fname[0] != 0) {
fd = burn_drive__fd_from_special_adr(fname);
is_rdwr = burn_drive__is_rdwr(fname, &stat_ret, &stbuf, is_rdwr = burn_drive__is_rdwr(fname, &stat_ret, &stbuf,
&read_size, 1); &read_size, 1 | 2);
if (stat_ret == -1 || is_rdwr) { if (stat_ret == -1 || is_rdwr) {
ret = burn_os_stdio_capacity(fname, &size); ret = burn_os_stdio_capacity(fname, &size);
if (ret == -1) { if (ret == -1) {
@ -1482,9 +1520,12 @@ int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname)
if (is_rdwr == 2 && if (is_rdwr == 2 &&
(burn_drive_role_4_allowed & 1)) (burn_drive_role_4_allowed & 1))
role = 4; role = 4;
else if (is_rdwr == 3 &&
(burn_drive_role_4_allowed & 1))
role = 5;
else else
role = 2; role = 2;
if (stat_ret != -1 && is_rdwr == 1 && if (stat_ret != -1 && role == 2 && fd == -1 &&
(burn_drive_role_4_allowed & 3) == 3) (burn_drive_role_4_allowed & 3) == 3)
role = burn_role_by_access(fname, role = burn_role_by_access(fname,
!!(burn_drive_role_4_allowed & 4)); !!(burn_drive_role_4_allowed & 4));
@ -1511,20 +1552,29 @@ int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname)
} }
free((char *) d); /* all sub pointers have been copied to *regd_d */ free((char *) d); /* all sub pointers have been copied to *regd_d */
d = regd_d; d = regd_d;
if (d->drive_role == 2 || d->drive_role == 3 || d->drive_role == 4) { if (d->drive_role >= 2 && d->drive_role <= 5) {
if (d->drive_role == 4) { if (d->drive_role == 4) {
if (read_size > 0)
d->status = BURN_DISC_FULL; d->status = BURN_DISC_FULL;
/* MMC for non-compliant drive */ else
d->current_profile = 0xffff; d->status = BURN_DISC_EMPTY;
d->block_types[BURN_WRITE_TAO] = 0; d->block_types[BURN_WRITE_TAO] = 0;
d->block_types[BURN_WRITE_SAO] = 0; d->block_types[BURN_WRITE_SAO] = 0;
} else {
if (d->drive_role == 5 && stat_ret != -1 &&
S_ISREG(stbuf.st_mode) && stbuf.st_size > 0) {
d->status = BURN_DISC_APPENDABLE;
d->block_types[BURN_WRITE_SAO] = 0;
d->role_5_nwa = stbuf.st_size / 2048 +
!!(stbuf.st_size % 2049);
} else { } else {
d->status = BURN_DISC_BLANK; d->status = BURN_DISC_BLANK;
/* MMC for non-compliant drive */ d->block_types[BURN_WRITE_SAO] =
d->current_profile = 0xffff; BURN_BLOCK_SAO;
d->block_types[BURN_WRITE_TAO] = BURN_BLOCK_MODE1;
d->block_types[BURN_WRITE_SAO] = BURN_BLOCK_SAO;
} }
d->block_types[BURN_WRITE_TAO] = BURN_BLOCK_MODE1;
}
d->current_profile = 0xffff; /* MMC for non-compliant drive */
strcpy(d->current_profile_text,"stdio file"); strcpy(d->current_profile_text,"stdio file");
d->current_is_cd_profile = 0; d->current_is_cd_profile = 0;
d->current_is_supported_profile = 1; d->current_is_supported_profile = 1;
@ -1555,6 +1605,10 @@ int burn_drive_grab_dummy(struct burn_drive_info *drive_infos[], char *fname)
strcpy((*drive_infos)[0].vendor,"YOYODYNE"); strcpy((*drive_infos)[0].vendor,"YOYODYNE");
strcpy((*drive_infos)[0].product,"WARP DRIVE"); strcpy((*drive_infos)[0].product,"WARP DRIVE");
strcpy((*drive_infos)[0].revision,"FX03"); strcpy((*drive_infos)[0].revision,"FX03");
} else if (d->drive_role == 5) {
strcpy((*drive_infos)[0].vendor,"YOYODYNE");
strcpy((*drive_infos)[0].product,"WARP DRIVE");
strcpy((*drive_infos)[0].revision,"FX04");
} else { } else {
strcpy((*drive_infos)[0].vendor,"FERENGI"); strcpy((*drive_infos)[0].vendor,"FERENGI");
strcpy((*drive_infos)[0].product,"VAPORWARE"); strcpy((*drive_infos)[0].product,"VAPORWARE");
@ -2186,6 +2240,11 @@ int burn_disc_track_lba_nwa(struct burn_drive *d, struct burn_write_opts *o,
return -1; return -1;
} }
*lba = *nwa = 0; *lba = *nwa = 0;
if (d->drive_role == 5 && trackno == 0 &&
d->status == BURN_DISC_APPENDABLE) {
*lba = *nwa = d->role_5_nwa;
return 1;
}
if (d->drive_role != 1) if (d->drive_role != 1)
return 0; return 0;
if (o != NULL) if (o != NULL)
@ -2496,12 +2555,39 @@ int burn_disc_get_multi_caps(struct burn_drive *d, enum burn_write_types wt,
size = d->media_capacity_remaining; size = d->media_capacity_remaining;
burn_os_stdio_capacity(d->devname, &size); burn_os_stdio_capacity(d->devname, &size);
burn_drive_set_media_capacity_remaining(d, size); burn_drive_set_media_capacity_remaining(d, size);
/* >>> This looks wrong ! */
/* >>> should add file size */
o->start_range_high = size; o->start_range_high = size;
o->start_alignment = 2048; /* imposting a drive, not a file */ o->start_alignment = 2048; /* imposting a drive, not a file */
o->might_do_sao = 4; o->might_do_sao = 4;
o->might_do_tao = 2; o->might_do_tao = 2;
o->advised_write_mode = BURN_WRITE_TAO; o->advised_write_mode = BURN_WRITE_TAO;
o->might_simulate = 1; o->might_simulate = 1;
} else if (d->drive_role == 5) {
/* stdio file drive : random access write-only */
o->start_adr = 1;
size = d->media_capacity_remaining;
burn_os_stdio_capacity(d->devname, &size);
burn_drive_set_media_capacity_remaining(d, size);
/* >>> start_range_low = file size rounded to 2048 */;
/* >>> This looks wrong ! */
/* >>> should add file size */
o->start_range_high = size;
o->start_alignment = 2048; /* imposting a drive, not a file */
if (s == BURN_DISC_APPENDABLE) {
if (wt == BURN_WRITE_SAO || wt == BURN_WRITE_RAW)
return 0;
o->might_do_sao = 0;
} else
o->might_do_sao = 4;
o->might_do_tao = 2;
o->advised_write_mode = BURN_WRITE_TAO;
o->might_simulate = 1;
} else if (d->drive_role != 1) { } else if (d->drive_role != 1) {
/* stdio file drive : sequential access write-only */ /* stdio file drive : sequential access write-only */
o->might_do_sao = 4; o->might_do_sao = 4;
@ -2750,13 +2836,20 @@ int burn_drive_equals_adr(struct burn_drive *d1, char *adr2_in, int role2)
fd = burn_drive__fd_from_special_adr(adr2); fd = burn_drive__fd_from_special_adr(adr2);
if (fd != -1) if (fd != -1)
exact_role_matters = 1; exact_role_matters = 1;
ret = burn_drive__is_rdwr(adr2, NULL, NULL, NULL, 1); ret = burn_drive__is_rdwr(adr2, NULL, NULL, NULL,
if (ret == 2 && burn_drive_role_4_allowed) 1 | 2);
if (ret == 2 && (burn_drive_role_4_allowed & 1))
role2 = 4; role2 = 4;
else if (ret == 3 && (burn_drive_role_4_allowed & 1))
role2 = 5;
else if (ret > 0) else if (ret > 0)
role2 = 2; role2 = 2;
else else
role2 = 3; role2 = 3;
if (fd == -1 &&
role2 == 2 && (burn_drive_role_4_allowed & 3) == 3)
role2 = burn_role_by_access(adr2,
!!(burn_drive_role_4_allowed & 4));
} }
} }

View File

@ -567,6 +567,7 @@ Range "scdbackup" : 0x00020000 to 0x0002ffff
0x0002017f (FAILURE,HIGH) = Failed to synchronize drive cache 0x0002017f (FAILURE,HIGH) = Failed to synchronize drive cache
0x00020180 (FAILURE,HIGH) = Premature end of input encountered 0x00020180 (FAILURE,HIGH) = Premature end of input encountered
0x00020181 (FAILURE,HIGH) = Pseudo-drive is a read-only file. Cannot write. 0x00020181 (FAILURE,HIGH) = Pseudo-drive is a read-only file. Cannot write.
0x00020182 (FAILURE,HIGH) = Cannot truncate disk file for pseudo blanking
libdax_audioxtr: libdax_audioxtr:
0x00020200 (SORRY,HIGH) = Cannot open audio source file 0x00020200 (SORRY,HIGH) = Cannot open audio source file

View File

@ -433,12 +433,15 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
ret = 0; goto ex; ret = 0; goto ex;
} }
if (lseek(fd, byte_address, SEEK_SET) == -1) { if (lseek(fd, byte_address, SEEK_SET) == -1) {
if (!(flag & 2)) if (!(flag & 2)) {
sprintf(msg, "Cannot address start byte %.f",
(double) byte_address);
libdax_msgs_submit(libdax_messenger, libdax_msgs_submit(libdax_messenger,
d->global_index, d->global_index,
0x00020147, 0x00020147,
LIBDAX_MSGS_SEV_SORRY, LIBDAX_MSGS_PRIO_HIGH, LIBDAX_MSGS_SEV_SORRY, LIBDAX_MSGS_PRIO_HIGH,
"Cannot address start byte", errno, 0); msg, errno, 0);
}
ret = 0; goto ex; ret = 0; goto ex;
} }
} }

View File

@ -134,6 +134,8 @@ struct burn_drive
1=MMC drive , 1=MMC drive ,
2=stdio random read-write 2=stdio random read-write
3=stdio sequential write-only 3=stdio sequential write-only
4=stdio random read-only
5=stdio random write-only
*/ */
int drive_role; int drive_role;
@ -285,6 +287,9 @@ struct burn_drive
0x7fffffff = unknown */ 0x7fffffff = unknown */
int media_read_capacity; int media_read_capacity;
/* ts B10314 : Next Writeable Adress for drive_role == 5 */
int role_5_nwa;
int toc_temp; int toc_temp;
struct burn_disc *disc; /* disc structure */ struct burn_disc *disc; /* disc structure */
int block_types[4]; int block_types[4];

View File

@ -1027,7 +1027,7 @@ int burn_precheck_write(struct burn_write_opts *o, struct burn_disc *disc,
reason_pt= reasons + strlen(reasons); reason_pt= reasons + strlen(reasons);
if (d->status == BURN_DISC_UNSUITABLE) if (d->status == BURN_DISC_UNSUITABLE)
goto unsuitable_profile; goto unsuitable_profile;
if (d->drive_role == 2 || if (d->drive_role == 2 || d->drive_role == 5 ||
d->current_profile == 0x1a || d->current_profile == 0x12 || d->current_profile == 0x1a || d->current_profile == 0x12 ||
d->current_profile == 0x43) { d->current_profile == 0x43) {
/* DVD+RW , DVD-RAM , BD-RE, emulated drive on stdio file */ /* DVD+RW , DVD-RAM , BD-RE, emulated drive on stdio file */
@ -2071,7 +2071,7 @@ int burn_stdio_open_write(struct burn_drive *d, off_t start_byte,
} }
if (start_byte < 0) if (start_byte < 0)
start_byte = 0; start_byte = 0;
if (d->drive_role == 2) { if (d->drive_role == 2 || d->drive_role == 5) {
lseek_res = lseek(fd, start_byte, SEEK_SET); lseek_res = lseek(fd, start_byte, SEEK_SET);
if (lseek_res == -1) { if (lseek_res == -1) {
sprintf(msg, "Cannot address start byte %.f", sprintf(msg, "Cannot address start byte %.f",
@ -2672,7 +2672,7 @@ int burn_random_access_write(struct burn_drive *d, off_t byte_address,
return 0; return 0;
} }
if(d->drive_role == 2) if(d->drive_role == 2 || d->drive_role == 5)
alignment = 2 * 1024; alignment = 2 * 1024;
if (d->current_profile == 0x12) /* DVD-RAM */ if (d->current_profile == 0x12) /* DVD-RAM */
alignment = 2 * 1024; alignment = 2 * 1024;