Truncating eventually detected damaged CD table-of-content
This commit is contained in:
parent
3b3da1b1ee
commit
d6570a143a
@ -1 +1 @@
|
|||||||
#define Cdrskin_timestamP "2008.11.26.210608"
|
#define Cdrskin_timestamP "2008.11.27.081027"
|
||||||
|
@ -531,6 +531,7 @@ Range "scdbackup" : 0x00020000 to 0x0002ffff
|
|||||||
0x0002015c (FAILURE,HIGH) = Fifo size is smaller than desired peek buffer
|
0x0002015c (FAILURE,HIGH) = Fifo size is smaller than desired peek buffer
|
||||||
0x0002015d (FAILURE,HIGH) = Fifo input ended short of desired peek buffer size
|
0x0002015d (FAILURE,HIGH) = Fifo input ended short of desired peek buffer size
|
||||||
0x0002015e (FATAL,HIGH) = Fifo is already under consumption when peeking
|
0x0002015e (FATAL,HIGH) = Fifo is already under consumption when peeking
|
||||||
|
0x0002015f (FAILURE,HIGH) = Damaged CD table-of-content detected and truncated
|
||||||
|
|
||||||
libdax_audioxtr:
|
libdax_audioxtr:
|
||||||
0x00020200 (SORRY,HIGH) = Cannot open audio source file
|
0x00020200 (SORRY,HIGH) = Cannot open audio source file
|
||||||
|
@ -529,13 +529,15 @@ int burn_session_get_hidefirst(struct burn_session *session)
|
|||||||
/* ts A80808 : Enhance CD toc to DVD toc */
|
/* ts A80808 : Enhance CD toc to DVD toc */
|
||||||
int burn_disc_cd_toc_extensions(struct burn_disc *d, int flag)
|
int burn_disc_cd_toc_extensions(struct burn_disc *d, int flag)
|
||||||
{
|
{
|
||||||
int sidx, tidx;
|
int sidx= 0, tidx= 0;
|
||||||
struct burn_toc_entry *entry, *prev_entry= NULL;
|
struct burn_toc_entry *entry, *prev_entry= NULL;
|
||||||
|
|
||||||
/* ts A81126 : ticket 146 : There is a SIGSIGV in here */
|
/* ts A81126 : ticket 146 : There is a SIGSIGV in here */
|
||||||
char msg_data[81], *msg;
|
char msg_data[321], *msg;
|
||||||
|
|
||||||
strcpy(msg_data, "burn_disc_cd_toc_extensions : ");
|
strcpy(msg_data,
|
||||||
|
"Damaged CD table-of-content detected and truncated.");
|
||||||
|
strcat(msg_data, " In burn_disc_cd_toc_extensions: ");
|
||||||
msg = msg_data + strlen(msg_data);
|
msg = msg_data + strlen(msg_data);
|
||||||
if (d->session == NULL) {
|
if (d->session == NULL) {
|
||||||
strcpy(msg, "d->session == NULL");
|
strcpy(msg, "d->session == NULL");
|
||||||
@ -543,19 +545,21 @@ int burn_disc_cd_toc_extensions(struct burn_disc *d, int flag)
|
|||||||
}
|
}
|
||||||
for (sidx = 0; sidx < d->sessions; sidx++) {
|
for (sidx = 0; sidx < d->sessions; sidx++) {
|
||||||
if (d->session[sidx] == NULL) {
|
if (d->session[sidx] == NULL) {
|
||||||
sprintf(msg, "d->session[%d] == NULL", sidx);
|
sprintf(msg, "d->session[%d of %d] == NULL",
|
||||||
|
sidx, d->sessions);
|
||||||
goto failure;
|
goto failure;
|
||||||
}
|
}
|
||||||
if (d->session[sidx]->track == NULL) {
|
if (d->session[sidx]->track == NULL) {
|
||||||
sprintf(msg, "d->session[%d]->track == NULL", sidx);
|
sprintf(msg, "d->session[%d of %d]->track == NULL",
|
||||||
|
sidx, d->sessions);
|
||||||
goto failure;
|
goto failure;
|
||||||
}
|
}
|
||||||
for (tidx = 0; tidx < d->session[sidx]->tracks + 1; tidx++) {
|
for (tidx = 0; tidx < d->session[sidx]->tracks + 1; tidx++) {
|
||||||
if (tidx < d->session[sidx]->tracks) {
|
if (tidx < d->session[sidx]->tracks) {
|
||||||
if (d->session[sidx]->track[tidx] == NULL) {
|
if (d->session[sidx]->track[tidx] == NULL) {
|
||||||
sprintf(msg,
|
sprintf(msg,
|
||||||
"d->session[%d]->track[%d] == NULL",
|
"d->session[%d of %d]->track[%d of %d] == NULL",
|
||||||
sidx, tidx);
|
sidx, d->sessions, tidx, d->session[sidx]->tracks);
|
||||||
goto failure;
|
goto failure;
|
||||||
}
|
}
|
||||||
entry = d->session[sidx]->track[tidx]->entry;
|
entry = d->session[sidx]->track[tidx]->entry;
|
||||||
@ -563,8 +567,8 @@ int burn_disc_cd_toc_extensions(struct burn_disc *d, int flag)
|
|||||||
entry = d->session[sidx]->leadout_entry;
|
entry = d->session[sidx]->leadout_entry;
|
||||||
if (entry == NULL) {
|
if (entry == NULL) {
|
||||||
sprintf(msg,
|
sprintf(msg,
|
||||||
"session %d, track %d of %d, entry == NULL",
|
"session %d of %d, track %d of %d, entry == NULL",
|
||||||
sidx, tidx, d->session[sidx]->tracks);
|
sidx, d->sessions, tidx, d->session[sidx]->tracks);
|
||||||
goto failure;
|
goto failure;
|
||||||
}
|
}
|
||||||
entry->session_msb = 0;
|
entry->session_msb = 0;
|
||||||
@ -588,8 +592,9 @@ int burn_disc_cd_toc_extensions(struct burn_disc *d, int flag)
|
|||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
failure:
|
failure:
|
||||||
libdax_msgs_submit(libdax_messenger, -1, 0x00000001,
|
libdax_msgs_submit(libdax_messenger, -1, 0x0002015f,
|
||||||
LIBDAX_MSGS_SEV_FATAL, LIBDAX_MSGS_PRIO_HIGH, msg_data, 0, 0);
|
LIBDAX_MSGS_SEV_FAILURE, LIBDAX_MSGS_PRIO_HIGH, msg_data, 0, 0);
|
||||||
|
d->sessions= sidx;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user