Compare commits

..

11 Commits

28 changed files with 216 additions and 817 deletions

View File

@ -1,12 +1,13 @@
Derek Foreman <derek@signalmarketing.com> and Ben Jansens <xor@orodu.net> Derek Foreman <derek@signalmarketing.com> and Ben Jansens <xor@orodu.net>
Copyright (C) 2002-2006 Derek Foreman and Ben Jansens Copyright (C) 2002-2006 Derek Foreman and Ben Jansens
Mario Danic <mario.danic@gmail.com>, Thomas Schmitt <scdbackup@gmx.net> Mario Danic <mario.danic@gmail.com>, Thomas Schmitt <scdbackup@gmx.net>
Copyright (C) 2006-2008 Mario Danic, Thomas Schmitt Copyright (C) 2006-2007 Mario Danic, Thomas Schmitt
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as it under the terms of the GNU General Public License as published by
published by the Free Software Foundation. the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful, This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of but WITHOUT ANY WARRANTY; without even the implied warranty of

View File

@ -101,9 +101,9 @@ test_structest_CPPFLAGS = -Ilibburn
test_structest_LDADD = $(libburn_libburn_la_OBJECTS) $(THREAD_LIBS) test_structest_LDADD = $(libburn_libburn_la_OBJECTS) $(THREAD_LIBS)
test_structest_SOURCES = test/structest.c test_structest_SOURCES = test/structest.c
## cdrskin construction site - ts A60816 - A80408 ## cdrskin construction site - ts A60816 - A71025
cdrskin_cdrskin_CPPFLAGS = -Ilibburn cdrskin_cdrskin_CPPFLAGS = -Ilibburn
cdrskin_cdrskin_CFLAGS = -DCdrskin_libburn_0_4_4 cdrskin_cdrskin_CFLAGS = -DCdrskin_libburn_0_4_2
# cdrskin_cdrskin_LDADD = $(libburn_libburn_la_OBJECTS) $(THREAD_LIBS) # cdrskin_cdrskin_LDADD = $(libburn_libburn_la_OBJECTS) $(THREAD_LIBS)
# ts A80123, change proposed by Simon Huggins to cause dynamic libburn linking # ts A80123, change proposed by Simon Huggins to cause dynamic libburn linking

87
README
View File

@ -19,7 +19,7 @@ commitment as written at the end of this text.
The rights and merits of the Libburn-copyright holders Derek Foreman and The rights and merits of the Libburn-copyright holders Derek Foreman and
Ben Jansens will be duely respected. Ben Jansens will be duely respected.
This libburnia-project.org toplevel README (C) 2006-2008 Thomas Schmitt This libburnia-project.org toplevel README (C) 2006-2007 Thomas Schmitt
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
Build and Installation Build and Installation
@ -39,19 +39,13 @@ into its toplevel directory (here: "libburn") and execute
./configure --prefix=/usr ./configure --prefix=/usr
make make
To make the libraries accessible for running resp. developing applications To make the libraries accessible for running resp. developing applications
and to install the cdrecord compatibility binary cdrskin, do:
make install make install
An important part of the project, libisofs, is hosted in a bzr repository at The other half of the project, libisofs, is hosted in the libburnia SVN, too:
launchpad.net : svn co http://svn.libburnia-project.org/libisofs/trunk libisofs
bzr branch lp:libisofs See README file there.
Another part the project, libisoburn, is hosted in the libburnia SVN, too:
svn co http://svn.libburnia-project.org/libisoburn/trunk libisoburn
See README files there.
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
@ -73,39 +67,29 @@ we would need : login on a development machine resp. a live OS on CD or DVD,
advise from a system person about the equivalent of Linux sg or FreeBSD CAM, advise from a system person about the equivalent of Linux sg or FreeBSD CAM,
volunteers for testing of realistic use cases. volunteers for testing of realistic use cases.
We have a well tested code base for burning data and audio CDs and many DVD We have a workable code base for burning CD and most single layer DVD.
types. The burn API is quite comprehensively documented and can be used to The burn API is quite comprehensively documented and can be used to build a
build a presentable application. presentable application.
We have a functional binary which emulates the core use cases of cdrecord in We have a functional binary which emulates parts of cdrecord in order to
order to prove that usability, and in order to allow you to explore libburn's prove that usability, and in order to allow you to explore libburnia's scope
scope by help of existing cdrecord frontends. by help of existing cdrecord frontends.
ISO 9660 filesystems with Rock Ridge and Joliet extensions can be created
and manipulated quite freely. This capability together with our burn capability
makes possible a single binary application which covers all steps of image
composition, updating and writing. Quite unique in the Linux world.
The project components (list subject to growth, hopefully): The project components (list subject to growth, hopefully):
- libburn is the library by which preformatted data get onto optical media. - libburn is the library by which preformatted data get onto optical media.
It uses either /dev/sgN (e.g. on kernel 2.4 with ide-scsi) or It uses either /dev/sgN (e.g. on kernel 2.4 with ide-scsi) or
/dev/srM or /dev/hdX (e.g. on kernel 2.6). /dev/hdX (e.g. on kernel 2.6).
libburn is the foundation of our cdrecord emulation. Its code is libburn is the foundation of our cdrecord emulation. Its code is
independent of cdrecord. Its DVD capabilities are learned from independent of cdrecord. Its DVD capabilities are learned from
studying the code of dvd+rw-tools and MMC-5 specs. No code but only studying the code of dvd+rw-tools and MMC-5 specs. No code but only
the pure SCSI knowledge has been taken from dvd+rw-tools, though. the pure SCSI knowledge has been taken from dvd+rw-tools, though.
- libisofs is the library to pack up hard disk files and directories into a - libisofs is the library to pack up hard disk files and directories into a
ISO 9660 disk image. This may then be brought to CD via libburn. ISO 9660 disk image. This may then be brought to media via libburn.
libisofs is to be the foundation of our upcoming mkisofs emulation. libisofs is to be the foundation of our upcoming mkisofs emulation.
- libisoburn is an add-on to libburn and libisofs which coordinates both and
also allows to grow ISO-9660 filesystem images on multi-session
media as well as on overwriteable media via the same API.
All media peculiarities are handled automatically.
- cdrskin is a limited cdrecord compatibility wrapper for libburn. - cdrskin is a limited cdrecord compatibility wrapper for libburn.
cdrecord is a powerful GPL'ed burn program included in Joerg Cdrecord is a powerful GPL'ed burn program included in Joerg
Schilling's cdrtools. cdrskin strives to be a second source for Schilling's cdrtools. cdrskin strives to be a second source for
the services traditionally provided by cdrecord. Additionally it the services traditionally provided by cdrecord. Additionally it
provides libburn's DVD capabilities, where only -sao is compatible provides libburn's DVD capabilities, where only -sao is compatible
@ -113,34 +97,14 @@ The project components (list subject to growth, hopefully):
cdrskin does not contain any bytes copied from cdrecord's sources. cdrskin does not contain any bytes copied from cdrecord's sources.
Many bytes have been copied from the message output of cdrecord Many bytes have been copied from the message output of cdrecord
runs, though. runs, though.
See cdrskin/README for more. See cdrskin/README and man cdrskin/cdrskin.1 for more.
- xorriso is an application of all three libraries which creates, loads, - test is a collection of application gestures and examples given by the
manipulates and writes ISO 9660 filesystem images with authors of the library features. The main API example for libburn
Rock Ridge extensions. Manipulation is not only adding or is test/libburner.c .
overwriting of files but also deletion, renaming, and attribute
changing.
See xorriso/README for more.
- "test" is a collection of application gestures and examples given by the
authors of the library features. The burn API example of libburn
is named test/libburner.c . The API for media information inquiry is
demonstrated in test/telltoc.c .
Explore these examples if you look for inspiration. Explore these examples if you look for inspiration.
We strive to be a responsive upstream. We plan to be a responsive upstream. Bear with us. We are still practicing.
Our libraries are committed to maintain older feature sets in newer versions.
This applies to source code headers (API) as well as to linkable objects (ABI).
The only exception from this rule is about non-release versions x.y.*[13579]
which are allowed to introduce new features, change those new features in
any way and even may revoke such new features before the next release of
x.y.*[02468]. As soon as it is released, a feature is promised to persist.
SONAMES:
libburn.so.4 (since 0.3.4, March 2007),
libisofs.so.6 (since 0.6.2, February 2008),
libisoburn.so.1 (since 0.1.0, February 2008).
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
@ -251,19 +215,6 @@ Project history as far as known to me:
cdrskin now is by default linked dynamically and does a runtime check cdrskin now is by default linked dynamically and does a runtime check
to ensure not to be started with a libburn which is older than itself. to ensure not to be started with a libburn which is older than itself.
- 3rd Feb 2008 libisofs-0.2.x (.so.5) has been deprecated.
- 14th Feb 2008 libisofs-0.6.2 permanently replaces the old libisofs-0.2.x.
It is the first release of new libisofs.so.6 which will guarantee future
API/ABI compatibility for its whole feature set.
- 15th Feb 2008 libisoburn-0.1.0 (.so.1) coordinates libisofs and libburn for
the purpose of ISO image reading and writing. It emulates multi-session on
overwriteable media. Application xorriso makes use of all three libraries.
- 8th Apr 2008 libburn-0.4.4 has proven to be capable of burning to DVD+R/DL
and read performance on disk file pseudo-drives has been improved.
------------------------------------------------------------------------------ ------------------------------------------------------------------------------

View File

@ -4,7 +4,7 @@
cdrskin. By Thomas Schmitt <scdbackup@gmx.net> cdrskin. By Thomas Schmitt <scdbackup@gmx.net>
Integrated sub project of libburnia-project.org but also published via: Integrated sub project of libburnia-project.org but also published via:
http://scdbackup.sourceforge.net/cdrskin_eng.html http://scdbackup.sourceforge.net/cdrskin_eng.html
http://scdbackup.sourceforge.net/cdrskin-0.4.4.pl00.tar.gz http://scdbackup.sourceforge.net/cdrskin-0.4.2.tar.gz
Copyright (C) 2006-2008 Thomas Schmitt, provided under GPL version 2. Copyright (C) 2006-2008 Thomas Schmitt, provided under GPL version 2.
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
@ -20,10 +20,10 @@ By using this software you agree to the disclaimer at the end of this text
Compilation, First Glimpse, Installation Compilation, First Glimpse, Installation
Obtain cdrskin-0.4.4.pl00.tar.gz, take it to a directory of your choice and do: Obtain cdrskin-0.4.2.tar.gz, take it to a directory of your choice and do:
tar xzf cdrskin-0.4.4.pl00.tar.gz tar xzf cdrskin-0.4.2.tar.gz
cd cdrskin-0.4.4 cd cdrskin-0.4.2
Within that directory execute: Within that directory execute:
@ -48,12 +48,8 @@ Version identification and help texts available afterwards:
Install (eventually as superuser) cdrskin to a directory where it can be found: Install (eventually as superuser) cdrskin to a directory where it can be found:
The command for global installation of both, libburn and cdrskin is The command for global installation of both, libburn and cdrskin is
make install make install
If the library libburn.so.4 is not found with a test run of cdrskin, then
try whether command
ldconfig
makes it accessible. With the statically linked binary this should not matter.
You may as well do the few necessary actions manually. If cdrskin was But you may as well do the few necessary actions manually. If cdrskin was
already installed by a previous version, or by "make install" in the course already installed by a previous version, or by "make install" in the course
of this installation, then find out where: of this installation, then find out where:
which cdrskin which cdrskin
@ -152,7 +148,7 @@ Burn image file my_image.iso to media
cdrskin -v dev=0,1,0 speed=12 fs=8m driveropts=burnfree padsize=300k \ cdrskin -v dev=0,1,0 speed=12 fs=8m driveropts=burnfree padsize=300k \
-eject my_image.iso -eject my_image.iso
Write multi-session to the same CD , DVD-R[W] or DVD+R[/DL] Write multi-session to the same CD , DVD-R[W] or DVD+R
cdrskin dev=/dev/hdc padsize=300k -multi 1.iso cdrskin dev=/dev/hdc padsize=300k -multi 1.iso
cdrskin dev=/dev/hdc padsize=300k -multi -tao 2.iso cdrskin dev=/dev/hdc padsize=300k -multi -tao 2.iso
cdrskin dev=/dev/hdc padsize=300k -multi -tao 3.iso cdrskin dev=/dev/hdc padsize=300k -multi -tao 3.iso
@ -341,13 +337,10 @@ Incremental Streaming afterwards. So blank=fast will do full blanking.
blank=deformat_sequential_quickest is faster but might yield DAO-only media. blank=deformat_sequential_quickest is faster but might yield DAO-only media.
DVD+R and DVD+R/DL DVD+R
From the view of cdrskin they behave much like DVD-R. Each track gets wrapped From the view of cdrskin they behave much like DVD-R. Each track gets wrapped
into an own session, though. into an own session, though.
DVD+R/DL appear as extra large DVD+R. cdrskin does not allow to set the address
of the layer break where ia reading drive might show some delay while switching
between both media layers.
Emulated Drives Emulated Drives

View File

@ -38,7 +38,7 @@ original="./libburn_svn_release.tgz"
# My changes are in $changes , mainly in $changes/cdrskin # My changes are in $changes , mainly in $changes/cdrskin
changes="./libburn-release" changes="./libburn-release"
skin_release="0.4.4" skin_release="0.4.2"
patch_level=".pl00" patch_level=".pl00"
skin_rev="$skin_release""$patch_level" skin_rev="$skin_release""$patch_level"

View File

@ -38,7 +38,7 @@ original="./libburn_svn.tgz"
# My changes are in $changes , mainly in $changes/cdrskin # My changes are in $changes , mainly in $changes/cdrskin
changes="./libburn-develop" changes="./libburn-develop"
skin_release="0.4.5" skin_release="0.4.3"
patch_level="" patch_level=""
skin_rev="$skin_release""$patch_level" skin_rev="$skin_release""$patch_level"

View File

@ -16,8 +16,8 @@
.\" .sp <n> insert n+1 empty lines .\" .sp <n> insert n+1 empty lines
.\" for manpage-specific macros, see man(7) .\" for manpage-specific macros, see man(7)
.SH NAME .SH NAME
cdrskin \- burns preformatted data to CD-R[W], DVD-R[W], DVD+R[W], DVD+R/DL, cdrskin \- burns preformatted data to CD-R[W], DVD-R[W], DVD+R[W], DVD-RAM
DVD-RAM via libburn. via libburn.
.SH SYNOPSIS .SH SYNOPSIS
.B cdrskin .B cdrskin
.RI [ options | track_source_addresses ] .RI [ options | track_source_addresses ]
@ -44,7 +44,7 @@ or in Session at Once mode for seamless tracks.
.br .br
Multi session on CD (follow-up sessions in TAO only) Multi session on CD (follow-up sessions in TAO only)
.br .br
or on DVD-R[W] (in Incremental mode) or on DVD+R[/DL]. or on DVD-R[W] (in Incremental mode) or on DVD+R.
.br .br
Single session on DVD-RW or DVD-R (Disk-at-once). Single session on DVD-RW or DVD-R (Disk-at-once).
.br .br
@ -163,7 +163,7 @@ Multiple cycles of blanking and overwriting with random numbers might be.
.SS .SS
.B Sequentially Recordable DVD Media: .B Sequentially Recordable DVD Media:
.br .br
Currently DVD-RW, DVD-R and DVD+R[/DL] can be used for the Sequential recording Currently DVD-RW, DVD-R and DVD+R can be used for the Sequential recording
model. model.
.br .br
DVD-RW must be in state "Sequential Recording". DVD-RW must be in state "Sequential Recording".
@ -198,9 +198,9 @@ unpredicted length and to keep media appendable by option
The only restriction towards CD-R[W] is the lack of support for -audio tracks. The only restriction towards CD-R[W] is the lack of support for -audio tracks.
Multiple tracks per session are permissible. Multiple tracks per session are permissible.
.br .br
The write modes for DVD+R[/DL] resemble those with DVD-R except that with +R The write modes for DVD+R resemble those with DVD-R except that with DVD+R
each track gets wrapped in an own session. There is no -dummy writing with each track gets wrapped in an own session. There is no -dummy writing with
DVD+R[/DL]. DVD+R.
.br .br
Quite deliberately write mode -sao insists in the tradition of a predicted Quite deliberately write mode -sao insists in the tradition of a predicted
track size and blank media, whereas -tao writes the tracks open ended and track size and blank media, whereas -tao writes the tracks open ended and
@ -598,7 +598,7 @@ One should use it only if inavoidable.
.TP .TP
.BI \-sao .BI \-sao
Write CD in Session At Once mode, a sequential DVD-R[W] in Disc-at-once Write CD in Session At Once mode, a sequential DVD-R[W] in Disc-at-once
(DAO) mode, or a DVD+R[/DL]. (DAO) mode, or a DVD+R.
.br .br
With CD this mode is able to put several audio tracks on media without With CD this mode is able to put several audio tracks on media without
producing audible gaps between them. producing audible gaps between them.
@ -606,8 +606,8 @@ producing audible gaps between them.
With DVD-R[W] this mode can only write a single track. With DVD-R[W] this mode can only write a single track.
No -multi is allowed with DVD-R[W] -sao. No -multi is allowed with DVD-R[W] -sao.
.br .br
-sao is permissible with overwriteable DVD and with DVD+R[/DL] but actually -sao is permissible with overwriteable DVD and with DVD+R but actually only
only imposes restrictions without providing known advantages. imposes restrictions without providing known advantages.
.br .br
-sao can only be used for tracks of fixely predicted size. This implies that -sao can only be used for tracks of fixely predicted size. This implies that
track arguments which depict stdin or named pipes need to be preceeded by track arguments which depict stdin or named pipes need to be preceeded by
@ -647,7 +647,7 @@ suffix ".wav".
.TP .TP
.BI \-tao .BI \-tao
Write CD in Track At Once (TAO) mode, sequential DVD-R[W] in Incremental Write CD in Track At Once (TAO) mode, sequential DVD-R[W] in Incremental
Streaming mode, or DVD+R[/DL] without traditional -sao restrictions. Streaming mode, or DVD+R without traditional -sao restrictions.
This mode also applies pro-forma to overwriteable DVD media. This mode also applies pro-forma to overwriteable DVD media.
.br .br
Mode -tao can be used with track sources of unpredictable size, like standard Mode -tao can be used with track sources of unpredictable size, like standard
@ -951,7 +951,7 @@ tested. Currently this applies to :
.br .br
Profile 0015h , DVD-R/DL Sequential (will not allow -multi). Profile 0015h , DVD-R/DL Sequential (will not allow -multi).
.br .br
Profile 0043h , BD-RE. Profile 002Bh , DVD+R/DL.
.br .br
If you really test such media, then please report the outcome on If you really test such media, then please report the outcome on
libburn-hackers@pykix.org libburn-hackers@pykix.org
@ -1131,7 +1131,7 @@ cdrskin -v dev=0,1,0 fs=32m speed=8 \\
.br .br
-tao padsize=300k - -tao padsize=300k -
.SS .SS
.B Write multi-session to the same CD, DVD-R[W] or DVD+R[/DL]: .B Write multi-session to the same CD, DVD-R[W] or DVD+R:
.br .br
cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 1.iso cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 1.iso
.br .br

View File

@ -88,7 +88,7 @@ or
/** The official program version */ /** The official program version */
#ifndef Cdrskin_prog_versioN #ifndef Cdrskin_prog_versioN
#define Cdrskin_prog_versioN "0.4.4" #define Cdrskin_prog_versioN "0.4.2"
#endif #endif
/** The official libburn interface revision to use. /** The official libburn interface revision to use.
@ -101,7 +101,7 @@ or
#define Cdrskin_libburn_minoR 4 #define Cdrskin_libburn_minoR 4
#endif #endif
#ifndef Cdrskin_libburn_micrO #ifndef Cdrskin_libburn_micrO
#define Cdrskin_libburn_micrO 4 #define Cdrskin_libburn_micrO 2
#endif #endif
@ -135,44 +135,44 @@ or
#endif /* Cdrskin_libburn_cvs_A60220_tS */ #endif /* Cdrskin_libburn_cvs_A60220_tS */
#ifdef Cdrskin_libburn_0_4_4 #ifdef Cdrskin_libburn_0_4_2
#define Cdrskin_libburn_versioN "0.4.4" #define Cdrskin_libburn_versioN "0.4.2"
#define Cdrskin_libburn_from_pykix_svN 1 #define Cdrskin_libburn_from_pykix_svN 1
#endif /* Cdrskin_libburn_0_4_2 */ #endif /* Cdrskin_libburn_0_4_2 */
#ifdef Cdrskin_libburn_0_4_5 #ifdef Cdrskin_libburn_0_4_3
#define Cdrskin_libburn_versioN "0.4.5" #define Cdrskin_libburn_versioN "0.4.3"
#define Cdrskin_libburn_from_pykix_svN 1 #define Cdrskin_libburn_from_pykix_svN 1
/* Place novelty switch macros here. /* Place novelty switch macros here.
Move them down to Cdrskin_libburn_from_pykix_svN on version leap Move them down to Cdrskin_libburn_from_pykix_svN on version leap
*/ */
/* there are no novelties in 0.4.5 yet */ /* there are no novelties in 0.4.3 yet */
#endif /* Cdrskin_libburn_0_4_5 */ #endif /* Cdrskin_libburn_0_4_3 */
#ifndef Cdrskin_libburn_versioN #ifndef Cdrskin_libburn_versioN
#define Cdrskin_libburn_0_4_4 #define Cdrskin_libburn_0_4_2
#define Cdrskin_libburn_versioN "0.4.4" #define Cdrskin_libburn_versioN "0.4.2"
#define Cdrskin_libburn_from_pykix_svN 1 #define Cdrskin_libburn_from_pykix_svN 1
#endif #endif
#ifdef Cdrskin_libburn_0_4_4 #ifdef Cdrskin_libburn_0_4_2
#undef Cdrskin_libburn_majoR #undef Cdrskin_libburn_majoR
#undef Cdrskin_libburn_minoR #undef Cdrskin_libburn_minoR
#undef Cdrskin_libburn_micrO #undef Cdrskin_libburn_micrO
#define Cdrskin_libburn_majoR 0 #define Cdrskin_libburn_majoR 0
#define Cdrskin_libburn_minoR 4 #define Cdrskin_libburn_minoR 4
#define Cdrskin_libburn_micrO 4 #define Cdrskin_libburn_micrO 2
#endif #endif
#ifdef Cdrskin_libburn_0_4_5 #ifdef Cdrskin_libburn_0_4_3
#undef Cdrskin_libburn_majoR #undef Cdrskin_libburn_majoR
#undef Cdrskin_libburn_minoR #undef Cdrskin_libburn_minoR
#undef Cdrskin_libburn_micrO #undef Cdrskin_libburn_micrO
#define Cdrskin_libburn_majoR 0 #define Cdrskin_libburn_majoR 0
#define Cdrskin_libburn_minoR 4 #define Cdrskin_libburn_minoR 4
#define Cdrskin_libburn_micrO 5 #define Cdrskin_libburn_micrO 3
#endif #endif
@ -242,8 +242,6 @@ or
/* 0.4.2 */ /* 0.4.2 */
/* no novel features but rather organizational changes */ /* no novel features but rather organizational changes */
/* 0.4.4 */
/* support for DVD+R/DL media is now official, BD-RE is experimental */
#ifdef Cdrskin_new_api_tesT #ifdef Cdrskin_new_api_tesT
@ -1911,53 +1909,19 @@ int Cdrpreskin_initialize_lib(struct CdrpreskiN *preskin, int flag)
{ {
int ret, major, minor, micro; int ret, major, minor, micro;
/* This is the minimum requirement of cdrskin towards the libburn header
at compile time.
It gets compared against the version macros in libburn/libburn.h :
burn_header_version_major
burn_header_version_minor
burn_header_version_micro
If the header is too old then the following code shall cause failure of
cdrskin compilation rather than to allow production of a program with
unpredictable bugs or memory corruption.
The compiler message supposed to appear in this case is:
error: 'LIBBURN_MISCONFIGURATION' undeclared (first use in this function)
error: 'INTENTIONAL_ABORT_OF_COMPILATION__HEADERFILE_libburn_dot_h_TOO_OLD__SEE_cdrskin_dot_c' undeclared (first use in this function)
error: 'LIBBURN_MISCONFIGURATION_' undeclared (first use in this function)
*/
/* The indendation is an advise of man gcc to help old compilers ignoring */
#if Cdrskin_libburn_majoR > burn_header_version_major
#define Cdrskin_libburn_dot_h_too_olD 1
#endif
#if Cdrskin_libburn_majoR == burn_header_version_major && Cdrskin_libburn_minoR > burn_header_version_minor
#define Cdrskin_libburn_dot_h_too_olD 1
#endif
#if Cdrskin_libburn_minoR == burn_header_version_minor && Cdrskin_libburn_micrO > burn_header_version_micro
#define Cdrskin_libburn_dot_h_too_olD 1
#endif
#ifdef Cdrskin_libburn_dot_h_too_olD
LIBBURN_MISCONFIGURATION = 0;
INTENTIONAL_ABORT_OF_COMPILATION__HEADERFILE_libburn_dot_h_TOO_OLD__SEE_cdrskin_dot_c = 0;
LIBBURN_MISCONFIGURATION_ = 0;
#endif
ret= burn_initialize(); ret= burn_initialize();
if(ret==0) { if(ret==0) {
fprintf(stderr,"cdrskin: FATAL : Initialization of libburn failed\n"); fprintf(stderr,"cdrskin: FATAL : Initialization of libburn failed\n");
return(0); return(0);
} }
/* This is the runtime check towards eventual dynamically linked libburn.
cdrskin deliberately does not to allow the library to be older than
the header file which was seen at compile time. More liberal would be
to use here Cdrskin_libburn_* instead of burn_header_version_* .
*/
burn_version(&major, &minor, &micro); burn_version(&major, &minor, &micro);
if(major<burn_header_version_major ||
(major==burn_header_version_major && (minor<burn_header_version_minor || /* <<< for testing only */
(minor==burn_header_version_minor && micro<burn_header_version_micro)))) { /* major= 0; minor= 3; micro= 6; */
if(major<Cdrskin_libburn_majoR ||
(major==Cdrskin_libburn_majoR && (minor<Cdrskin_libburn_minoR ||
(minor==Cdrskin_libburn_minoR && micro<Cdrskin_libburn_micrO)))) {
fprintf(stderr,"cdrskin: FATAL : libburn version too old: %d.%d.%d . Need at least: %d.%d.%d .\n", fprintf(stderr,"cdrskin: FATAL : libburn version too old: %d.%d.%d . Need at least: %d.%d.%d .\n",
major, minor, micro, major, minor, micro,
Cdrskin_libburn_majoR, Cdrskin_libburn_minoR, Cdrskin_libburn_micrO); Cdrskin_libburn_majoR, Cdrskin_libburn_minoR, Cdrskin_libburn_micrO);
@ -2588,7 +2552,7 @@ set_dev:;
printf("\n"); printf("\n");
printf("Usage: %s [options|source_addresses]\n", argv[0]); printf("Usage: %s [options|source_addresses]\n", argv[0]);
printf("Burns preformatted data to CD or DVD via libburn.\n"); printf("Burns preformatted data to CD-R, CD-RW or DVD+RW via libburn.\n");
printf("For the cdrecord compatible options which control the work of\n"); printf("For the cdrecord compatible options which control the work of\n");
printf( printf(
"blanking and burning see output of option -help rather than --help.\n"); "blanking and burning see output of option -help rather than --help.\n");
@ -2863,9 +2827,7 @@ set_severities:;
printf( printf(
"Cdrecord 2.01-Emulation Copyright (C) 2006-2008, see libburnia-project.org\n"); "Cdrecord 2.01-Emulation Copyright (C) 2006-2008, see libburnia-project.org\n");
printf("libburn interface : %d.%d.%d\n", printf("libburn interface : %s\n",Cdrskin_libburn_versioN);
burn_header_version_major, burn_header_version_minor,
burn_header_version_micro);
burn_version(&major, &minor, &micro); burn_version(&major, &minor, &micro);
printf("libburn in use : %d.%d.%d\n", major, minor, micro); printf("libburn in use : %d.%d.%d\n", major, minor, micro);

View File

@ -2,7 +2,7 @@
<HEAD> <HEAD>
<META NAME="description" CONTENT="cdrskin, a limited cdrecord compatibility wrapper for libburn"> <META NAME="description" CONTENT="cdrskin, a limited cdrecord compatibility wrapper for libburn">
<META NAME="keywords" CONTENT="cdrskin, libburn, libburnia, burn, CD, DVD, linux, recording, burning, CD-R, CD-RW, DVD-R, DVD-RW, DVD+RW, DVD+R, DVD+R/DL, DVD-RAM, cdrecord, compatible, scdbackup"> <META NAME="keywords" CONTENT="cdrskin, libburn, libburnia, burn, CD, DVD, linux, recording, burning, CD-R, CD-RW, DVD-R, DVD-RW, DVD+RW, DVD+R, cdrecord, compatible, scdbackup">
<META NAME="robots" CONTENT="follow"> <META NAME="robots" CONTENT="follow">
<TITLE>cdrskin homepage english</TITLE> <TITLE>cdrskin homepage english</TITLE>
</HEAD> </HEAD>
@ -24,8 +24,8 @@
<P> <P>
<H2>Purpose:</H2> <H2>Purpose:</H2>
Burns preformatted data to CD and DVD media:<BR> Burns preformatted data to CD and single layer DVD media:<BR>
CD-R, DVD-R, DVD+R, DVD+R/DL, CD-RW, DVD-RW, DVD-RAM, DVD+RW CD-R, DVD-R, DVD+R, CD-RW, DVD-RW, DVD-RAM, DVD+RW
</P> </P>
<P> <P>
@ -56,7 +56,7 @@ and to MMC-5 for DVD).
GPL software included:<BR> GPL software included:<BR>
</H2> </H2>
<DL> <DL>
<DT>libburn-0.4.4</DT> <DT>libburn-0.4.2</DT>
<DD>(founded by Derek Foreman and Ben Jansens, <DD>(founded by Derek Foreman and Ben Jansens,
furthered by team of libburnia-project.org)</DD> furthered by team of libburnia-project.org)</DD>
<DD>transfers data to CD and DVD</DD> <DD>transfers data to CD and DVD</DD>
@ -125,7 +125,7 @@ as listed by option --devices.</DT>
<DD><KBD>&nbsp;&nbsp;cdrskin -v dev=0,1,0 fs=32m speed=8 \</KBD></DD> <DD><KBD>&nbsp;&nbsp;cdrskin -v dev=0,1,0 fs=32m speed=8 \</KBD></DD>
<DD><KBD>&nbsp;&nbsp;-tao padsize=300k -</KBD></DD> <DD><KBD>&nbsp;&nbsp;-tao padsize=300k -</KBD></DD>
<DT>Write several sessions to the same CD, DVD-R[W] or DVD+R[/DL]:</DT> <DT>Write several sessions to the same CD, DVD-R[W] or DVD+R:</DT>
<DD>$<KBD>&nbsp;cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 1.iso</KBD> <DD>$<KBD>&nbsp;cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 1.iso</KBD>
</DD> </DD>
<DD>$<KBD>&nbsp;cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 2.iso</KBD> <DD>$<KBD>&nbsp;cdrskin dev=/dev/hdc -v padsize=300k -multi -tao 2.iso</KBD>
@ -166,16 +166,8 @@ man cdrecord</A></KBD></DD>
this "don't bother Joerg" demand.) this "don't bother Joerg" demand.)
</DD> </DD>
</DL> </DL>
<DL>
<DT>Learn to know a more versatile way to burn ISO 9660 formatted data</DT>
<DD>
Standalone ISO 9660 multi-session CD/DVD tool
<A HREF="http://scdbackup.sourceforge.net/xorriso_eng.html">xorriso</A>.
</DD>
</DL>
Testers wanted who are willing to risk some double layer DVD-R media Testers wanted who are willing to risk some double layer DVD media.
or to do experiments on BD-RE.
</P> </P>
@ -184,8 +176,8 @@ or to do experiments on BD-RE.
<P> <P>
<DL> <DL>
<DT>Download as source code (see README):</DT> <DT>Download as source code (see README):</DT>
<DD><A HREF="cdrskin-0.4.4.pl00.tar.gz">cdrskin-0.4.4.pl00.tar.gz</A> <DD><A HREF="cdrskin-0.4.2.pl00.tar.gz">cdrskin-0.4.2.pl00.tar.gz</A>
(715 KB). (700 KB).
</DD> </DD>
<DD> <DD>
The cdrskin tarballs are source code identical with libburn releases The cdrskin tarballs are source code identical with libburn releases
@ -193,8 +185,6 @@ of the same version number.
They get produced via a different procedure, though.<BR> They get produced via a different procedure, though.<BR>
cdrskin is part of libburn - full libburn is provided with cdrskin releases. cdrskin is part of libburn - full libburn is provided with cdrskin releases.
</DD> </DD>
<!-- This is not offered any more for 0.4.4 and 0.4.5
<DD>&nbsp;</DD> <DD>&nbsp;</DD>
<DT>Download as single x86 binaries (untar and move to /usr/bin/cdrskin):</DT> <DT>Download as single x86 binaries (untar and move to /usr/bin/cdrskin):</DT>
<DD><A HREF="cdrskin_0.4.2.pl00-x86-suse9_0.tar.gz"> <DD><A HREF="cdrskin_0.4.2.pl00-x86-suse9_0.tar.gz">
@ -209,9 +199,6 @@ cdrskin_0.4.2.pl00-x86-suse9_0-static.tar.gz</A>, (310 KB), -static compiled,
<DD>runs on SuSE 7.2 (2.4.4), and on the systems above.</DD> <DD>runs on SuSE 7.2 (2.4.4), and on the systems above.</DD>
</DL> </DL>
</DD> </DD>
-->
</DL> </DL>
<DL><DT>Documentation:</DT> <DL><DT>Documentation:</DT>
<DD><A HREF="README_cdrskin">README</A> an introduction</DD> <DD><A HREF="README_cdrskin">README</A> an introduction</DD>
@ -234,10 +221,9 @@ cdrskin_0.4.2.pl00-x86-suse9_0-static.tar.gz</A>, (310 KB), -static compiled,
<HR> <HR>
<P> <P>
Enhancements towards previous stable version cdrskin-0.4.2: Enhancements towards previous stable version cdrskin-0.4.0:
<UL> <UL>
<LI>Support for DVD+R/DL media is now official</LI> <LI>Safe dynamic linking possible with libburn.so.4</LI>
<LI>Experimental code for BD-RE with --allow_untested_media</LI>
</UL> </UL>
<!-- <!--
@ -253,25 +239,25 @@ Enhancements towards previous stable version cdrskin-0.4.2:
<P> <P>
<DL> <DL>
<DT><H3>Development snapshot, version 0.4.5 :</H3></DT> <DT><H3>Development snapshot, version 0.4.3 :</H3></DT>
<DD>Enhancements towards stable version 0.4.4.pl00: <DD>Enhancements towards stable version 0.4.2.pl00:
<UL> <UL>
<LI>none yet</LI>
<!-- <!--
--> -->
<LI>none yet</LI>
</UL> </UL>
</DD> </DD>
<DD>&nbsp;</DD> <DD>&nbsp;</DD>
<DD><A HREF="README_cdrskin_devel">README 0.4.5</A> <DD><A HREF="README_cdrskin_devel">README 0.4.3</A>
<DD><A HREF="cdrskin__help_devel">cdrskin_0.4.5 --help</A></DD> <DD><A HREF="cdrskin__help_devel">cdrskin_0.4.3 --help</A></DD>
<DD><A HREF="cdrskin_help_devel">cdrskin_0.4.5 -help</A></DD> <DD><A HREF="cdrskin_help_devel">cdrskin_0.4.3 -help</A></DD>
<DD><A HREF="man_1_cdrskin_devel.html">man cdrskin (as of 0.4.5)</A></DD> <DD><A HREF="man_1_cdrskin_devel.html">man cdrskin (as of 0.4.3)</A></DD>
<DD>&nbsp;</DD> <DD>&nbsp;</DD>
<DT>Maintainers of cdrskin unstable packages please use SVN of <DT>Maintainers of cdrskin unstable packages please use SVN of
<A HREF="http://libburnia-project.org"> libburnia-project.org</A></DT> <A HREF="http://libburnia-project.org"> libburnia-project.org</A></DT>
<DD>Download: <KBD><B>svn co http://svn.libburnia-project.org/libburn/trunk libburn</B> <DD>Download: <KBD><B>svn co http://svn.libburnia-project.org/libburn/trunk libburn</B>
</KBD></DD> </KBD></DD>
<DD>Build: <KBD><B>cd libburn ; ./bootstrap ; ./configure --prefix /usr ; make ; cdrskin/compile_cdrskin.sh</B> <DD>Build: <KBD><B>cd libburn ; ./bootstrap ; ./configure --prefix /usr ; make</B>
</KBD></DD> </KBD></DD>
<DD>Build of SVN versions needs <A HREF="http://sources.redhat.com/autobook/"> <DD>Build of SVN versions needs <A HREF="http://sources.redhat.com/autobook/">
autotools</A> of at least version 1.7 installed. autotools</A> of at least version 1.7 installed.
@ -279,20 +265,15 @@ But after the run of <KBD>./bootstrap</KBD>, only
vanilla tools like make and gcc are needed.</DD> vanilla tools like make and gcc are needed.</DD>
</DD> </DD>
<DD>&nbsp;</DD> <DD>&nbsp;</DD>
<DT>The following download is intended for adventurous end users or <DT>The following downloads are intended for adventurous end users or
admins with full system souvereignty.</DT> admins with full system souvereignty.</DT>
<DD>Source (./bootstrap is already applied, build tested, for more see <DD>Source (./bootstrap is already applied, build tested, for more see
<A HREF="README_cdrskin_devel">upcoming README</A> ): <A HREF="README_cdrskin_devel">upcoming README</A> ):
</DD> </DD>
<DD> <DD>
<A HREF="cdrskin-0.4.5.tar.gz">cdrskin-0.4.5.tar.gz</A> <A HREF="cdrskin-0.4.3.tar.gz">cdrskin-0.4.3.tar.gz</A>
(715 KB). (700 KB).
</DD> </DD>
<!-- This is not offered any more for 0.4.4 and 0.4.5
<DT>The following downloads are intended for adventurous end users or
admins with full system souvereignty.</DT>
<DD>Binary (untar and move to /usr/bin/cdrskin):</DD> <DD>Binary (untar and move to /usr/bin/cdrskin):</DD>
<DD><A HREF="cdrskin_0.4.3-x86-suse9_0.tar.gz"> <DD><A HREF="cdrskin_0.4.3-x86-suse9_0.tar.gz">
cdrskin_0.4.3-x86-suse9_0.tar.gz</A>, (110 KB). cdrskin_0.4.3-x86-suse9_0.tar.gz</A>, (110 KB).
@ -300,8 +281,6 @@ cdrskin_0.4.3-x86-suse9_0.tar.gz</A>, (110 KB).
<DD><A HREF="cdrskin_0.4.3-x86-suse9_0-static.tar.gz"> <DD><A HREF="cdrskin_0.4.3-x86-suse9_0-static.tar.gz">
cdrskin_0.4.3-x86-suse9_0-static.tar.gz</A>, (310 KB) cdrskin_0.4.3-x86-suse9_0-static.tar.gz</A>, (310 KB)
</DD> </DD>
-->
</DL> </DL>
</P> </P>
@ -349,8 +328,6 @@ Example how to setup K3b to use cdrskin for burning data CD projects.
is a GUI frontend which uses cdrecord for CD burning.) is a GUI frontend which uses cdrecord for CD burning.)
</P> </P>
<!--
<HR> <HR>
<A NAME="scdbackup"> <A NAME="scdbackup">
@ -405,8 +382,6 @@ and try again.
</DL> </DL>
</P> </P>
-->
<HR> <HR>
<A NAME="cdrecord"> <A NAME="cdrecord">
@ -466,25 +441,13 @@ and by <A HREF="http://sourceforge.net">sourceforge.net</A><BR>
<HR> <HR>
<DL> <DL>
<DT>Links to my other published software projects : <DT>Links to my other published software projects :
<DD><A HREF="http://scdbackup.webframe.org/xorriso_eng.html">
xorriso, a standalone ISO 9660 multi-session CD/DVD burn tool.
No mkisofs needed.
<DL>
<DD>
<A HREF="http://scdbackup.sourceforge.net/xorriso_eng.html">
(a second source of above)</A>
</DD>
</DL>
</DD>
<DD><A HREF=http://scdbackup.webframe.org/main_eng.html> <DD><A HREF=http://scdbackup.webframe.org/main_eng.html>
scdbackup, multi volume CD backup</A> scdbackup, multi volume CD backup</A>
<DL><DD><A HREF=http://scdbackup.sourceforge.net/main_eng.html> <DL><DD><A HREF=http://scdbackup.sourceforge.net/main_eng.html>
(a second source of above)</A></DD></DL></DD> (a second source of above)</A></DL>
<DD><A HREF=http://stic.sourceforge.net>Some Tools for Image Collectors</A> <DD><A HREF=http://stic.sourceforge.net>Some Tools for Image Collectors</A>
</DD>
<DD><A HREF=http://scdbackup.webframe.org/pppoem> <DD><A HREF=http://scdbackup.webframe.org/pppoem>
pppoem, a DSL throughput monitor (mainly for Linux kernel 2.4)</A> pppoem, a DSL throughput monitor (mainly for Linux kernel 2.4)</A>
</DD>
</DL> </DL>
<BR><BR> <BR><BR>
Legal statement: This website does not serve any commercial purpose.<BR> Legal statement: This website does not serve any commercial purpose.<BR>

View File

@ -1 +1 @@
#define Cdrskin_timestamP "2008.04.08.100001" #define Cdrskin_timestamP "2008.02.01.100001"

View File

@ -5037,197 +5037,14 @@ Updated changelog before release
----------------------------- release - cdrskin-0.4.2.pl00 - 2008.02.01.100001 ----------------------------- release - cdrskin-0.4.2.pl00 - 2008.02.01.100001
* Safe dynamic linking possible with libburn.so.4 * Safe dynamic linking possible with libburn.so.4
------------------------------------ cycle - cdrskin-0.4.3 - 2008.02.01.225039 ------------------------------------ cycle - cdrskin-0.4.3 - 2008.
2008.02.03.092013 [1463]
libburn/libdax_msgs.h
Registered error code range "libisofs-xorriso"
2008.02.03.092134 [1464]
configure.ac
Incremented LT_* to get libburn.so.4.8.0 (forgot to do 4.7.1 anyway)
2008.02.03.092509 [1465]
libburn/libburn.h
libburn/init.c
New API call burn_sev_to_text()
4 Feb 2008 [1473]
README
Announced deprecation of libisofs-0.2.x, temporory employment of libisofs-0.6.1
2008.02.04.175209 [1474]
libburn/libdax_msgs.h
Registered range "libisoburn" 0x00060000 to 0x00006ffff
2008.02.06.174009 [1482]
libburn/libdax_msgs.h
Re-instated range "vreixo" with old and new codes, adjusted severity definitions
2008.02.06.182222 [1483]
libburn/libburn.h
Copied usage discussion about *_header_version_* from libisoburn
2008.02.06.230041 [1488]
libburn/read.c
Installed a simple address logger in burn_read_data
2008.02.07.232820 [1492]
libburn/read.c
Added debug message in case of burn_read_data() return 0
2008.02.08.073414 [1493]
libburn/mmc.c
Allowed DVD +/- DL for reading
2008.02.11.190802 [1518]
libburn/libdax_msgs.h
libburn/libdax_msgs.c
Introduced LIBDAX_MSGS_SEV_MISHAP
2008.02.14.074108 [1522]
libburn/libburn.h
Micro corrections in comment text
14 Feb 2008 [1523]
COPYRIGHT
Updated year
14 Feb 2008 [1524]
cdrskin/README
Pointed to ldconfig
2008.02.16.121102 [1541]
configure.ac
Corrected typo in comment
16 Feb 2008 [1542]
doc/comments
README
cdrskin/wiki_plain.txt
Updated project interrelations
2008.02.21.200956 [1554]
libburn/sg-linux.c
Testwise inquiry of ioctl(CDROM_MEDIA_CHANGED) (disabled by default)
21 Feb 2008 [1555]
test/libburner.c
Directed error message to proper output channel
2008.02.21.201238 [1556]
libburn/libdax_msgs.h
libburn/libdax_msgs.c
Introduced severity ERRFILE
2008.02.21.202216 [1557]
libburn/libdax_msgs.c
Mapped unknown severity text to ALL rather than NEVER
2008.02.21.215250 [1560]
libburn/libdax_msgs.h
Weakened demand to print file path in following message
2008.02.22.150939 [1562]
libburn/libdax_msgs.h
libburn/init.c
New error code 0x00040008
2008.02.22.213527 [1563]
libburn/libdax_msgs.h
libburn/libdax_msgs.c
Imported changes from libiso_msgs.h
2008.02.22.213726 [1564]
libburn/init.c
Changed meaning of unrecognized severity texts from FATAL to ALL
2008.02.28.123152 [1565]
libburn/libburn.h
libburn/spc.c
libburn/mmc.c
libburn/write.c
cdrskin/cdrskin.1
Made support for DVD+R DL official, enabled untested support for BD-RE
2008.02.28.132325 [1586]
libburn/mmc.c
cdrskin/README
cdrskin/cdrskin.c
cdrskin/cdrskin_eng.html
cdrskin/wiki_plain.txt
test/libburner.c
Mentioned support for DVD+R/DL.
------------------------------------ cycle - cdrskin-0.4.3 - 2008.03.01.154319
* Support for DVD+R/DL media is now official
* Experimental code for BD-RE with --allow_untested_media
1 Mar 2008 [1595]
cdrskin/changelog.txt
Updated changelog
2008.03.03.202930 [1598]
libburn/libburn.h
libburn/drive.c
libburn/read.c
Got rid of a cumbersome open-close cycle with burn_read_data() on stdio:
2 Apr 2008 [1654]
COPYRIGHT
Corrected GPL version
------------------------------------ cycle - cdrskin-0.4.3 - 2008.04.07.152331
* libburn: Improved read performance from stdio: pseudo-drives
2008.04.08.100001 [ZeroFourFour 1669]
Makefile.am
configure.ac
README
libburn/libburn.h (burn_header_version_*)
cdrskin/cdrskin.c
cdrskin/README
cdrskin/compile_cdrskin.sh
cdrskin/cdrskin_timestamp.h
cdrskin/wiki_plain.txt
cdrskin/cdrskin_eng.html
doc/comments
Made number transition and activated development documentation
8 Apr 2008 [ZeroFourFour 1670]
- cdrskin/add_ts_changes_to_libburn_0_4_2
- cdrskin/add_ts_changes_to_libburn_0_4_3
+ cdrskin/add_ts_changes_to_libburn_0_4_4
+ cdrskin/add_ts_changes_to_libburn_0_4_5
Updated cdrskin tarball generator
8 Apr 2008 [ZeroFourFour 1671]
cdrskin/changelog.txt
Documented changes and release timestamp
2008.04.08.100001 [ZeroFourFour 1672]
libburn/util.c
Switched from configure.ac versioning to libburn.h versioning
8 Apr 2008 [ZeroFourFour ]
cdrskin/changelog.txt
Documented last minute changes
----------------------------- release - cdrskin-0.4.4.pl00 - 2008.04.08.100001
* Support for DVD+R/DL media is now official
* Experimental code for BD-RE with --allow_untested_media
* libburn: Improved read performance from stdio: pseudo-drives
------------------------------------ cycle - cdrskin-0.4.5 -
------------------------------------ cycle - cdrskin-0.4.5 -
=============================================================================== ===============================================================================
TODO TODO
=============================================================================== ===============================================================================
@since tags
Check all SORRY and FATAL errors whether they should become FAILUREs Check all SORRY and FATAL errors whether they should become FAILUREs
Refuse writing if track size exceeds free media space Refuse writing if track size exceeds free media space

View File

@ -1,13 +1,13 @@
#!/bin/sh #!/bin/sh
# compile_cdrskin.sh # compile_cdrskin.sh
# Copyright 2005 - 2008 Thomas Schmitt, scdbackup@gmx.net, GPL version 2 # Copyright 2005 - 2008 Thomas Schmitt, scdbackup@gmx.net, GPL
# to be executed within ./libburn-* resp ./cdrskin-* # to be executed within ./libburn-* resp ./cdrskin-*
debug_opts="-O2" debug_opts="-O2"
def_opts= def_opts=
largefile_opts="-D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE=1" largefile_opts="-D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE=1"
libvers="-DCdrskin_libburn_0_4_4" libvers="-DCdrskin_libburn_0_4_2"
cleanup_src_or_obj="libburn/cleanup.o" cleanup_src_or_obj="libburn/cleanup.o"
libdax_msgs_o="libburn/libdax_msgs.o" libdax_msgs_o="libburn/libdax_msgs.o"
libdax_audioxtr_o="libburn/libdax_audioxtr.o" libdax_audioxtr_o="libburn/libdax_audioxtr.o"
@ -33,15 +33,15 @@ do
libdax_audioxtr_o= libdax_audioxtr_o=
libdax_msgs_o="libburn/message.o" libdax_msgs_o="libburn/message.o"
cleanup_src_or_obj="-DCleanup_has_no_libburn_os_H cdrskin/cleanup.c" cleanup_src_or_obj="-DCleanup_has_no_libburn_os_H cdrskin/cleanup.c"
elif test "$i" = "-libburn_0_4_4" elif test "$i" = "-libburn_0_4_2"
then then
libvers="-DCdrskin_libburn_0_4_4" libvers="-DCdrskin_libburn_0_4_2"
libdax_audioxtr_o="libburn/libdax_audioxtr.o" libdax_audioxtr_o="libburn/libdax_audioxtr.o"
libdax_msgs_o="libburn/libdax_msgs.o" libdax_msgs_o="libburn/libdax_msgs.o"
cleanup_src_or_obj="libburn/cleanup.o" cleanup_src_or_obj="libburn/cleanup.o"
elif test "$i" = "-libburn_svn" elif test "$i" = "-libburn_svn"
then then
libvers="-DCdrskin_libburn_0_4_5" libvers="-DCdrskin_libburn_0_4_3"
libdax_audioxtr_o="libburn/libdax_audioxtr.o" libdax_audioxtr_o="libburn/libdax_audioxtr.o"
libdax_msgs_o="libburn/libdax_msgs.o" libdax_msgs_o="libburn/libdax_msgs.o"
cleanup_src_or_obj="libburn/cleanup.o" cleanup_src_or_obj="libburn/cleanup.o"
@ -76,7 +76,7 @@ do
echo " -compile_cdrfifo compile program cdrskin/cdrfifo." echo " -compile_cdrfifo compile program cdrskin/cdrfifo."
echo " -compile_dewav compile program test/dewav without libburn." echo " -compile_dewav compile program test/dewav without libburn."
echo " -cvs_A60220 set macro to match libburn-CVS of 20 Feb 2006." echo " -cvs_A60220 set macro to match libburn-CVS of 20 Feb 2006."
echo " -libburn_0_4_4 set macro to match libburn-0.4.4." echo " -libburn_0_4_2 set macro to match libburn-0.4.2."
echo " -libburn_svn set macro to match current libburn-SVN." echo " -libburn_svn set macro to match current libburn-SVN."
echo " -no_largefile do not use 64 bit off_t (must match libburn)." echo " -no_largefile do not use 64 bit off_t (must match libburn)."
echo " -do_not_compile_cdrskin omit compilation of cdrskin/cdrskin." echo " -do_not_compile_cdrskin omit compilation of cdrskin/cdrskin."

View File

@ -16,7 +16,7 @@ manpage="cdrskin"
raw_html=$(pwd)/"cdrskin/raw_man_1_cdrskin.html" raw_html=$(pwd)/"cdrskin/raw_man_1_cdrskin.html"
htmlpage=$(pwd)/"cdrskin/man_1_cdrskin.html" htmlpage=$(pwd)/"cdrskin/man_1_cdrskin.html"
if test -r "$man_dir"/"$manpage".1 if test -r "$manpage"
then then
dummy=dummy dummy=dummy
else else
@ -56,7 +56,7 @@ then
-e 's/^If you only got one CD capable drive/\&nbsp;<BR>If you only got one CD capable drive/' \ -e 's/^If you only got one CD capable drive/\&nbsp;<BR>If you only got one CD capable drive/' \
-e 's/<b>Emulated drives:<\/b>/\&nbsp;<BR><b>Emulated drives:<\/b>/' \ -e 's/<b>Emulated drives:<\/b>/\&nbsp;<BR><b>Emulated drives:<\/b>/' \
-e 's/^Alphabetical list of options/\&nbsp;<BR>Alphabetical list of options/' \ -e 's/^Alphabetical list of options/\&nbsp;<BR>Alphabetical list of options/' \
-e 's/<\/body>/<BR><HR><FONT SIZE=-1><CENTER>(HTML generated from '"$manpage"'.1 on '"$(date)"' by '$(basename "$0")' )<\/CENTER><\/FONT><\/body>/' \ -e 's/and for all others\.<\/td><\/table>/and for all others.<\/td><\/table> <BR><HR><FONT SIZE=-1><CENTER>(HTML generated from '"$manpage"'.1 on '"$(date)"' by '$(basename "$0")' )<\/CENTER><\/FONT>/' \
-e 's/See section FILES/See section <A HREF="#FILES">FILES<\/A>/' \ -e 's/See section FILES/See section <A HREF="#FILES">FILES<\/A>/' \
-e 's/See section EXAMPLES/See section <A HREF="#EXAMPLES">EXAMPLES<\/A>/' \ -e 's/See section EXAMPLES/See section <A HREF="#EXAMPLES">EXAMPLES<\/A>/' \
<"$2" >"$htmlpage" <"$2" >"$htmlpage"

View File

@ -10,7 +10,7 @@ Schilling's cdrtools. cdrskin strives to be a second source for the services
traditionally provided by cdrecord. Currently it does CD-R and CD-RW this way. traditionally provided by cdrecord. Currently it does CD-R and CD-RW this way.
Overwriteable media DVD-RAM, DVD+RW and DVD-RW are handled differently than Overwriteable media DVD-RAM, DVD+RW and DVD-RW are handled differently than
with cdrecord-ProDVD in order to offer TAO-like single track recording. with cdrecord-ProDVD in order to offer TAO-like single track recording.
Sequential DVD-R[W], DVD+R, DVD+R/DL are handled like CD-R[W] with TAO and Sequential DVD-R[W] and DVD+R are handled like CD-R[W] with TAO and
multi-session. Additionally cdrskin offers cdrecord-ProDVD-like mode DAO multi-session. Additionally cdrskin offers cdrecord-ProDVD-like mode DAO
with DVD-R[W]. with DVD-R[W].
@ -23,7 +23,7 @@ About libburn API for burning CD and DVD: http://api.libburnia-project.org
-------------------------------------------------------------------------- --------------------------------------------------------------------------
For yet unsupported media types see the advice to use dvd+rw-tools at For dual layer DVD types see the advice to use dvd+rw-tools at
the end of this text. the end of this text.
-------------------------------------------------------------------------- --------------------------------------------------------------------------
@ -115,9 +115,9 @@ All files used as pseudo-drives have to offer rw-permission.
-------------------------------------------------------------------------- --------------------------------------------------------------------------
The DVD capabilities of cdrskin differ from those of cdrecord-ProDVD. cdrskin The DVD capabilities of cdrskin differ from those of cdrecord-ProDVD. cdrskin
offers TAO-like multi-session with DVD-R[W], DVD+R[/DL] and TAO-like single offers TAO-like multi-session with DVD-R[W], DVD+R and TAO-like single session
session with overwriteable DVD media. It also offers DAO on DVD-R[W] which is with overwriteable DVD media. It also offers DAO on DVD-R[W] which is probably
probably the same as the traditional cdrecord-ProDVD write mode. the same as the traditional cdrecord-ProDVD write mode.
Non-cdrecord blank mode blank=format_overwrite brings a DVD-RW Non-cdrecord blank mode blank=format_overwrite brings a DVD-RW
disc from its initial profile "Sequential Recording" into profile state disc from its initial profile "Sequential Recording" into profile state
@ -268,10 +268,10 @@ for an illustrated example with K3b 0.10 .
DVD advise: DVD advise:
For burning of DVD media other than DVD-RAM, DVD+RW, DVD+R, DVD+R/DL, For burning of DVD media other than DVD-RAM, DVD+RW, DVD+R, DVD-RW, DVD-R,
DVD-RW, DVD-R, the cdrskin project currently advises to use the cdrskin project currently advises to use Andy Polyakov's dvd+rw-tools
Andy Polyakov's dvd+rw-tools which despite their historic name are which despite their historic name are capable of all the media above
capable of all the media above and more, including BD discs. and also do dual layer and even BD discs.
http://fy.chalmers.se/~appro/linux/DVD+RW/tools http://fy.chalmers.se/~appro/linux/DVD+RW/tools
@ -279,27 +279,20 @@ They are not compatible or related to cdrecord resp. cdrecord-ProDVD
(now obsoleted by original source cdrtools cdrecord with identical (now obsoleted by original source cdrtools cdrecord with identical
capabilities besides the license key). capabilities besides the license key).
--------------------------------------------------------------------------
Advanced multi-session use cases:
A special feature of dvd+rw-tools is growing of ISO-9660 filesystems on A special feature of dvd+rw-tools is growing of ISO-9660 filesystems on
overwriteable media. This is not the same as multi-session writing of cdrskin overwriteable media. This is not the same as multi-session writing of cdrskin
with CD media, but retrieves additional information from the existing ISO with CD media, but retrieves additional information from the existing ISO
image and finally manipulates the start sectors of this existing image. image and finally manipulates the start sectors of this existing image.
So, inspired by growisofs, cdrskin can offer DVD multi-session not only with So, inspired by growisofs, cdrskin can offer DVD multi-session not only with
sequential DVD-R[W] and with DVD+R [DL], but also with DVD-RAM, DVD+RW and sequential DVD-R[W] and with DVD+R, but also with DVD-RAM, DVD+RW and
even regular disk files or block devices other than CD/DVD writers. even regular disk files or block devices other than CD/DVD writers.
This is enabled by option --grow_overwriteable_iso. This is enabled by option --grow_overwriteable_iso.
The libburnia project provides an integrated ISO-9660 multi-session tool We are currently preparing an integrated ISO-9660 multi-session tool
named [wiki:Xorriso xorriso] which tries to go one step beyond named [wiki:Xorriso xorriso] which will try to go one step beyond
growisofs. It uses [wiki:Libburn libburn] , [wiki:Libisofs libisofs] growisofs.
and [wiki:Libisoburn libisoburn].
See [http://scdbackup.sourceforge.net/man_1_xorriso.html man xorriso].
-------------------------------------------------------------------------- --------------------------------------------------------------------------

View File

@ -1,4 +1,4 @@
AC_INIT([libburn], [0.4.4], [http://libburnia-project.org]) AC_INIT([libburn], [0.4.2], [http://libburnia-project.org])
AC_PREREQ([2.50]) AC_PREREQ([2.50])
dnl AC_CONFIG_HEADER([config.h]) dnl AC_CONFIG_HEADER([config.h])
@ -57,35 +57,26 @@ dnl Beware of libburn-0.2.6 which had SONAME=6 and is not binary compatible.
dnl Applications for libburn-0.2 to libburn-0.3.1 need recompilation but no dnl Applications for libburn-0.2 to libburn-0.3.1 need recompilation but no
dnl source code changes. dnl source code changes.
dnl dnl
dnl Neatly versioned stable releases meanwhile:
dnl 0.4.2 = libburn.so.4.7.0
dnl 0.4.4 = libburn.so.4.9.0
dnl
dnl So LT_CURRENT, LT_REVISION and LT_AGE get set directly here. dnl So LT_CURRENT, LT_REVISION and LT_AGE get set directly here.
dnl SONAME of the emerging library is LT_CURRENT - LT_AGE. dnl SONAME of the emerging library is LT_CURRENT - LT_AGE.
dnl The linker will do no finer checks. Especially no age range check for dnl The linker will do no finer checks. Especially no age range check for
dnl the application binary. If SONAME matches, then the couple starts. dnl the application binary. If SONAME matches, then the couple starts.
dnl dnl
dnl Therefore at run time info is provided by libburn function burn_version(). dnl Therefore at run time info is provided by libburn function burn_version().
dnl It returns the major, minor and micro revision of the library. dnl It returns the MAJOR, MINOR and MICRO revision of the library.
dnl Before using any API feature, a program should check for age. dnl Before using any API feature, a program should check for age.
dnl dnl
dnl The variables BURN_*_VERSION are mere copies for informing libtool.
dnl The true values which get issued and should be compared are macros
dnl defined in libburn/libburn.h .
dnl
dnl Normally one can allow a program to run with a library which passed the dnl Normally one can allow a program to run with a library which passed the
dnl linker SONAME test and which is not older than the library it was dnl linker SONAME test and which is not older than the library it was
dnl developed for. Library2 is younger than library1 if: dnl developed for. Library2 is younger than library1 if:
dnl major2>major1 || (major2==major1 && dnl MAJOR2>MAJOR1 || (MAJOR2==MAJOR1 &&
dnl (minor2>minor1 || (minor2==minor1 && micro2 > micro1))) dnl (MINOR2>MINOR1 || (MINOR2==MINOR1 && MICRO2 > MICRO1)))
dnl dnl
dnl If BURN_*_VERSION changes, be sure to change AC_INIT above to match. dnl If BURN_*_VERSION changes, be sure to change AC_INIT above to match.
dnl dnl
dnl As said: Only copies. Original in libburn/libburn.h : burn_header_version_*
BURN_MAJOR_VERSION=0 BURN_MAJOR_VERSION=0
BURN_MINOR_VERSION=4 BURN_MINOR_VERSION=4
BURN_MICRO_VERSION=4 BURN_MICRO_VERSION=2
BURN_VERSION=$BURN_MAJOR_VERSION.$BURN_MINOR_VERSION.$BURN_MICRO_VERSION BURN_VERSION=$BURN_MAJOR_VERSION.$BURN_MINOR_VERSION.$BURN_MICRO_VERSION
AC_SUBST(BURN_MAJOR_VERSION) AC_SUBST(BURN_MAJOR_VERSION)
@ -95,16 +86,10 @@ AC_SUBST(BURN_VERSION)
dnl Libtool versioning dnl Libtool versioning
LT_RELEASE=$BURN_MAJOR_VERSION.$BURN_MINOR_VERSION.$BURN_MICRO_VERSION LT_RELEASE=$BURN_MAJOR_VERSION.$BURN_MINOR_VERSION.$BURN_MICRO_VERSION
dnl # SONAME = 11 - 7 = 4 . Library name = libburn.so.4.7.0
dnl ts A80127 LT_CURRENT=11
dnl This is the release version libburn-0.4.4 = libburn.so.4.9.0
dnl ### This is the development version after libburn-0.4.4 = libburn.so.4.9.0
dnl ### LT_CURRENT++, LT_AGE++ has not yet happened.
dnl
dnl SONAME = 13 - 9 = 4 . Library name = libburn.so.4.9.0
LT_CURRENT=13
LT_REVISION=0 LT_REVISION=0
LT_AGE=9 LT_AGE=7
LT_CURRENT_MINUS_AGE=`expr $LT_CURRENT - $LT_AGE` LT_CURRENT_MINUS_AGE=`expr $LT_CURRENT - $LT_AGE`
AC_SUBST(LT_RELEASE) AC_SUBST(LT_RELEASE)
@ -113,7 +98,7 @@ AC_SUBST(LT_REVISION)
AC_SUBST(LT_AGE) AC_SUBST(LT_AGE)
AC_SUBST(LT_CURRENT_MINUS_AGE) AC_SUBST(LT_CURRENT_MINUS_AGE)
dnl ts A71207: This is done only not to break any old components # ts A71207: This is done only not to break any old components
BURN_INTERFACE_AGE=$LT_REVISION BURN_INTERFACE_AGE=$LT_REVISION
BURN_BINARY_AGE=`expr $LT_AGE + $BURN_INTERFACE_AGE` BURN_BINARY_AGE=`expr $LT_AGE + $BURN_INTERFACE_AGE`
AC_SUBST(BURN_INTERFACE_AGE) AC_SUBST(BURN_INTERFACE_AGE)

View File

@ -7,10 +7,10 @@
Libburnia is an open-source project for reading, mastering and writing Libburnia is an open-source project for reading, mastering and writing
optical discs. optical discs.
For now this means CD-R, CD-RW, DVD-RAM, DVD+RW, DVD+R, DVD+R/DL, DVD-RW, DVD-R. For now this means CD-R, CD-RW, DVD-RAM, DVD+RW, DVD+R, DVD-RW, DVD-R.
Not supported yet are DVD-R/DL, HD-DVD, BD (blue ray). Testers for Not supported yet are dual layer media, HD-DVD, BD (blue ray). Testers for
BD and DVD-R/DL are wanted, though. dual layer DVD+/-R are wanted, though.
The project comprises of several more or less interdependent parts which The project comprises of several more or less interdependent parts which
together strive to be a usable foundation for application development. together strive to be a usable foundation for application development.
@ -22,18 +22,13 @@ we would need : login on a development machine resp. a live OS on CD or DVD,
advise from a system person about the equivalent of Linux sg or FreeBSD CAM, advise from a system person about the equivalent of Linux sg or FreeBSD CAM,
volunteers for testing of realistic use cases. volunteers for testing of realistic use cases.
We have a well tested code base for burning data and audio CDs and many DVD We have a workable code base for burning data and audio CDs and many DVD types.
types. The burn API is quite comprehensively documented and can be used to The burn API is quite comprehensively documented and can be used to build a
build a presentable application. presentable application.
We have a functional binary which emulates the core use cases of cdrecord in We have a functional binary which emulates the core use cases of cdrecord in
order to prove that usability, and in order to allow you to explore libburn's order to prove that usability, and in order to allow you to explore libburn's
scope by help of existing cdrecord frontends. scope by help of existing cdrecord frontends.
ISO 9660 filesystems with Rock Ridge and Joliet extensions can be created
and manipulated quite freely. This capability together with our burn capability
makes possible a single binary application which covers all steps of image
composition, updating and writing. Quite unique in the Linux world.
@subsection components The project components (list subject to growth, hopefully): @subsection components The project components (list subject to growth, hopefully):
- libburn is the library by which preformatted data get onto optical media. - libburn is the library by which preformatted data get onto optical media.
@ -48,10 +43,10 @@ composition, updating and writing. Quite unique in the Linux world.
ISO 9660 disk image. This may then be brought to CD via libburn. ISO 9660 disk image. This may then be brought to CD via libburn.
libisofs is to be the foundation of our upcoming mkisofs emulation. libisofs is to be the foundation of our upcoming mkisofs emulation.
- libisoburn is an add-on to libburn and libisofs which coordinates both and - libisoburn is an add-on to libburn and libisofs which allows to grow
also allows to grow ISO-9660 filesystem images on multi-session ISO-9660 filesystem images on multi-session media as well as
media as well as on overwriteable media via the same API. on overwriteable media via the same API. All media peculiarities
All media peculiarities are handled automatically. are handled automatically.
- cdrskin is a limited cdrecord compatibility wrapper for libburn. - cdrskin is a limited cdrecord compatibility wrapper for libburn.
cdrecord is a powerful GPL'ed burn program included in Joerg cdrecord is a powerful GPL'ed burn program included in Joerg
@ -64,12 +59,12 @@ composition, updating and writing. Quite unique in the Linux world.
runs, though. runs, though.
See cdrskin/README for more. See cdrskin/README for more.
- xorriso is an application of all three libraries which creates, loads, - xorriso is an upcomming application of all three libraries which creates,
manipulates and writes ISO 9660 filesystem images with loads, manipulates and writes ISO 9660 filesystem images with
Rock Ridge extensions. Manipulation is not only adding or Rock Ridge extensions. Manipulation will not only be adding or
overwriting of files but also deletion, renaming, and attribute overwriting of files but also deletion, renaming, and attribute
changing. changing.
See xorriso/README for more See SVN of libisoburn, man test/xorriso.1, test/compile_xorriso.sh
- "test" is a collection of application gestures and examples given by the - "test" is a collection of application gestures and examples given by the
authors of the library features. The burn API example of libburn authors of the library features. The burn API example of libburn
@ -77,19 +72,7 @@ composition, updating and writing. Quite unique in the Linux world.
demonstrated in test/telltoc.c . demonstrated in test/telltoc.c .
Explore these examples if you look for inspiration. Explore these examples if you look for inspiration.
We strive to be a responsive upstream. We plan to be a responsive upstream. Bear with us.
Our libraries are committed to maintain older feature sets in newer versions.
This applies to source code headers (API) as well as to linkable objects (ABI).
The only exception from this rule is about non-release versions x.y.*[13579]
which are allowed to introduce new features, change those new features in
any way and even may revoke such new features before the next release of
x.y.*[02468]. As soon as it is released, a feature is promised to persist.
SONAMES:
libburn.so.4 (since 0.3.4, March 2007),
libisofs.so.6 (since 0.6.2, February 2008),
libisoburn.so.1 (since 0.1.0, February 2008).
@section using Using the libraries @section using Using the libraries

View File

@ -439,9 +439,6 @@ int burn_drive_mark_unready(struct burn_drive *d)
burn_disc_free(d->disc); burn_disc_free(d->disc);
d->disc = NULL; d->disc = NULL;
} }
if (d->stdio_fd >= 0)
close (d->stdio_fd);
d->stdio_fd = -1;
return 1; return 1;
} }
@ -1701,10 +1698,7 @@ int burn_abort(int patience,
occup = burn_drive_is_occupied(&(drive_array[i])); occup = burn_drive_is_occupied(&(drive_array[i]));
if(occup == -2) if(occup == -2)
continue; continue;
if(drive_array[i].drive_role != 1) { if(occup <= 10) {
drive_array[i].busy = BURN_DRIVE_IDLE;
burn_drive_forget(&(drive_array[i]), 1);
} else if(occup <= 10) {
burn_drive_forget(&(drive_array[i]), 1); burn_drive_forget(&(drive_array[i]), 1);
} else if(occup <= 100) { } else if(occup <= 100) {
if(first_round) if(first_round)

View File

@ -247,7 +247,7 @@ int burn_msgs_submit(int error_code, char msg_text[], int os_errno,
ret = libdax_msgs__text_to_sev(severity, &sevno, 0); ret = libdax_msgs__text_to_sev(severity, &sevno, 0);
if (ret <= 0) if (ret <= 0)
sevno = LIBDAX_MSGS_SEV_ALL; sevno = LIBDAX_MSGS_SEV_FATAL;
if (error_code <= 0) { if (error_code <= 0) {
switch(sevno) { switch(sevno) {
case LIBDAX_MSGS_SEV_ABORT: error_code = 0x00040000; case LIBDAX_MSGS_SEV_ABORT: error_code = 0x00040000;
@ -258,7 +258,7 @@ int burn_msgs_submit(int error_code, char msg_text[], int os_errno,
break; case LIBDAX_MSGS_SEV_NOTE: error_code = 0x00040005; break; case LIBDAX_MSGS_SEV_NOTE: error_code = 0x00040005;
break; case LIBDAX_MSGS_SEV_UPDATE: error_code = 0x00040006; break; case LIBDAX_MSGS_SEV_UPDATE: error_code = 0x00040006;
break; case LIBDAX_MSGS_SEV_DEBUG: error_code = 0x00040007; break; case LIBDAX_MSGS_SEV_DEBUG: error_code = 0x00040007;
break; default: error_code = 0x00040008; break; default: error_code = 0x00040001;
} }
} }
if (d != NULL) if (d != NULL)
@ -275,16 +275,8 @@ int burn_text_to_sev(char *severity_name, int *sevno, int flag)
int ret; int ret;
ret = libdax_msgs__text_to_sev(severity_name, sevno, 0); ret = libdax_msgs__text_to_sev(severity_name, sevno, 0);
return ret; if (ret <= 0)
} *sevno = LIBDAX_MSGS_SEV_FATAL;
/* ts A80202 API */
int burn_sev_to_text(int severity_number, char **severity_name, int flag)
{
int ret;
ret = libdax_msgs__sev_to_text(severity_number, severity_name, 0);
return ret; return ret;
} }

View File

@ -642,7 +642,7 @@ struct burn_speed_descriptor {
This must be called before using any other functions in the library. It This must be called before using any other functions in the library. It
may be called more than once with no effect. may be called more than once with no effect.
It is possible to 'restart' the library by shutting it down and It is possible to 'restart' the library by shutting it down and
re-initializing it. Once this was necessary if you follow the older and re-initializing it. This is necessary if you follow the older and
more general way of accessing a drive via burn_drive_scan() and more general way of accessing a drive via burn_drive_scan() and
burn_drive_grab(). See burn_drive_scan_and_grab() with its strong burn_drive_grab(). See burn_drive_scan_and_grab() with its strong
urges and its explanations. urges and its explanations.
@ -730,7 +730,7 @@ void burn_preset_device_open(int exclusive, int blocking, int abort_on_busy);
/** Allows the use of media types which are implemented in libburn but not yet /** Allows the use of media types which are implemented in libburn but not yet
tested. The list of those untested profiles is subject to change. tested. The list of those untested profiles is subject to change.
Currently it contains: 0x15 "DVD-R/DL sequential recording", Currently it contains: 0x15 "DVD-R/DL sequential recording",
0x43 "BD-RE" 0x2b "DVD+R/DL"
If you really test such media, then please report the outcome on If you really test such media, then please report the outcome on
libburn-hackers@pykix.org libburn-hackers@pykix.org
If ever then this call should be done soon after burn_initialize() before If ever then this call should be done soon after burn_initialize() before
@ -809,7 +809,8 @@ void burn_allow_untested_profiles(int yes);
(cdrom/burner). Thus use with driveno 0 only. On failure (cdrom/burner). Thus use with driveno 0 only. On failure
the array has no valid elements at all. the array has no valid elements at all.
The returned array should be freed via burn_drive_info_free() The returned array should be freed via burn_drive_info_free()
when it is no longer needed. when it is no longer needed, and before calling a scan
function again.
This is a result from call burn_drive_scan(). See there. This is a result from call burn_drive_scan(). See there.
Use with driveno 0 only. Use with driveno 0 only.
@param adr The persistent address of the desired drive. Either once @param adr The persistent address of the desired drive. Either once
@ -1093,11 +1094,10 @@ off_t burn_disc_available_space(struct burn_drive *d,
0x09 "CD-R", 0x0a "CD-RW", 0x09 "CD-R", 0x0a "CD-RW",
0x11 "DVD-R sequential recording", 0x12 "DVD-RAM", 0x11 "DVD-R sequential recording", 0x12 "DVD-RAM",
0x13 "DVD-RW restricted overwrite", 0x14 "DVD-RW sequential recording", 0x13 "DVD-RW restricted overwrite", 0x14 "DVD-RW sequential recording",
0x1a "DVD+RW", 0x1b "DVD+R" 0x1a "DVD+RW", 0x1b "DVD+R".
0x2b "DVD+R/DL"
If enabled by burn_allow_untested_profiles() it also writes to profiles If enabled by burn_allow_untested_profiles() it also writes to profiles
0x15 "DVD-R/DL sequential recording", 0x43 "BD-RE". 0x15 "DVD-R/DL sequential recording", 0x2b "DVD+R/DL".
Writeable stdio-drives return this profile: Writeable stdio-drives return this profile
0xffff "stdio file" 0xffff "stdio file"
@param d The drive where the media is inserted. @param d The drive where the media is inserted.
@param pno Profile Number as of mmc5r03c.pdf, table 89 @param pno Profile Number as of mmc5r03c.pdf, table 89
@ -1107,7 +1107,6 @@ off_t burn_disc_available_space(struct burn_drive *d,
int burn_disc_get_profile(struct burn_drive *d, int *pno, char name[80]); int burn_disc_get_profile(struct burn_drive *d, int *pno, char name[80]);
/** Tells whether a disc can be erased or not /** Tells whether a disc can be erased or not
@param d The drive to inquire.
@return Non-zero means erasable @return Non-zero means erasable
*/ */
int burn_disc_erasable(struct burn_drive *d); int burn_disc_erasable(struct burn_drive *d);
@ -2037,8 +2036,8 @@ int burn_track_get_mode(struct burn_track *track);
*/ */
int burn_session_get_hidefirst(struct burn_session *session); int burn_session_get_hidefirst(struct burn_session *session);
/** Returns the library's version in its parts. /** Returns the library's version in its parts
This is the runtime counterpart of the three build time macros This is the runtime counterpart of the three build time macros
burn_header_version_* below. burn_header_version_* below.
@param major The major version number @param major The major version number
@param minor The minor version number @param minor The minor version number
@ -2066,54 +2065,12 @@ void burn_version(int *major, int *minor, int *micro);
*/ */
#define burn_header_version_major 0 #define burn_header_version_major 0
#define burn_header_version_minor 4 #define burn_header_version_minor 4
#define burn_header_version_micro 4 #define burn_header_version_micro 2
/** Note: /** Note:
Above version numbers are also recorded in configure.ac because libtool Above version numbers are also recorded in configure.ac and indirectly
wants them as parameters at build time. lead to the reply of burn_version().
For the library compatibility check BURN_*_VERSION in configure.ac So the version triples in configure.ac and libburn.h must be kept equal.
are not decisive. Only the three numbers above do matter. In future versions the triple of libburn.h will be decisive alone.
*/
/** Usage discussion:
Some developers of the libburnia project have differing
opinions how to ensure the compatibility of libaries
and applications.
It is about whether to use at compile time and at runtime
the version numbers isoburn_header_version_* provided here.
Thomas Schmitt advises to use them.
Vreixo Formoso advises to use other means.
At compile time:
Vreixo Formoso advises to leave proper version matching
to properly programmed checks in the the application's
build system, which will eventually refuse compilation.
Thomas Schmitt advises to use the macros defined here
for comparison with the application's requirements of
library revisions and to eventually break compilation.
Both advises are combinable. I.e. be master of your
build system and have #if checks in the source code
of your application, nevertheless.
At runtime (via *_is_compatible()):
Vreixo Formoso advises to compare the application's
requirements of library revisions with the runtime
library. This is to allow runtime libraries which are
young enough for the application but too old for
the lib*.h files seen at compile time.
Thomas Schmitt advises to compare the header
revisions defined here with the runtime library.
This is to enforce a strictly monotonous chain
of revisions from app to header to library,
at the cost of excluding some older libraries.
These two advises are mutually exclusive.
*/ */
@ -2189,16 +2146,6 @@ int burn_msgs_submit(int error_code, char msg_text[], int os_errno,
int burn_text_to_sev(char *severity_name, int *severity_number, int flag); int burn_text_to_sev(char *severity_name, int *severity_number, int flag);
/* ts A80202 : @since 0.4.4 */
/** Convert a severity number into a severity name
@param severity_number The rank number: the higher, the more severe.
@param severity_name A name as with burn_msgs_submit(), e.g. "SORRY".
@param flag Bitfield for control purposes (unused yet, submit 0)
*/
int burn_sev_to_text(int severity_number, char **severity_name, int flag);
/* ts A70915 */ /* ts A70915 */
/** Replace the messenger object handle of libburn by a compatible handle /** Replace the messenger object handle of libburn by a compatible handle
obtained from a related library. obtained from a related library.
@ -2259,7 +2206,7 @@ void burn_set_signal_handling(void *handle, burn_abort_handler_t handler,
drive buffer without further data transfer). drive buffer without further data transfer).
@param flag Bitfield for control purposes: @param flag Bitfield for control purposes:
bit0 = flush the drive buffer after eventual writing bit0 = flush the drive buffer after eventual writing
@return 1=sucessful , <=0 : number of transfered bytes * -1 @return 1=sucessful , <=0 : number of tranfered bytes * -1
*/ */
int burn_random_access_write(struct burn_drive *d, off_t byte_address, int burn_random_access_write(struct burn_drive *d, off_t byte_address,
char *data, off_t data_count, int flag); char *data, off_t data_count, int flag);

View File

@ -254,8 +254,6 @@ int libdax_msgs__text_to_sev(char *severity_name, int *severity,
*severity= LIBDAX_MSGS_SEV_FATAL; *severity= LIBDAX_MSGS_SEV_FATAL;
else if(strncmp(severity_name,"FAILURE",7)==0) else if(strncmp(severity_name,"FAILURE",7)==0)
*severity= LIBDAX_MSGS_SEV_FAILURE; *severity= LIBDAX_MSGS_SEV_FAILURE;
else if(strncmp(severity_name,"MISHAP",6)==0)
*severity= LIBDAX_MSGS_SEV_MISHAP;
else if(strncmp(severity_name,"SORRY",5)==0) else if(strncmp(severity_name,"SORRY",5)==0)
*severity= LIBDAX_MSGS_SEV_SORRY; *severity= LIBDAX_MSGS_SEV_SORRY;
else if(strncmp(severity_name,"WARNING",7)==0) else if(strncmp(severity_name,"WARNING",7)==0)
@ -268,12 +266,10 @@ int libdax_msgs__text_to_sev(char *severity_name, int *severity,
*severity= LIBDAX_MSGS_SEV_UPDATE; *severity= LIBDAX_MSGS_SEV_UPDATE;
else if(strncmp(severity_name,"DEBUG",5)==0) else if(strncmp(severity_name,"DEBUG",5)==0)
*severity= LIBDAX_MSGS_SEV_DEBUG; *severity= LIBDAX_MSGS_SEV_DEBUG;
else if(strncmp(severity_name,"ERRFILE",7)==0)
*severity= LIBDAX_MSGS_SEV_ERRFILE;
else if(strncmp(severity_name,"ALL",3)==0) else if(strncmp(severity_name,"ALL",3)==0)
*severity= LIBDAX_MSGS_SEV_ALL; *severity= LIBDAX_MSGS_SEV_ALL;
else { else {
*severity= LIBDAX_MSGS_SEV_ALL; *severity= LIBDAX_MSGS_SEV_NEVER;
return(0); return(0);
} }
return(1); return(1);
@ -284,7 +280,7 @@ int libdax_msgs__sev_to_text(int severity, char **severity_name,
int flag) int flag)
{ {
if(flag&1) { if(flag&1) {
*severity_name= "NEVER\nABORT\nFATAL\nFAILURE\nMISHAP\nSORRY\nWARNING\nHINT\nNOTE\nUPDATE\nDEBUG\nERRFILE\nALL"; *severity_name= "NEVER\nABORT\nFATAL\nFAILURE\nSORRY\nWARNING\nHINT\nNOTE\nUPDATE\nDEBUG\nALL";
return(1); return(1);
} }
*severity_name= ""; *severity_name= "";
@ -296,8 +292,6 @@ int libdax_msgs__sev_to_text(int severity, char **severity_name,
*severity_name= "FATAL"; *severity_name= "FATAL";
else if(severity>=LIBDAX_MSGS_SEV_FAILURE) else if(severity>=LIBDAX_MSGS_SEV_FAILURE)
*severity_name= "FAILURE"; *severity_name= "FAILURE";
else if(severity>=LIBDAX_MSGS_SEV_MISHAP)
*severity_name= "MISHAP";
else if(severity>=LIBDAX_MSGS_SEV_SORRY) else if(severity>=LIBDAX_MSGS_SEV_SORRY)
*severity_name= "SORRY"; *severity_name= "SORRY";
else if(severity>=LIBDAX_MSGS_SEV_WARNING) else if(severity>=LIBDAX_MSGS_SEV_WARNING)
@ -310,8 +304,6 @@ int libdax_msgs__sev_to_text(int severity, char **severity_name,
*severity_name= "UPDATE"; *severity_name= "UPDATE";
else if(severity>=LIBDAX_MSGS_SEV_DEBUG) else if(severity>=LIBDAX_MSGS_SEV_DEBUG)
*severity_name= "DEBUG"; *severity_name= "DEBUG";
else if(severity>=LIBDAX_MSGS_SEV_ERRFILE)
*severity_name= "ERRFILE";
else if(severity>=LIBDAX_MSGS_SEV_ALL) else if(severity>=LIBDAX_MSGS_SEV_ALL)
*severity_name= "ALL"; *severity_name= "ALL";
else { else {

View File

@ -120,19 +120,6 @@ struct libdax_msgs_item;
*/ */
#define LIBDAX_MSGS_SEV_ALL 0x00000000 #define LIBDAX_MSGS_SEV_ALL 0x00000000
/** Messages of this severity shall transport plain disk file paths
whenever an event of severity SORRY or above is related with an
individual disk file.
No message text shall be added to the file path. The ERRFILE message
shall be issued before the human readable message which carries the
true event severity. That message should contain the file path so it
can be found by strstr(message, path)!=NULL.
The error code shall be the same as with the human readable message.
*/
#define LIBDAX_MSGS_SEV_ERRFILE 0x08000000
/** Debugging messages not to be visible to normal users by default /** Debugging messages not to be visible to normal users by default
*/ */
#define LIBDAX_MSGS_SEV_DEBUG 0x10000000 #define LIBDAX_MSGS_SEV_DEBUG 0x10000000
@ -154,19 +141,12 @@ struct libdax_msgs_item;
#define LIBDAX_MSGS_SEV_WARNING 0x50000000 #define LIBDAX_MSGS_SEV_WARNING 0x50000000
/** Non-fatal error messages indicating that parts of an action failed but /** Non-fatal error messages indicating that important parts of an action
processing may go on if one accepts deviations from the desired result. failed but processing may go on if one accepts deviations from the
desired result.
SORRY may also be the severity for incidents which are severe enough E.g.: One of several libisofs input files cannot be found.
for FAILURE but happen within already started irrevocable actions,
like ISO image generation. A precondition for such a severity ease is
that the action can be continued after the incident.
See below MISHAP for what xorriso would need instead of this kind of SORRY
and generates for itself in case of libisofs image generation.
E.g.: A pattern yields no result.
A speed setting cannot be made. A speed setting cannot be made.
A libisofs input file is inaccessible during image generation.
After SORRY a function should try to go on if that makes any sense After SORRY a function should try to go on if that makes any sense
and if no threshold prescribes abort on SORRY. The function should and if no threshold prescribes abort on SORRY. The function should
@ -176,31 +156,15 @@ struct libdax_msgs_item;
#define LIBDAX_MSGS_SEV_SORRY 0x60000000 #define LIBDAX_MSGS_SEV_SORRY 0x60000000
/** A FAILURE (see below) which can be tolerated during long lasting /** Non-fatal error indicating that a complete action failed and that
operations just because they cannot simply be stopped or revoked. only a thorough new setup of preconditions will give hope for success.
xorriso converts libisofs SORRY messages issued during image generation
into MISHAP messages in order to allow its evaluators to distinguish
image generation problems from minor image composition problems.
E.g.:
A libisofs input file is inaccessible during image generation.
After a MISHAP a function should behave like after SORRY.
*/
#define LIBDAX_MSGS_SEV_MISHAP 0x64000000
/** Non-fatal error indicating that an important part of an action failed and
that only a new setup of preconditions will give hope for sufficient
success.
E.g.: No media is inserted in the output drive. E.g.: No media is inserted in the output drive.
No write mode can be found for inserted media. No write mode can be found for inserted media.
A libisofs input file is inaccessible during grafting. All libisofs input files are inaccessible.
After FAILURE a function should end with a return value indicating failure. After FAILURE a function should end very soon with a return value
It is at the discretion of the function whether it ends immediately in any indicating failure.
case or whether it tries to go on if the eventual threshold allows.
*/ */
#define LIBDAX_MSGS_SEV_FAILURE 0x68000000 #define LIBDAX_MSGS_SEV_FAILURE 0x68000000
@ -535,81 +499,34 @@ Range "scdbackup" : 0x00020000 to 0x0002ffff
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
Range "vreixo" : 0x00030000 to 0x0003ffff Range "vreixo" : 0x00030000 to 0x0003ffff
0x0003ffff (FAILURE,HIGH) = Operation canceled General:
0x0003fffe (FATAL,HIGH) = Unknown or unexpected fatal error 0x00031001 (SORRY,HIGH) = Cannot read file (ignored)
0x0003fffd (FAILURE,HIGH) = Unknown or unexpected error 0x00031002 (FATAL,HIGH) = Cannot read file (operation canceled)
0x0003fffc (FATAL,HIGH) = Internal programming error
0x0003fffb (FAILURE,HIGH) = NULL pointer where NULL not allowed
0x0003fffa (FATAL,HIGH) = Memory allocation error
0x0003fff9 (FATAL,HIGH) = Interrupted by a signal
0x0003fff8 (FAILURE,HIGH) = Invalid parameter value
0x0003fff7 (FATAL,HIGH) = Cannot create a needed thread
0x0003fff6 (FAILURE,HIGH) = Write error
0x0003fff5 (FAILURE,HIGH) = Buffer read error
0x0003ffc0 (FAILURE,HIGH) = Trying to add a node already added to another dir
0x0003ffbf (FAILURE,HIGH) = Node with same name already exist
0x0003ffbe (FAILURE,HIGH) = Trying to remove a node that was not added to dir
0x0003ffbd (FAILURE,HIGH) = A requested node does not exist
0x0003ffbc (FAILURE,HIGH) = Image already bootable
0x0003ffbb (FAILURE,HIGH) = Trying to use an invalid file as boot image
0x0003ff80 (FAILURE,HIGH) = Error on file operation
0x0003ff7f (FAILURE,HIGH) = Trying to open an already openned file
0x0003ff7e (FAILURE,HIGH) = Access to file is not allowed
0x0003ff7d (FAILURE,HIGH) = Incorrect path to file
0x0003ff7c (FAILURE,HIGH) = The file does not exist in the filesystem
0x0003ff7b (FAILURE,HIGH) = Trying to read or close a file not openned
0x0003ff7a (FAILURE,HIGH) = Directory used where no dir is expected
0x0003ff79 (FAILURE,HIGH) = File read error
0x0003ff78 (FAILURE,HIGH) = Not dir used where a dir is expected
0x0003ff77 (FAILURE,HIGH) = Not symlink used where a symlink is expected
0x0003ff76 (FAILURE,HIGH) = Cannot seek to specified location
0x0003ff75 (HINT,MEDIUM) = File not supported in ECMA-119 tree and ignored
0x0003ff74 (HINT,MEDIUM) = File bigger than supported by used standard
0x0003ff73 (MISHAP,HIGH) = File read error during image creation
0x0003ff72 (HINT,MEDIUM) = Cannot convert filename to requested charset
0x0003ff71 (SORRY,HIGH) = File cannot be added to the tree
0x0003ff70 (HINT,MEDIUM) = File path breaks specification constraints
0x0003ff00 (FAILURE,HIGH) = Charset conversion error
0x0003feff (FAILURE,HIGH) = Too much files to mangle
0x0003fec0 (FAILURE,HIGH) = Wrong or damaged Primary Volume Descriptor
0x0003febf (SORRY,HIGH) = Wrong or damaged RR entry
0x0003febe (SORRY,HIGH) = Unsupported RR feature
0x0003febd (FAILURE,HIGH) = Wrong or damaged ECMA-119
0x0003febc (FAILURE,HIGH) = Unsupported ECMA-119 feature
0x0003febb (SORRY,HIGH) = Wrong or damaged El-Torito catalog
0x0003feba (SORRY,HIGH) = Unsupported El-Torito feature
0x0003feb9 (SORRY,HIGH) = Cannot patch isolinux boot image
0x0003feb8 (SORRY,HIGH) = Unsupported SUSP feature
0x0003feb7 (WARNING,HIGH) = Error on a RR entry that can be ignored
0x0003feb6 (HINT,MEDIUM) = Error on a RR entry that can be ignored
0x0003feb5 (WARNING,HIGH) = Multiple ER SUSP entries found
0x0003feb4 (HINT,MEDIUM) = Unsupported volume descriptor found
0x0003feb3 (WARNING,HIGH) = El-Torito related warning
0x0003feb2 (MISHAP,HIGH) = Image write cancelled
0x0003feb1 (WARNING,HIGH) = El-Torito image is hidden
Outdated codes which may not be re-used for other purposes than Image reading:
re-instating them, if ever: 0x00031000 (FATAL,HIGH) = Unsupported ISO-9660 image
0x00031001 (HINT,MEDIUM) = Unsupported Vol Desc that will be ignored
X 0x00031001 (SORRY,HIGH) = Cannot read file (ignored) 0x00031002 (FATAL,HIGH) = Damaged ISO-9660 image
X 0x00031002 (FATAL,HIGH) = Cannot read file (operation canceled) 0x00031003 (SORRY,HIGH) = Cannot read previous image file
X 0x00031000 (FATAL,HIGH) = Unsupported ISO-9660 image
X 0x00031001 (HINT,MEDIUM) = Unsupported Vol Desc that will be ignored Rock-Ridge:
X 0x00031002 (FATAL,HIGH) = Damaged ISO-9660 image 0x00030101 (HINT,MEDIUM) = Unsupported SUSP entry that will be ignored
X 0x00031003 (SORRY,HIGH) = Cannot read previous image file 0x00030102 (SORRY,HIGH) = Wrong/damaged SUSP entry
X 0x00030101 (HINT,MEDIUM) = Unsupported SUSP entry that will be ignored 0x00030103 (WARNING,MEDIUM)= Multiple SUSP ER entries where found
X 0x00030102 (SORRY,HIGH) = Wrong/damaged SUSP entry 0x00030111 (SORRY,HIGH) = Unsupported RR feature
X 0x00030103 (WARNING,MEDIUM)= Multiple SUSP ER entries where found 0x00030112 (SORRY,HIGH) = Error in a Rock Ridge entry
X 0x00030111 (SORRY,HIGH) = Unsupported RR feature
X 0x00030112 (SORRY,HIGH) = Error in a Rock Ridge entry El-Torito:
X 0x00030201 (HINT,MEDIUM) = Unsupported Boot Vol Desc that will be ignored 0x00030201 (HINT,MEDIUM) = Unsupported Boot Vol Desc that will be ignored
X 0x00030202 (SORRY,HIGH) = Wrong El-Torito catalog 0x00030202 (SORRY,HIGH) = Wrong El-Torito catalog
X 0x00030203 (HINT,MEDIUM) = Unsupported El-Torito feature 0x00030203 (HINT,MEDIUM) = Unsupported El-Torito feature
X 0x00030204 (SORRY,HIGH) = Invalid file to be an El-Torito image 0x00030204 (SORRY,HIGH) = Invalid file to be an El-Torito image
X 0x00030205 (WARNING,MEDIUM)= Cannot properly patch isolinux image 0x00030205 (WARNING,MEDIUM)= Cannot properly patch isolinux image
X 0x00030206 (WARNING,MEDIUM)= Copying El-Torito from a previous image without 0x00030206 (WARNING,MEDIUM)= Copying El-Torito from a previous image without
X enought info about it enought info about it
X 0x00030301 (NOTE,MEDIUM) = Unsupported file type for Joliet tree
Joliet:
0x00030301 (NOTE,MEDIUM) = Unsupported file type for Joliet tree
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
@ -623,23 +540,6 @@ Range "application" : 0x00040000 to 0x0004ffff
0x00040005 (NOTE,HIGH) : Application supplied message 0x00040005 (NOTE,HIGH) : Application supplied message
0x00040006 (UPDATE,HIGH) : Application supplied message 0x00040006 (UPDATE,HIGH) : Application supplied message
0x00040007 (DEBUG,HIGH) : Application supplied message 0x00040007 (DEBUG,HIGH) : Application supplied message
0x00040008 (*,HIGH) : Application supplied message
------------------------------------------------------------------------------
Range "libisofs-xorriso" : 0x00050000 to 0x0005ffff
This is an alternative representation of libisofs.so.6 error codes in xorriso.
If values returned by iso_error_get_code() do not fit into 0x30000 to 0x3ffff
then they get truncated to 16 bit and mapped into this range.
(This should never need to happen, of course.)
------------------------------------------------------------------------------
Range "libisoburn" : 0x00060000 to 0x00006ffff
0x00060000 (*,*) : Message which shall be attributed to libisoburn
>>> the messages of libisoburn need to be registered individually
------------------------------------------------------------------------------ ------------------------------------------------------------------------------

View File

@ -91,8 +91,6 @@ extern struct libdax_msgs *libdax_messenger;
ts A70208 : Finally made tests with DVD-R. Worked exactly as new DVD-RW. ts A70208 : Finally made tests with DVD-R. Worked exactly as new DVD-RW.
ts A70306 : Implemented DVD+R (always -multi for now) ts A70306 : Implemented DVD+R (always -multi for now)
ts A70330 : Allowed finalizing of DVD+R. ts A70330 : Allowed finalizing of DVD+R.
ts A80228 : Made DVD+R/DL support official after nightmorph reported success
in http://libburnia-project.org/ticket/13
*/ */
/* ts A70519 : With MMC commands of data direction FROM_DRIVE: /* ts A70519 : With MMC commands of data direction FROM_DRIVE:
@ -308,9 +306,8 @@ int mmc_read_track_info(struct burn_drive *d, int trackno, struct buffer *buf,
c.opcode[1] = 1; c.opcode[1] = 1;
if(trackno<=0) { if(trackno<=0) {
if (d->current_profile == 0x1a || d->current_profile == 0x13 || if (d->current_profile == 0x1a || d->current_profile == 0x13 ||
d->current_profile == 0x12 || d->current_profile == 0x43) d->current_profile == 0x12 )
/* DVD+RW , DVD-RW restricted overwrite , DVD-RAM /* DVD+RW , DVD-RW restricted overwrite , DVD-RAM */
BD-RE */
trackno = 1; trackno = 1;
else if (d->current_profile == 0x10 || else if (d->current_profile == 0x10 ||
d->current_profile == 0x11 || d->current_profile == 0x11 ||
@ -352,7 +349,7 @@ int mmc_get_nwa(struct burn_drive *d, int trackno, int *lba, int *nwa)
*nwa = mmc_four_char_to_int(data + 12); *nwa = mmc_four_char_to_int(data + 12);
num = mmc_four_char_to_int(data + 16); num = mmc_four_char_to_int(data + 16);
if (d->current_profile == 0x1a || d->current_profile == 0x13 || if (d->current_profile == 0x1a || d->current_profile == 0x13 ||
d->current_profile == 0x12 || d->current_profile == 0x43) { d->current_profile == 0x12) {
/* overwriteable */ /* overwriteable */
*lba = *nwa = num = 0; *lba = *nwa = num = 0;
} else if (!(data[7]&1)) { } else if (!(data[7]&1)) {
@ -1425,7 +1422,6 @@ static int mmc_read_disc_info_al(struct burn_drive *d, int *alloc_len)
disc_status = 2; /* always full and finalized */ disc_status = 2; /* always full and finalized */
d->erasable = 0; /* never erasable */ d->erasable = 0; /* never erasable */
} }
switch (disc_status) { switch (disc_status) {
case 0: case 0:
d->toc_entries = 0; d->toc_entries = 0;
@ -1449,15 +1445,6 @@ static int mmc_read_disc_info_al(struct burn_drive *d, int *alloc_len)
break; break;
} }
/* ts A80207 : DVD +/- R DL can normally be read but not be written */
if((d->current_profile == 0x2b || d->current_profile == 0x15) &&
!d->current_is_supported_profile) {
if(d->status == BURN_DISC_APPENDABLE)
d->status = BURN_DISC_FULL;
d->erasable = 0; /* never erasable */
d->current_is_supported_profile = 1;
}
if ((d->current_profile != 0 || d->status != BURN_DISC_UNREADY) if ((d->current_profile != 0 || d->status != BURN_DISC_UNREADY)
&& ! d->current_is_supported_profile) { && ! d->current_is_supported_profile) {
if (!d->silent_on_scsi_error) { if (!d->silent_on_scsi_error) {
@ -1493,7 +1480,7 @@ static int mmc_read_disc_info_al(struct burn_drive *d, int *alloc_len)
ts A70112 : same for DVD-RAM ts A70112 : same for DVD-RAM
*/ */
if (d->current_profile == 0x1a || d->current_profile == 0x13 || if (d->current_profile == 0x1a || d->current_profile == 0x13 ||
d->current_profile == 0x12 || d->current_profile == 0x43) d->current_profile == 0x12)
d->status = BURN_DISC_BLANK; d->status = BURN_DISC_BLANK;
if (d->status == BURN_DISC_BLANK) { if (d->status == BURN_DISC_BLANK) {
@ -2107,8 +2094,7 @@ static int mmc_get_configuration_al(struct burn_drive *d, int *alloc_len)
d->current_is_supported_profile = 1; d->current_is_supported_profile = 1;
#endif #endif
#ifdef Libburn_support_dvd_raM #ifdef Libburn_support_dvd_raM
if (cp == 0x12 || (cp == 0x43 && burn_support_untested_profiles)) if (cp == 0x12)
/* DVD-RAM , BD-RE */
d->current_is_supported_profile = 1; d->current_is_supported_profile = 1;
#endif #endif
#ifdef Libburn_support_dvd_r_seQ #ifdef Libburn_support_dvd_r_seQ
@ -2118,7 +2104,8 @@ static int mmc_get_configuration_al(struct burn_drive *d, int *alloc_len)
d->current_is_supported_profile = 1; d->current_is_supported_profile = 1;
#endif #endif
#ifdef Libburn_support_dvd_plus_R #ifdef Libburn_support_dvd_plus_R
if (cp == 0x1b || cp == 0x2b) /* DVD+R , DVD+R/DL */ if (cp == 0x1b || (cp == 0x2b && burn_support_untested_profiles))
/* DVD+R , DVD+R/DL */
d->current_is_supported_profile = 1; d->current_is_supported_profile = 1;
#endif #endif
@ -3007,9 +2994,8 @@ int mmc_compose_mode_page_5(struct burn_drive *d,
pd[13] = 16; pd[13] = 16;
} else if (d->current_profile == 0x1a || d->current_profile == 0x1b || } else if (d->current_profile == 0x1a || d->current_profile == 0x1b ||
d->current_profile == 0x2b || d->current_profile == 0x12 || d->current_profile == 0x2b || d->current_profile == 0x12) {
d->current_profile == 0x43) { /* not with DVD+R[W][/DL] or DVD-RAM */;
/* not with DVD+R[W][/DL] or DVD-RAM or BD-RE */;
return 0; return 0;
} else { } else {
/* Traditional setup for CD */ /* Traditional setup for CD */

View File

@ -325,19 +325,6 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
char msg[81], *wpt; char msg[81], *wpt;
struct buffer buf; struct buffer buf;
/*
#define Libburn_read_data_adr_logginG 1
*/
#ifdef Libburn_read_data_adr_logginG
static FILE *log_fp= NULL;
if(log_fp == NULL)
log_fp = fopen("/tmp/burn_read_data_log", "a");
if(log_fp!=NULL)
fprintf(log_fp, "%d\n", (int) (byte_address / 2048));
#endif /* Libburn_read_data_logginG */
*data_count = 0; *data_count = 0;
sose_mem = d->silent_on_scsi_error; sose_mem = d->silent_on_scsi_error;
@ -388,10 +375,7 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
#define O_LARGEFILE 0 #define O_LARGEFILE 0
#endif #endif
fd = d->stdio_fd; fd = open(d->devname, O_RDONLY | O_LARGEFILE);
if (fd < 0)
d->stdio_fd = fd =
open(d->devname, O_RDONLY | O_LARGEFILE);
if (fd == -1) { if (fd == -1) {
if (errno != ENOENT || !(flag & 2)) if (errno != ENOENT || !(flag & 2))
libdax_msgs_submit(libdax_messenger, libdax_msgs_submit(libdax_messenger,
@ -464,14 +448,6 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
wpt += 2048; wpt += 2048;
*data_count += 2048; *data_count += 2048;
} }
libdax_msgs_submit(libdax_messenger,
d->global_index,
0x00020000,
LIBDAX_MSGS_SEV_DEBUG, LIBDAX_MSGS_PRIO_HIGH,
"burn_read_data() returns 0",
0, 0);
ret = 0; goto ex; ret = 0; goto ex;
} }
memcpy(wpt, d->buffer->data, cpy_size); memcpy(wpt, d->buffer->data, cpy_size);
@ -481,10 +457,8 @@ int burn_read_data(struct burn_drive *d, off_t byte_address,
ret = 1; ret = 1;
ex:; ex:;
/* <<< let it open until drive is given up or writing shall happen
if (fd != -1) if (fd != -1)
close(fd); close(fd);
*/
d->buffer = NULL; d->buffer = NULL;
d->busy = BURN_DRIVE_IDLE; d->busy = BURN_DRIVE_IDLE;
return ret; return ret;

View File

@ -308,28 +308,6 @@ static int sg_close_drive_fd(char *fname, int driveno, int *fd, int sorry)
if(*fd < 0) if(*fd < 0)
return(0); return(0);
#ifdef CDROM_MEDIA_CHANGED_disabled_because_not_helpful
#ifdef CDSL_CURRENT
/* ts A80217 : wondering whether the os knows about our activities */
ret = ioctl(*fd, CDROM_MEDIA_CHANGED, CDSL_CURRENT);
sprintf(msg, "ioctl(CDROM_MEDIA_CHANGED) == %d", ret);
libdax_msgs_submit(libdax_messenger, driveno, 0x00000002,
LIBDAX_MSGS_SEV_DEBUG, LIBDAX_MSGS_PRIO_HIGH, msg, 0, 0);
#ifdef BLKFLSBUF_disabled_because_not_helpful
ret = ioctl(*fd, BLKFLSBUF, 0);
sprintf(msg, "ioctl(BLKFLSBUF) == %d", ret);
os_errno = 0;
if(ret == -1)
os_errno = errno;
libdax_msgs_submit(libdax_messenger, driveno, 0x00000002,
LIBDAX_MSGS_SEV_DEBUG, LIBDAX_MSGS_PRIO_HIGH, msg, os_errno,0);
#endif /* BLKFLSBUF */
#endif /* CDSL_CURRENT */
#endif /* CDROM_MEDIA_CHANGED */
ret = close(*fd); ret = close(*fd);
*fd = -1337; *fd = -1337;
if(ret != -1) { if(ret != -1) {

View File

@ -580,7 +580,7 @@ void spc_sense_write_params(struct burn_drive *d)
/* ts A70212 : try to setup d->media_capacity_remaining */ /* ts A70212 : try to setup d->media_capacity_remaining */
if (d->current_profile == 0x1a || d->current_profile == 0x13 || if (d->current_profile == 0x1a || d->current_profile == 0x13 ||
d->current_profile == 0x12 || d->current_profile == 0x43) d->current_profile == 0x12)
d->read_format_capacities(d, -1); d->read_format_capacities(d, -1);
else if (d->status == BURN_DISC_BLANK || else if (d->status == BURN_DISC_BLANK ||
(d->current_is_cd_profile && d->status == BURN_DISC_APPENDABLE)) { (d->current_is_cd_profile && d->status == BURN_DISC_APPENDABLE)) {

View File

@ -47,14 +47,7 @@ char *burn_strndup(char *s, int n)
void burn_version(int *major, int *minor, int *micro) void burn_version(int *major, int *minor, int *micro)
{ {
/* ts A80408 : switched from configure.ac versioning to libburn.h versioning */
#ifdef burn_header_version_major
*major = burn_header_version_major;
*minor = burn_header_version_minor;
*micro = burn_header_version_micro;
#else
*major = BURN_MAJOR_VERSION; *major = BURN_MAJOR_VERSION;
*minor = BURN_MINOR_VERSION; *minor = BURN_MINOR_VERSION;
*micro = BURN_MICRO_VERSION; *micro = BURN_MICRO_VERSION;
#endif
} }

View File

@ -967,9 +967,8 @@ int burn_precheck_write(struct burn_write_opts *o, struct burn_disc *disc,
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->current_profile == 0x1a || d->current_profile == 0x12 || d->current_profile == 0x1a || d->current_profile == 0x12) {
d->current_profile == 0x43) { /* DVD+RW , DVD-RAM , emulated drive on stdio file */
/* DVD+RW , DVD-RAM , BD-RE, emulated drive on stdio file */
if (o->start_byte >= 0 && (o->start_byte % 2048)) if (o->start_byte >= 0 && (o->start_byte % 2048))
strcat(reasons, strcat(reasons,
"write start address not properly aligned to 2048, "); "write start address not properly aligned to 2048, ");
@ -1371,8 +1370,8 @@ int burn_dvd_write_session(struct burn_write_opts *o,
ret = burn_disc_close_session_dvd_minus_r(o, s); ret = burn_disc_close_session_dvd_minus_r(o, s);
if (ret <= 0) if (ret <= 0)
return 0; return 0;
} else if (d->current_profile == 0x12 || d->current_profile == 0x43) { } else if (d->current_profile == 0x12) {
/* DVD-RAM , BD-RE */ /* DVD-RAM */
/* ??? any finalization needed ? */; /* ??? any finalization needed ? */;
} else if (d->current_profile == 0x13) { } else if (d->current_profile == 0x13) {
/* DVD-RW restricted overwrite */ /* DVD-RW restricted overwrite */
@ -1523,9 +1522,8 @@ int burn_dvd_write_sync(struct burn_write_opts *o,
d->needs_close_session = 0; d->needs_close_session = 0;
if (d->current_profile == 0x1a || d->current_profile == 0x12 || if (d->current_profile == 0x1a || d->current_profile == 0x12) {
d->current_profile == 0x43) { /* DVD+RW , DVD-RAM */
/* DVD+RW , DVD-RAM , BD-RE */
ret = 1; ret = 1;
if (d->current_profile == 0x1a) if (d->current_profile == 0x1a)
ret = burn_disc_setup_dvd_plus_rw(o, disc); ret = burn_disc_setup_dvd_plus_rw(o, disc);
@ -2193,8 +2191,6 @@ int burn_random_access_write(struct burn_drive *d, off_t byte_address,
alignment = 32 * 1024; alignment = 32 * 1024;
if (d->current_profile == 0x1a) /* DVD+RW */ if (d->current_profile == 0x1a) /* DVD+RW */
alignment = 2 * 1024; alignment = 2 * 1024;
if (d->current_profile == 0x43) /* BD-RE */
alignment = 2 * 1024;
if (alignment == 0) { if (alignment == 0) {
sprintf(msg, "Write start address not supported"); sprintf(msg, "Write start address not supported");
libdax_msgs_submit(libdax_messenger, d->global_index, libdax_msgs_submit(libdax_messenger, d->global_index,

View File

@ -9,7 +9,7 @@
libburner is a minimal demo application for the library libburn as provided libburner is a minimal demo application for the library libburn as provided
on http://libburnia-project.org . It can list the available devices, can on http://libburnia-project.org . It can list the available devices, can
blank a CD-RW or DVD-RW, can format a DVD-RW, can burn to CD-R, CD-RW, DVD-R, blank a CD-RW or DVD-RW, can format a DVD-RW, can burn to CD-R, CD-RW, DVD-R,
DVD+R, DVD+R/DL, DVD+RW, DVD-RAM or DVD-RW. Not supported yet: DVD-R/DL, BD. DVD+R, DVD+RW, DVD-RAM or DVD-RW. Not supported yet: double layer media.
It's main purpose, nevertheless, is to show you how to use libburn and also It's main purpose, nevertheless, is to show you how to use libburn and also
to serve the libburnia team as reference application. libburner.c does indeed to serve the libburnia team as reference application. libburner.c does indeed
@ -29,7 +29,7 @@
libburner_blank_disc() libburner_blank_disc()
or you can format a DVD-RW to profile "Restricted Overwrite" (needed once) or you can format a DVD-RW to profile "Restricted Overwrite" (needed once)
libburner_format_row() libburner_format_row()
With the aquired drive you can burn to CD or DVD With the aquired drive you can burn to CD-R, CD-RW, DVD+RW, DVD-RAM, DVD-RW
libburner_payload() libburner_payload()
When everything is done, main() releases the drive and shuts down libburn: When everything is done, main() releases the drive and shuts down libburn:
burn_drive_release(); burn_drive_release();
@ -443,8 +443,7 @@ int libburner_payload(struct burn_drive *drive,
/* Use the fifo object as data source for the track */ /* Use the fifo object as data source for the track */
if (burn_track_set_source(track, fifo_src[trackno]) if (burn_track_set_source(track, fifo_src[trackno])
!= BURN_SOURCE_OK) { != BURN_SOURCE_OK) {
fprintf(stderr, printf("FATAL: Cannot attach source object to track object\n");
"FATAL: Cannot attach source object to track object\n");
return 0; return 0;
} }