Compare commits
73 Commits
release-0.
...
release-0.
Author | SHA1 | Date | |
---|---|---|---|
438024d11b | |||
1d6fdf51dc | |||
281462802f | |||
2b2a86ea2e | |||
c0963596e5 | |||
9be5b241e2 | |||
fcde936670 | |||
73c6bc49c6 | |||
5ed507da83 | |||
ae626b9570 | |||
3528493b92 | |||
9cf460a3b1 | |||
84132ec7bf | |||
eb23260459 | |||
4978424328 | |||
e4cf93665a | |||
3d9367d52a | |||
03b030c56d | |||
a3fe82100b | |||
02d7a690eb | |||
ace0d1ab2e | |||
59d143c1f0 | |||
da2c0520cc | |||
517f520570 | |||
98d2b4c996 | |||
481d425580 | |||
99e988d652 | |||
38a7b4a5b1 | |||
9dc894584d | |||
1a7ab679cd | |||
016baf9984 | |||
b089f2e978 | |||
c3d5ab7bc7 | |||
f13167335a | |||
f0f378c38f | |||
907b44c556 | |||
00011036dd | |||
55497d3931 | |||
c47f206fe3 | |||
386ce0e60a | |||
9fe4172f0d | |||
61f2cdd02b | |||
f87c63da41 | |||
afebbe187d | |||
3951df25be | |||
4b0f175a89 | |||
633a8ada9e | |||
ce723a8c39 | |||
83ace3b486 | |||
23d3c43022 | |||
00470cbfea | |||
4c1abdf2bd | |||
f7842518fb | |||
d756551385 | |||
ced02f5903 | |||
819e3218f6 | |||
c874a159e2 | |||
a68e108333 | |||
da23a8166c | |||
cbb376a137 | |||
3852621bc0 | |||
0ff4cb34ed | |||
d863451771 | |||
78308eea24 | |||
0ab2b8260c | |||
a30bd36a81 | |||
3814396b08 | |||
f88d8a76b0 | |||
6bc1395e15 | |||
6bf538ff40 | |||
c992687200 | |||
9cfa55345e | |||
d9a11a3b8d |
@ -1,12 +1,12 @@
|
|||||||
Vreixo Formoso <metalpain2002@yahoo.es>,
|
Vreixo Formoso <metalpain2002@yahoo.es>,
|
||||||
Mario Danic <mario.danic@gmail.com>,
|
Mario Danic <mario.danic@gmail.com>,
|
||||||
Thomas Schmitt <scdbackup@gmx.net>
|
Thomas Schmitt <scdbackup@gmx.net>
|
||||||
Copyright (C) 2007-2008 Vreixo Formoso, Mario Danic, Thomas Schmitt
|
Copyright (C) 2007-2010 Vreixo Formoso, 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 version 2 or later
|
||||||
published by the Free Software Foundation.
|
as published by the Free Software Foundation.
|
||||||
|
|
||||||
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
|
||||||
|
@ -261,6 +261,7 @@ EXTRA_DIST = \
|
|||||||
doc/susp_aaip_2_0.txt \
|
doc/susp_aaip_2_0.txt \
|
||||||
doc/susp_aaip_isofs_names.txt \
|
doc/susp_aaip_isofs_names.txt \
|
||||||
doc/zisofs_format.txt \
|
doc/zisofs_format.txt \
|
||||||
|
doc/checksums.txt \
|
||||||
libisofs/aaip-os-dummy.c \
|
libisofs/aaip-os-dummy.c \
|
||||||
libisofs/aaip-os-linux.c \
|
libisofs/aaip-os-linux.c \
|
||||||
libisofs/aaip-os-freebsd.c
|
libisofs/aaip-os-freebsd.c
|
||||||
|
373
README
373
README
@ -4,93 +4,9 @@
|
|||||||
|
|
||||||
Released under GPL (see COPYING file for details).
|
Released under GPL (see COPYING file for details).
|
||||||
|
|
||||||
Copyright (C) 2008 Vreixo Formoso, Mario Danic, Thomas Schmitt
|
Copyright (C) 2008 - 2010 Vreixo Formoso, Mario Danic, Thomas Schmitt
|
||||||
|
|
||||||
libisofs is part of the libburnia project (libburnia-project.org)
|
libisofs is part of the libburnia project (libburnia-project.org)
|
||||||
------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
libisofs is a library to create an ISO-9660 filesystem, and supports extensions
|
|
||||||
like RockRidge or Joliet. It is also a full featured ISO-9660 editor, allowing
|
|
||||||
you to modify an ISO image or multisession disc, including file addition and
|
|
||||||
removal, change of file names and attributes, etc
|
|
||||||
|
|
||||||
Features:
|
|
||||||
---------
|
|
||||||
|
|
||||||
- Image creation
|
|
||||||
- Creates ISO-9660 images from local files.
|
|
||||||
- Support for RockRidge and Joliet extensions.
|
|
||||||
- Support for ISO-9660:1999 (version 2)
|
|
||||||
- Support for El-Torito bootable images.
|
|
||||||
- Full featured edition of file names and attributes on the image.
|
|
||||||
- Several options to relax ISO-9660 constraints.
|
|
||||||
- Special options for images intended for distribution (suitable default
|
|
||||||
modes for files, hiding of real timestamps...)
|
|
||||||
- Multisession
|
|
||||||
- Support for growing an existing image
|
|
||||||
- Full-featured edition of the image files, including: addition of new
|
|
||||||
files, removing of existent files, moving files, renaming files,
|
|
||||||
change file attributes (permissions, timestamps...)
|
|
||||||
- Support for "emulated multisession" or image growing, suitable for non
|
|
||||||
multisession media such as DVD+RW
|
|
||||||
- Image modification
|
|
||||||
- It can create a completely new image from files on another image.
|
|
||||||
- Full-featured edition of image contents
|
|
||||||
- Others
|
|
||||||
- Handling of different input and output charset
|
|
||||||
- Good integration with libburn for image burning.
|
|
||||||
- Reliable, good handling of different kind of errors.
|
|
||||||
|
|
||||||
Requirements:
|
|
||||||
-------------
|
|
||||||
|
|
||||||
- libburn 0.4.2 headers must be installed at compile time. It is not required
|
|
||||||
at runtime.
|
|
||||||
|
|
||||||
Know bugs:
|
|
||||||
----------
|
|
||||||
|
|
||||||
Multisession and image growing can lead to undesired results in several cases:
|
|
||||||
|
|
||||||
a) Images with unsupported features, such as:
|
|
||||||
- UDF.
|
|
||||||
- HSF/HFS+ or other Mac extensions.
|
|
||||||
- El-Torito with multiple entries.
|
|
||||||
- ECMA-119 with extended attributes, multiple extends per file.
|
|
||||||
- Non El-Torito boot info.
|
|
||||||
- zisofs compressed images.
|
|
||||||
- ...
|
|
||||||
In all these cases, the resulting new image (or new session) could lack some
|
|
||||||
features of the original image.
|
|
||||||
In some cases libisofs will issue warning messages, or even refuse to grow
|
|
||||||
or modify the image. Others remain undetected. Images created with libisofs
|
|
||||||
do not have this problems.
|
|
||||||
|
|
||||||
b) Bootable El-Torito images may have several problems, that result in a new
|
|
||||||
image that is not bootable, or that boots from an outdated session. In many
|
|
||||||
cases it is recommended to add boot info again in the new session.
|
|
||||||
|
|
||||||
- isolinux images won't be bootable after a modify. This is because
|
|
||||||
isolinux images need to have hardcoded the root dir lba. libisofs cannot
|
|
||||||
know whether an image is an isolinux image or not, so the user is
|
|
||||||
responsible to tell libisofs that it must patch the image, with the
|
|
||||||
el_torito_patch_isolinux_image() function. This problem could also exists
|
|
||||||
on other boot images.
|
|
||||||
- Most boot images are highly dependent of the image contents, so if the
|
|
||||||
user moves or removes some files on image it is possible they won't boot
|
|
||||||
anymore.
|
|
||||||
- There is no safer way to modify hidden boot images, as the size of the
|
|
||||||
boot image can't be figured out.
|
|
||||||
|
|
||||||
c) Generated images could have different ECMA-119 low level names, due to
|
|
||||||
different way to mangle names, to new files added that force old files to
|
|
||||||
be renamed, to different relaxed contraints... This only affect the
|
|
||||||
ISO-9660 info, not the RR names, so it shouldn't be a problem in most
|
|
||||||
cases. If your app. relies on low level ISO-9660 names, you will need to
|
|
||||||
ensure all node names are valid ISO names (maybe together with some
|
|
||||||
relaxed contraints), otherwise libisofs might arbitrarily change the names.
|
|
||||||
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
Download, Build and Installation
|
Download, Build and Installation
|
||||||
@ -98,7 +14,7 @@ c) Generated images could have different ECMA-119 low level names, due to
|
|||||||
libisofs code is mantained in a Bazaar repository at Launchpad
|
libisofs code is mantained in a Bazaar repository at Launchpad
|
||||||
(https://launchpad.net/libisofs/). You can download it with:
|
(https://launchpad.net/libisofs/). You can download it with:
|
||||||
|
|
||||||
$ bzr branch lp:libisofs
|
$ bzr branch lp:libisofs/for-libisoburn
|
||||||
|
|
||||||
Our build system is based on autotools. For preparing the build you will need
|
Our build system is based on autotools. For preparing the build you will need
|
||||||
autotools of at least version 1.7. If you have download the code from the
|
autotools of at least version 1.7. If you have download the code from the
|
||||||
@ -109,7 +25,8 @@ repository, first of all you need to execute
|
|||||||
on toplevel dir to execute autotools.
|
on toplevel dir to execute autotools.
|
||||||
|
|
||||||
Alternatively you may unpack a release tarball for which you do not need
|
Alternatively you may unpack a release tarball for which you do not need
|
||||||
autotools installed.
|
autotools installed. For the most recent release of libisofs see:
|
||||||
|
http://libburnia-project.org/wiki/Releases
|
||||||
|
|
||||||
To build libisofs it should be sufficient to go into its toplevel directory
|
To build libisofs it should be sufficient to go into its toplevel directory
|
||||||
and execute
|
and execute
|
||||||
@ -125,176 +42,119 @@ See INSTALL file for further details.
|
|||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
Overview of libburnia-project.org
|
libisofs is a library to create an ISO-9660 filesystem, supports extensions
|
||||||
|
like RockRidge or Joliet, and introduces an own extension AAIP.
|
||||||
|
It is a full featured ISO-9660 editor which composes and changes the directory
|
||||||
|
tree of an ISO image. This tree and its newly imported data file contents get
|
||||||
|
then written as independent single-session image or as add-on session for the
|
||||||
|
image from where the tree was originally loaded.
|
||||||
|
|
||||||
libburnia-project.org is an open-source software project for reading, mastering
|
Features:
|
||||||
and writing optical discs.
|
---------
|
||||||
For now this means only CD media and all single layer DVD media except DVD+R.
|
|
||||||
|
|
||||||
The project comprises of several more or less interdependent parts which
|
- Image creation
|
||||||
together strive to be a usable foundation for application development.
|
- Creates ISO-9660 images from local files.
|
||||||
These are libraries, language bindings, and middleware binaries which emulate
|
- Support for RockRidge and Joliet extensions.
|
||||||
classical (and valuable) Linux tools.
|
- Support for ISO-9660:1999 (version 2).
|
||||||
|
- Support for El-Torito bootable images. Tested are: PC-BIOS and EFI.
|
||||||
|
- Support for multi-extent data files up to 400 GB (level 3).
|
||||||
|
- Full-featured edition of the image files, including: addition of new
|
||||||
|
files, removing of existent files, moving files, renaming files,
|
||||||
|
change file attributes (permissions, timestamps...)
|
||||||
|
- Optional recording per file of non-ISO 9660 features:
|
||||||
|
ACL, xattr, content MD5, hard link relations.
|
||||||
|
They do not hamper image readability by operating systems but can be
|
||||||
|
retrieved only via libisofs.
|
||||||
|
- Optional zisofs compression, gzip compression, external filter
|
||||||
|
processes.
|
||||||
|
- Several options to relax ISO-9660 constraints.
|
||||||
|
- Special options for images intended for distribution (suitable
|
||||||
|
default modes for files, hiding of real timestamps...).
|
||||||
|
- Image reading
|
||||||
|
- Image tree and data heap can be verified by stream reading and
|
||||||
|
eventually recorded MD5 tags.
|
||||||
|
- Directory tree and file attributes of ISO 9660 session get loaded
|
||||||
|
into memory for editing or for extraction into local filesystem.
|
||||||
|
- File content can be read by applications.
|
||||||
|
- Automatic zisofs decompression.
|
||||||
|
- Optional application of gzip decompression or external filter
|
||||||
|
processes.
|
||||||
|
- Eventually recorded MD5 of data file can be obtained, MD5 of data
|
||||||
|
stream can be computed and compared.
|
||||||
|
- Helper functions for restoring ACL and/or xattr to the local
|
||||||
|
filesystem.
|
||||||
|
- Multisession
|
||||||
|
- Support for growing an existing image on multi-session media.
|
||||||
|
- Support for "emulated multisession" on overwriteable media such as
|
||||||
|
DVD+RW, USB sticks, regular files.
|
||||||
|
- Support for blindly prepared add-on sessions (mkisofs style -M -C)
|
||||||
|
suitable for pipes which lead to an external burn program.
|
||||||
|
- Image modification
|
||||||
|
- Creates a completely new image from files out of another image and
|
||||||
|
eventual editing operations. Suitable for any target medium.
|
||||||
|
- Others
|
||||||
|
- Handling of different input and output charset.
|
||||||
|
- Good integration with libburn for image burning.
|
||||||
|
- Reliable, good handling of different kind of errors.
|
||||||
|
|
||||||
Our scope is currently Linux 2.4 and 2.6 only. For ports to other systems
|
Requirements:
|
||||||
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,
|
|
||||||
volunteers for testing of realistic use cases.
|
|
||||||
|
|
||||||
We have a workable code base for burning CD and most single layer DVD.
|
- iconv() functions for character set conversion must be available.
|
||||||
The burn API is quite comprehensively documented and can be used to build a
|
Either implicitely as in Linux or by a separate library like libiconv
|
||||||
presentable application.
|
on FreeBSD.
|
||||||
We have a functional binary which emulates parts of cdrecord in order to
|
|
||||||
prove that usability, and in order to allow you to explore libburnia's scope
|
|
||||||
by help of existing cdrecord frontends.
|
|
||||||
|
|
||||||
The project components (list subject to growth, hopefully):
|
Know bugs:
|
||||||
|
----------
|
||||||
|
|
||||||
- libburn is the library by which preformatted data get onto optical media.
|
Multisession and image growing can lead to undesired results in several cases:
|
||||||
It uses either /dev/sgN (e.g. on kernel 2.4 with ide-scsi) or
|
|
||||||
/dev/hdX (e.g. on kernel 2.6).
|
|
||||||
libburn is the foundation of our cdrecord emulation. Its code is
|
|
||||||
independent of cdrecord. Its DVD capabilities are learned from
|
|
||||||
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.
|
|
||||||
|
|
||||||
- libisofs is the library to pack up hard disk files and directories into a
|
a) Images with unsupported features, such as:
|
||||||
ISO 9660 disk image. This may then be brought to media via libburn.
|
- UDF.
|
||||||
libisofs is to be the foundation of our upcoming mkisofs emulation.
|
- HSF/HFS+ or other Mac extensions.
|
||||||
|
- ECMA-119 Extended attributes.
|
||||||
|
- Non El-Torito boot info.
|
||||||
|
- ...
|
||||||
|
In all these cases, the resulting new image (or new session) could lack some
|
||||||
|
features of the original image. Nevertheless, the ECMA-119 System Area with
|
||||||
|
an eventual Master Boot Record gets preserved by default.
|
||||||
|
In some cases libisofs will issue warning messages, or even refuse to grow
|
||||||
|
or modify the image. Others remain undetected. Images created with libisofs
|
||||||
|
do not have this problems.
|
||||||
|
|
||||||
- cdrskin is a limited cdrecord compatibility wrapper for libburn.
|
b) Bootable El-Torito images may have several problems, that result in a new
|
||||||
Cdrecord is a powerful GPL'ed burn program included in Joerg
|
image that is not bootable, or that boots from an outdated session. In many
|
||||||
Schilling's cdrtools. cdrskin strives to be a second source for
|
cases it is recommended to add boot info again in the new session.
|
||||||
the services traditionally provided by cdrecord. Additionally it
|
|
||||||
provides libburn's DVD capabilities, where only -sao is compatible
|
|
||||||
with cdrecord.
|
|
||||||
cdrskin does not contain any bytes copied from cdrecord's sources.
|
|
||||||
Many bytes have been copied from the message output of cdrecord
|
|
||||||
runs, though.
|
|
||||||
See cdrskin/README and man cdrskin/cdrskin.1 for more.
|
|
||||||
|
|
||||||
- test is a collection of application gestures and examples given by the
|
- isolinux images won't be bootable after a modify. This is because
|
||||||
authors of the library features. The main API example for libburn
|
isolinux images need to have hardcoded the root dir lba in their boot
|
||||||
is test/libburner.c .
|
information table.
|
||||||
Explore these examples if you look for inspiration.
|
libisofs makes an educated guess at load time whether a boot image
|
||||||
|
contains such a table. Its outcome can be inquired by call
|
||||||
|
el_torito_seems_boot_info_table().
|
||||||
|
If one knows to have isolinux or GRUB El-Torito-bootable images, or if
|
||||||
|
a boot information table seems to exist, it is advised to apply the
|
||||||
|
el_torito_patch_isolinux_image() function.
|
||||||
|
Most boot images are highly dependent of the image contents, so if the
|
||||||
|
user moves or removes some files on image it is possible they won't boot
|
||||||
|
anymore.
|
||||||
|
- There is no safe way to modify hidden boot images, as the size of the
|
||||||
|
boot image can't be figured out.
|
||||||
|
|
||||||
We plan to be a responsive upstream. Bear with us. We are still practicing.
|
c) Generated images could have different ECMA-119 low level names, due to
|
||||||
|
different way to mangle names, to new files added that force old files to
|
||||||
|
be renamed, to different relaxed contraints... This only affect the
|
||||||
------------------------------------------------------------------------------
|
ISO-9660 info, not the RR names, so it shouldn't be a problem in most
|
||||||
Project history as far as known to me:
|
cases. If your app. relies on low level ISO-9660 names, you will need to
|
||||||
|
ensure all node names are valid ISO names (maybe together with some
|
||||||
- Founded in 2002 as it seems. See mailing list archives
|
relaxed contraints), otherwise libisofs might arbitrarily change the names.
|
||||||
http://lists.freedesktop.org/archives/libburn/
|
|
||||||
The site of this founder team is reachable and offers download of a
|
|
||||||
(somewhat outdated) tarball and from CVS :
|
|
||||||
http://icculus.org/burn/
|
|
||||||
Copyright holders and most probably founders:
|
|
||||||
Derek Foreman and Ben Jansens.
|
|
||||||
|
|
||||||
- I came to using libburn in 2005. Founded the cdrskin project and submitted
|
|
||||||
necessary patches which were accepted or implemented better. Except one
|
|
||||||
remaining patch which prevented cdrskin from using vanilla libburn from CVS.
|
|
||||||
The cdrskin project site is reachable and offers download of the heavily
|
|
||||||
patched (elsewise outdated) tarball under the name cdrskin-0.1.2 :
|
|
||||||
http://scdbackup.sourceforge.net/cdrskin_eng.html
|
|
||||||
It has meanwhile moved to use vanilla libburn.pykix.org , though.
|
|
||||||
Version 0.1.4 constitutes the first release of this kind.
|
|
||||||
|
|
||||||
- In July 2006 our team mate Mario Danic announced a revival of libburn
|
|
||||||
which by about nearly everybody else was perceived as unfriendly fork.
|
|
||||||
Derek Foreman four days later posted a message which expressed his
|
|
||||||
discontent.
|
|
||||||
The situation first caused me to publically regret it and then - after i
|
|
||||||
got the opportunity to move in with cdrskin - gave me true reason to
|
|
||||||
personally apologize to Derek Foreman, Ben Jansens and the contibutors at
|
|
||||||
icculus.org/burn. Posted to both projects:
|
|
||||||
http://lists.freedesktop.org/archives/libburn/2006-August/000446.html
|
|
||||||
http://mailman-mail1.webfaction.com/pipermail/libburn-hackers/2006-August/000024.html
|
|
||||||
|
|
||||||
- Mid August 2006 project cdrskin established a branch office in
|
|
||||||
libburn.pykix.org so that all maintainers of our tools have one single place
|
|
||||||
to get the current (at least slightely) usable coordinated versions of
|
|
||||||
everything.
|
|
||||||
Project cdrskin will live forth independendly for a while but it is committed
|
|
||||||
to stay in sync with libburn.pykix.org (or some successor, if ever).
|
|
||||||
cdrskin is also committed to support icculus.org/burn if the pending fork
|
|
||||||
is made reality by content changes in that project. It will cease to maintain
|
|
||||||
a patched version of icculus.org/burn though. Precondition for a new
|
|
||||||
release of cdrskin on base of icculus.org/burn would be the pending
|
|
||||||
"whitelist patch" therefore.
|
|
||||||
I would rather prefer if both projects find consense and merge, or at least
|
|
||||||
cooperate. I have not given up hope totally, yet.
|
|
||||||
I, personally, will honor any approach.
|
|
||||||
|
|
||||||
- 2nd September 2006 the decision is made to strive for a consolidation of
|
|
||||||
copyright and a commitment to GPL in a reasonable and open minded way.
|
|
||||||
This is to avoid long term problems with code of unknown origin and
|
|
||||||
with finding consense among the not so clearly defined group of copyright
|
|
||||||
claimers and -holders.
|
|
||||||
libisofs is already claimed sole copyright Mario Danic.
|
|
||||||
cdrskin and libburner are already claimed sole copyright Thomas Schmitt.
|
|
||||||
Rewrites of other components will follow and concluded by claiming full
|
|
||||||
copyright within the group of libburn.pykix.org-copyright holders.
|
|
||||||
|
|
||||||
- 16th September 2006 feature freeze for release of libburn-0.2.2 .
|
|
||||||
|
|
||||||
- 20th September 2006 release of libburn-0.2.2 .
|
|
||||||
|
|
||||||
- 26th October 2006 feature freeze for cdrskin-0.2.4 based on libburn-0.2.3 .
|
|
||||||
This version of cdrskin is much more cdrecord compatible in repect
|
|
||||||
to drive addressing and audio features.
|
|
||||||
|
|
||||||
- 30th October 2006 release of cdrskin-0.2.4 .
|
|
||||||
|
|
||||||
- 13th November 2006 splitting releases of libburn+cdrskin from libisofs.
|
|
||||||
|
|
||||||
- 24th November 2006 release of libburn-0.2.6 and cdrskin-0.2.6 . cdrskin has
|
|
||||||
become suitable for unaware frontends as long as they perform only the core
|
|
||||||
of cdrecord use cases (including open-ended input streams, audio, and
|
|
||||||
multi-session).
|
|
||||||
|
|
||||||
- 28th November 2006 the umbrella project which encloses both, libisofs and
|
|
||||||
libburn, is now called libburnia. For the origin of this name, see
|
|
||||||
http://en.wikipedia.org/wiki/Liburnians .
|
|
||||||
|
|
||||||
- 16th January 2007 release of libburn-0.3.0 and cdrskin-0.3.0 . Now the scope
|
|
||||||
is widened to a first class of DVD media: overwriteable single layer types
|
|
||||||
DVD-RAM, DVD+RW, DVD-RW. This is not a cdrecord emulation but rather inspired
|
|
||||||
by dvd+rw-tools' "poor man" writing facility for this class of media.
|
|
||||||
Taking a bow towards Andy Polyakov.
|
|
||||||
|
|
||||||
- 11th February 2007 version 0.3.2 covers sequential DVD-RW and DVD-R with
|
|
||||||
multi-session and with DAO.
|
|
||||||
|
|
||||||
- 12th March 2007 version 0.3.4 supports DVD+R and thus covers all single layer
|
|
||||||
DVD media. Code for double layer DVD+/-R is implemented but awaits a tester
|
|
||||||
yet.
|
|
||||||
|
|
||||||
- 23th April 2007 version 0.3.6 follows the unanimous opinion of Linux kernel
|
|
||||||
people that one should not use /dev/sg on kernel 2.6.
|
|
||||||
|
|
||||||
- 31st July 2007 version 0.3.8 marks the first anniversary of libburn revival.
|
|
||||||
We look back on improved stability, a substantially extended list of media
|
|
||||||
and write modes, and better protection against typical user mishaps.
|
|
||||||
|
|
||||||
- 24th October 2007 version 0.4.0 is the foundation of new library libisoburn
|
|
||||||
and an upcomming integrated application for manipulating and writing
|
|
||||||
ISO 9660 + Rock Ridge images. cdrskin-0.4.0 got capabilities like growisofs
|
|
||||||
by these enhancements: growing of overwriteable media and disk files.
|
|
||||||
Taking again a bow towards Andy Polyakov.
|
|
||||||
|
|
||||||
- 26th Januar 2008 version 0.4.2 rectifies the version numbering so that we
|
|
||||||
reliably release libburn.so.4 as should have been done since libburn-0.3.2.
|
|
||||||
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.
|
|
||||||
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
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 as published by
|
it under the terms of the GNU General Public License version 2 or later
|
||||||
the Free Software Foundation. To be exact: version 2 of that License.
|
as published by the Free Software Foundation.
|
||||||
|
|
||||||
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
|
||||||
@ -309,19 +169,19 @@ Project history as far as known to me:
|
|||||||
Clarification in my name and in the name of Mario Danic, upcoming copyright
|
Clarification in my name and in the name of Mario Danic, upcoming copyright
|
||||||
holders on toplevel of libburnia. To be fully in effect after the remaining
|
holders on toplevel of libburnia. To be fully in effect after the remaining
|
||||||
other copyrighted code has been replaced by ours and by copyright-free
|
other copyrighted code has been replaced by ours and by copyright-free
|
||||||
contributions of our friends:
|
contributions of our friends.
|
||||||
|
|
||||||
|
Note:
|
||||||
|
In the particular case of libisofs there is no foreign copyright involved.
|
||||||
|
As of 2010 foreign copyright is only in component libburn.
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
We, the copyright holders, agree on the interpretation that
|
We will not raise any legal protest to dynamic linking of our libraries
|
||||||
dynamical linking of our libraries constitutes "use of" and
|
with applications that are not under GPL, as long as they fulfill
|
||||||
not "derivation from" our work in the sense of GPL, provided
|
the condition of offering the library source code used, whether
|
||||||
those libraries are compiled from our unaltered code.
|
altered or unaltered, under the GPLv2+, along with the application.
|
||||||
|
Nevertheless, the safest legal position is not to link libburn with
|
||||||
Thus you may link our libraries dynamically with applications
|
non-GPL compatible programs.
|
||||||
which are not under GPL. You may distribute our libraries and
|
|
||||||
application tools in binary form, if you fulfill the usual
|
|
||||||
condition of GPL to offer a copy of the source code -altered
|
|
||||||
or unaltered- under GPL.
|
|
||||||
|
|
||||||
We ask you politely to use our work in open source spirit
|
We ask you politely to use our work in open source spirit
|
||||||
and with the due reference to the entire open source community.
|
and with the due reference to the entire open source community.
|
||||||
@ -335,7 +195,10 @@ It is the open source idea of responsible freedom which will be
|
|||||||
decisive and you will have to prove that you exhausted all own
|
decisive and you will have to prove that you exhausted all own
|
||||||
means to qualify for GPL.
|
means to qualify for GPL.
|
||||||
|
|
||||||
For now we are firmly committed to maintain one single license: GPL.
|
We are firmly committed to allow GPLv2+ now and with future releases.
|
||||||
|
|
||||||
signed: Mario Danic, Thomas Schmitt
|
Signed: Mario Danic, Thomas Schmitt
|
||||||
|
Agreement joined later by: Vreixo Formoso
|
||||||
|
|
||||||
|
Public contact: <libburn-hackers@pykix.org>
|
||||||
|
|
||||||
|
65
acinclude.m4
65
acinclude.m4
@ -1,3 +1,14 @@
|
|||||||
|
AC_DEFUN([LIBBURNIA_SET_FLAGS],
|
||||||
|
[
|
||||||
|
case $target_os in
|
||||||
|
freebsd*)
|
||||||
|
LDFLAGS="$LDFLAGS -L/usr/local/lib"
|
||||||
|
CPPFLAGS="$CPPFLAGS -I/usr/local/include"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
AC_DEFUN([TARGET_SHIZZLE],
|
AC_DEFUN([TARGET_SHIZZLE],
|
||||||
[
|
[
|
||||||
ARCH=""
|
ARCH=""
|
||||||
@ -39,8 +50,9 @@ dnl From Bruno Haible.
|
|||||||
dnl
|
dnl
|
||||||
AC_DEFUN([LIBBURNIA_CHECK_ICONV],
|
AC_DEFUN([LIBBURNIA_CHECK_ICONV],
|
||||||
[
|
[
|
||||||
|
|
||||||
dnl Check whether it is allowed to link with -liconv
|
dnl Check whether it is allowed to link with -liconv
|
||||||
AC_MSG_CHECKING([for separate -liconv ])
|
AC_MSG_CHECKING([for iconv() in separate -liconv ])
|
||||||
libburnia_liconv="no"
|
libburnia_liconv="no"
|
||||||
libburnia_save_LIBS="$LIBS"
|
libburnia_save_LIBS="$LIBS"
|
||||||
LIBS="$LIBS -liconv"
|
LIBS="$LIBS -liconv"
|
||||||
@ -54,6 +66,13 @@ AC_DEFUN([LIBBURNIA_CHECK_ICONV],
|
|||||||
)
|
)
|
||||||
AC_MSG_RESULT([$libburnia_liconv])
|
AC_MSG_RESULT([$libburnia_liconv])
|
||||||
|
|
||||||
|
if test x"$libburnia_save_LIBS" = x"$LIBS"
|
||||||
|
then
|
||||||
|
dnl GNU iconv has no function iconv() but libiconv() and a macro iconv()
|
||||||
|
dnl It is not tested whether this is detected by above macro.
|
||||||
|
AC_CHECK_LIB(iconv, libiconv, , )
|
||||||
|
fi
|
||||||
|
|
||||||
dnl Check for iconv(..., const char **inbuf, ...)
|
dnl Check for iconv(..., const char **inbuf, ...)
|
||||||
AC_MSG_CHECKING([for const qualifier with iconv() ])
|
AC_MSG_CHECKING([for const qualifier with iconv() ])
|
||||||
AC_TRY_COMPILE([
|
AC_TRY_COMPILE([
|
||||||
@ -68,6 +87,50 @@ size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, si
|
|||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
dnl LIBBURNIA_ASSERT_ICONV is by Thomas Schmitt, libburnia project
|
||||||
|
dnl
|
||||||
|
AC_DEFUN([LIBBURNIA_ASSERT_ICONV],
|
||||||
|
[
|
||||||
|
if test x$LIBISOFS_ASSUME_ICONV = x
|
||||||
|
then
|
||||||
|
dnl Check for the essential gestures of libisofs/util.c
|
||||||
|
AC_MSG_CHECKING([for iconv() to be accessible now ])
|
||||||
|
AC_TRY_LINK([
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <wchar.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <limits.h>
|
||||||
|
#include <iconv.h>
|
||||||
|
#include <locale.h>
|
||||||
|
#include <langinfo.h>
|
||||||
|
#include <unistd.h>],
|
||||||
|
[iconv_t cd = iconv_open("","");
|
||||||
|
iconv(cd,NULL,NULL,NULL,NULL);
|
||||||
|
iconv_close(cd);
|
||||||
|
], [iconv_test="yes"], [iconv_test="no"]
|
||||||
|
)
|
||||||
|
AC_MSG_RESULT([$iconv_test])
|
||||||
|
if test x$iconv_test = xno
|
||||||
|
then
|
||||||
|
echo >&2
|
||||||
|
echo "Cannot get function iconv() to work. Configuration aborted." >&2
|
||||||
|
echo "Check whether your system needs a separate libiconv installed." >&2
|
||||||
|
echo "If it is installed but not found, try something like" >&2
|
||||||
|
echo ' export LDFLAGS="$LDFLAGS -L/usr/local/lib"' >&2
|
||||||
|
echo ' export CPPFLAGS="$CPPFLAGS -I/usr/local/include"' >&2
|
||||||
|
echo ' export LIBS="$LIBS -liconv"' >&2
|
||||||
|
echo "You may override this test by exporting variable" >&2
|
||||||
|
echo " LIBISOFS_ASSUME_ICONV=yes" >&2
|
||||||
|
echo >&2
|
||||||
|
(exit 1); exit 1;
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
dnl LIBBURNIA_SET_PKGCONFIG determines the install directory for the *.pc file.
|
dnl LIBBURNIA_SET_PKGCONFIG determines the install directory for the *.pc file.
|
||||||
dnl Important: Must be performed _after_ TARGET_SHIZZLE
|
dnl Important: Must be performed _after_ TARGET_SHIZZLE
|
||||||
dnl
|
dnl
|
||||||
|
31
configure.ac
31
configure.ac
@ -1,17 +1,13 @@
|
|||||||
AC_INIT([libisofs], [0.6.22], [http://libburnia-project.org])
|
AC_INIT([libisofs], [0.6.34], [http://libburnia-project.org])
|
||||||
AC_PREREQ([2.50])
|
AC_PREREQ([2.50])
|
||||||
dnl AC_CONFIG_HEADER([config.h])
|
dnl AC_CONFIG_HEADER([config.h])
|
||||||
|
|
||||||
AC_CANONICAL_HOST
|
AC_CANONICAL_HOST
|
||||||
AC_CANONICAL_TARGET
|
AC_CANONICAL_TARGET
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE([subdir-objects])
|
LIBBURNIA_SET_FLAGS
|
||||||
|
|
||||||
dnl A61101 This breaks Linux build (makes 32 bit off_t)
|
AM_INIT_AUTOMAKE([subdir-objects])
|
||||||
dnl http://sourceware.org/autobook/autobook/autobook_96.html says
|
|
||||||
dnl one must include some config.h and this was a pitfall.
|
|
||||||
dnl So why dig the pit at all ?
|
|
||||||
dnl AM_CONFIG_HEADER(config.h)
|
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl if MAJOR or MINOR version changes, be sure to change AC_INIT above to match
|
dnl if MAJOR or MINOR version changes, be sure to change AC_INIT above to match
|
||||||
@ -37,14 +33,14 @@ dnl iso_lib_version(). It returns the major, minor and micro revision of the
|
|||||||
dnl library. This means LIBISOFS_*_VERSION kept its second job which does not
|
dnl library. This means LIBISOFS_*_VERSION kept its second job which does not
|
||||||
dnl comply to the usual ways of configure.ac . I.e. now *officially* this is
|
dnl comply to the usual ways of configure.ac . I.e. now *officially* this is
|
||||||
dnl the source code release version as announced to the public. It has no
|
dnl the source code release version as announced to the public. It has no
|
||||||
dnl conection to SONAME or libtool version numbering.
|
dnl connection to SONAME or libtool version numbering.
|
||||||
dnl It rather feeds the API function iso_lib_version().
|
dnl It rather feeds the API function iso_lib_version().
|
||||||
dnl
|
dnl
|
||||||
dnl If LIBISOFS_*_VERSION changes, be sure to change AC_INIT above to match.
|
dnl If LIBISOFS_*_VERSION changes, be sure to change AC_INIT above to match.
|
||||||
dnl
|
dnl
|
||||||
LIBISOFS_MAJOR_VERSION=0
|
LIBISOFS_MAJOR_VERSION=0
|
||||||
LIBISOFS_MINOR_VERSION=6
|
LIBISOFS_MINOR_VERSION=6
|
||||||
LIBISOFS_MICRO_VERSION=22
|
LIBISOFS_MICRO_VERSION=34
|
||||||
LIBISOFS_VERSION=$LIBISOFS_MAJOR_VERSION.$LIBISOFS_MINOR_VERSION.$LIBISOFS_MICRO_VERSION
|
LIBISOFS_VERSION=$LIBISOFS_MAJOR_VERSION.$LIBISOFS_MINOR_VERSION.$LIBISOFS_MICRO_VERSION
|
||||||
|
|
||||||
AC_SUBST(LIBISOFS_MAJOR_VERSION)
|
AC_SUBST(LIBISOFS_MAJOR_VERSION)
|
||||||
@ -54,11 +50,11 @@ AC_SUBST(LIBISOFS_VERSION)
|
|||||||
|
|
||||||
dnl Libtool versioning
|
dnl Libtool versioning
|
||||||
LT_RELEASE=$LIBISOFS_MAJOR_VERSION.$LIBISOFS_MINOR_VERSION
|
LT_RELEASE=$LIBISOFS_MAJOR_VERSION.$LIBISOFS_MINOR_VERSION
|
||||||
# 2009.08.25 development jump has not yet happened
|
# 2010.05.03 development jump has not yet happened
|
||||||
# SONAME = 24 - 18 = 6 . Library name = libisofs.6.18.0
|
# SONAME = 36 - 30 = 6 . Library name = libisofs.6.30.0
|
||||||
LT_CURRENT=24
|
LT_CURRENT=36
|
||||||
|
LT_AGE=30
|
||||||
LT_REVISION=0
|
LT_REVISION=0
|
||||||
LT_AGE=18
|
|
||||||
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)
|
||||||
@ -89,6 +85,9 @@ dnl If iconv(3) is in an extra lib, then it gets added to variable LIBS.
|
|||||||
dnl If not, then no -liconv will be added.
|
dnl If not, then no -liconv will be added.
|
||||||
LIBBURNIA_CHECK_ICONV
|
LIBBURNIA_CHECK_ICONV
|
||||||
|
|
||||||
|
dnl To abort configuration if iconv() still cannot be compiled
|
||||||
|
LIBBURNIA_ASSERT_ICONV
|
||||||
|
|
||||||
|
|
||||||
AC_PROG_LIBTOOL
|
AC_PROG_LIBTOOL
|
||||||
AC_SUBST(LIBTOOL_DEPS)
|
AC_SUBST(LIBTOOL_DEPS)
|
||||||
@ -196,9 +195,11 @@ AC_ARG_ENABLE(zlib,
|
|||||||
if test "x$enable_zlib" = xyes; then
|
if test "x$enable_zlib" = xyes; then
|
||||||
dnl Check whether there is the header for zlib.
|
dnl Check whether there is the header for zlib.
|
||||||
dnl If not, erase this macro which would enable use of compress2() and others.
|
dnl If not, erase this macro which would enable use of compress2() and others.
|
||||||
dnl The empty parameter after "compress2" causes -lz.
|
dnl Linking fails on SuSE 9.0 because zlib has compress2() but lacks
|
||||||
|
dnl compressBound(). So compressBound is the more modern thing to test.
|
||||||
|
dnl The empty parameter after "compressBound" causes -lz.
|
||||||
ZLIB_DEF="-DLibisofs_with_zliB"
|
ZLIB_DEF="-DLibisofs_with_zliB"
|
||||||
AC_CHECK_HEADER(zlib.h, AC_CHECK_LIB(z, compress2, , ZLIB_DEF= ), ZLIB_DEF= )
|
AC_CHECK_HEADER(zlib.h, AC_CHECK_LIB(z, compressBound, , ZLIB_DEF= ), ZLIB_DEF= )
|
||||||
else
|
else
|
||||||
ZLIB_DEF=
|
ZLIB_DEF=
|
||||||
fi
|
fi
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
11
demo/demo.c
11
demo/demo.c
@ -3,9 +3,9 @@
|
|||||||
* Copyright (c) 2007 - 2009 Vreixo Formoso, Thomas Schmitt
|
* Copyright (c) 2007 - 2009 Vreixo Formoso, Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
*
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static char helptext[][80] = {
|
static char helptext[][80] = {
|
||||||
@ -65,6 +65,11 @@ static char helptext[][80] = {
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------- from demo/tree.c ----------------------- */
|
/* ------------------------- from demo/tree.c ----------------------- */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -10,6 +10,12 @@
|
|||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
print_permissions(mode_t mode)
|
print_permissions(mode_t mode)
|
||||||
{
|
{
|
||||||
|
11
demo/lsl.c
11
demo/lsl.c
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
@ -13,6 +14,12 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Little test program to test filesystem implementations.
|
* Little test program to test filesystem implementations.
|
||||||
*
|
*
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
by Thomas Schmitt - mailto:scdbackup@gmx.net
|
by Thomas Schmitt - mailto:scdbackup@gmx.net
|
||||||
Libburnia project - mailto:libburn-hackers@pykix.org
|
Libburnia project - mailto:libburn-hackers@pykix.org
|
||||||
16 Aug 2009
|
26 Aug 2009
|
||||||
|
|
||||||
|
|
||||||
MD5 is a 128 bit message digest with a very low probability to be the same for
|
MD5 is a 128 bit message digest with a very low probability to be the same for
|
||||||
@ -59,7 +59,7 @@ Entry number N + 1 holds the MD5 checksum of entries 0 to N.
|
|||||||
|
|
||||||
Because the inquiry of AAIP attributes demands loading of the image tree,
|
Because the inquiry of AAIP attributes demands loading of the image tree,
|
||||||
there are also checksum tags which can be detected on the fly when reading
|
there are also checksum tags which can be detected on the fly when reading
|
||||||
and checksumming the session from the start point as learned from a media
|
and checksumming the session from its start point as learned from a media
|
||||||
table-of-content.
|
table-of-content.
|
||||||
|
|
||||||
The superblock checksum tag is written after the ECMA-119 volume descriptors.
|
The superblock checksum tag is written after the ECMA-119 volume descriptors.
|
||||||
@ -67,8 +67,8 @@ The tree checksum tag is written after the ECMA-119 directory entries.
|
|||||||
The session checksum tag is written after all payload including the checksum
|
The session checksum tag is written after all payload including the checksum
|
||||||
array. (Then follows eventual padding.)
|
array. (Then follows eventual padding.)
|
||||||
|
|
||||||
The tags are a single lines of printable text, padded by 0 bytes. They have
|
The tags are single lines of printable text at the very beginning of a block
|
||||||
the following format:
|
of 2048 bytes. They have the following format:
|
||||||
|
|
||||||
Tag_id pos=# range_start=# range_size=# [session_start|next=#] md5=# self=#\n
|
Tag_id pos=# range_start=# range_size=# [session_start|next=#] md5=# self=#\n
|
||||||
|
|
||||||
@ -79,16 +79,15 @@ Tag_id distinguishes the following tag types
|
|||||||
"libisofs_checksum_tag_v1" Session tag
|
"libisofs_checksum_tag_v1" Session tag
|
||||||
|
|
||||||
A relocated superblock may appear at LBA 0 of an image which was produced for
|
A relocated superblock may appear at LBA 0 of an image which was produced for
|
||||||
being stored in a disk file or on overwriteable media (e.g. DVD+R, BD-RE).
|
being stored in a disk file or on overwriteable media (e.g. DVD+RW, BD-RE).
|
||||||
Typically there is a first session recorded with a superblock at LBA 32 and
|
Typically there is a first session recorded with a superblock at LBA 32 and
|
||||||
the next session may follow shortly after its session tag. (There may be a gap
|
the next session may follow shortly after its session tag. (Typically at the
|
||||||
of padding, often 150 blocks, and aligning to the next address that is
|
next block address which is divisible by 32.) Normally no session starts after
|
||||||
divisible by 32.) Normally no session starts after the address given by
|
the address given by parameter session_start=.
|
||||||
parameter session_start=.
|
|
||||||
|
|
||||||
Session oriented media like CD-R[W], DVD+R, BD-R will have no relocated
|
Session oriented media like CD-R[W], DVD+R, BD-R will have no relocated
|
||||||
superblock but rather bear a table-of-content on media level (to be inquired
|
superblock but rather bear a table-of-content on media level (to be inquired
|
||||||
by MMC commands(.
|
by MMC commands).
|
||||||
|
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
@ -162,9 +161,14 @@ checksums as strings of 32 hex digits.
|
|||||||
The MD5 checksum of the tag itself up to and including the last hex digit of
|
The MD5 checksum of the tag itself up to and including the last hex digit of
|
||||||
parameter "md5=".
|
parameter "md5=".
|
||||||
|
|
||||||
The newline character at the end is mandatory. For now all bytes of the
|
The newline character at the end is mandatory. After that newline there may
|
||||||
block after that newline shall be zero. There may arise future extensions.
|
follow more lines. Their meaning is not necessarily described in this document.
|
||||||
|
|
||||||
|
One such line type is the scdbackup checksum tag, an ancestor of libisofs tags
|
||||||
|
which is suitable only for single session images which begin at LBA 0. It bears
|
||||||
|
a checksum record which by its MD5 covers all bytes from LBA 0 up to the
|
||||||
|
newline character preceding the scdbackup tag. See scdbackup/README appendix
|
||||||
|
VERIFY for details.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -183,11 +187,11 @@ whether its MD5 matches the MD5 of the data blocks which were read before.
|
|||||||
|
|
||||||
With tag type 2:
|
With tag type 2:
|
||||||
|
|
||||||
Keep the original MD5 context of the data blocks and clone
|
Keep the original MD5 context of the data blocks and clone one for obtaining
|
||||||
one for obtaining the MD5 bytes.
|
the MD5 bytes.
|
||||||
If the MD5s match, then compute the checksum block into the kept MD5 context
|
If the MD5s match, then compute the checksum block and all folowing ones into
|
||||||
and go on with reading and computing for the tree checksum tag. This will be
|
the kept MD5 context and go on with reading and computing for the tree checksum
|
||||||
found at block address next_tag, verified and parsed by:
|
tag. This will be found at block address next_tag, verified and parsed by:
|
||||||
iso_util_decode_md5_tag(block, &tag_type, &pos,
|
iso_util_decode_md5_tag(block, &tag_type, &pos,
|
||||||
&range_start, &range_size, &next_tag, md5, 3);
|
&range_start, &range_size, &next_tag, md5, 3);
|
||||||
|
|
||||||
@ -200,14 +204,12 @@ With tag type 4:
|
|||||||
End the MD5 context and start a new context for the session which you will
|
End the MD5 context and start a new context for the session which you will
|
||||||
read next.
|
read next.
|
||||||
|
|
||||||
You may look for the first session by starting to read at LBA 32, or you may
|
Then look for the actual session by starting to read at the address given by
|
||||||
look for the last session by starting to read at the address given by parameter
|
parameter session_start= which is returned by iso_util_decode_md5_tag() as
|
||||||
session_start=. The former is suitable for a check of the whole image, the
|
next_tag. Go on by looking for tag type 2 and follow above prescription.
|
||||||
latter is the shortest way to ensure that the tree of the last session is
|
|
||||||
not corrupted.
|
|
||||||
|
|
||||||
|
|
||||||
Checking a Whole Session
|
Checking the Data Part of the Session
|
||||||
|
|
||||||
In order to check the trustworthyness of a whole session, continue reading
|
In order to check the trustworthyness of a whole session, continue reading
|
||||||
and checksumming after the tree was verified.
|
and checksumming after the tree was verified.
|
||||||
@ -224,6 +226,20 @@ bytes in parameter md5 match the MD5 computed from the data blocks which were
|
|||||||
read before the tag block.
|
read before the tag block.
|
||||||
|
|
||||||
|
|
||||||
|
Checking All Sessions
|
||||||
|
|
||||||
|
If the media is sequentially recordable, obtain a table of content and check
|
||||||
|
the first track of each session as prescribed above in Checking Before Image
|
||||||
|
Tree Loading and in Checking the Data Part of the Session.
|
||||||
|
|
||||||
|
With disk files or overwriteable media, look for a relocated superblock tag
|
||||||
|
but do not hop to address next_tag (given by session_start=). Instead look at
|
||||||
|
LBA 32 for the first session and check it as prescribed above.
|
||||||
|
After reaching its end, round up the read address to the next multiple of 32
|
||||||
|
and check whether it is smaller than session_start= from the super block.
|
||||||
|
If so, expect another session to start there.
|
||||||
|
|
||||||
|
|
||||||
Checking Single Files in a Loaded Image
|
Checking Single Files in a Loaded Image
|
||||||
|
|
||||||
An image may consist of many sessions wherein many data blocks may not belong
|
An image may consist of many sessions wherein many data blocks may not belong
|
||||||
@ -264,3 +280,41 @@ to iso_image_import() when reading the image. If this source is associated
|
|||||||
to a libburn drive, then libburn function burn_read_data() can read directly
|
to a libburn drive, then libburn function burn_read_data() can read directly
|
||||||
from it.
|
from it.
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
scdbackup Checksum Tags
|
||||||
|
|
||||||
|
The session checksum tag does not occupy its whole block. So there is room to
|
||||||
|
store a scdbackup stream checksum tag, which is an ancestor format of the tags
|
||||||
|
described here. This feature allows scdbackup to omit its own checksum filter
|
||||||
|
if using xorriso as ISO 9660 formatter program.
|
||||||
|
Such a tag makes only sense if the session begins at LBA 0.
|
||||||
|
|
||||||
|
See scdbackup-*/README, appendix VERIFY for a specification.
|
||||||
|
|
||||||
|
Example of a scdbackup checksum tag:
|
||||||
|
scdbackup_checksum_tag_v0.1 2456606865 61 2_2 B00109.143415 2456606865 485bbef110870c45754d7adcc844a72c c2355d5ea3c94d792ff5893dfe0d6d7b
|
||||||
|
|
||||||
|
The tag is located at byte position 2456606865, contains 61 bytes of scdbackup
|
||||||
|
checksum record (the next four words):
|
||||||
|
Name of the backup volume is "2_2".
|
||||||
|
Written in year B0 = 2010 (A9 = 2009, B1 = 2011), January (01), 9th (09),
|
||||||
|
14:34:15 local time.
|
||||||
|
The size of the volume is 2456606865 bytes, which have a MD5 sum of
|
||||||
|
485bbef110870c45754d7adcc844a72c.
|
||||||
|
The checksum of "2_2 B00109.143415 2456606865 485bbef110870c45754d7adcc844a72c"
|
||||||
|
is c2355d5ea3c94d792ff5893dfe0d6d7b.
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
This text is under
|
||||||
|
Copyright (c) 2009 - 2010 Thomas Schmitt <scdbackup@gmx.net>
|
||||||
|
It shall only be modified in sync with libisofs and other software which
|
||||||
|
makes use of libisofs checksums. Please mail change requests to mailing list
|
||||||
|
<libburn-hackers@pykix.org> or to the copyright holder in private.
|
||||||
|
Only if you cannot reach the copyright holder for at least one month it is
|
||||||
|
permissible to modify this text under the same license as the affected
|
||||||
|
copy of libisofs.
|
||||||
|
If you do so, you commit yourself to taking reasonable effort to stay in
|
||||||
|
sync with the other interested users of this text.
|
||||||
|
|
||||||
|
@ -443,3 +443,14 @@ Program mkisofs emits entry XA
|
|||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
This text is under
|
||||||
|
Copyright (c) 2009 - 2010 Thomas Schmitt <scdbackup@gmx.net>
|
||||||
|
It shall only be modified in sync with libisofs and other software which
|
||||||
|
makes use of AAIP. Please mail change requests to mailing list
|
||||||
|
<libburn-hackers@pykix.org> or to the copyright holder in private.
|
||||||
|
Only if you cannot reach the copyright holder for at least one month it is
|
||||||
|
permissible to modify this text under the same license as the affected
|
||||||
|
copy of libisofs.
|
||||||
|
If you do so, you commit yourself to taking reasonable effort to stay in
|
||||||
|
sync with the other interested users of this text.
|
||||||
|
|
||||||
|
@ -149,3 +149,14 @@ Registered:
|
|||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
This text is under
|
||||||
|
Copyright (c) 2009 - 2010 Thomas Schmitt <scdbackup@gmx.net>
|
||||||
|
It shall only be modified in sync with libisofs and other software which
|
||||||
|
makes use of AAIP. Please mail change requests to mailing list
|
||||||
|
<libburn-hackers@pykix.org> or to the copyright holder in private.
|
||||||
|
Only if you cannot reach the copyright holder for at least one month it is
|
||||||
|
permissible to modify this text under the same license as the affected
|
||||||
|
copy of libisofs.
|
||||||
|
If you do so, you commit yourself to taking reasonable effort to stay in
|
||||||
|
sync with the other interested users of this text.
|
||||||
|
|
||||||
|
@ -141,3 +141,14 @@ SUSP 1.12
|
|||||||
RRIP 1.12
|
RRIP 1.12
|
||||||
ftp://ftp.ymi.com/pub/rockridge/rrip112.ps
|
ftp://ftp.ymi.com/pub/rockridge/rrip112.ps
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
This text is under
|
||||||
|
Copyright (c) 2009 - 2010 Thomas Schmitt <scdbackup@gmx.net>
|
||||||
|
It shall reflect the effective technical specifications as implemented in
|
||||||
|
zisofs-tools and the Linux kernel. So please contact mailing list
|
||||||
|
<libburn-hackers@pykix.org> or to the copyright holder in private, if you
|
||||||
|
want to make changes.
|
||||||
|
Only if you cannot reach the copyright holder for at least one month it is
|
||||||
|
permissible to modify and distribute this text under the license "BSD revised".
|
||||||
|
|
||||||
|
@ -11,10 +11,14 @@
|
|||||||
|
|
||||||
To be included by aaip_0_2.c
|
To be included by aaip_0_2.c
|
||||||
|
|
||||||
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2
|
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2+
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
aaip-os-freebsd.c
|
aaip-os-freebsd.c
|
||||||
Arbitrary Attribute Interchange Protocol , system adapter for getting and
|
Arbitrary Attribute Interchange Protocol , system adapter for getting and
|
||||||
setting of ACLs and ixattr.
|
setting of ACLs and xattr.
|
||||||
|
|
||||||
To be included by aaip_0_2.c
|
To be included by aaip_0_2.c
|
||||||
|
|
||||||
@ -11,6 +11,10 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -18,6 +22,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#ifndef Libisofs_with_aaip_acL
|
#ifndef Libisofs_with_aaip_acL
|
||||||
/* It seems ACL is fixely integrated in FreeBSD libc. There is no libacl. */
|
/* It seems ACL is fixely integrated in FreeBSD libc. There is no libacl. */
|
||||||
@ -37,13 +42,14 @@
|
|||||||
finally has to be freed by a call to this function
|
finally has to be freed by a call to this function
|
||||||
with bit15 of flag.
|
with bit15 of flag.
|
||||||
@param flag Bitfield for control purposes
|
@param flag Bitfield for control purposes
|
||||||
bit0= obtain default ACL rather than access ACL
|
(bit0= obtain default ACL rather than access ACL)
|
||||||
bit4= set *text = NULL and return 2
|
bit4= set *text = NULL and return 2
|
||||||
if the ACL matches st_mode permissions.
|
if the ACL matches st_mode permissions.
|
||||||
bit5= in case of symbolic link: inquire link target
|
bit5= in case of symbolic link: inquire link target
|
||||||
bit15= free text and return 1
|
bit15= free text and return 1
|
||||||
@return > 0 ok
|
@return > 0 ok
|
||||||
0 ACL support not enabled at compile time
|
0 ACL support not enabled at compile time
|
||||||
|
or filesystem does not support ACL
|
||||||
-1 failure of system ACL service (see errno)
|
-1 failure of system ACL service (see errno)
|
||||||
-2 attempt to inquire ACL of a symbolic
|
-2 attempt to inquire ACL of a symbolic
|
||||||
link without bit4 or bit5
|
link without bit4 or bit5
|
||||||
@ -88,8 +94,18 @@ int aaip_get_acl_text(char *path, char **text, int flag)
|
|||||||
|
|
||||||
acl= acl_get_file(path, ACL_TYPE_ACCESS);
|
acl= acl_get_file(path, ACL_TYPE_ACCESS);
|
||||||
|
|
||||||
if(acl == NULL)
|
if(acl == NULL) {
|
||||||
|
if(errno == EOPNOTSUPP) {
|
||||||
|
/* filesystem does not support ACL */
|
||||||
|
if(flag & 16)
|
||||||
|
return(2);
|
||||||
|
|
||||||
|
/* >>> ??? fake ACL from POSIX permissions ? */;
|
||||||
|
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
return(-1);
|
return(-1);
|
||||||
|
}
|
||||||
*text= acl_to_text(acl, NULL);
|
*text= acl_to_text(acl, NULL);
|
||||||
acl_free(acl);
|
acl_free(acl);
|
||||||
|
|
||||||
@ -181,10 +197,8 @@ int aaip_get_attr_list(char *path, size_t *num_attrs, char ***names,
|
|||||||
|
|
||||||
if(flag & 1) { /* Obtain ACL */
|
if(flag & 1) { /* Obtain ACL */
|
||||||
/* access-ACL */
|
/* access-ACL */
|
||||||
ret= aaip_get_acl_text(path, &acl_text, flag & (16 | 32));
|
aaip_get_acl_text(path, &acl_text, flag & (16 | 32));
|
||||||
if(ret <= 0)
|
if(acl_text == NULL)
|
||||||
goto ex;
|
|
||||||
if(ret == 2)
|
|
||||||
{ret= 1; goto ex;} /* empty ACL / only st_mode info was found in ACL */
|
{ret= 1; goto ex;} /* empty ACL / only st_mode info was found in ACL */
|
||||||
ret= aaip_encode_acl(acl_text, (mode_t) 0, &a_acl_len, &a_acl, flag & 2);
|
ret= aaip_encode_acl(acl_text, (mode_t) 0, &a_acl_len, &a_acl, flag & 2);
|
||||||
if(ret <= 0)
|
if(ret <= 0)
|
||||||
|
@ -7,10 +7,14 @@
|
|||||||
|
|
||||||
To be included by aaip_0_2.c
|
To be included by aaip_0_2.c
|
||||||
|
|
||||||
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2
|
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2+
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -18,6 +22,8 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
|
||||||
#ifdef Libisofs_with_aaip_acL
|
#ifdef Libisofs_with_aaip_acL
|
||||||
#include <sys/acl.h>
|
#include <sys/acl.h>
|
||||||
@ -46,6 +52,7 @@
|
|||||||
2 only st_mode permissions exist and bit 4 is set
|
2 only st_mode permissions exist and bit 4 is set
|
||||||
or empty ACL and bit0 is set
|
or empty ACL and bit0 is set
|
||||||
0 ACL support not enabled at compile time
|
0 ACL support not enabled at compile time
|
||||||
|
or filesystem does not support ACL
|
||||||
-1 failure of system ACL service (see errno)
|
-1 failure of system ACL service (see errno)
|
||||||
-2 attempt to inquire ACL of a symbolic link without
|
-2 attempt to inquire ACL of a symbolic link without
|
||||||
bit4 or bit5 resp. with no suitable link target
|
bit4 or bit5 resp. with no suitable link target
|
||||||
@ -79,8 +86,18 @@ int aaip_get_acl_text(char *path, char **text, int flag)
|
|||||||
}
|
}
|
||||||
|
|
||||||
acl= acl_get_file(path, (flag & 1) ? ACL_TYPE_DEFAULT : ACL_TYPE_ACCESS);
|
acl= acl_get_file(path, (flag & 1) ? ACL_TYPE_DEFAULT : ACL_TYPE_ACCESS);
|
||||||
if(acl == NULL)
|
if(acl == NULL) {
|
||||||
|
if(errno == ENOTSUP) {
|
||||||
|
/* filesystem does not support ACL */
|
||||||
|
if(flag & 16)
|
||||||
|
return(2);
|
||||||
|
|
||||||
|
/* >>> ??? fake ACL from POSIX permissions ? */;
|
||||||
|
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
return(-1);
|
return(-1);
|
||||||
|
}
|
||||||
*text= acl_to_text(acl, NULL);
|
*text= acl_to_text(acl, NULL);
|
||||||
acl_free(acl);
|
acl_free(acl);
|
||||||
|
|
||||||
|
@ -7,10 +7,14 @@
|
|||||||
See test/aaip_0_2.h
|
See test/aaip_0_2.h
|
||||||
http://libburnia-project.org/wiki/AAIP
|
http://libburnia-project.org/wiki/AAIP
|
||||||
|
|
||||||
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2
|
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2+
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -567,7 +571,7 @@ ex:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Linux man 5 acl says:
|
/* GNU/Linux man 5 acl says:
|
||||||
The permissions defined by ACLs are a superset of the permissions speci-
|
The permissions defined by ACLs are a superset of the permissions speci-
|
||||||
fied by the file permission bits. The permissions defined for the file
|
fied by the file permission bits. The permissions defined for the file
|
||||||
owner correspond to the permissions of the ACL_USER_OBJ entry. The per-
|
owner correspond to the permissions of the ACL_USER_OBJ entry. The per-
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
test/aaip_0_2.h - Public declarations
|
test/aaip_0_2.h - Public declarations
|
||||||
|
|
||||||
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2
|
Copyright (c) 2009 Thomas Schmitt, libburnia project, GPLv2+
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -16,6 +17,10 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Use the copy of the struct burn_source definition in libisofs.h
|
Use the copy of the struct burn_source definition in libisofs.h
|
||||||
*/
|
*/
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_BUFFER_H_
|
#ifndef LIBISO_BUFFER_H_
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
/* libisofs.h defines aaip_xinfo_func */
|
/* libisofs.h defines aaip_xinfo_func */
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
|
||||||
@ -19,6 +24,11 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -94,7 +104,7 @@ int default_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
|||||||
IsoNode *new;
|
IsoNode *new;
|
||||||
IsoFilesystem *fs;
|
IsoFilesystem *fs;
|
||||||
char *name;
|
char *name;
|
||||||
unsigned char *aa_string;
|
unsigned char *aa_string = NULL;
|
||||||
char *a_text = NULL, *d_text = NULL;
|
char *a_text = NULL, *d_text = NULL;
|
||||||
|
|
||||||
if (builder == NULL || src == NULL || node == NULL) {
|
if (builder == NULL || src == NULL || node == NULL) {
|
||||||
@ -211,6 +221,9 @@ int default_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
|||||||
}
|
}
|
||||||
iso_aa_get_acl_text(aa_string, info.st_mode, &a_text, &d_text,
|
iso_aa_get_acl_text(aa_string, info.st_mode, &a_text, &d_text,
|
||||||
1 << 15); /* free ACL texts */
|
1 << 15); /* free ACL texts */
|
||||||
|
if(aa_string != NULL)
|
||||||
|
free(aa_string);
|
||||||
|
aa_string = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Obtain ownership of eventual AAIP string */
|
/* Obtain ownership of eventual AAIP string */
|
||||||
@ -221,6 +234,8 @@ int default_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
|||||||
ret = iso_node_add_xinfo(new, aaip_xinfo_func, aa_string);
|
ret = iso_node_add_xinfo(new, aaip_xinfo_func, aa_string);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
} else if(aa_string != NULL) {
|
||||||
|
free(aa_string);
|
||||||
}
|
}
|
||||||
|
|
||||||
*node = new;
|
*node = new;
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_BUILDER_H_
|
#ifndef LIBISO_BUILDER_H_
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
@ -1,13 +1,18 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
* Copyright (c) 2007 Mario Danic
|
* Copyright (c) 2007 Mario Danic
|
||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 - 2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Use the copy of the struct burn_source definition in libisofs.h
|
Use the copy of the struct burn_source definition in libisofs.h
|
||||||
*/
|
*/
|
||||||
@ -26,16 +31,15 @@
|
|||||||
#include "rockridge.h"
|
#include "rockridge.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "system_area.h"
|
#include "system_area.h"
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
#include "md5.h"
|
#include "md5.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
|
#include <ctype.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <locale.h>
|
#include <locale.h>
|
||||||
#include <langinfo.h>
|
#include <langinfo.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TODO #00011 : guard against bad path table usage with more than 65535 dirs
|
* TODO #00011 : guard against bad path table usage with more than 65535 dirs
|
||||||
@ -69,16 +73,16 @@ void ecma119_image_free(Ecma119Image *t)
|
|||||||
free(t->input_charset);
|
free(t->input_charset);
|
||||||
if (t->output_charset != NULL)
|
if (t->output_charset != NULL)
|
||||||
free(t->output_charset);
|
free(t->output_charset);
|
||||||
|
if (t->bootsrc != NULL)
|
||||||
#ifdef Libisofs_with_checksumS
|
free(t->bootsrc);
|
||||||
|
if (t->system_area_data != NULL)
|
||||||
|
free(t->system_area_data);
|
||||||
if (t->checksum_ctx != NULL) { /* dispose checksum context */
|
if (t->checksum_ctx != NULL) { /* dispose checksum context */
|
||||||
char md5[16];
|
char md5[16];
|
||||||
iso_md5_end(&(t->checksum_ctx), md5);
|
iso_md5_end(&(t->checksum_ctx), md5);
|
||||||
}
|
}
|
||||||
if (t->checksum_buffer != NULL)
|
if (t->checksum_buffer != NULL)
|
||||||
free(t->checksum_buffer);
|
free(t->checksum_buffer);
|
||||||
#endif
|
|
||||||
|
|
||||||
if (t->writers != NULL)
|
if (t->writers != NULL)
|
||||||
free(t->writers);
|
free(t->writers);
|
||||||
free(t);
|
free(t);
|
||||||
@ -90,7 +94,7 @@ void ecma119_image_free(Ecma119Image *t)
|
|||||||
static
|
static
|
||||||
int need_version_number(Ecma119Image *t, Ecma119Node *n)
|
int need_version_number(Ecma119Image *t, Ecma119Node *n)
|
||||||
{
|
{
|
||||||
if (t->omit_version_numbers) {
|
if (t->omit_version_numbers & 1) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (n->type == ECMA119_DIR || n->type == ECMA119_PLACEHOLDER) {
|
if (n->type == ECMA119_DIR || n->type == ECMA119_PLACEHOLDER) {
|
||||||
@ -249,17 +253,11 @@ int ecma119_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
target->m_path_table_pos = target->curblock;
|
target->m_path_table_pos = target->curblock;
|
||||||
target->curblock += DIV_UP(path_table_size, BLOCK_SIZE);
|
target->curblock += DIV_UP(path_table_size, BLOCK_SIZE);
|
||||||
target->path_table_size = path_table_size;
|
target->path_table_size = path_table_size;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (target->md5_session_checksum) {
|
if (target->md5_session_checksum) {
|
||||||
/* Account for tree checksum tag */
|
/* Account for tree checksum tag */
|
||||||
target->checksum_tree_tag_pos = target->curblock;
|
target->checksum_tree_tag_pos = target->curblock;
|
||||||
target->curblock++;
|
target->curblock++;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -336,7 +334,7 @@ void write_one_dir_record(Ecma119Image *t, Ecma119Node *node, int file_id,
|
|||||||
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
||||||
}
|
}
|
||||||
rec->flags[0] = ((node->type == ECMA119_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
rec->flags[0] = ((node->type == ECMA119_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
||||||
iso_bb(rec->vol_seq_number, 1, 2);
|
iso_bb(rec->vol_seq_number, (uint32_t) 1, 2);
|
||||||
rec->len_fi[0] = len_fi;
|
rec->len_fi[0] = len_fi;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -377,7 +375,7 @@ int ecma119_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
IsoImage *image;
|
IsoImage *image;
|
||||||
Ecma119Image *t;
|
Ecma119Image *t;
|
||||||
struct ecma119_pri_vol_desc vol;
|
struct ecma119_pri_vol_desc vol;
|
||||||
|
int i;
|
||||||
char *vol_id, *pub_id, *data_id, *volset_id;
|
char *vol_id, *pub_id, *data_id, *volset_id;
|
||||||
char *system_id, *application_id, *copyright_file_id;
|
char *system_id, *application_id, *copyright_file_id;
|
||||||
char *abstract_file_id, *biblio_file_id;
|
char *abstract_file_id, *biblio_file_id;
|
||||||
@ -414,9 +412,9 @@ int ecma119_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
strncpy_pad((char*)vol.system_id, system_id, 32);
|
strncpy_pad((char*)vol.system_id, system_id, 32);
|
||||||
strncpy_pad((char*)vol.volume_id, vol_id, 32);
|
strncpy_pad((char*)vol.volume_id, vol_id, 32);
|
||||||
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
||||||
iso_bb(vol.vol_set_size, 1, 2);
|
iso_bb(vol.vol_set_size, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.vol_seq_number, 1, 2);
|
iso_bb(vol.vol_seq_number, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.block_size, BLOCK_SIZE, 2);
|
iso_bb(vol.block_size, (uint32_t) BLOCK_SIZE, 2);
|
||||||
iso_bb(vol.path_table_size, t->path_table_size, 4);
|
iso_bb(vol.path_table_size, t->path_table_size, 4);
|
||||||
iso_lsb(vol.l_path_table_pos, t->l_path_table_pos, 4);
|
iso_lsb(vol.l_path_table_pos, t->l_path_table_pos, 4);
|
||||||
iso_msb(vol.m_path_table_pos, t->m_path_table_pos, 4);
|
iso_msb(vol.m_path_table_pos, t->m_path_table_pos, 4);
|
||||||
@ -432,9 +430,44 @@ int ecma119_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
strncpy_pad((char*)vol.abstract_file_id, abstract_file_id, 37);
|
strncpy_pad((char*)vol.abstract_file_id, abstract_file_id, 37);
|
||||||
strncpy_pad((char*)vol.bibliographic_file_id, biblio_file_id, 37);
|
strncpy_pad((char*)vol.bibliographic_file_id, biblio_file_id, 37);
|
||||||
|
|
||||||
|
if (t->vol_uuid[0]) {
|
||||||
|
for(i = 0; i < 16; i++)
|
||||||
|
if(t->vol_uuid[i] < '0' || t->vol_uuid[i] > '9')
|
||||||
|
break;
|
||||||
|
else
|
||||||
|
vol.vol_creation_time[i] = t->vol_uuid[i];
|
||||||
|
for(; i < 16; i++)
|
||||||
|
vol.vol_creation_time[i] = '1';
|
||||||
|
vol.vol_creation_time[16] = 0;
|
||||||
|
} else if (t->vol_creation_time > 0)
|
||||||
|
iso_datetime_17(vol.vol_creation_time, t->vol_creation_time,
|
||||||
|
t->always_gmt);
|
||||||
|
else
|
||||||
iso_datetime_17(vol.vol_creation_time, t->now, t->always_gmt);
|
iso_datetime_17(vol.vol_creation_time, t->now, t->always_gmt);
|
||||||
|
|
||||||
|
if (t->vol_uuid[0]) {
|
||||||
|
for(i = 0; i < 16; i++)
|
||||||
|
if(t->vol_uuid[i] < '0' || t->vol_uuid[i] > '9')
|
||||||
|
break;
|
||||||
|
else
|
||||||
|
vol.vol_modification_time[i] = t->vol_uuid[i];
|
||||||
|
for(; i < 16; i++)
|
||||||
|
vol.vol_modification_time[i] = '1';
|
||||||
|
vol.vol_modification_time[16] = 0;
|
||||||
|
} else if (t->vol_modification_time > 0)
|
||||||
|
iso_datetime_17(vol.vol_modification_time, t->vol_modification_time,
|
||||||
|
t->always_gmt);
|
||||||
|
else
|
||||||
iso_datetime_17(vol.vol_modification_time, t->now, t->always_gmt);
|
iso_datetime_17(vol.vol_modification_time, t->now, t->always_gmt);
|
||||||
iso_datetime_17(vol.vol_effective_time, t->now, t->always_gmt);
|
|
||||||
|
if (t->vol_expiration_time > 0)
|
||||||
|
iso_datetime_17(vol.vol_expiration_time, t->vol_expiration_time,
|
||||||
|
t->always_gmt);
|
||||||
|
|
||||||
|
if (t->vol_effective_time > 0)
|
||||||
|
iso_datetime_17(vol.vol_effective_time, t->vol_effective_time,
|
||||||
|
t->always_gmt);
|
||||||
|
|
||||||
vol.file_structure_version[0] = 1;
|
vol.file_structure_version[0] = 1;
|
||||||
|
|
||||||
free(vol_id);
|
free(vol_id);
|
||||||
@ -695,16 +728,10 @@ int ecma119_writer_write_data(IsoImageWriter *writer)
|
|||||||
ret = write_path_tables(t);
|
ret = write_path_tables(t);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (t->md5_session_checksum) {
|
if (t->md5_session_checksum) {
|
||||||
/* Write tree checksum tag */
|
/* Write tree checksum tag */
|
||||||
ret = iso_md5_write_tag(t, 3);
|
ret = iso_md5_write_tag(t, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -892,8 +919,6 @@ void *write_function(void *arg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/* Write superblock checksum tag */
|
/* Write superblock checksum tag */
|
||||||
if (target->md5_session_checksum && target->checksum_ctx != NULL) {
|
if (target->md5_session_checksum && target->checksum_ctx != NULL) {
|
||||||
res = iso_md5_write_tag(target, 2);
|
res = iso_md5_write_tag(target, 2);
|
||||||
@ -901,9 +926,6 @@ void *write_function(void *arg)
|
|||||||
goto write_error;
|
goto write_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
/* write data for each writer */
|
/* write data for each writer */
|
||||||
for (i = 0; i < target->nwriters; ++i) {
|
for (i = 0; i < target->nwriters; ++i) {
|
||||||
writer = target->writers[i];
|
writer = target->writers[i];
|
||||||
@ -913,15 +935,16 @@ void *write_function(void *arg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/* Transplant checksum buffer from Ecma119Image to IsoImage */
|
/* Transplant checksum buffer from Ecma119Image to IsoImage */
|
||||||
transplant_checksum_buffer(target, 0);
|
transplant_checksum_buffer(target, 0);
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
iso_ring_buffer_writer_close(target->buffer, 0);
|
iso_ring_buffer_writer_close(target->buffer, 0);
|
||||||
|
|
||||||
|
#ifdef Libisofs_with_pthread_exiT
|
||||||
pthread_exit(NULL);
|
pthread_exit(NULL);
|
||||||
|
#else
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
write_error: ;
|
write_error: ;
|
||||||
if (res == ISO_CANCELED) {
|
if (res == ISO_CANCELED) {
|
||||||
@ -934,20 +957,20 @@ void *write_function(void *arg)
|
|||||||
}
|
}
|
||||||
iso_ring_buffer_writer_close(target->buffer, 1);
|
iso_ring_buffer_writer_close(target->buffer, 1);
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
/* Transplant checksum buffer away from Ecma119Image */
|
||||||
|
|
||||||
/* Transplant checksum buffer from Ecma119Image to IsoImage */
|
|
||||||
transplant_checksum_buffer(target, 0);
|
transplant_checksum_buffer(target, 0);
|
||||||
|
/* Invalidate the transplanted checksum buffer in IsoImage */
|
||||||
|
iso_image_free_checksums(target->image, 0);
|
||||||
|
|
||||||
|
#ifdef Libisofs_with_pthread_exiT
|
||||||
|
pthread_exit(NULL);
|
||||||
|
#else
|
||||||
|
return NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
pthread_exit(NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
|
|
||||||
static
|
static
|
||||||
int checksum_prepare_image(IsoImage *src, int flag)
|
int checksum_prepare_image(IsoImage *src, int flag)
|
||||||
{
|
{
|
||||||
@ -1042,15 +1065,14 @@ int checksum_prepare_nodes(Ecma119Image *target, IsoNode *node, int flag)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
static
|
static
|
||||||
int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
||||||
{
|
{
|
||||||
int ret, i, voldesc_size, nwriters, image_checksums_mad = 0;
|
int ret, i, voldesc_size, nwriters, image_checksums_mad = 0, tag_pos;
|
||||||
Ecma119Image *target;
|
Ecma119Image *target;
|
||||||
int el_torito_writer_index = -1, file_src_writer_index= -1;
|
int el_torito_writer_index = -1, file_src_writer_index = -1;
|
||||||
|
int system_area_options = 0;
|
||||||
|
char *system_area = NULL;
|
||||||
|
|
||||||
/* 1. Allocate target and copy opts there */
|
/* 1. Allocate target and copy opts there */
|
||||||
target = calloc(1, sizeof(Ecma119Image));
|
target = calloc(1, sizeof(Ecma119Image));
|
||||||
@ -1111,6 +1133,44 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
/* el-torito? */
|
/* el-torito? */
|
||||||
target->eltorito = (src->bootcat == NULL ? 0 : 1);
|
target->eltorito = (src->bootcat == NULL ? 0 : 1);
|
||||||
target->catalog = src->bootcat;
|
target->catalog = src->bootcat;
|
||||||
|
if (target->catalog != NULL) {
|
||||||
|
target->num_bootsrc = target->catalog->num_bootimages;
|
||||||
|
target->bootsrc = calloc(target->num_bootsrc + 1,
|
||||||
|
sizeof(IsoFileSrc *));
|
||||||
|
if (target->bootsrc == NULL) {
|
||||||
|
ret = ISO_OUT_OF_MEM;
|
||||||
|
goto target_cleanup;
|
||||||
|
}
|
||||||
|
for (i= 0; i < target->num_bootsrc; i++)
|
||||||
|
target->bootsrc[i] = NULL;
|
||||||
|
} else {
|
||||||
|
target->num_bootsrc = 0;
|
||||||
|
target->bootsrc = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opts->system_area_data != NULL) {
|
||||||
|
system_area = opts->system_area_data;
|
||||||
|
system_area_options = opts->system_area_options;
|
||||||
|
} else if (src->system_area_data != NULL) {
|
||||||
|
system_area = src->system_area_data;
|
||||||
|
system_area_options = src->system_area_options;
|
||||||
|
}
|
||||||
|
target->system_area_data = NULL;
|
||||||
|
if (system_area != NULL) {
|
||||||
|
target->system_area_data = calloc(32768, 1);
|
||||||
|
if (target->system_area_data == NULL) {
|
||||||
|
ret = ISO_OUT_OF_MEM;
|
||||||
|
goto target_cleanup;
|
||||||
|
}
|
||||||
|
memcpy(target->system_area_data, system_area, 32768);
|
||||||
|
}
|
||||||
|
target->system_area_options = system_area_options;
|
||||||
|
|
||||||
|
target->vol_creation_time = opts->vol_creation_time;
|
||||||
|
target->vol_modification_time = opts->vol_modification_time;
|
||||||
|
target->vol_expiration_time = opts->vol_expiration_time;
|
||||||
|
target->vol_effective_time = opts->vol_effective_time;
|
||||||
|
strcpy(target->vol_uuid, opts->vol_uuid);
|
||||||
|
|
||||||
target->input_charset = strdup(iso_get_local_charset(0));
|
target->input_charset = strdup(iso_get_local_charset(0));
|
||||||
if (target->input_charset == NULL) {
|
if (target->input_charset == NULL) {
|
||||||
@ -1128,10 +1188,10 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
goto target_cleanup;
|
goto target_cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
target->md5_file_checksums = opts->md5_file_checksums;
|
target->md5_file_checksums = opts->md5_file_checksums;
|
||||||
target->md5_session_checksum = opts->md5_session_checksum;
|
target->md5_session_checksum = opts->md5_session_checksum;
|
||||||
|
strcpy(target->scdbackup_tag_parm, opts->scdbackup_tag_parm);
|
||||||
|
target->scdbackup_tag_written = opts->scdbackup_tag_written;
|
||||||
target->checksum_idx_counter = 0;
|
target->checksum_idx_counter = 0;
|
||||||
target->checksum_ctx = NULL;
|
target->checksum_ctx = NULL;
|
||||||
target->checksum_counter = 0;
|
target->checksum_counter = 0;
|
||||||
@ -1145,8 +1205,6 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
target->checksum_range_size = 0;
|
target->checksum_range_size = 0;
|
||||||
target->opts_overwrite = 0;
|
target->opts_overwrite = 0;
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 2. Based on those options, create needed writers: iso, joliet...
|
* 2. Based on those options, create needed writers: iso, joliet...
|
||||||
* Each writer inits its structures and stores needed info into
|
* Each writer inits its structures and stores needed info into
|
||||||
@ -1170,9 +1228,6 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
nwriters++;
|
nwriters++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if ((target->md5_file_checksums & 1) || target->md5_session_checksum) {
|
if ((target->md5_file_checksums & 1) || target->md5_session_checksum) {
|
||||||
nwriters++;
|
nwriters++;
|
||||||
image_checksums_mad = 1; /* from here on the loaded checksums are
|
image_checksums_mad = 1; /* from here on the loaded checksums are
|
||||||
@ -1189,9 +1244,6 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
target->checksum_idx_counter = 0;
|
target->checksum_idx_counter = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
target->writers = malloc(nwriters * sizeof(void*));
|
target->writers = malloc(nwriters * sizeof(void*));
|
||||||
if (target->writers == NULL) {
|
if (target->writers == NULL) {
|
||||||
ret = ISO_OUT_OF_MEM;
|
ret = ISO_OUT_OF_MEM;
|
||||||
@ -1249,19 +1301,12 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
goto target_cleanup;
|
goto target_cleanup;
|
||||||
}
|
}
|
||||||
file_src_writer_index = target->nwriters - 1;
|
file_src_writer_index = target->nwriters - 1;
|
||||||
|
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if ((target->md5_file_checksums & 1) || target->md5_session_checksum) {
|
if ((target->md5_file_checksums & 1) || target->md5_session_checksum) {
|
||||||
ret = checksum_writer_create(target);
|
ret = checksum_writer_create(target);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto target_cleanup;
|
goto target_cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 3.
|
* 3.
|
||||||
* Call compute_data_blocks() in each Writer.
|
* Call compute_data_blocks() in each Writer.
|
||||||
@ -1360,11 +1405,10 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
memcpy(vol->std_identifier, "CD001", 5);
|
memcpy(vol->std_identifier, "CD001", 5);
|
||||||
vol->vol_desc_version[0] = 1;
|
vol->vol_desc_version[0] = 1;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/* Write relocated superblock checksum tag */
|
/* Write relocated superblock checksum tag */
|
||||||
|
tag_pos = voldesc_size / BLOCK_SIZE + 16 + 1;
|
||||||
if (target->md5_session_checksum) {
|
if (target->md5_session_checksum) {
|
||||||
target->checksum_rlsb_tag_pos = voldesc_size / BLOCK_SIZE + 16 + 1;
|
target->checksum_rlsb_tag_pos = tag_pos;
|
||||||
if (target->checksum_rlsb_tag_pos < 32) {
|
if (target->checksum_rlsb_tag_pos < 32) {
|
||||||
ret = iso_md5_start(&(target->checksum_ctx));
|
ret = iso_md5_start(&(target->checksum_ctx));
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
@ -1377,10 +1421,21 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto target_cleanup;
|
goto target_cleanup;
|
||||||
}
|
}
|
||||||
|
tag_pos++;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
/* Clean out eventual checksum tags */
|
||||||
|
for (i = tag_pos; i < 32; i++) {
|
||||||
|
int tag_type;
|
||||||
|
uint32_t pos, range_start, range_size, next_tag;
|
||||||
|
char md5[16];
|
||||||
|
|
||||||
|
ret = iso_util_decode_md5_tag((char *)(opts->overwrite + i * 2048),
|
||||||
|
&tag_type, &pos, &range_start,
|
||||||
|
&range_size, &next_tag, md5, 0);
|
||||||
|
if (ret > 0)
|
||||||
|
opts->overwrite[i * 2048] = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1392,8 +1447,6 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
|
|
||||||
|
|
||||||
/* 4. Create and start writing thread */
|
/* 4. Create and start writing thread */
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
if (target->md5_session_checksum) {
|
if (target->md5_session_checksum) {
|
||||||
/* After any fake writes are done: Initialize image checksum context */
|
/* After any fake writes are done: Initialize image checksum context */
|
||||||
if (target->checksum_ctx != NULL)
|
if (target->checksum_ctx != NULL)
|
||||||
@ -1407,8 +1460,6 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
iso_image_free_checksums(target->image, 0);
|
iso_image_free_checksums(target->image, 0);
|
||||||
image_checksums_mad = 0;
|
image_checksums_mad = 0;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/* ensure the thread is created joinable */
|
/* ensure the thread is created joinable */
|
||||||
pthread_attr_init(&(target->th_attr));
|
pthread_attr_init(&(target->th_attr));
|
||||||
pthread_attr_setdetachstate(&(target->th_attr), PTHREAD_CREATE_JOINABLE);
|
pthread_attr_setdetachstate(&(target->th_attr), PTHREAD_CREATE_JOINABLE);
|
||||||
@ -1433,14 +1484,8 @@ int ecma119_image_new(IsoImage *src, IsoWriteOpts *opts, Ecma119Image **img)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
|
|
||||||
target_cleanup: ;
|
target_cleanup: ;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if(image_checksums_mad) /* No checksums is better than mad checksums */
|
if(image_checksums_mad) /* No checksums is better than mad checksums */
|
||||||
iso_image_free_checksums(target->image, 0);
|
iso_image_free_checksums(target->image, 0);
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
ecma119_image_free(target);
|
ecma119_image_free(target);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1580,17 +1625,11 @@ int iso_write(Ecma119Image *target, void *buf, size_t count)
|
|||||||
/* reader cancelled */
|
/* reader cancelled */
|
||||||
return ISO_CANCELED;
|
return ISO_CANCELED;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (target->checksum_ctx != NULL) {
|
if (target->checksum_ctx != NULL) {
|
||||||
/* Add to image checksum */
|
/* Add to image checksum */
|
||||||
target->checksum_counter += count;
|
target->checksum_counter += count;
|
||||||
iso_md5_compute(target->checksum_ctx, (char *) buf, (int) count);
|
iso_md5_compute(target->checksum_ctx, (char *) buf, (int) count);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/* total size is 0 when writing the overwrite buffer */
|
/* total size is 0 when writing the overwrite buffer */
|
||||||
if (ret > 0 && (target->total_size != (off_t) 0)){
|
if (ret > 0 && (target->total_size != (off_t) 0)){
|
||||||
unsigned int kbw, kbt;
|
unsigned int kbw, kbt;
|
||||||
@ -1627,6 +1666,7 @@ int iso_write_opts_new(IsoWriteOpts **opts, int profile)
|
|||||||
if (wopts == NULL) {
|
if (wopts == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
|
wopts->scdbackup_tag_written = NULL;
|
||||||
|
|
||||||
switch (profile) {
|
switch (profile) {
|
||||||
case 0:
|
case 0:
|
||||||
@ -1656,6 +1696,14 @@ int iso_write_opts_new(IsoWriteOpts **opts, int profile)
|
|||||||
wopts->fifo_size = 1024; /* 2 MB buffer */
|
wopts->fifo_size = 1024; /* 2 MB buffer */
|
||||||
wopts->sort_files = 1; /* file sorting is always good */
|
wopts->sort_files = 1; /* file sorting is always good */
|
||||||
|
|
||||||
|
wopts->system_area_data = NULL;
|
||||||
|
wopts->system_area_options = 0;
|
||||||
|
wopts->vol_creation_time = 0;
|
||||||
|
wopts->vol_modification_time = 0;
|
||||||
|
wopts->vol_expiration_time = 0;
|
||||||
|
wopts->vol_effective_time = 0;
|
||||||
|
wopts->vol_uuid[0]= 0;
|
||||||
|
|
||||||
*opts = wopts;
|
*opts = wopts;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -1667,6 +1715,8 @@ void iso_write_opts_free(IsoWriteOpts *opts)
|
|||||||
}
|
}
|
||||||
|
|
||||||
free(opts->output_charset);
|
free(opts->output_charset);
|
||||||
|
if(opts->system_area_data != NULL)
|
||||||
|
free(opts->system_area_data);
|
||||||
free(opts);
|
free(opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1732,7 +1782,7 @@ int iso_write_opts_set_omit_version_numbers(IsoWriteOpts *opts, int omit)
|
|||||||
if (opts == NULL) {
|
if (opts == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
opts->omit_version_numbers = omit ? 1 : 0;
|
opts->omit_version_numbers = omit & 3;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1768,7 +1818,7 @@ int iso_write_opts_set_no_force_dots(IsoWriteOpts *opts, int no)
|
|||||||
if (opts == NULL) {
|
if (opts == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
opts->no_force_dots = no ? 1 : 0;
|
opts->no_force_dots = no & 3;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1855,14 +1905,40 @@ int iso_write_opts_set_sort_files(IsoWriteOpts *opts, int sort)
|
|||||||
|
|
||||||
int iso_write_opts_set_record_md5(IsoWriteOpts *opts, int session, int files)
|
int iso_write_opts_set_record_md5(IsoWriteOpts *opts, int session, int files)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
opts->md5_session_checksum = session & 1;
|
opts->md5_session_checksum = session & 1;
|
||||||
opts->md5_file_checksums = files & 3;
|
opts->md5_file_checksums = files & 3;
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
int iso_write_opts_set_scdbackup_tag(IsoWriteOpts *opts,
|
||||||
|
char *name, char *timestamp,
|
||||||
|
char *tag_written)
|
||||||
|
{
|
||||||
|
char eff_name[81], eff_time[19];
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; name[i] != 0 && i < 80; i++)
|
||||||
|
if (isspace((int) ((unsigned char *) name)[i]))
|
||||||
|
eff_name[i] = '_';
|
||||||
|
else
|
||||||
|
eff_name[i] = name[i];
|
||||||
|
if (i == 0)
|
||||||
|
eff_name[i++] = '_';
|
||||||
|
eff_name[i] = 0;
|
||||||
|
for (i = 0; timestamp[i] != 0 && i < 18; i++)
|
||||||
|
if (isspace((int) ((unsigned char *) timestamp)[i]))
|
||||||
|
eff_time[i] = '_';
|
||||||
|
else
|
||||||
|
eff_time[i] = timestamp[i];
|
||||||
|
if (i == 0)
|
||||||
|
eff_time[i++] = '_';
|
||||||
|
eff_time[i] = 0;
|
||||||
|
|
||||||
|
sprintf(opts->scdbackup_tag_parm, "%s %s", eff_name, eff_time);
|
||||||
|
|
||||||
|
opts->scdbackup_tag_written = tag_written;
|
||||||
|
if (tag_written != NULL)
|
||||||
|
tag_written[0] = 0;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2014,3 +2090,43 @@ int iso_write_opts_get_data_start(IsoWriteOpts *opts, uint32_t *data_start,
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @param data Either NULL or 32 kB of data. Do not submit less bytes !
|
||||||
|
* @param options bit0 = apply GRUB protective msdos label
|
||||||
|
* @param flag bit0 = invalidate any attached system area data
|
||||||
|
* same as data == NULL
|
||||||
|
*/
|
||||||
|
int iso_write_opts_set_system_area(IsoWriteOpts *opts, char data[32768],
|
||||||
|
int options, int flag)
|
||||||
|
{
|
||||||
|
if (data == NULL || (flag & 1)) { /* Disable */
|
||||||
|
if (opts->system_area_data != NULL)
|
||||||
|
free(opts->system_area_data);
|
||||||
|
opts->system_area_data = NULL;
|
||||||
|
} else if (!(flag & 2)) {
|
||||||
|
if (opts->system_area_data == NULL) {
|
||||||
|
opts->system_area_data = calloc(32768, 1);
|
||||||
|
if (opts->system_area_data == NULL)
|
||||||
|
return ISO_OUT_OF_MEM;
|
||||||
|
}
|
||||||
|
memcpy(opts->system_area_data, data, 32768);
|
||||||
|
}
|
||||||
|
if (!(flag & 4))
|
||||||
|
opts->system_area_options = options & 3;
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
int iso_write_opts_set_pvd_times(IsoWriteOpts *opts,
|
||||||
|
time_t vol_creation_time, time_t vol_modification_time,
|
||||||
|
time_t vol_expiration_time, time_t vol_effective_time,
|
||||||
|
char *vol_uuid)
|
||||||
|
{
|
||||||
|
opts->vol_creation_time = vol_creation_time;
|
||||||
|
opts->vol_modification_time = vol_modification_time;
|
||||||
|
opts->vol_expiration_time = vol_expiration_time;
|
||||||
|
opts->vol_effective_time = vol_effective_time;
|
||||||
|
strncpy(opts->vol_uuid, vol_uuid, 16);
|
||||||
|
opts->vol_uuid[16] = 0;
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_ECMA119_H_
|
#ifndef LIBISO_ECMA119_H_
|
||||||
@ -56,8 +57,10 @@ struct iso_write_opts {
|
|||||||
/**
|
/**
|
||||||
* Omit the version number (";1") at the end of the ISO-9660 identifiers.
|
* Omit the version number (";1") at the end of the ISO-9660 identifiers.
|
||||||
* Version numbers are usually not used.
|
* Version numbers are usually not used.
|
||||||
|
* bit0= ECMA-119 and Joliet (for historical reasons)
|
||||||
|
* bit1= Joliet
|
||||||
*/
|
*/
|
||||||
unsigned int omit_version_numbers :1;
|
unsigned int omit_version_numbers :2;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allow ISO-9660 directory hierarchy to be deeper than 8 levels.
|
* Allow ISO-9660 directory hierarchy to be deeper than 8 levels.
|
||||||
@ -81,8 +84,10 @@ struct iso_write_opts {
|
|||||||
* ISO-9660 forces filenames to have a ".", that separates file name from
|
* ISO-9660 forces filenames to have a ".", that separates file name from
|
||||||
* extension. libisofs adds it if original filename doesn't has one. Set
|
* extension. libisofs adds it if original filename doesn't has one. Set
|
||||||
* this to 1 to prevent this behavior
|
* this to 1 to prevent this behavior
|
||||||
|
* bit0= ECMA-119
|
||||||
|
* bit1= Joliet
|
||||||
*/
|
*/
|
||||||
unsigned int no_force_dots :1;
|
unsigned int no_force_dots :2;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allow lowercase characters in ISO-9660 filenames. By default, only
|
* Allow lowercase characters in ISO-9660 filenames. By default, only
|
||||||
@ -147,8 +152,6 @@ struct iso_write_opts {
|
|||||||
*/
|
*/
|
||||||
unsigned int dir_rec_mtime :1;
|
unsigned int dir_rec_mtime :1;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Compute MD5 checksum for the whole session and record it as index 0 of
|
* Compute MD5 checksum for the whole session and record it as index 0 of
|
||||||
* the checksum blocks after the data area of the session. The layout and
|
* the checksum blocks after the data area of the session. The layout and
|
||||||
@ -169,8 +172,6 @@ struct iso_write_opts {
|
|||||||
*/
|
*/
|
||||||
unsigned int md5_file_checksums :2;
|
unsigned int md5_file_checksums :2;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/** If files should be sorted based on their weight. */
|
/** If files should be sorted based on their weight. */
|
||||||
unsigned int sort_files :1;
|
unsigned int sort_files :1;
|
||||||
|
|
||||||
@ -281,6 +282,38 @@ struct iso_write_opts {
|
|||||||
*/
|
*/
|
||||||
uint32_t data_start_lba;
|
uint32_t data_start_lba;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If not empty: A text holding parameters "name" and "timestamp" for
|
||||||
|
* a scdbackup stream checksum tag. See scdbackup/README appendix VERIFY.
|
||||||
|
* It makes sense only for single session images which start at LBA 0.
|
||||||
|
* Such a tag may be part of a libisofs checksum tag block after the
|
||||||
|
* session tag line. It then covers the whole session up to its own start
|
||||||
|
* position.
|
||||||
|
*/
|
||||||
|
char scdbackup_tag_parm[100];
|
||||||
|
|
||||||
|
/* If not NULL: A pointer to an application provided array with
|
||||||
|
at least 512 characters. The effectively written scdbackup tag
|
||||||
|
will be copied to this memory location.
|
||||||
|
*/
|
||||||
|
char *scdbackup_tag_written;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* See ecma119_image : System Area related information
|
||||||
|
*/
|
||||||
|
char *system_area_data;
|
||||||
|
int system_area_options;
|
||||||
|
|
||||||
|
/* User settable PVD time stamps */
|
||||||
|
time_t vol_creation_time;
|
||||||
|
time_t vol_modification_time;
|
||||||
|
time_t vol_expiration_time;
|
||||||
|
time_t vol_effective_time;
|
||||||
|
/* To eventually override vol_creation_time and vol_modification_time
|
||||||
|
* by unconverted string with timezone 0
|
||||||
|
*/
|
||||||
|
char vol_uuid[17];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct ecma119_image Ecma119Image;
|
typedef struct ecma119_image Ecma119Image;
|
||||||
@ -311,11 +344,11 @@ struct ecma119_image
|
|||||||
unsigned int always_gmt :1;
|
unsigned int always_gmt :1;
|
||||||
|
|
||||||
/* relaxed constraints */
|
/* relaxed constraints */
|
||||||
unsigned int omit_version_numbers :1;
|
unsigned int omit_version_numbers :2;
|
||||||
unsigned int allow_deep_paths :1;
|
unsigned int allow_deep_paths :1;
|
||||||
unsigned int allow_longer_paths :1;
|
unsigned int allow_longer_paths :1;
|
||||||
unsigned int max_37_char_filenames :1;
|
unsigned int max_37_char_filenames :1;
|
||||||
unsigned int no_force_dots :1;
|
unsigned int no_force_dots :2;
|
||||||
unsigned int allow_lowercase :1;
|
unsigned int allow_lowercase :1;
|
||||||
unsigned int allow_full_ascii :1;
|
unsigned int allow_full_ascii :1;
|
||||||
|
|
||||||
@ -336,13 +369,9 @@ struct ecma119_image
|
|||||||
/* Store in ECMA-119 timestamp mtime of source */
|
/* Store in ECMA-119 timestamp mtime of source */
|
||||||
unsigned int dir_rec_mtime :1;
|
unsigned int dir_rec_mtime :1;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
unsigned int md5_session_checksum :1;
|
unsigned int md5_session_checksum :1;
|
||||||
unsigned int md5_file_checksums :2;
|
unsigned int md5_file_checksums :2;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Mode replace. If one of these flags is set, the correspodent values are
|
* Mode replace. If one of these flags is set, the correspodent values are
|
||||||
* replaced with values below.
|
* replaced with values below.
|
||||||
@ -417,7 +446,28 @@ struct ecma119_image
|
|||||||
*/
|
*/
|
||||||
struct el_torito_boot_catalog *catalog;
|
struct el_torito_boot_catalog *catalog;
|
||||||
IsoFileSrc *cat; /**< location of the boot catalog in the new image */
|
IsoFileSrc *cat; /**< location of the boot catalog in the new image */
|
||||||
IsoFileSrc *bootimg; /**< location of the boot image in the new image */
|
|
||||||
|
int num_bootsrc;
|
||||||
|
IsoFileSrc **bootsrc; /* location of the boot images in the new image */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* System Area related information
|
||||||
|
*/
|
||||||
|
/* Content of an embedded boot image. Valid if not NULL.
|
||||||
|
* In that case it must point to a memory buffer at least 32 kB.
|
||||||
|
*/
|
||||||
|
char *system_area_data;
|
||||||
|
/*
|
||||||
|
* bit0= make bytes 446 - 512 of the system area a partition
|
||||||
|
* table which reserves partition 1 from byte 63*512 to the
|
||||||
|
* end of the ISO image. Assumed are 63 secs/hed, 255 head/cyl.
|
||||||
|
* (GRUB protective msdos label.)
|
||||||
|
* This works with and without system_area_data.
|
||||||
|
* bit1= apply isohybrid MBR patching to the system area.
|
||||||
|
* This works only with system_area_data plus ISOLINUX boot image
|
||||||
|
* and only if not bit0 is set.
|
||||||
|
*/
|
||||||
|
int system_area_options;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Number of pad blocks that we need to write. Padding blocks are blocks
|
* Number of pad blocks that we need to write. Padding blocks are blocks
|
||||||
@ -440,8 +490,6 @@ struct ecma119_image
|
|||||||
/* tree of files sources */
|
/* tree of files sources */
|
||||||
IsoRBTree *files;
|
IsoRBTree *files;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
unsigned int checksum_idx_counter;
|
unsigned int checksum_idx_counter;
|
||||||
void *checksum_ctx;
|
void *checksum_ctx;
|
||||||
off_t checksum_counter;
|
off_t checksum_counter;
|
||||||
@ -464,7 +512,8 @@ struct ecma119_image
|
|||||||
is submitted with ecma119_image_new() ?
|
is submitted with ecma119_image_new() ?
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
char scdbackup_tag_parm[100];
|
||||||
|
char *scdbackup_tag_written;
|
||||||
|
|
||||||
/* Buffer for communication between burn_source and writer thread */
|
/* Buffer for communication between burn_source and writer thread */
|
||||||
IsoRingBuffer *buffer;
|
IsoRingBuffer *buffer;
|
||||||
@ -472,6 +521,16 @@ struct ecma119_image
|
|||||||
/* writer thread descriptor */
|
/* writer thread descriptor */
|
||||||
pthread_t wthread;
|
pthread_t wthread;
|
||||||
pthread_attr_t th_attr;
|
pthread_attr_t th_attr;
|
||||||
|
|
||||||
|
/* User settable PVD time stamps */
|
||||||
|
time_t vol_creation_time;
|
||||||
|
time_t vol_modification_time;
|
||||||
|
time_t vol_expiration_time;
|
||||||
|
time_t vol_effective_time;
|
||||||
|
/* To eventually override vol_creation_time and vol_modification_time
|
||||||
|
* by unconverted string with timezone 0
|
||||||
|
*/
|
||||||
|
char vol_uuid[17];
|
||||||
};
|
};
|
||||||
|
|
||||||
#define BP(a,b) [(b) - (a) + 1]
|
#define BP(a,b) [(b) - (a) + 1]
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "ecma119_tree.h"
|
#include "ecma119_tree.h"
|
||||||
#include "ecma119.h"
|
#include "ecma119.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
@ -63,18 +68,18 @@ int get_iso_name(Ecma119Image *img, IsoNode *iso, char **name)
|
|||||||
} else {
|
} else {
|
||||||
if (img->max_37_char_filenames) {
|
if (img->max_37_char_filenames) {
|
||||||
isoname = iso_r_fileid(ascii_name, 36, relaxed,
|
isoname = iso_r_fileid(ascii_name, 36, relaxed,
|
||||||
img->no_force_dots ? 0 : 1);
|
(img->no_force_dots & 1) ? 0 : 1);
|
||||||
} else if (img->iso_level == 1) {
|
} else if (img->iso_level == 1) {
|
||||||
if (relaxed) {
|
if (relaxed) {
|
||||||
isoname = iso_r_fileid(ascii_name, 11, relaxed,
|
isoname = iso_r_fileid(ascii_name, 11, relaxed,
|
||||||
img->no_force_dots ? 0 : 1);
|
(img->no_force_dots & 1) ? 0 : 1);
|
||||||
} else {
|
} else {
|
||||||
isoname = iso_1_fileid(ascii_name);
|
isoname = iso_1_fileid(ascii_name);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (relaxed) {
|
if (relaxed) {
|
||||||
isoname = iso_r_fileid(ascii_name, 30, relaxed,
|
isoname = iso_r_fileid(ascii_name, 30, relaxed,
|
||||||
img->no_force_dots ? 0 : 1);
|
(img->no_force_dots & 1) ? 0 : 1);
|
||||||
} else {
|
} else {
|
||||||
isoname = iso_2_fileid(ascii_name);
|
isoname = iso_2_fileid(ascii_name);
|
||||||
}
|
}
|
||||||
@ -145,15 +150,11 @@ int create_dir(Ecma119Image *img, IsoDir *iso, Ecma119Node **node)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new ECMA-119 node representing a regular file from a iso file
|
|
||||||
* node.
|
|
||||||
*/
|
|
||||||
static
|
static
|
||||||
int create_file(Ecma119Image *img, IsoFile *iso, Ecma119Node **node)
|
int create_file_src(Ecma119Image *img, IsoFile *iso, IsoFileSrc **src)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
IsoFileSrc *src;
|
|
||||||
off_t size;
|
off_t size;
|
||||||
|
|
||||||
size = iso_stream_get_size(iso->stream);
|
size = iso_stream_get_size(iso->stream);
|
||||||
@ -165,8 +166,25 @@ int create_file(Ecma119Image *img, IsoFile *iso, Ecma119Node **node)
|
|||||||
free(ipath);
|
free(ipath);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
ret = iso_file_src_create(img, iso, src);
|
||||||
|
if (ret < 0) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
ret = iso_file_src_create(img, iso, &src);
|
|
||||||
|
/**
|
||||||
|
* Create a new ECMA-119 node representing a regular file from a iso file
|
||||||
|
* node.
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
int create_file(Ecma119Image *img, IsoFile *iso, Ecma119Node **node)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
IsoFileSrc *src;
|
||||||
|
|
||||||
|
ret = create_file_src(img, iso, &src);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -266,58 +284,78 @@ void ecma119_node_free(Ecma119Node *node)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* @param flag
|
||||||
|
* bit0= iso is in a hidden directory. Thus hide it.
|
||||||
* @return
|
* @return
|
||||||
* 1 success, 0 node ignored, < 0 error
|
* 1 success, 0 node ignored, < 0 error
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
||||||
int depth, int pathlen)
|
int depth, int pathlen, int flag)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, hidden;
|
||||||
Ecma119Node *node;
|
Ecma119Node *node = NULL;
|
||||||
int max_path;
|
int max_path;
|
||||||
char *iso_name= NULL;
|
char *iso_name= NULL, *ipath = NULL;
|
||||||
|
IsoFileSrc *src = NULL;
|
||||||
|
|
||||||
if (image == NULL || iso == NULL || tree == NULL) {
|
if (image == NULL || iso == NULL || tree == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
|
*tree = NULL;
|
||||||
|
|
||||||
|
hidden = flag & 1;
|
||||||
if (iso->hidden & LIBISO_HIDE_ON_RR) {
|
if (iso->hidden & LIBISO_HIDE_ON_RR) {
|
||||||
/* file will be ignored */
|
hidden = 1;
|
||||||
return 0;
|
if (!((iso->hidden & LIBISO_HIDE_BUT_WRITE) ||
|
||||||
|
iso->type == LIBISO_BOOT)) {
|
||||||
|
return 0; /* file will be ignored */
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hidden) {
|
||||||
|
max_path= pathlen;
|
||||||
|
} else {
|
||||||
ret = get_iso_name(image, iso, &iso_name);
|
ret = get_iso_name(image, iso, &iso_name);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
iso_name = NULL; /* invalid, do not free */
|
||||||
|
goto ex;
|
||||||
}
|
}
|
||||||
max_path = pathlen + 1 + (iso_name ? strlen(iso_name) : 0);
|
max_path = pathlen + 1 + (iso_name ? strlen(iso_name) : 0);
|
||||||
if (!image->rockridge) {
|
if (!image->rockridge) {
|
||||||
if ((iso->type == LIBISO_DIR && depth > 8) && !image->allow_deep_paths) {
|
if ((iso->type == LIBISO_DIR && depth > 8) &&
|
||||||
char *ipath = iso_tree_get_node_path(iso);
|
!image->allow_deep_paths) {
|
||||||
return iso_msg_submit(image->image->id, ISO_FILE_IMGPATH_WRONG, 0,
|
ipath = iso_tree_get_node_path(iso);
|
||||||
"File \"%s\" can't be added, because directory depth "
|
ret = iso_msg_submit(image->image->id, ISO_FILE_IMGPATH_WRONG,
|
||||||
|
0, "File \"%s\" can't be added, "
|
||||||
|
"because directory depth "
|
||||||
"is greater than 8.", ipath);
|
"is greater than 8.", ipath);
|
||||||
free(iso_name);
|
goto ex;
|
||||||
free(ipath);
|
|
||||||
return ret;
|
|
||||||
} else if (max_path > 255 && !image->allow_longer_paths) {
|
} else if (max_path > 255 && !image->allow_longer_paths) {
|
||||||
char *ipath = iso_tree_get_node_path(iso);
|
ipath = iso_tree_get_node_path(iso);
|
||||||
ret = iso_msg_submit(image->image->id, ISO_FILE_IMGPATH_WRONG, 0,
|
ret = iso_msg_submit(image->image->id, ISO_FILE_IMGPATH_WRONG,
|
||||||
"File \"%s\" can't be added, because path length "
|
0, "File \"%s\" can't be added, "
|
||||||
|
"because path length "
|
||||||
"is greater than 255 characters", ipath);
|
"is greater than 255 characters", ipath);
|
||||||
free(iso_name);
|
goto ex;
|
||||||
free(ipath);
|
}
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (iso->type) {
|
switch (iso->type) {
|
||||||
case LIBISO_FILE:
|
case LIBISO_FILE:
|
||||||
|
if (hidden) {
|
||||||
|
ret = create_file_src(image, (IsoFile *) iso, &src);
|
||||||
|
} else {
|
||||||
ret = create_file(image, (IsoFile*)iso, &node);
|
ret = create_file(image, (IsoFile*)iso, &node);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case LIBISO_SYMLINK:
|
case LIBISO_SYMLINK:
|
||||||
|
if (hidden) {
|
||||||
|
ret = 0; /* Hidden means non-existing */
|
||||||
|
goto ex;
|
||||||
|
}
|
||||||
if (image->rockridge) {
|
if (image->rockridge) {
|
||||||
ret = create_symlink(image, (IsoSymlink*)iso, &node);
|
ret = create_symlink(image, (IsoSymlink*)iso, &node);
|
||||||
} else {
|
} else {
|
||||||
@ -330,6 +368,10 @@ int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case LIBISO_SPECIAL:
|
case LIBISO_SPECIAL:
|
||||||
|
if (hidden) {
|
||||||
|
ret = 0; /* Hidden means non-existing */
|
||||||
|
goto ex;
|
||||||
|
}
|
||||||
if (image->rockridge) {
|
if (image->rockridge) {
|
||||||
ret = create_special(image, (IsoSpecial*)iso, &node);
|
ret = create_special(image, (IsoSpecial*)iso, &node);
|
||||||
} else {
|
} else {
|
||||||
@ -343,7 +385,11 @@ int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
|||||||
break;
|
break;
|
||||||
case LIBISO_BOOT:
|
case LIBISO_BOOT:
|
||||||
if (image->eltorito) {
|
if (image->eltorito) {
|
||||||
|
if (hidden) {
|
||||||
|
ret = el_torito_catalog_file_src_create(image, &src);
|
||||||
|
} else {
|
||||||
ret = create_boot_cat(image, (IsoBoot*)iso, &node);
|
ret = create_boot_cat(image, (IsoBoot*)iso, &node);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
/* log and ignore */
|
/* log and ignore */
|
||||||
ret = iso_msg_submit(image->image->id, ISO_FILE_IGNORED, 0,
|
ret = iso_msg_submit(image->image->id, ISO_FILE_IGNORED, 0,
|
||||||
@ -354,21 +400,27 @@ int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
|||||||
{
|
{
|
||||||
IsoNode *pos;
|
IsoNode *pos;
|
||||||
IsoDir *dir = (IsoDir*)iso;
|
IsoDir *dir = (IsoDir*)iso;
|
||||||
|
|
||||||
|
if (!hidden) {
|
||||||
ret = create_dir(image, dir, &node);
|
ret = create_dir(image, dir, &node);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
goto ex;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
ret = ISO_SUCCESS;
|
||||||
pos = dir->children;
|
pos = dir->children;
|
||||||
while (pos) {
|
while (pos) {
|
||||||
int cret;
|
int cret;
|
||||||
Ecma119Node *child;
|
Ecma119Node *child;
|
||||||
cret = create_tree(image, pos, &child, depth + 1, max_path);
|
cret = create_tree(image, pos, &child, depth + 1, max_path,
|
||||||
|
!!hidden);
|
||||||
if (cret < 0) {
|
if (cret < 0) {
|
||||||
/* error */
|
/* error */
|
||||||
|
if (!hidden)
|
||||||
ecma119_node_free(node);
|
ecma119_node_free(node);
|
||||||
ret = cret;
|
ret = cret;
|
||||||
break;
|
break;
|
||||||
} else if (cret == ISO_SUCCESS) {
|
} else if (cret == ISO_SUCCESS && !hidden) {
|
||||||
/* add child to this node */
|
/* add child to this node */
|
||||||
int nchildren = node->info.dir->nchildren++;
|
int nchildren = node->info.dir->nchildren++;
|
||||||
node->info.dir->children[nchildren] = child;
|
node->info.dir->children[nchildren] = child;
|
||||||
@ -380,15 +432,30 @@ int create_tree(Ecma119Image *image, IsoNode *iso, Ecma119Node **tree,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* should never happen */
|
/* should never happen */
|
||||||
return ISO_ASSERT_FAILURE;
|
ret = ISO_ASSERT_FAILURE;
|
||||||
|
goto ex;
|
||||||
}
|
}
|
||||||
if (ret <= 0) {
|
if (ret <= 0) {
|
||||||
free(iso_name);
|
goto ex;
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
if (!hidden) {
|
||||||
node->iso_name = iso_name;
|
node->iso_name = iso_name;
|
||||||
|
iso_name = NULL; /* now owned by node, do not free */
|
||||||
*tree = node;
|
*tree = node;
|
||||||
return ISO_SUCCESS;
|
node = NULL; /* now owned by caller, do not free */
|
||||||
|
}
|
||||||
|
ret = ISO_SUCCESS;
|
||||||
|
ex:
|
||||||
|
if (iso_name != NULL)
|
||||||
|
free(iso_name);
|
||||||
|
if (ipath != NULL)
|
||||||
|
free(ipath);
|
||||||
|
if (node != NULL)
|
||||||
|
ecma119_node_free(node);
|
||||||
|
if (hidden && ret == ISO_SUCCESS)
|
||||||
|
ret = 0;
|
||||||
|
/* The sources of hidden files are now owned by the rb-tree */
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -980,7 +1047,7 @@ int ecma119_tree_create(Ecma119Image *img)
|
|||||||
int ret;
|
int ret;
|
||||||
Ecma119Node *root;
|
Ecma119Node *root;
|
||||||
|
|
||||||
ret = create_tree(img, (IsoNode*)img->image->root, &root, 1, 0);
|
ret = create_tree(img, (IsoNode*)img->image->root, &root, 1, 0, 0);
|
||||||
if (ret <= 0) {
|
if (ret <= 0) {
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
/* unexpected error, root ignored!! This can't happen */
|
/* unexpected error, root ignored!! This can't happen */
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_ECMA119_TREE_H_
|
#ifndef LIBISO_ECMA119_TREE_H_
|
||||||
|
@ -1,11 +1,17 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
|
* Copyright (c) 2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "eltorito.h"
|
#include "eltorito.h"
|
||||||
#include "stream.h"
|
#include "stream.h"
|
||||||
#include "fsource.h"
|
#include "fsource.h"
|
||||||
@ -16,9 +22,10 @@
|
|||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This table should be written with accuracy values at offset
|
* This table should be written with the actual values at offset
|
||||||
* 8 of boot image, when used ISOLINUX boot loader
|
* 8 of boot image, when used ISOLINUX boot loader
|
||||||
*/
|
*/
|
||||||
struct boot_info_table {
|
struct boot_info_table {
|
||||||
@ -54,6 +61,19 @@ struct hard_disc_mbr {
|
|||||||
uint8_t sign2;
|
uint8_t sign2;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_set_boot_platform_id(ElToritoBootImage *bootimg, uint8_t id)
|
||||||
|
{
|
||||||
|
bootimg->platform_id = id;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_boot_platform_id(ElToritoBootImage *bootimg)
|
||||||
|
{
|
||||||
|
return bootimg->platform_id;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the load segment for the initial boot image. This is only for
|
* Sets the load segment for the initial boot image. This is only for
|
||||||
* no emulation boot images, and is a NOP for other image types.
|
* no emulation boot images, and is a NOP for other image types.
|
||||||
@ -65,6 +85,14 @@ void el_torito_set_load_seg(ElToritoBootImage *bootimg, short segment)
|
|||||||
bootimg->load_seg = segment;
|
bootimg->load_seg = segment;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_load_seg(ElToritoBootImage *bootimg)
|
||||||
|
{
|
||||||
|
if (bootimg->load_seg < 0)
|
||||||
|
return 0xffff - bootimg->load_seg;
|
||||||
|
return bootimg->load_seg;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the number of sectors (512b) to be load at load segment during
|
* Sets the number of sectors (512b) to be load at load segment during
|
||||||
* the initial boot procedure. This is only for no emulation boot images,
|
* the initial boot procedure. This is only for no emulation boot images,
|
||||||
@ -77,6 +105,14 @@ void el_torito_set_load_size(ElToritoBootImage *bootimg, short sectors)
|
|||||||
bootimg->load_size = sectors;
|
bootimg->load_size = sectors;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_load_size(ElToritoBootImage *bootimg)
|
||||||
|
{
|
||||||
|
if (bootimg->load_size < 0)
|
||||||
|
return 0xffff - bootimg->load_size;
|
||||||
|
return bootimg->load_size;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Marks the specified boot image as not bootable
|
* Marks the specified boot image as not bootable
|
||||||
*/
|
*/
|
||||||
@ -85,8 +121,50 @@ void el_torito_set_no_bootable(ElToritoBootImage *bootimg)
|
|||||||
bootimg->bootable = 0;
|
bootimg->bootable = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_bootable(ElToritoBootImage *bootimg)
|
||||||
|
{
|
||||||
|
return !!bootimg->bootable;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_set_id_string(ElToritoBootImage *bootimg, uint8_t id_string[28])
|
||||||
|
{
|
||||||
|
memcpy(bootimg->id_string, id_string, 28);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_id_string(ElToritoBootImage *bootimg, uint8_t id_string[28])
|
||||||
|
{
|
||||||
|
|
||||||
|
memcpy(id_string, bootimg->id_string, 28);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_set_selection_crit(ElToritoBootImage *bootimg, uint8_t crit[20])
|
||||||
|
{
|
||||||
|
memcpy(bootimg->selection_crit, crit, 20);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_selection_crit(ElToritoBootImage *bootimg, uint8_t crit[20])
|
||||||
|
{
|
||||||
|
|
||||||
|
memcpy(crit, bootimg->selection_crit, 20);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_seems_boot_info_table(ElToritoBootImage *bootimg, int flag)
|
||||||
|
{
|
||||||
|
return bootimg->seems_boot_info_table;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Specifies that this image needs to be patched. This involves the writting
|
* Specifies that this image needs to be patched. This involves the writing
|
||||||
* of a 56 bytes boot information table at offset 8 of the boot image file.
|
* of a 56 bytes boot information table at offset 8 of the boot image file.
|
||||||
* The original boot image file won't be modified.
|
* The original boot image file won't be modified.
|
||||||
* This is needed for isolinux boot images.
|
* This is needed for isolinux boot images.
|
||||||
@ -105,7 +183,7 @@ void el_torito_patch_isolinux_image(ElToritoBootImage *bootimg)
|
|||||||
* bitmask style flag. The following values are defined:
|
* bitmask style flag. The following values are defined:
|
||||||
*
|
*
|
||||||
* bit 0 -> 1 to path the image, 0 to not
|
* bit 0 -> 1 to path the image, 0 to not
|
||||||
* Patching the image involves the writting of a 56 bytes
|
* Patching the image involves the writing of a 56 bytes
|
||||||
* boot information table at offset 8 of the boot image file.
|
* boot information table at offset 8 of the boot image file.
|
||||||
* The original boot image file won't be modified. This is needed
|
* The original boot image file won't be modified. This is needed
|
||||||
* to allow isolinux images to be bootable.
|
* to allow isolinux images to be bootable.
|
||||||
@ -123,31 +201,36 @@ int el_torito_set_isolinux_options(ElToritoBootImage *bootimg, int options, int
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO getter for boot image properties should be exposed
|
/* API */
|
||||||
* useful when reading discs */
|
int el_torito_get_isolinux_options(ElToritoBootImage *bootimg, int flag)
|
||||||
int el_torito_get_boot_media_type(const ElToritoBootImage *bootimg)
|
{
|
||||||
|
return bootimg->isolinux_options & 0x03;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int el_torito_get_boot_media_type(ElToritoBootImage *bootimg,
|
||||||
|
enum eltorito_boot_media_type *media_type)
|
||||||
{
|
{
|
||||||
if (bootimg) {
|
if (bootimg) {
|
||||||
switch (bootimg->type) {
|
switch (bootimg->type) {
|
||||||
case 1:
|
case 1:
|
||||||
case 2:
|
case 2:
|
||||||
case 3:
|
case 3:
|
||||||
return ELTORITO_FLOPPY_EMUL;
|
*media_type = ELTORITO_FLOPPY_EMUL;
|
||||||
break;
|
return 1;
|
||||||
case 4:
|
case 4:
|
||||||
return ELTORITO_HARD_DISC_EMUL;
|
*media_type = ELTORITO_HARD_DISC_EMUL;
|
||||||
break;
|
return 1;
|
||||||
case 0:
|
case 0:
|
||||||
return ELTORITO_NO_EMUL;
|
*media_type = ELTORITO_NO_EMUL;
|
||||||
break;
|
return 1;
|
||||||
default:
|
default:
|
||||||
/* should never happen */
|
/* should never happen */
|
||||||
return ISO_ASSERT_FAILURE;
|
return ISO_ASSERT_FAILURE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return ISO_WRONG_ARG_VALUE;
|
|
||||||
}
|
}
|
||||||
|
return ISO_WRONG_ARG_VALUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
@ -332,10 +415,15 @@ int create_image(IsoImage *image, const char *image_path,
|
|||||||
boot->image = (IsoFile*)imgfile;
|
boot->image = (IsoFile*)imgfile;
|
||||||
iso_node_ref(imgfile); /* get our ref */
|
iso_node_ref(imgfile); /* get our ref */
|
||||||
boot->bootable = 1;
|
boot->bootable = 1;
|
||||||
|
boot->seems_boot_info_table = 0;
|
||||||
|
boot->isolinux_options = 0;
|
||||||
boot->type = boot_media_type;
|
boot->type = boot_media_type;
|
||||||
boot->load_size = load_sectors;
|
|
||||||
boot->partition_type = partition_type;
|
boot->partition_type = partition_type;
|
||||||
|
boot->load_seg = 0;
|
||||||
|
boot->load_size = load_sectors;
|
||||||
|
boot->platform_id = 0; /* 80x86 */
|
||||||
|
memset(boot->id_string, 0, sizeof(boot->id_string));
|
||||||
|
memset(boot->selection_crit, 0, sizeof(boot->selection_crit));
|
||||||
if (bootimg) {
|
if (bootimg) {
|
||||||
*bootimg = boot;
|
*bootimg = boot;
|
||||||
}
|
}
|
||||||
@ -348,7 +436,7 @@ int iso_image_set_boot_image(IsoImage *image, const char *image_path,
|
|||||||
const char *catalog_path,
|
const char *catalog_path,
|
||||||
ElToritoBootImage **boot)
|
ElToritoBootImage **boot)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, i;
|
||||||
struct el_torito_boot_catalog *catalog;
|
struct el_torito_boot_catalog *catalog;
|
||||||
ElToritoBootImage *boot_image= NULL;
|
ElToritoBootImage *boot_image= NULL;
|
||||||
IsoBoot *cat_node= NULL;
|
IsoBoot *cat_node= NULL;
|
||||||
@ -407,13 +495,17 @@ int iso_image_set_boot_image(IsoImage *image, const char *image_path,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* creates the catalog with the given image */
|
/* creates the catalog with the given image */
|
||||||
catalog = malloc(sizeof(struct el_torito_boot_catalog));
|
catalog = calloc(1, sizeof(struct el_torito_boot_catalog));
|
||||||
if (catalog == NULL) {
|
if (catalog == NULL) {
|
||||||
ret = ISO_OUT_OF_MEM;
|
ret = ISO_OUT_OF_MEM;
|
||||||
goto boot_image_cleanup;
|
goto boot_image_cleanup;
|
||||||
}
|
}
|
||||||
catalog->image = boot_image;
|
catalog->num_bootimages = 1;
|
||||||
|
catalog->bootimages[0] = boot_image;
|
||||||
|
for (i = 1; i < Libisofs_max_boot_imageS; i++)
|
||||||
|
catalog->bootimages[i] = NULL;
|
||||||
catalog->node = cat_node;
|
catalog->node = cat_node;
|
||||||
|
catalog->sort_weight = 1000; /* slightly high */
|
||||||
iso_node_ref((IsoNode*)cat_node);
|
iso_node_ref((IsoNode*)cat_node);
|
||||||
image->bootcat = catalog;
|
image->bootcat = catalog;
|
||||||
|
|
||||||
@ -436,7 +528,7 @@ boot_image_cleanup:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get El-Torito boot image of an ISO image, if any.
|
* Get the boot catalog and the El-Torito default boot image of an ISO image.
|
||||||
*
|
*
|
||||||
* This can be useful, for example, to check if a volume read from a previous
|
* This can be useful, for example, to check if a volume read from a previous
|
||||||
* session or an existing image is bootable. It can also be useful to get
|
* session or an existing image is bootable. It can also be useful to get
|
||||||
@ -480,10 +572,10 @@ int iso_image_get_boot_image(IsoImage *image, ElToritoBootImage **boot,
|
|||||||
|
|
||||||
/* ok, image is bootable */
|
/* ok, image is bootable */
|
||||||
if (boot) {
|
if (boot) {
|
||||||
*boot = image->bootcat->image;
|
*boot = image->bootcat->bootimages[0];
|
||||||
}
|
}
|
||||||
if (imgnode) {
|
if (imgnode) {
|
||||||
*imgnode = image->bootcat->image->image;
|
*imgnode = image->bootcat->bootimages[0]->image;
|
||||||
}
|
}
|
||||||
if (catnode) {
|
if (catnode) {
|
||||||
*catnode = image->bootcat->node;
|
*catnode = image->bootcat->node;
|
||||||
@ -491,6 +583,40 @@ int iso_image_get_boot_image(IsoImage *image, ElToritoBootImage **boot,
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int iso_image_get_all_boot_imgs(IsoImage *image, int *num_boots,
|
||||||
|
ElToritoBootImage ***boots, IsoFile ***bootnodes, int flag)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct el_torito_boot_catalog *cat;
|
||||||
|
|
||||||
|
if (image == NULL)
|
||||||
|
return ISO_NULL_POINTER;
|
||||||
|
if (image->bootcat == NULL)
|
||||||
|
return 0;
|
||||||
|
cat = image->bootcat;
|
||||||
|
*num_boots = cat->num_bootimages;
|
||||||
|
*boots = NULL;
|
||||||
|
*bootnodes = NULL;
|
||||||
|
if (*num_boots <= 0)
|
||||||
|
return 0;
|
||||||
|
*boots = calloc(*num_boots, sizeof(ElToritoBootImage *));
|
||||||
|
*bootnodes = calloc(*num_boots, sizeof(IsoFile *));
|
||||||
|
if(*boots == NULL || *bootnodes == NULL) {
|
||||||
|
if (*boots != NULL)
|
||||||
|
free(*boots);
|
||||||
|
if (*bootnodes != NULL)
|
||||||
|
free(*bootnodes);
|
||||||
|
*boots = NULL;
|
||||||
|
*bootnodes = NULL;
|
||||||
|
return ISO_OUT_OF_MEM;
|
||||||
|
}
|
||||||
|
for (i = 0; i < *num_boots; i++) {
|
||||||
|
(*boots)[i] = cat->bootimages[i];
|
||||||
|
(*bootnodes)[i] = image->bootcat->bootimages[i]->image;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes the El-Torito bootable image.
|
* Removes the El-Torito bootable image.
|
||||||
*
|
*
|
||||||
@ -505,27 +631,81 @@ void iso_image_remove_boot_image(IsoImage *image)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* remove catalog node from its parent
|
* remove catalog node from its parent and dispose it
|
||||||
* (the reference will be disposed next)
|
* (another reference is with the catalog)
|
||||||
*/
|
*/
|
||||||
iso_node_take((IsoNode*)image->bootcat->node);
|
if (iso_node_get_parent((IsoNode*) image->bootcat->node) != NULL) {
|
||||||
|
iso_node_take((IsoNode*) image->bootcat->node);
|
||||||
|
iso_node_unref((IsoNode*) image->bootcat->node);
|
||||||
|
}
|
||||||
|
|
||||||
/* free boot catalog and image, including references to nodes */
|
/* free boot catalog and image, including references to nodes */
|
||||||
el_torito_boot_catalog_free(image->bootcat);
|
el_torito_boot_catalog_free(image->bootcat);
|
||||||
image->bootcat = NULL;
|
image->bootcat = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int iso_image_add_boot_image(IsoImage *image, const char *image_path,
|
||||||
|
enum eltorito_boot_media_type type, int flag,
|
||||||
|
ElToritoBootImage **boot)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
struct el_torito_boot_catalog *catalog = image->bootcat;
|
||||||
|
ElToritoBootImage *boot_img;
|
||||||
|
|
||||||
|
if(catalog == NULL)
|
||||||
|
return ISO_BOOT_NO_CATALOG;
|
||||||
|
if (catalog->num_bootimages >= Libisofs_max_boot_imageS)
|
||||||
|
return ISO_BOOT_IMAGE_OVERFLOW;
|
||||||
|
ret = create_image(image, image_path, type, &boot_img);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
catalog->bootimages[catalog->num_bootimages] = boot_img;
|
||||||
|
catalog->num_bootimages++;
|
||||||
|
if (boot != NULL)
|
||||||
|
*boot = boot_img;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int iso_image_set_boot_catalog_weight(IsoImage *image, int sort_weight)
|
||||||
|
{
|
||||||
|
if (image->bootcat == NULL)
|
||||||
|
return 0;
|
||||||
|
image->bootcat->sort_weight = sort_weight;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* API */
|
||||||
|
int iso_image_set_boot_catalog_hidden(IsoImage *image, int hide_attrs)
|
||||||
|
{
|
||||||
|
if (image->bootcat == NULL)
|
||||||
|
return 0;
|
||||||
|
if (image->bootcat->node == NULL)
|
||||||
|
return 0;
|
||||||
|
iso_node_set_hidden((IsoNode *) image->bootcat->node, hide_attrs);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void el_torito_boot_catalog_free(struct el_torito_boot_catalog *cat)
|
void el_torito_boot_catalog_free(struct el_torito_boot_catalog *cat)
|
||||||
{
|
{
|
||||||
struct el_torito_boot_image *image;
|
struct el_torito_boot_image *image;
|
||||||
|
int i;
|
||||||
|
|
||||||
if (cat == NULL) {
|
if (cat == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
image = cat->image;
|
for (i = 0; i < Libisofs_max_boot_imageS; i++) {
|
||||||
|
image = cat->bootimages[i];
|
||||||
|
if (image == NULL)
|
||||||
|
continue;
|
||||||
|
if ((IsoNode*)image->image != NULL)
|
||||||
iso_node_unref((IsoNode*)image->image);
|
iso_node_unref((IsoNode*)image->image);
|
||||||
free(image);
|
free(image);
|
||||||
|
}
|
||||||
|
if ((IsoNode*)cat->node != NULL)
|
||||||
iso_node_unref((IsoNode*)cat->node);
|
iso_node_unref((IsoNode*)cat->node);
|
||||||
free(cat);
|
free(cat);
|
||||||
}
|
}
|
||||||
@ -537,11 +717,12 @@ struct catalog_stream
|
|||||||
{
|
{
|
||||||
Ecma119Image *target;
|
Ecma119Image *target;
|
||||||
uint8_t buffer[BLOCK_SIZE];
|
uint8_t buffer[BLOCK_SIZE];
|
||||||
int offset; /* -1 if stream is not openned */
|
int offset; /* -1 if stream is not opened */
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
write_validation_entry(uint8_t *buf)
|
write_validation_entry(uint8_t *buf, uint8_t platform_id,
|
||||||
|
uint8_t id_string[24])
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
int checksum;
|
int checksum;
|
||||||
@ -549,10 +730,10 @@ write_validation_entry(uint8_t *buf)
|
|||||||
struct el_torito_validation_entry *ve =
|
struct el_torito_validation_entry *ve =
|
||||||
(struct el_torito_validation_entry*)buf;
|
(struct el_torito_validation_entry*)buf;
|
||||||
ve->header_id[0] = 1;
|
ve->header_id[0] = 1;
|
||||||
ve->platform_id[0] = 0; /* 0: 80x86, 1: PowerPC, 2: Mac */
|
ve->platform_id[0] = platform_id;
|
||||||
|
memcpy(ve->id_string, id_string, sizeof(ve->id_string));
|
||||||
ve->key_byte1[0] = 0x55;
|
ve->key_byte1[0] = 0x55;
|
||||||
ve->key_byte2[0] = 0xAA;
|
ve->key_byte2[0] = 0xAA;
|
||||||
|
|
||||||
/* calculate the checksum, to ensure sum of all words is 0 */
|
/* calculate the checksum, to ensure sum of all words is 0 */
|
||||||
checksum = 0;
|
checksum = 0;
|
||||||
for (i = 0; i < sizeof(struct el_torito_validation_entry); i += 2) {
|
for (i = 0; i < sizeof(struct el_torito_validation_entry); i += 2) {
|
||||||
@ -561,35 +742,64 @@ write_validation_entry(uint8_t *buf)
|
|||||||
iso_lsb(ve->checksum, checksum, 2);
|
iso_lsb(ve->checksum, checksum, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
write_section_header(uint8_t *buf, Ecma119Image *t, int idx, int num_entries)
|
||||||
|
{
|
||||||
|
int pi;
|
||||||
|
char *id_string;
|
||||||
|
|
||||||
|
struct el_torito_section_header *e =
|
||||||
|
(struct el_torito_section_header *) buf;
|
||||||
|
|
||||||
|
/* 0x90 = more section headers follow , 0x91 = final section */
|
||||||
|
e->header_indicator[0] = 0x90 + (idx == t->catalog->num_bootimages - 1);
|
||||||
|
pi= e->platform_id[0] = t->catalog->bootimages[idx]->platform_id;
|
||||||
|
e->num_entries[0] = num_entries & 0xff;
|
||||||
|
e->num_entries[1] = (num_entries >> 8) & 0xff;;
|
||||||
|
id_string = (char *) e->id_string;
|
||||||
|
memcpy(id_string, t->catalog->bootimages[idx]->id_string,
|
||||||
|
sizeof(e->id_string));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Write one section entry.
|
* Write one section entry.
|
||||||
* Currently this is used only for default image (the only supported just now)
|
* Usable for the Default Entry
|
||||||
|
* and for Section Entries with Selection criteria type == 0
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
write_section_entry(uint8_t *buf, Ecma119Image *t)
|
write_section_entry(uint8_t *buf, Ecma119Image *t, int idx)
|
||||||
{
|
{
|
||||||
struct el_torito_boot_image *img;
|
struct el_torito_boot_image *img;
|
||||||
struct el_torito_section_entry *se =
|
struct el_torito_section_entry *se =
|
||||||
(struct el_torito_section_entry*)buf;
|
(struct el_torito_section_entry*)buf;
|
||||||
|
|
||||||
img = t->catalog->image;
|
img = t->catalog->bootimages[idx];
|
||||||
|
|
||||||
se->boot_indicator[0] = img->bootable ? 0x88 : 0x00;
|
se->boot_indicator[0] = img->bootable ? 0x88 : 0x00;
|
||||||
se->boot_media_type[0] = img->type;
|
se->boot_media_type[0] = img->type;
|
||||||
iso_lsb(se->load_seg, img->load_seg, 2);
|
iso_lsb(se->load_seg, img->load_seg, 2);
|
||||||
se->system_type[0] = img->partition_type;
|
se->system_type[0] = img->partition_type;
|
||||||
iso_lsb(se->sec_count, img->load_size, 2);
|
iso_lsb(se->sec_count, img->load_size, 2);
|
||||||
iso_lsb(se->block, t->bootimg->sections[0].block, 4);
|
iso_lsb(se->block, t->bootsrc[idx]->sections[0].block, 4);
|
||||||
|
se->selec_criteria[0] = img->selection_crit[0];
|
||||||
|
memcpy(se->vendor_sc, img->selection_crit + 1, 19);
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
int catalog_open(IsoStream *stream)
|
int catalog_open(IsoStream *stream)
|
||||||
{
|
{
|
||||||
|
int i, j, k, num_entries;
|
||||||
struct catalog_stream *data;
|
struct catalog_stream *data;
|
||||||
|
uint8_t *wpt;
|
||||||
|
struct el_torito_boot_catalog *cat;
|
||||||
|
struct el_torito_boot_image **boots;
|
||||||
|
|
||||||
if (stream == NULL) {
|
if (stream == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
data = stream->data;
|
data = stream->data;
|
||||||
|
cat = data->target->catalog;
|
||||||
|
boots = cat->bootimages;
|
||||||
|
|
||||||
if (data->offset != -1) {
|
if (data->offset != -1) {
|
||||||
return ISO_FILE_ALREADY_OPENED;
|
return ISO_FILE_ALREADY_OPENED;
|
||||||
@ -598,11 +808,36 @@ int catalog_open(IsoStream *stream)
|
|||||||
memset(data->buffer, 0, BLOCK_SIZE);
|
memset(data->buffer, 0, BLOCK_SIZE);
|
||||||
|
|
||||||
/* fill the buffer with the catalog contents */
|
/* fill the buffer with the catalog contents */
|
||||||
write_validation_entry(data->buffer);
|
write_validation_entry(data->buffer,
|
||||||
|
boots[0]->platform_id, boots[0]->id_string);
|
||||||
|
|
||||||
/* write default entry */
|
/* write default entry = first boot image */
|
||||||
write_section_entry(data->buffer + 32, data->target);
|
write_section_entry(data->buffer + 32, data->target, 0);
|
||||||
|
|
||||||
|
/* IMPORTANT: The maximum number of boot images must fit into BLOCK_SIZE */
|
||||||
|
wpt = data->buffer + 64;
|
||||||
|
for (i = 1; i < cat->num_bootimages; ) {
|
||||||
|
/* Look ahead and put images of same platform_id and id_string
|
||||||
|
into the same section */
|
||||||
|
for (j = i + 1; j < cat->num_bootimages; j++) {
|
||||||
|
if (boots[i]->platform_id != boots[j]->platform_id)
|
||||||
|
break;
|
||||||
|
for (k = 0; k < sizeof(boots[i]->id_string); k++)
|
||||||
|
if (boots[i]->id_string[k] != boots[j]->id_string[k])
|
||||||
|
break;
|
||||||
|
if (k < sizeof(boots[i]->id_string))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
num_entries = j - i;
|
||||||
|
|
||||||
|
write_section_header(wpt, data->target, i, num_entries);
|
||||||
|
wpt += 32;
|
||||||
|
for (j = 0; j < num_entries; j++) {
|
||||||
|
write_section_entry(wpt, data->target, i);
|
||||||
|
wpt += 32;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
data->offset = 0;
|
data->offset = 0;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -702,11 +937,11 @@ int catalog_stream_new(Ecma119Image *target, IsoStream **stream)
|
|||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
|
|
||||||
str = malloc(sizeof(IsoStream));
|
str = calloc(1, sizeof(IsoStream));
|
||||||
if (str == NULL) {
|
if (str == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
data = malloc(sizeof(struct catalog_stream));
|
data = calloc(1, sizeof(struct catalog_stream));
|
||||||
if (str == NULL) {
|
if (str == NULL) {
|
||||||
free(str);
|
free(str);
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
@ -740,7 +975,7 @@ int el_torito_catalog_file_src_create(Ecma119Image *target, IsoFileSrc **src)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
file = malloc(sizeof(IsoFileSrc));
|
file = calloc(1, sizeof(IsoFileSrc));
|
||||||
if (file == NULL) {
|
if (file == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
@ -753,9 +988,10 @@ int el_torito_catalog_file_src_create(Ecma119Image *target, IsoFileSrc **src)
|
|||||||
|
|
||||||
/* fill fields */
|
/* fill fields */
|
||||||
file->prev_img = 0; /* TODO allow copy of old img catalog???? */
|
file->prev_img = 0; /* TODO allow copy of old img catalog???? */
|
||||||
|
file->checksum_index = 0;
|
||||||
file->nsections = 1;
|
file->nsections = 1;
|
||||||
file->sections = calloc(1, sizeof(struct iso_file_section));
|
file->sections = calloc(1, sizeof(struct iso_file_section));
|
||||||
file->sort_weight = 1000; /* slightly high */
|
file->sort_weight = target->catalog->sort_weight;
|
||||||
file->stream = stream;
|
file->stream = stream;
|
||||||
|
|
||||||
ret = iso_file_src_add(target, file, src);
|
ret = iso_file_src_add(target, file, src);
|
||||||
@ -771,27 +1007,26 @@ int el_torito_catalog_file_src_create(Ecma119Image *target, IsoFileSrc **src)
|
|||||||
/******************* EL-TORITO WRITER *******************************/
|
/******************* EL-TORITO WRITER *******************************/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Patch an isolinux boot image.
|
* Insert boot info table content into buf.
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* 1 on success, 0 error (but continue), < 0 error
|
* 1 on success, 0 error (but continue), < 0 error
|
||||||
*/
|
*/
|
||||||
static
|
int make_boot_info_table(uint8_t *buf, uint32_t pvd_lba,
|
||||||
int patch_boot_image(uint8_t *buf, Ecma119Image *t, size_t imgsize)
|
uint32_t boot_lba, uint32_t imgsize)
|
||||||
{
|
{
|
||||||
struct boot_info_table *info;
|
struct boot_info_table *info;
|
||||||
uint32_t checksum;
|
uint32_t checksum;
|
||||||
size_t offset;
|
uint32_t offset;
|
||||||
|
|
||||||
if (imgsize < 64) {
|
info = (struct boot_info_table *) (buf + 8);
|
||||||
return iso_msg_submit(t->image->id, ISO_ISOLINUX_CANT_PATCH, 0,
|
if (imgsize < 64)
|
||||||
"Isolinux image too small. We won't patch it.");
|
return ISO_ISOLINUX_CANT_PATCH;
|
||||||
}
|
|
||||||
|
|
||||||
/* compute checksum, as the the sum of all 32 bit words in boot image
|
/* compute checksum, as the the sum of all 32 bit words in boot image
|
||||||
* from offset 64 */
|
* from offset 64 */
|
||||||
checksum = 0;
|
checksum = 0;
|
||||||
offset = (size_t) 64;
|
offset = 64;
|
||||||
|
|
||||||
while (offset <= imgsize - 4) {
|
while (offset <= imgsize - 4) {
|
||||||
checksum += iso_read_lsb(buf + offset, 4);
|
checksum += iso_read_lsb(buf + offset, 4);
|
||||||
@ -806,16 +1041,36 @@ int patch_boot_image(uint8_t *buf, Ecma119Image *t, size_t imgsize)
|
|||||||
checksum += iso_read_lsb(buf + offset, imgsize - offset);
|
checksum += iso_read_lsb(buf + offset, imgsize - offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* patch boot info table */
|
|
||||||
info = (struct boot_info_table*)(buf + 8);
|
|
||||||
/*memset(info, 0, sizeof(struct boot_info_table));*/
|
/*memset(info, 0, sizeof(struct boot_info_table));*/
|
||||||
iso_lsb(info->bi_pvd, t->ms_block + 16, 4);
|
iso_lsb(info->bi_pvd, pvd_lba, 4);
|
||||||
iso_lsb(info->bi_file, t->bootimg->sections[0].block, 4);
|
iso_lsb(info->bi_file, boot_lba, 4);
|
||||||
iso_lsb(info->bi_length, imgsize, 4);
|
iso_lsb(info->bi_length, imgsize, 4);
|
||||||
iso_lsb(info->bi_csum, checksum, 4);
|
iso_lsb(info->bi_csum, checksum, 4);
|
||||||
|
memset(buf + 24, 0, 40);
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Patch an isolinux boot image.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* 1 on success, 0 error (but continue), < 0 error
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
int patch_boot_image(uint8_t *buf, Ecma119Image *t, size_t imgsize, int idx)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (imgsize < 64) {
|
||||||
|
return iso_msg_submit(t->image->id, ISO_ISOLINUX_CANT_PATCH, 0,
|
||||||
|
"Isolinux image too small. We won't patch it.");
|
||||||
|
}
|
||||||
|
ret = make_boot_info_table(buf, t->ms_block + (uint32_t) 16,
|
||||||
|
t->bootsrc[idx]->sections[0].block,
|
||||||
|
(uint32_t) imgsize);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
||||||
{
|
{
|
||||||
@ -824,7 +1079,11 @@ int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
* this is a good place to do so.
|
* this is a good place to do so.
|
||||||
*/
|
*/
|
||||||
Ecma119Image *t;
|
Ecma119Image *t;
|
||||||
int ret;
|
int ret, idx;
|
||||||
|
size_t size;
|
||||||
|
uint8_t *buf;
|
||||||
|
IsoStream *new = NULL;
|
||||||
|
IsoStream *original = NULL;
|
||||||
|
|
||||||
if (writer == NULL) {
|
if (writer == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
@ -832,14 +1091,17 @@ int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
|
|
||||||
t = writer->target;
|
t = writer->target;
|
||||||
|
|
||||||
if (t->catalog->image->isolinux_options & 0x01) {
|
/* Patch the boot image info tables if indicated */
|
||||||
/* we need to patch the image */
|
for (idx = 0; idx < t->catalog->num_bootimages; idx++) {
|
||||||
size_t size;
|
if (!(t->catalog->bootimages[idx]->isolinux_options & 0x01))
|
||||||
uint8_t *buf;
|
continue;
|
||||||
IsoStream *new = NULL;
|
original = t->bootsrc[idx]->stream;
|
||||||
IsoStream *original = t->bootimg->stream;
|
|
||||||
size = (size_t) iso_stream_get_size(original);
|
size = (size_t) iso_stream_get_size(original);
|
||||||
buf = malloc(size);
|
|
||||||
|
/* >>> BOOT ts B00428 :
|
||||||
|
check whether size is not too large for buffering */;
|
||||||
|
|
||||||
|
buf = calloc(1, size);
|
||||||
if (buf == NULL) {
|
if (buf == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
@ -854,7 +1116,7 @@ int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ok, patch the read buffer */
|
/* ok, patch the read buffer */
|
||||||
ret = patch_boot_image(buf, t, size);
|
ret = patch_boot_image(buf, t, size, idx);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -865,7 +1127,7 @@ int eltorito_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
t->bootimg->stream = new;
|
t->bootsrc[idx]->stream = new;
|
||||||
iso_stream_unref(original);
|
iso_stream_unref(original);
|
||||||
}
|
}
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
@ -916,12 +1178,12 @@ int eltorito_writer_free_data(IsoImageWriter *writer)
|
|||||||
|
|
||||||
int eltorito_writer_create(Ecma119Image *target)
|
int eltorito_writer_create(Ecma119Image *target)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, idx;
|
||||||
IsoImageWriter *writer;
|
IsoImageWriter *writer;
|
||||||
IsoFile *bootimg;
|
IsoFile *bootimg;
|
||||||
IsoFileSrc *src;
|
IsoFileSrc *src;
|
||||||
|
|
||||||
writer = malloc(sizeof(IsoImageWriter));
|
writer = calloc(1, sizeof(IsoImageWriter));
|
||||||
if (writer == NULL) {
|
if (writer == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
@ -947,17 +1209,20 @@ int eltorito_writer_create(Ecma119Image *target)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
bootimg = target->catalog->image->image;
|
|
||||||
|
for (idx = 0; idx < target->catalog->num_bootimages; idx++) {
|
||||||
|
bootimg = target->catalog->bootimages[idx]->image;
|
||||||
ret = iso_file_src_create(target, bootimg, &src);
|
ret = iso_file_src_create(target, bootimg, &src);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
target->bootimg = src;
|
target->bootsrc[idx] = src;
|
||||||
|
|
||||||
/* if we have selected to patch the image, it needs to be copied always */
|
/* For patching an image, it needs to be copied always */
|
||||||
if (target->catalog->image->isolinux_options & 0x01) {
|
if (target->catalog->bootimages[idx]->isolinux_options & 0x01) {
|
||||||
src->prev_img = 0;
|
src->prev_img = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* we need the bootable volume descriptor */
|
/* we need the bootable volume descriptor */
|
||||||
target->curblock++;
|
target->curblock++;
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
|
* Copyright (c) 2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -26,25 +28,45 @@ struct Iso_Boot
|
|||||||
IsoNode node;
|
IsoNode node;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Not more than 32 so that all entries fit into 2048 bytes */
|
||||||
|
#define Libisofs_max_boot_imageS 32
|
||||||
|
|
||||||
struct el_torito_boot_catalog {
|
struct el_torito_boot_catalog {
|
||||||
IsoBoot *node; /* node of the catalog */
|
IsoBoot *node; /* node of the catalog */
|
||||||
struct el_torito_boot_image *image; /* default boot image */
|
|
||||||
|
int num_bootimages;
|
||||||
|
struct el_torito_boot_image *bootimages[Libisofs_max_boot_imageS];
|
||||||
|
/* [0]= default boot image */
|
||||||
|
|
||||||
|
/* Weight value for image sorting */
|
||||||
|
int sort_weight;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct el_torito_boot_image {
|
struct el_torito_boot_image {
|
||||||
IsoFile *image;
|
IsoFile *image;
|
||||||
|
|
||||||
unsigned int bootable:1; /**< If the entry is bootable. */
|
unsigned int bootable:1; /**< If the entry is bootable. */
|
||||||
|
/**
|
||||||
|
* Whether the boot image seems to contain a boot_info_table
|
||||||
|
*/
|
||||||
|
unsigned int seems_boot_info_table:1;
|
||||||
/**
|
/**
|
||||||
* isolinux options
|
* isolinux options
|
||||||
* bit 0 -> whether to patch image
|
* bit 0 -> whether to patch image
|
||||||
* bit 1 -> whether to create isolinux image
|
* bit 1 -> whether to put built-in isolinux 3.72 isohybrid-MBR into image
|
||||||
|
* System Area (deprecated)
|
||||||
*/
|
*/
|
||||||
unsigned int isolinux_options:2;
|
unsigned int isolinux_options:2;
|
||||||
unsigned char type; /**< The type of image */
|
unsigned char type; /**< The type of image */
|
||||||
unsigned char partition_type; /**< type of partition for HD-emul images */
|
unsigned char partition_type; /**< type of partition for HD-emul images */
|
||||||
short load_seg; /**< Load segment for the initial boot image. */
|
short load_seg; /**< Load segment for the initial boot image. */
|
||||||
short load_size; /**< Number of sectors to load. */
|
short load_size; /**< Number of sectors to load. */
|
||||||
|
|
||||||
|
/* Byte 1 of Validation Entry or Section Header Entry:
|
||||||
|
0= 80x86, 1= PowerPC, 2= Mac, 0xef= EFI */
|
||||||
|
uint8_t platform_id;
|
||||||
|
uint8_t id_string[28];
|
||||||
|
uint8_t selection_crit[20];
|
||||||
};
|
};
|
||||||
|
|
||||||
/** El-Torito, 2.1 */
|
/** El-Torito, 2.1 */
|
||||||
@ -74,8 +96,8 @@ struct el_torito_default_entry {
|
|||||||
struct el_torito_section_header {
|
struct el_torito_section_header {
|
||||||
uint8_t header_indicator BP(1, 1);
|
uint8_t header_indicator BP(1, 1);
|
||||||
uint8_t platform_id BP(2, 2);
|
uint8_t platform_id BP(2, 2);
|
||||||
uint8_t number BP(3, 4);
|
uint8_t num_entries BP(3, 4);
|
||||||
uint8_t character BP(5, 32);
|
uint8_t id_string BP(5, 32);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** El-Torito, 2.4 */
|
/** El-Torito, 2.4 */
|
||||||
@ -105,4 +127,14 @@ int el_torito_catalog_file_src_create(Ecma119Image *target, IsoFileSrc **src);
|
|||||||
*/
|
*/
|
||||||
int eltorito_writer_create(Ecma119Image *target);
|
int eltorito_writer_create(Ecma119Image *target);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Insert boot info table content into buf.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* 1 on success, 0 error (but continue), < 0 error
|
||||||
|
*/
|
||||||
|
int make_boot_info_table(uint8_t *buf, uint32_t pvd_lba,
|
||||||
|
uint32_t boot_lba, uint32_t imgsize);
|
||||||
|
|
||||||
|
|
||||||
#endif /* LIBISO_ELTORITO_H */
|
#endif /* LIBISO_ELTORITO_H */
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "filesrc.h"
|
#include "filesrc.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
@ -13,16 +18,18 @@
|
|||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
#include "image.h"
|
#include "image.h"
|
||||||
#include "stream.h"
|
#include "stream.h"
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
#include "md5.h"
|
#include "md5.h"
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
int iso_file_src_cmp(const void *n1, const void *n2)
|
int iso_file_src_cmp(const void *n1, const void *n2)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
@ -47,11 +54,8 @@ int iso_file_src_create(Ecma119Image *img, IsoFile *file, IsoFileSrc **src)
|
|||||||
unsigned int fs_id;
|
unsigned int fs_id;
|
||||||
dev_t dev_id;
|
dev_t dev_id;
|
||||||
ino_t ino_id;
|
ino_t ino_id;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
int cret, no_md5= 0;
|
int cret, no_md5= 0;
|
||||||
void *xipt = NULL;
|
void *xipt = NULL;
|
||||||
#endif
|
|
||||||
|
|
||||||
if (img == NULL || file == NULL || src == NULL) {
|
if (img == NULL || file == NULL || src == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
@ -97,9 +101,6 @@ int iso_file_src_create(Ecma119Image *img, IsoFile *file, IsoFileSrc **src)
|
|||||||
/* insert the filesrc in the tree */
|
/* insert the filesrc in the tree */
|
||||||
ret = iso_rbtree_insert(img->files, fsrc, (void**)src);
|
ret = iso_rbtree_insert(img->files, fsrc, (void**)src);
|
||||||
if (ret <= 0) {
|
if (ret <= 0) {
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (ret == 0 && (*src)->checksum_index > 0) {
|
if (ret == 0 && (*src)->checksum_index > 0) {
|
||||||
/* Duplicate file source was mapped to previously registered source
|
/* Duplicate file source was mapped to previously registered source
|
||||||
*/
|
*/
|
||||||
@ -107,17 +108,12 @@ int iso_file_src_create(Ecma119Image *img, IsoFile *file, IsoFileSrc **src)
|
|||||||
if (cret < 0)
|
if (cret < 0)
|
||||||
ret = cret;
|
ret = cret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
free(fsrc->sections);
|
free(fsrc->sections);
|
||||||
free(fsrc);
|
free(fsrc);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
iso_stream_ref(fsrc->stream);
|
iso_stream_ref(fsrc->stream);
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if ((img->md5_file_checksums & 1) &&
|
if ((img->md5_file_checksums & 1) &&
|
||||||
file->from_old_session && img->appendable) {
|
file->from_old_session && img->appendable) {
|
||||||
ret = iso_node_get_xinfo((IsoNode *) file, checksum_md5_xinfo_func,
|
ret = iso_node_get_xinfo((IsoNode *) file, checksum_md5_xinfo_func,
|
||||||
@ -132,19 +128,17 @@ int iso_file_src_create(Ecma119Image *img, IsoFile *file, IsoFileSrc **src)
|
|||||||
|
|
||||||
if ((img->md5_file_checksums & 1) && !no_md5) {
|
if ((img->md5_file_checksums & 1) && !no_md5) {
|
||||||
img->checksum_idx_counter++;
|
img->checksum_idx_counter++;
|
||||||
if (img->checksum_idx_counter < 0x80000000) {
|
if (img->checksum_idx_counter < 0x7fffffff) {
|
||||||
fsrc->checksum_index = img->checksum_idx_counter;
|
fsrc->checksum_index = img->checksum_idx_counter;
|
||||||
} else {
|
} else {
|
||||||
fsrc->checksum_index= 0;
|
fsrc->checksum_index= 0;
|
||||||
img->checksum_idx_counter= 0x80000000; /* keep from rolling over */
|
img->checksum_idx_counter= 0x7fffffff; /* keep from rolling over */
|
||||||
}
|
}
|
||||||
cret = iso_file_set_isofscx(file, (*src)->checksum_index, 0);
|
cret = iso_file_set_isofscx(file, (*src)->checksum_index, 0);
|
||||||
if (cret < 0)
|
if (cret < 0)
|
||||||
return cret;
|
return cret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -298,21 +292,16 @@ int filesrc_read(IsoFileSrc *file, char *buf, size_t count)
|
|||||||
return iso_stream_read_buffer(file->stream, buf, count, &got);
|
return iso_stream_read_buffer(file->stream, buf, count, &got);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/* @return 1=ok, md5 is valid,
|
/* @return 1=ok, md5 is valid,
|
||||||
0= not ok, go on,
|
0= not ok, go on,
|
||||||
<0 fatal error, abort
|
<0 fatal error, abort
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static
|
static
|
||||||
int filesrc_make_md5(Ecma119Image *t, IsoFileSrc *file, char md5[16], int flag)
|
int filesrc_make_md5(Ecma119Image *t, IsoFileSrc *file, char md5[16], int flag)
|
||||||
{
|
{
|
||||||
return iso_stream_make_md5(file->stream, md5, 0);
|
return iso_stream_make_md5(file->stream, md5, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
static
|
static
|
||||||
int filesrc_writer_write_data(IsoImageWriter *writer)
|
int filesrc_writer_write_data(IsoImageWriter *writer)
|
||||||
{
|
{
|
||||||
@ -325,13 +314,9 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
char buffer[BLOCK_SIZE];
|
char buffer[BLOCK_SIZE];
|
||||||
off_t file_size;
|
off_t file_size;
|
||||||
uint32_t nblocks;
|
uint32_t nblocks;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
void *ctx= NULL;
|
void *ctx= NULL;
|
||||||
char md5[16], pre_md5[16];
|
char md5[16], pre_md5[16];
|
||||||
int pre_md5_valid = 0;
|
int pre_md5_valid = 0;
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
if (writer == NULL) {
|
if (writer == NULL) {
|
||||||
return ISO_ASSERT_FAILURE;
|
return ISO_ASSERT_FAILURE;
|
||||||
@ -347,17 +332,11 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
was_error = 0;
|
was_error = 0;
|
||||||
file_size = iso_file_src_get_size(file);
|
file_size = iso_file_src_get_size(file);
|
||||||
nblocks = DIV_UP(file_size, BLOCK_SIZE);
|
nblocks = DIV_UP(file_size, BLOCK_SIZE);
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
pre_md5_valid = 0;
|
pre_md5_valid = 0;
|
||||||
if (file->checksum_index > 0 && (t->md5_file_checksums & 2)) {
|
if (file->checksum_index > 0 && (t->md5_file_checksums & 2)) {
|
||||||
/* Obtain an MD5 of content by a first read pass */
|
/* Obtain an MD5 of content by a first read pass */
|
||||||
pre_md5_valid = filesrc_make_md5(t, file, pre_md5, 0);
|
pre_md5_valid = filesrc_make_md5(t, file, pre_md5, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
res = filesrc_open(file);
|
res = filesrc_open(file);
|
||||||
iso_stream_get_file_name(file->stream, name);
|
iso_stream_get_file_name(file->stream, name);
|
||||||
if (res < 0) {
|
if (res < 0) {
|
||||||
@ -401,18 +380,12 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (file->checksum_index > 0) {
|
if (file->checksum_index > 0) {
|
||||||
/* initialize file checksum */
|
/* initialize file checksum */
|
||||||
res = iso_md5_start(&ctx);
|
res = iso_md5_start(&ctx);
|
||||||
if (res <= 0)
|
if (res <= 0)
|
||||||
file->checksum_index = 0;
|
file->checksum_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/* write file contents to image */
|
/* write file contents to image */
|
||||||
for (b = 0; b < nblocks; ++b) {
|
for (b = 0; b < nblocks; ++b) {
|
||||||
int wres;
|
int wres;
|
||||||
@ -428,9 +401,6 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
ret = wres;
|
ret = wres;
|
||||||
goto ex;
|
goto ex;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (file->checksum_index > 0) {
|
if (file->checksum_index > 0) {
|
||||||
/* Add to file checksum */
|
/* Add to file checksum */
|
||||||
if (file_size - b * BLOCK_SIZE > BLOCK_SIZE)
|
if (file_size - b * BLOCK_SIZE > BLOCK_SIZE)
|
||||||
@ -441,9 +411,6 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
if (res <= 0)
|
if (res <= 0)
|
||||||
file->checksum_index = 0;
|
file->checksum_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
filesrc_close(file);
|
filesrc_close(file);
|
||||||
@ -478,9 +445,6 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
ret = res;
|
ret = res;
|
||||||
goto ex;
|
goto ex;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (file->checksum_index > 0) {
|
if (file->checksum_index > 0) {
|
||||||
/* Add to file checksum */
|
/* Add to file checksum */
|
||||||
if (file_size - b * BLOCK_SIZE > BLOCK_SIZE)
|
if (file_size - b * BLOCK_SIZE > BLOCK_SIZE)
|
||||||
@ -491,15 +455,10 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
if (res <= 0)
|
if (res <= 0)
|
||||||
file->checksum_index = 0;
|
file->checksum_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (file->checksum_index > 0 &&
|
||||||
#ifdef Libisofs_with_checksumS
|
file->checksum_index <= t->checksum_idx_counter) {
|
||||||
|
|
||||||
if (file->checksum_index > 0) {
|
|
||||||
/* Obtain checksum and dispose checksum context */
|
/* Obtain checksum and dispose checksum context */
|
||||||
res = iso_md5_end(&ctx, md5);
|
res = iso_md5_end(&ctx, md5);
|
||||||
if (res <= 0)
|
if (res <= 0)
|
||||||
@ -522,19 +481,12 @@ int filesrc_writer_write_data(IsoImageWriter *writer)
|
|||||||
/* Write md5 into checksum buffer at file->checksum_index */
|
/* Write md5 into checksum buffer at file->checksum_index */
|
||||||
memcpy(t->checksum_buffer + 16 * file->checksum_index, md5, 16);
|
memcpy(t->checksum_buffer + 16 * file->checksum_index, md5, 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = ISO_SUCCESS;
|
ret = ISO_SUCCESS;
|
||||||
ex:;
|
ex:;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
if (ctx != NULL) /* avoid any memory leak */
|
if (ctx != NULL) /* avoid any memory leak */
|
||||||
iso_md5_end(&ctx, md5);
|
iso_md5_end(&ctx, md5);
|
||||||
#endif
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,7 +502,7 @@ int iso_file_src_writer_create(Ecma119Image *target)
|
|||||||
{
|
{
|
||||||
IsoImageWriter *writer;
|
IsoImageWriter *writer;
|
||||||
|
|
||||||
writer = malloc(sizeof(IsoImageWriter));
|
writer = calloc(1, sizeof(IsoImageWriter));
|
||||||
if (writer == NULL) {
|
if (writer == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_FILESRC_H_
|
#ifndef LIBISO_FILESRC_H_
|
||||||
#define LIBISO_FILESRC_H_
|
#define LIBISO_FILESRC_H_
|
||||||
@ -17,14 +18,8 @@
|
|||||||
struct Iso_File_Src
|
struct Iso_File_Src
|
||||||
{
|
{
|
||||||
unsigned int prev_img :1; /**< if the file comes from a previous image */
|
unsigned int prev_img :1; /**< if the file comes from a previous image */
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
unsigned int checksum_index :31;
|
unsigned int checksum_index :31;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
/** File Sections of the file in the image */
|
/** File Sections of the file in the image */
|
||||||
struct iso_file_section *sections;
|
struct iso_file_section *sections;
|
||||||
int nsections;
|
int nsections;
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "filter.h"
|
#include "filter.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2008 Vreixo Formoso
|
* Copyright (c) 2008 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_FILTER_H_
|
#ifndef LIBISO_FILTER_H_
|
||||||
#define LIBISO_FILTER_H_
|
#define LIBISO_FILTER_H_
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*
|
*
|
||||||
* It implements a filter facility which can pipe a IsoStream into an external
|
* It implements a filter facility which can pipe a IsoStream into an external
|
||||||
* process, read its output and forward it as IsoStream output to an IsoFile.
|
* process, read its output and forward it as IsoStream output to an IsoFile.
|
||||||
@ -12,6 +13,10 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../libisofs.h"
|
#include "../libisofs.h"
|
||||||
#include "../filter.h"
|
#include "../filter.h"
|
||||||
#include "../fsource.h"
|
#include "../fsource.h"
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*
|
*
|
||||||
* It implements a filter facility which can pipe a IsoStream into gzip
|
* It implements a filter facility which can pipe a IsoStream into gzip
|
||||||
* compression resp. uncompression, read its output and forward it as IsoStream
|
* compression resp. uncompression, read its output and forward it as IsoStream
|
||||||
@ -16,6 +17,10 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../libisofs.h"
|
#include "../libisofs.h"
|
||||||
#include "../filter.h"
|
#include "../filter.h"
|
||||||
#include "../fsource.h"
|
#include "../fsource.h"
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2008 Vreixo Formoso
|
* Copyright (c) 2008 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../libisofs.h"
|
#include "../libisofs.h"
|
||||||
#include "../filter.h"
|
#include "../filter.h"
|
||||||
#include "../fsource.h"
|
#include "../fsource.h"
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*
|
*
|
||||||
* It implements a filter facility which can pipe a IsoStream into zisofs
|
* It implements a filter facility which can pipe a IsoStream into zisofs
|
||||||
* compression resp. uncompression, read its output and forward it as IsoStream
|
* compression resp. uncompression, read its output and forward it as IsoStream
|
||||||
@ -13,6 +14,10 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../libisofs.h"
|
#include "../libisofs.h"
|
||||||
#include "../filter.h"
|
#include "../filter.h"
|
||||||
#include "../fsource.h"
|
#include "../fsource.h"
|
||||||
@ -825,6 +830,9 @@ int ziso_cmp_ino(IsoStream *s1, IsoStream *s2)
|
|||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef Libisofs_with_zliB
|
||||||
|
|
||||||
static
|
static
|
||||||
void ziso_filter_free(FilterContext *filter)
|
void ziso_filter_free(FilterContext *filter)
|
||||||
{
|
{
|
||||||
@ -938,6 +946,7 @@ int ziso_create_context(FilterContext **filter, int flag)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* Libisofs_with_zliB */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @param flag bit0= if_block_reduction rather than if_reduction
|
* @param flag bit0= if_block_reduction rather than if_reduction
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2008 Vreixo Formoso
|
* Copyright (c) 2008 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
|
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 - 2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -12,6 +13,10 @@
|
|||||||
* IsoDataSource to read image data.
|
* IsoDataSource to read image data.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "ecma119.h"
|
#include "ecma119.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
@ -30,6 +35,11 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Options for image reading.
|
* Options for image reading.
|
||||||
* There are four kind of options:
|
* There are four kind of options:
|
||||||
@ -96,6 +106,12 @@ struct iso_read_opts
|
|||||||
*/
|
*/
|
||||||
int auto_input_charset;
|
int auto_input_charset;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable or disable loading of the first 32768 bytes of the session and
|
||||||
|
* submission by iso_write_opts_set_system_area(data, 0).
|
||||||
|
*/
|
||||||
|
int load_system_area;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -267,12 +283,20 @@ typedef struct
|
|||||||
|
|
||||||
/* el-torito information */
|
/* el-torito information */
|
||||||
unsigned int eltorito : 1; /* is el-torito available */
|
unsigned int eltorito : 1; /* is el-torito available */
|
||||||
unsigned int bootable:1; /**< If the entry is bootable. */
|
int num_bootimgs;
|
||||||
unsigned char type; /**< The type of image */
|
unsigned char platform_ids[Libisofs_max_boot_imageS];
|
||||||
unsigned char partition_type; /**< type of partition for HD-emul images */
|
unsigned char id_strings[Libisofs_max_boot_imageS][28];
|
||||||
short load_seg; /**< Load segment for the initial boot image. */
|
unsigned char selection_crits[Libisofs_max_boot_imageS][20];
|
||||||
short load_size; /**< Number of sectors to load. */
|
unsigned char boot_flags[Libisofs_max_boot_imageS]; /* bit0= bootable */
|
||||||
uint32_t imgblock; /**< Block for El-Torito boot image */
|
unsigned char media_types[Libisofs_max_boot_imageS];
|
||||||
|
unsigned char partition_types[Libisofs_max_boot_imageS];
|
||||||
|
short load_segs[Libisofs_max_boot_imageS];
|
||||||
|
short load_sizes[Libisofs_max_boot_imageS];
|
||||||
|
/** Block addresses of for El-Torito boot images.
|
||||||
|
Needed to recognize them when the get read from the directory tree.
|
||||||
|
*/
|
||||||
|
uint32_t bootblocks[Libisofs_max_boot_imageS];
|
||||||
|
|
||||||
uint32_t catblock; /**< Block for El-Torito catalog */
|
uint32_t catblock; /**< Block for El-Torito catalog */
|
||||||
|
|
||||||
/* Whether inode numbers from PX entries shall be discarded */
|
/* Whether inode numbers from PX entries shall be discarded */
|
||||||
@ -2100,19 +2124,15 @@ int read_root_susp_entries(_ImageFsData *data, uint32_t block)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
int read_pvm(_ImageFsData *data, uint32_t block)
|
int read_pvd_block(IsoDataSource *src, uint32_t block, uint8_t *buffer,
|
||||||
|
uint32_t *image_size)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct ecma119_pri_vol_desc *pvm;
|
struct ecma119_pri_vol_desc *pvm;
|
||||||
struct ecma119_dir_record *rootdr;
|
|
||||||
uint8_t buffer[BLOCK_SIZE];
|
|
||||||
|
|
||||||
/* read PVM */
|
ret = src->read_block(src, block, buffer);
|
||||||
ret = data->src->read_block(data->src, block, buffer);
|
if (ret < 0)
|
||||||
if (ret < 0) {
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
|
||||||
|
|
||||||
pvm = (struct ecma119_pri_vol_desc *)buffer;
|
pvm = (struct ecma119_pri_vol_desc *)buffer;
|
||||||
|
|
||||||
/* sanity checks */
|
/* sanity checks */
|
||||||
@ -2122,20 +2142,55 @@ int read_pvm(_ImageFsData *data, uint32_t block)
|
|||||||
|
|
||||||
return ISO_WRONG_PVD;
|
return ISO_WRONG_PVD;
|
||||||
}
|
}
|
||||||
|
if (image_size != NULL)
|
||||||
|
*image_size = iso_read_bb(pvm->vol_space_size, 4, NULL);
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static
|
||||||
|
int read_pvm(_ImageFsData *data, uint32_t block)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
struct ecma119_pri_vol_desc *pvm;
|
||||||
|
struct ecma119_dir_record *rootdr;
|
||||||
|
uint8_t buffer[BLOCK_SIZE];
|
||||||
|
|
||||||
|
ret = read_pvd_block(data->src, block, buffer, NULL);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
/* ok, it is a valid PVD */
|
/* ok, it is a valid PVD */
|
||||||
|
pvm = (struct ecma119_pri_vol_desc *)buffer;
|
||||||
|
|
||||||
/* fill volume attributes */
|
/* fill volume attributes */
|
||||||
/* TODO take care of input charset */
|
/* TODO take care of input charset */
|
||||||
data->volset_id = strcopy((char*)pvm->vol_set_id, 128);
|
data->volset_id = iso_util_strcopy_untail((char*)pvm->vol_set_id, 128);
|
||||||
data->volume_id = strcopy((char*)pvm->volume_id, 32);
|
data->volume_id = iso_util_strcopy_untail((char*)pvm->volume_id, 32);
|
||||||
data->publisher_id = strcopy((char*)pvm->publisher_id, 128);
|
data->publisher_id =
|
||||||
data->data_preparer_id = strcopy((char*)pvm->data_prep_id, 128);
|
iso_util_strcopy_untail((char*)pvm->publisher_id, 128);
|
||||||
data->system_id = strcopy((char*)pvm->system_id, 32);
|
data->data_preparer_id =
|
||||||
data->application_id = strcopy((char*)pvm->application_id, 128);
|
iso_util_strcopy_untail((char*)pvm->data_prep_id, 128);
|
||||||
data->copyright_file_id = strcopy((char*)pvm->copyright_file_id, 37);
|
data->system_id = iso_util_strcopy_untail((char*)pvm->system_id, 32);
|
||||||
data->abstract_file_id = strcopy((char*)pvm->abstract_file_id, 37);
|
data->application_id =
|
||||||
data->biblio_file_id = strcopy((char*)pvm->bibliographic_file_id, 37);
|
iso_util_strcopy_untail((char*)pvm->application_id, 128);
|
||||||
|
data->copyright_file_id =
|
||||||
|
iso_util_strcopy_untail((char*) pvm->copyright_file_id, 37);
|
||||||
|
data->abstract_file_id =
|
||||||
|
iso_util_strcopy_untail((char*) pvm->abstract_file_id, 37);
|
||||||
|
data->biblio_file_id =
|
||||||
|
iso_util_strcopy_untail((char*) pvm->bibliographic_file_id, 37);
|
||||||
|
if (data->copyright_file_id[0] == '_' && data->copyright_file_id[1] == 0 &&
|
||||||
|
data->abstract_file_id[0] == '_' && data->abstract_file_id[1] == 0 &&
|
||||||
|
data->biblio_file_id[0] == '_' && data->biblio_file_id[1] == 0) {
|
||||||
|
/* This is bug output from libisofs <= 0.6.23 . The texts mean file
|
||||||
|
names and should have been empty to indicate that there are no such
|
||||||
|
files. It is obvious that not all three roles can be fulfilled by
|
||||||
|
one file "_" so that one cannot spoil anything by assuming them
|
||||||
|
empty now.
|
||||||
|
*/
|
||||||
|
data->copyright_file_id[0] = 0;
|
||||||
|
data->abstract_file_id[0] = 0;
|
||||||
|
data->biblio_file_id[0] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
data->nblocks = iso_read_bb(pvm->vol_space_size, 4, NULL);
|
data->nblocks = iso_read_bb(pvm->vol_space_size, 4, NULL);
|
||||||
|
|
||||||
@ -2160,11 +2215,13 @@ int read_pvm(_ImageFsData *data, uint32_t block)
|
|||||||
static
|
static
|
||||||
int read_el_torito_boot_catalog(_ImageFsData *data, uint32_t block)
|
int read_el_torito_boot_catalog(_ImageFsData *data, uint32_t block)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, i, rx, last_done, idx;
|
||||||
struct el_torito_validation_entry *ve;
|
struct el_torito_validation_entry *ve;
|
||||||
struct el_torito_default_entry *entry;
|
struct el_torito_section_header *sh;
|
||||||
|
struct el_torito_section_entry *entry; /* also usable as default_entry */
|
||||||
unsigned char buffer[BLOCK_SIZE];
|
unsigned char buffer[BLOCK_SIZE];
|
||||||
|
|
||||||
|
data->num_bootimgs = 0;
|
||||||
ret = data->src->read_block(data->src, block, buffer);
|
ret = data->src->read_block(data->src, block, buffer);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
@ -2175,34 +2232,70 @@ int read_el_torito_boot_catalog(_ImageFsData *data, uint32_t block)
|
|||||||
/* check if it is a valid catalog (TODO: check also the checksum)*/
|
/* check if it is a valid catalog (TODO: check also the checksum)*/
|
||||||
if ( (ve->header_id[0] != 1) || (ve->key_byte1[0] != 0x55)
|
if ( (ve->header_id[0] != 1) || (ve->key_byte1[0] != 0x55)
|
||||||
|| (ve->key_byte2[0] != 0xAA) ) {
|
|| (ve->key_byte2[0] != 0xAA) ) {
|
||||||
|
iso_msg_submit(data->msgid, ISO_WRONG_EL_TORITO, 0,
|
||||||
return iso_msg_submit(data->msgid, ISO_WRONG_EL_TORITO, 0,
|
|
||||||
"Wrong or damaged El-Torito Catalog. El-Torito info "
|
"Wrong or damaged El-Torito Catalog. El-Torito info "
|
||||||
"will be ignored.");
|
"will be ignored.");
|
||||||
|
return ISO_WRONG_EL_TORITO;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for a valid platform */
|
/* check for a valid platform */
|
||||||
if (ve->platform_id[0] != 0) {
|
if (ve->platform_id[0] != 0 && ve->platform_id[0] != 0xef) {
|
||||||
return iso_msg_submit(data->msgid, ISO_UNSUPPORTED_EL_TORITO, 0,
|
iso_msg_submit(data->msgid, ISO_UNSUPPORTED_EL_TORITO, 0,
|
||||||
"Unsupported El-Torito platform. Only 80x86 is "
|
"Unsupported El-Torito platform. Only 80x86 and EFI are "
|
||||||
"supported. El-Torito info will be ignored.");
|
"supported. El-Torito info will be ignored.");
|
||||||
|
return ISO_UNSUPPORTED_EL_TORITO;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ok, once we are here we assume it is a valid catalog */
|
/* ok, once we are here we assume it is a valid catalog */
|
||||||
|
|
||||||
/* parse the default entry */
|
/* parse the default entry */
|
||||||
entry = (struct el_torito_default_entry *)(buffer + 32);
|
entry = (struct el_torito_section_entry *)(buffer + 32);
|
||||||
|
|
||||||
data->eltorito = 1;
|
data->eltorito = 1;
|
||||||
data->bootable = entry->boot_indicator[0] ? 1 : 0;
|
/* The Default Entry is declared mandatory */
|
||||||
data->type = entry->boot_media_type[0];
|
data->num_bootimgs = 1;
|
||||||
data->partition_type = entry->system_type[0];
|
data->platform_ids[0] = ve->platform_id[0];
|
||||||
data->load_seg = iso_read_lsb(entry->load_seg, 2);
|
memcpy(data->id_strings[0], ve->id_string, 24);
|
||||||
data->load_size = iso_read_lsb(entry->sec_count, 2);
|
memset(data->id_strings[0] + 24, 0, 4);
|
||||||
data->imgblock = iso_read_lsb(entry->block, 4);
|
data->boot_flags[0] = entry->boot_indicator[0] ? 1 : 0;
|
||||||
|
data->media_types[0] = entry->boot_media_type[0];
|
||||||
/* TODO #00018 : check if there are more entries in the boot catalog */
|
data->partition_types[0] = entry->system_type[0];
|
||||||
|
data->load_segs[0] = iso_read_lsb(entry->load_seg, 2);
|
||||||
|
data->load_sizes[0] = iso_read_lsb(entry->sec_count, 2);
|
||||||
|
data->bootblocks[0] = iso_read_lsb(entry->block, 4);
|
||||||
|
/* The Default Entry has no selection criterion */
|
||||||
|
memset(data->selection_crits[0], 0, 20);
|
||||||
|
|
||||||
|
/* Read eventual more entries from the boot catalog */
|
||||||
|
last_done = 0;
|
||||||
|
for (rx = 64; (buffer[rx] & 0xfe) == 0x90 && !last_done; rx += 32) {
|
||||||
|
last_done = buffer[rx] & 1;
|
||||||
|
/* Read Section Header */
|
||||||
|
sh = (struct el_torito_section_header *) (buffer + rx);
|
||||||
|
for (i = 0; i < sh->num_entries[0]; i++) {
|
||||||
|
rx += 32;
|
||||||
|
if (data->num_bootimgs >= Libisofs_max_boot_imageS) {
|
||||||
|
ret = iso_msg_submit(data->msgid, ISO_EL_TORITO_WARN, 0,
|
||||||
|
"Too many boot images found. List truncated.");
|
||||||
|
goto after_bootblocks;
|
||||||
|
}
|
||||||
|
/* Read bootblock from section entry */
|
||||||
|
entry = (struct el_torito_section_entry *)(buffer + rx);
|
||||||
|
idx = data->num_bootimgs;
|
||||||
|
data->platform_ids[idx] = sh->platform_id[0];
|
||||||
|
memcpy(data->id_strings[idx], sh->id_string, 28);
|
||||||
|
data->boot_flags[idx] = entry->boot_indicator[0] ? 1 : 0;
|
||||||
|
data->media_types[idx] = entry->boot_media_type[0];
|
||||||
|
data->partition_types[idx] = entry->system_type[0];
|
||||||
|
data->load_segs[idx] = iso_read_lsb(entry->load_seg, 2);
|
||||||
|
data->load_sizes[idx] = iso_read_lsb(entry->sec_count, 2);
|
||||||
|
data->bootblocks[idx] = iso_read_lsb(entry->block, 4);
|
||||||
|
data->selection_crits[idx][0] = entry->selec_criteria[0];
|
||||||
|
memcpy(data->selection_crits[idx] + 1, entry->vendor_sc, 19);
|
||||||
|
data->num_bootimgs++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
after_bootblocks:;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2286,7 +2379,7 @@ ex:
|
|||||||
int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
||||||
int msgid, IsoImageFilesystem **fs)
|
int msgid, IsoImageFilesystem **fs)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, i;
|
||||||
uint32_t block;
|
uint32_t block;
|
||||||
IsoImageFilesystem *ifs;
|
IsoImageFilesystem *ifs;
|
||||||
_ImageFsData *data;
|
_ImageFsData *data;
|
||||||
@ -2325,9 +2418,13 @@ int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
|||||||
data->md5_load = !opts->nomd5;
|
data->md5_load = !opts->nomd5;
|
||||||
data->aaip_version = -1;
|
data->aaip_version = -1;
|
||||||
data->make_new_ino = opts->make_new_ino;
|
data->make_new_ino = opts->make_new_ino;
|
||||||
|
data->num_bootimgs = 0;
|
||||||
|
for (i = 0; i < Libisofs_max_boot_imageS; i++)
|
||||||
|
data->bootblocks[i] = 0;
|
||||||
data->inode_counter = 0;
|
data->inode_counter = 0;
|
||||||
data->px_ino_status = 0;
|
data->px_ino_status = 0;
|
||||||
|
|
||||||
|
|
||||||
data->local_charset = strdup(iso_get_local_charset(0));
|
data->local_charset = strdup(iso_get_local_charset(0));
|
||||||
if (data->local_charset == NULL) {
|
if (data->local_charset == NULL) {
|
||||||
ret = ISO_OUT_OF_MEM;
|
ret = ISO_OUT_OF_MEM;
|
||||||
@ -2346,9 +2443,6 @@ int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
|||||||
ifs->free = ifs_fs_free;
|
ifs->free = ifs_fs_free;
|
||||||
|
|
||||||
/* read Volume Descriptors and ensure it is a valid image */
|
/* read Volume Descriptors and ensure it is a valid image */
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (data->md5_load) {
|
if (data->md5_load) {
|
||||||
/* From opts->block on : check for superblock and tree tags */;
|
/* From opts->block on : check for superblock and tree tags */;
|
||||||
ret = iso_src_check_sb_tree(src, opts->block, 0);
|
ret = iso_src_check_sb_tree(src, opts->block, 0);
|
||||||
@ -2363,8 +2457,6 @@ int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
/* 1. first, open the filesystem */
|
/* 1. first, open the filesystem */
|
||||||
ifs_fs_open(ifs);
|
ifs_fs_open(ifs);
|
||||||
|
|
||||||
@ -2394,23 +2486,20 @@ int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
|||||||
|| vol->vol_desc_version[0] != 1
|
|| vol->vol_desc_version[0] != 1
|
||||||
|| strncmp((char*)vol->boot_sys_id,
|
|| strncmp((char*)vol->boot_sys_id,
|
||||||
"EL TORITO SPECIFICATION", 23)) {
|
"EL TORITO SPECIFICATION", 23)) {
|
||||||
|
iso_msg_submit(data->msgid,
|
||||||
ret = iso_msg_submit(data->msgid,
|
|
||||||
ISO_UNSUPPORTED_EL_TORITO, 0,
|
ISO_UNSUPPORTED_EL_TORITO, 0,
|
||||||
"Unsupported Boot Vol. Desc. Only El-Torito "
|
"Unsupported Boot Vol. Desc. Only El-Torito "
|
||||||
"Specification, Version 1.0 Volume "
|
"Specification, Version 1.0 Volume "
|
||||||
"Descriptors are supported. Ignoring boot info");
|
"Descriptors are supported. Ignoring boot info");
|
||||||
if (ret < 0) {
|
} else {
|
||||||
goto fs_cleanup;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
data->catblock = iso_read_lsb(vol->boot_catalog, 4);
|
data->catblock = iso_read_lsb(vol->boot_catalog, 4);
|
||||||
ret = read_el_torito_boot_catalog(data, data->catblock);
|
ret = read_el_torito_boot_catalog(data, data->catblock);
|
||||||
if (ret < 0) {
|
if (ret < 0 && ret != ISO_UNSUPPORTED_EL_TORITO &&
|
||||||
|
ret != ISO_WRONG_EL_TORITO) {
|
||||||
goto fs_cleanup;
|
goto fs_cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
/* suplementary volume descritor */
|
/* suplementary volume descritor */
|
||||||
@ -2458,11 +2547,8 @@ int iso_image_filesystem_new(IsoDataSource *src, struct iso_read_opts *opts,
|
|||||||
*/
|
*/
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ret = iso_msg_submit(data->msgid, ISO_UNSUPPORTED_VD, 0,
|
iso_msg_submit(data->msgid, ISO_UNSUPPORTED_VD, 0,
|
||||||
"Ignoring Volume descriptor %x.", buffer[0]);
|
"Ignoring Volume descriptor %x.", buffer[0]);
|
||||||
if (ret < 0) {
|
|
||||||
goto fs_cleanup;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
block++;
|
block++;
|
||||||
@ -2582,7 +2668,7 @@ static
|
|||||||
int image_builder_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
int image_builder_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
||||||
IsoFileSource *src, IsoNode **node)
|
IsoFileSource *src, IsoNode **node)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, idx;
|
||||||
struct stat info;
|
struct stat info;
|
||||||
IsoNode *new;
|
IsoNode *new;
|
||||||
char *name;
|
char *name;
|
||||||
@ -2694,11 +2780,16 @@ int image_builder_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
|||||||
new = (IsoNode*) file;
|
new = (IsoNode*) file;
|
||||||
new->refcount = 0;
|
new->refcount = 0;
|
||||||
|
|
||||||
if (fsdata->eltorito && data->sections[0].block == fsdata->imgblock) {
|
for (idx = 0; idx < fsdata->num_bootimgs; idx++)
|
||||||
|
if (fsdata->eltorito && data->sections[0].block ==
|
||||||
|
fsdata->bootblocks[idx])
|
||||||
|
break;
|
||||||
|
if (idx < fsdata->num_bootimgs) {
|
||||||
/* it is boot image node */
|
/* it is boot image node */
|
||||||
if (image->bootcat->image->image != NULL) {
|
|
||||||
|
if (image->bootcat->bootimages[idx]->image != NULL) {
|
||||||
ret = iso_msg_submit(image->id, ISO_EL_TORITO_WARN, 0,
|
ret = iso_msg_submit(image->id, ISO_EL_TORITO_WARN, 0,
|
||||||
"More than one image node has been found.");
|
"More than one ISO node has been found for the same boot image.");
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
free(name);
|
free(name);
|
||||||
iso_stream_unref(stream);
|
iso_stream_unref(stream);
|
||||||
@ -2706,7 +2797,7 @@ int image_builder_create_node(IsoNodeBuilder *builder, IsoImage *image,
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* and set the image node */
|
/* and set the image node */
|
||||||
image->bootcat->image->image = file;
|
image->bootcat->bootimages[idx]->image = file;
|
||||||
new->refcount++;
|
new->refcount++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2846,7 +2937,7 @@ int iso_image_builder_new(IsoNodeBuilder *old, IsoNodeBuilder **builder)
|
|||||||
* accessible from the ISO filesystem.
|
* accessible from the ISO filesystem.
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
int create_boot_img_filesrc(IsoImageFilesystem *fs, IsoImage *image,
|
int create_boot_img_filesrc(IsoImageFilesystem *fs, IsoImage *image, int idx,
|
||||||
IsoFileSource **src)
|
IsoFileSource **src)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
@ -2903,8 +2994,7 @@ int create_boot_img_filesrc(IsoImageFilesystem *fs, IsoImage *image,
|
|||||||
ifsdata->parent = NULL;
|
ifsdata->parent = NULL;
|
||||||
ifsdata->info = atts;
|
ifsdata->info = atts;
|
||||||
ifsdata->name = NULL;
|
ifsdata->name = NULL;
|
||||||
|
ifsdata->sections[0].block = fsdata->bootblocks[idx];
|
||||||
ifsdata->sections[0].block = fsdata->imgblock;
|
|
||||||
ifsdata->sections[0].size = BLOCK_SIZE;
|
ifsdata->sections[0].size = BLOCK_SIZE;
|
||||||
ifsdata->nsections = 1;
|
ifsdata->nsections = 1;
|
||||||
|
|
||||||
@ -2921,12 +3011,112 @@ boot_fs_cleanup: ;
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** ??? >>> ts B00428 : should the max size become public ? */
|
||||||
|
#define Libisofs_boot_image_max_sizE (4096*1024)
|
||||||
|
|
||||||
|
/** Guess which of the loaded boot images contain boot information tables.
|
||||||
|
Set boot->seems_boot_info_table accordingly.
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
int iso_image_eval_boot_info_table(IsoImage *image, struct iso_read_opts *opts,
|
||||||
|
IsoDataSource *src, uint32_t iso_image_size, int flag)
|
||||||
|
{
|
||||||
|
int i, ret, section_count, todo, chunk;
|
||||||
|
uint32_t img_lba, img_size, boot_pvd_found, image_pvd, alleged_size;
|
||||||
|
struct iso_file_section *sections = NULL;
|
||||||
|
struct el_torito_boot_image *boot;
|
||||||
|
uint8_t *boot_image_buf = NULL, boot_info_found[16], buf[BLOCK_SIZE];
|
||||||
|
IsoStream *stream = NULL;
|
||||||
|
IsoFile *boot_file;
|
||||||
|
|
||||||
|
if (image->bootcat == NULL)
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
for (i = 0; i < image->bootcat->num_bootimages; i++) {
|
||||||
|
boot = image->bootcat->bootimages[i];
|
||||||
|
boot_file = boot->image;
|
||||||
|
boot->seems_boot_info_table = 0;
|
||||||
|
img_size = iso_file_get_size(boot_file);
|
||||||
|
if (img_size > Libisofs_boot_image_max_sizE || img_size < 64)
|
||||||
|
continue;
|
||||||
|
img_lba = 0;
|
||||||
|
sections = NULL;
|
||||||
|
ret = iso_file_get_old_image_sections(boot_file,
|
||||||
|
§ion_count, §ions, 0);
|
||||||
|
if (ret == 1 && section_count > 0)
|
||||||
|
img_lba = sections[0].block;
|
||||||
|
if (sections != NULL) {
|
||||||
|
free(sections);
|
||||||
|
sections = NULL;
|
||||||
|
}
|
||||||
|
if(img_lba == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
boot_image_buf = calloc(1, img_size);
|
||||||
|
if (boot_image_buf == NULL) {
|
||||||
|
ret = ISO_OUT_OF_MEM;
|
||||||
|
goto ex;
|
||||||
|
}
|
||||||
|
stream = iso_file_get_stream(boot_file);
|
||||||
|
ret = iso_stream_open(stream);
|
||||||
|
if (ret < 0) {
|
||||||
|
stream = NULL;
|
||||||
|
goto ex;
|
||||||
|
}
|
||||||
|
for (todo = img_size; todo > 0; ) {
|
||||||
|
if (todo > BLOCK_SIZE)
|
||||||
|
chunk = BLOCK_SIZE;
|
||||||
|
else
|
||||||
|
chunk = todo;
|
||||||
|
ret = iso_stream_read(stream, boot_image_buf + (img_size - todo),
|
||||||
|
chunk);
|
||||||
|
if (ret != chunk) {
|
||||||
|
ret = (ret < 0) ? ret : ISO_FILE_READ_ERROR;
|
||||||
|
goto ex;
|
||||||
|
}
|
||||||
|
todo -= chunk;
|
||||||
|
}
|
||||||
|
iso_stream_close(stream);
|
||||||
|
stream = NULL;
|
||||||
|
|
||||||
|
memcpy(boot_info_found, boot_image_buf + 8, 16);
|
||||||
|
boot_pvd_found = iso_read_lsb(boot_info_found, 4);
|
||||||
|
image_pvd = (uint32_t) (opts->block + 16);
|
||||||
|
|
||||||
|
/* Accomodate to eventually relocated superblock */
|
||||||
|
if (image_pvd != boot_pvd_found &&
|
||||||
|
image_pvd == 16 && boot_pvd_found < iso_image_size) {
|
||||||
|
/* Check whether there is a PVD at boot_pvd_found
|
||||||
|
and whether it bears the same image size
|
||||||
|
*/
|
||||||
|
ret = read_pvd_block(src, boot_pvd_found, buf, &alleged_size);
|
||||||
|
if (ret == 1 &&
|
||||||
|
alleged_size + boot_pvd_found == iso_image_size + image_pvd)
|
||||||
|
image_pvd = boot_pvd_found;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = make_boot_info_table(boot_image_buf, image_pvd,
|
||||||
|
img_lba, img_size);
|
||||||
|
if (ret < 0)
|
||||||
|
goto ex;
|
||||||
|
if (memcmp(boot_image_buf + 8, boot_info_found, 16) == 0)
|
||||||
|
boot->seems_boot_info_table = 1;
|
||||||
|
free(boot_image_buf);
|
||||||
|
boot_image_buf = NULL;
|
||||||
|
}
|
||||||
|
ret = 1;
|
||||||
|
ex:;
|
||||||
|
if (boot_image_buf != NULL)
|
||||||
|
free(boot_image_buf);
|
||||||
|
if (stream != NULL)
|
||||||
|
iso_stream_close(stream);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
int iso_image_import(IsoImage *image, IsoDataSource *src,
|
int iso_image_import(IsoImage *image, IsoDataSource *src,
|
||||||
struct iso_read_opts *opts,
|
struct iso_read_opts *opts,
|
||||||
IsoReadImageFeatures **features)
|
IsoReadImageFeatures **features)
|
||||||
{
|
{
|
||||||
int ret, hflag;
|
int ret, hflag, i, idx;
|
||||||
IsoImageFilesystem *fs;
|
IsoImageFilesystem *fs;
|
||||||
IsoFilesystem *fsback;
|
IsoFilesystem *fsback;
|
||||||
IsoNodeBuilder *blback;
|
IsoNodeBuilder *blback;
|
||||||
@ -2934,9 +3124,9 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
IsoFileSource *newroot;
|
IsoFileSource *newroot;
|
||||||
_ImageFsData *data;
|
_ImageFsData *data;
|
||||||
struct el_torito_boot_catalog *oldbootcat;
|
struct el_torito_boot_catalog *oldbootcat;
|
||||||
|
uint8_t *rpt;
|
||||||
#ifdef Libisofs_with_checksumS
|
IsoFileSource *boot_src;
|
||||||
int i;
|
IsoNode *node;
|
||||||
uint32_t old_checksum_start_lba;
|
uint32_t old_checksum_start_lba;
|
||||||
uint32_t old_checksum_end_lba;
|
uint32_t old_checksum_end_lba;
|
||||||
uint32_t old_checksum_idx_count;
|
uint32_t old_checksum_idx_count;
|
||||||
@ -2944,21 +3134,37 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
char checksum_type[81];
|
char checksum_type[81];
|
||||||
uint32_t checksum_size;
|
uint32_t checksum_size;
|
||||||
size_t size;
|
size_t size;
|
||||||
uint8_t *rpt;
|
|
||||||
void *ctx = NULL;
|
void *ctx = NULL;
|
||||||
char md5[16];
|
char md5[16];
|
||||||
#endif
|
|
||||||
|
|
||||||
if (image == NULL || src == NULL || opts == NULL) {
|
if (image == NULL || src == NULL || opts == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ret = iso_image_filesystem_new(src, opts, image->id, &fs);
|
ret = iso_image_filesystem_new(src, opts, image->id, &fs);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
data = fs->data;
|
data = fs->data;
|
||||||
|
|
||||||
|
|
||||||
|
if (opts->load_system_area) {
|
||||||
|
if (image->system_area_data != NULL)
|
||||||
|
free(image->system_area_data);
|
||||||
|
image->system_area_data = calloc(32768, 1);
|
||||||
|
if (image->system_area_data == NULL)
|
||||||
|
return ISO_OUT_OF_MEM;
|
||||||
|
image->system_area_options = 0;
|
||||||
|
/* Read 32768 bytes */
|
||||||
|
for (i = 0; i < 16; i++) {
|
||||||
|
rpt = (uint8_t *) (image->system_area_data + i * 2048);
|
||||||
|
ret = src->read_block(src, opts->block + i, rpt);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* get root from filesystem */
|
/* get root from filesystem */
|
||||||
ret = fs->get_root(fs, &newroot);
|
ret = fs->get_root(fs, &newroot);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
@ -2971,14 +3177,11 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
oldroot = image->root;
|
oldroot = image->root;
|
||||||
oldbootcat = image->bootcat; /* could be NULL */
|
oldbootcat = image->bootcat; /* could be NULL */
|
||||||
image->bootcat = NULL;
|
image->bootcat = NULL;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
old_checksum_start_lba = image->checksum_start_lba;
|
old_checksum_start_lba = image->checksum_start_lba;
|
||||||
old_checksum_end_lba = image->checksum_end_lba;
|
old_checksum_end_lba = image->checksum_end_lba;
|
||||||
old_checksum_idx_count = image->checksum_idx_count;
|
old_checksum_idx_count = image->checksum_idx_count;
|
||||||
old_checksum_array = image->checksum_array;
|
old_checksum_array = image->checksum_array;
|
||||||
image->checksum_array = NULL;
|
image->checksum_array = NULL;
|
||||||
#endif
|
|
||||||
|
|
||||||
/* create new builder */
|
/* create new builder */
|
||||||
ret = iso_image_builder_new(blback, &image->builder);
|
ret = iso_image_builder_new(blback, &image->builder);
|
||||||
@ -3023,23 +3226,34 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
struct el_torito_boot_catalog *catalog;
|
struct el_torito_boot_catalog *catalog;
|
||||||
ElToritoBootImage *boot_image= NULL;
|
ElToritoBootImage *boot_image= NULL;
|
||||||
|
|
||||||
boot_image = calloc(1, sizeof(ElToritoBootImage));
|
|
||||||
if (boot_image == NULL) {
|
|
||||||
ret = ISO_OUT_OF_MEM;
|
|
||||||
goto import_revert;
|
|
||||||
}
|
|
||||||
boot_image->bootable = data->bootable;
|
|
||||||
boot_image->type = data->type;
|
|
||||||
boot_image->partition_type = data->partition_type;
|
|
||||||
boot_image->load_seg = data->load_seg;
|
|
||||||
boot_image->load_size = data->load_size;
|
|
||||||
|
|
||||||
catalog = calloc(1, sizeof(struct el_torito_boot_catalog));
|
catalog = calloc(1, sizeof(struct el_torito_boot_catalog));
|
||||||
if (catalog == NULL) {
|
if (catalog == NULL) {
|
||||||
ret = ISO_OUT_OF_MEM;
|
ret = ISO_OUT_OF_MEM;
|
||||||
goto import_revert;
|
goto import_revert;
|
||||||
}
|
}
|
||||||
catalog->image = boot_image;
|
|
||||||
|
catalog->num_bootimages = 0;
|
||||||
|
for (idx = 0; idx < data->num_bootimgs; idx++) {
|
||||||
|
boot_image = calloc(1, sizeof(ElToritoBootImage));
|
||||||
|
if (boot_image == NULL) {
|
||||||
|
ret = ISO_OUT_OF_MEM;
|
||||||
|
goto import_revert;
|
||||||
|
}
|
||||||
|
boot_image->image = NULL;
|
||||||
|
boot_image->bootable = data->boot_flags[idx] & 1;
|
||||||
|
boot_image->type = data->media_types[idx];
|
||||||
|
boot_image->partition_type = data->partition_types[idx];
|
||||||
|
boot_image->load_seg = data->load_segs[idx];
|
||||||
|
boot_image->load_size = data->load_sizes[idx];
|
||||||
|
boot_image->platform_id = data->platform_ids[idx];
|
||||||
|
memcpy(boot_image->id_string, data->id_strings[idx], 28);
|
||||||
|
memcpy(boot_image->selection_crit, data->selection_crits, 20);
|
||||||
|
|
||||||
|
catalog->bootimages[catalog->num_bootimages] = boot_image;
|
||||||
|
catalog->num_bootimages++;
|
||||||
|
}
|
||||||
|
for ( ; idx < Libisofs_max_boot_imageS; idx++)
|
||||||
|
catalog->bootimages[idx] = NULL;
|
||||||
image->bootcat = catalog;
|
image->bootcat = catalog;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3073,21 +3287,23 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (data->eltorito) {
|
if (data->eltorito) {
|
||||||
/* if catalog and image nodes were not filled, we create them here */
|
/* if catalog and boot image nodes were not filled,
|
||||||
if (image->bootcat->image->image == NULL) {
|
we create them here */
|
||||||
IsoFileSource *src;
|
for (idx = 0; idx < image->bootcat->num_bootimages; idx++) {
|
||||||
IsoNode *node;
|
if (image->bootcat->bootimages[idx]->image != NULL)
|
||||||
ret = create_boot_img_filesrc(fs, image, &src);
|
continue;
|
||||||
|
ret = create_boot_img_filesrc(fs, image, idx, &boot_src);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
iso_node_builder_unref(image->builder);
|
iso_node_builder_unref(image->builder);
|
||||||
goto import_revert;
|
goto import_revert;
|
||||||
}
|
}
|
||||||
ret = image_builder_create_node(image->builder, image, src, &node);
|
ret = image_builder_create_node(image->builder, image, boot_src,
|
||||||
|
&node);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
iso_node_builder_unref(image->builder);
|
iso_node_builder_unref(image->builder);
|
||||||
goto import_revert;
|
goto import_revert;
|
||||||
}
|
}
|
||||||
image->bootcat->image->image = (IsoFile*)node;
|
image->bootcat->bootimages[idx]->image = (IsoFile*)node;
|
||||||
|
|
||||||
/* warn about hidden images */
|
/* warn about hidden images */
|
||||||
iso_msg_submit(image->id, ISO_EL_TORITO_HIDDEN, 0,
|
iso_msg_submit(image->id, ISO_EL_TORITO_HIDDEN, 0,
|
||||||
@ -3140,8 +3356,6 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
(*features)->size = data->nblocks;
|
(*features)->size = data->nblocks;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (data->md5_load) {
|
if (data->md5_load) {
|
||||||
/* Read checksum array */
|
/* Read checksum array */
|
||||||
ret = iso_root_get_isofsca((IsoNode *) image->root,
|
ret = iso_root_get_isofsca((IsoNode *) image->root,
|
||||||
@ -3194,7 +3408,9 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
ret = iso_image_eval_boot_info_table(image, opts, src, data->nblocks, 0);
|
||||||
|
if (ret < 0)
|
||||||
|
goto import_revert;
|
||||||
|
|
||||||
ret = ISO_SUCCESS;
|
ret = ISO_SUCCESS;
|
||||||
goto import_cleanup;
|
goto import_cleanup;
|
||||||
@ -3205,14 +3421,11 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
el_torito_boot_catalog_free(image->bootcat);
|
el_torito_boot_catalog_free(image->bootcat);
|
||||||
image->root = oldroot;
|
image->root = oldroot;
|
||||||
image->bootcat = oldbootcat;
|
image->bootcat = oldbootcat;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
old_checksum_start_lba = image->checksum_start_lba;
|
old_checksum_start_lba = image->checksum_start_lba;
|
||||||
old_checksum_end_lba = image->checksum_end_lba;
|
old_checksum_end_lba = image->checksum_end_lba;
|
||||||
old_checksum_idx_count = image->checksum_idx_count;
|
old_checksum_idx_count = image->checksum_idx_count;
|
||||||
image->checksum_array = old_checksum_array;
|
image->checksum_array = old_checksum_array;
|
||||||
old_checksum_array = NULL;
|
old_checksum_array = NULL;
|
||||||
#endif
|
|
||||||
|
|
||||||
import_cleanup:;
|
import_cleanup:;
|
||||||
|
|
||||||
@ -3223,14 +3436,10 @@ int iso_image_import(IsoImage *image, IsoDataSource *src,
|
|||||||
iso_file_source_unref(newroot);
|
iso_file_source_unref(newroot);
|
||||||
fs->close(fs);
|
fs->close(fs);
|
||||||
iso_filesystem_unref(fs);
|
iso_filesystem_unref(fs);
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
if (old_checksum_array != NULL)
|
if (old_checksum_array != NULL)
|
||||||
free(old_checksum_array);
|
free(old_checksum_array);
|
||||||
if (ctx != NULL)
|
if (ctx != NULL)
|
||||||
iso_md5_end(&ctx, md5);
|
iso_md5_end(&ctx, md5);
|
||||||
#endif
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3307,8 +3516,9 @@ int iso_read_opts_new(IsoReadOpts **opts, int profile)
|
|||||||
|
|
||||||
ropts->file_mode = 0444;
|
ropts->file_mode = 0444;
|
||||||
ropts->dir_mode = 0555;
|
ropts->dir_mode = 0555;
|
||||||
ropts->noaaip= 1;
|
ropts->noaaip = 1;
|
||||||
ropts->nomd5= 1;
|
ropts->nomd5 = 1;
|
||||||
|
ropts->load_system_area = 0;
|
||||||
|
|
||||||
*opts = ropts;
|
*opts = ropts;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
@ -3444,6 +3654,15 @@ int iso_read_opts_auto_input_charset(IsoReadOpts *opts, int mode)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int iso_read_opts_load_system_area(IsoReadOpts *opts, int mode)
|
||||||
|
{
|
||||||
|
if (opts == NULL) {
|
||||||
|
return ISO_NULL_POINTER;
|
||||||
|
}
|
||||||
|
opts->load_system_area = mode & 1;
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Destroy an IsoReadImageFeatures object obtained with iso_image_import.
|
* Destroy an IsoReadImageFeatures object obtained with iso_image_import.
|
||||||
*/
|
*/
|
||||||
|
@ -3,14 +3,19 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Filesystem/FileSource implementation to access the local filesystem.
|
* Filesystem/FileSource implementation to access the local filesystem.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "fsource.h"
|
#include "fsource.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "aaip_0_2.h"
|
#include "aaip_0_2.h"
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "fsource.h"
|
#include "fsource.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_FSOURCE_H_
|
#ifndef LIBISO_FSOURCE_H_
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "image.h"
|
#include "image.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
@ -73,19 +78,17 @@ int iso_image_new(const char *name, IsoImage **image)
|
|||||||
img->volset_id = strdup(name);
|
img->volset_id = strdup(name);
|
||||||
img->volume_id = strdup(name);
|
img->volume_id = strdup(name);
|
||||||
}
|
}
|
||||||
|
img->system_area_data = NULL;
|
||||||
|
img->system_area_options = 0;
|
||||||
img->builder_ignore_acl = 1;
|
img->builder_ignore_acl = 1;
|
||||||
img->builder_ignore_ea = 1;
|
img->builder_ignore_ea = 1;
|
||||||
img->inode_counter = 0;
|
img->inode_counter = 0;
|
||||||
img->used_inodes = NULL;
|
img->used_inodes = NULL;
|
||||||
img->used_inodes_start = 0;
|
img->used_inodes_start = 0;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
img->checksum_start_lba = 0;
|
img->checksum_start_lba = 0;
|
||||||
img->checksum_end_lba = 0;
|
img->checksum_end_lba = 0;
|
||||||
img->checksum_idx_count = 0;
|
img->checksum_idx_count = 0;
|
||||||
img->checksum_array = NULL;
|
img->checksum_array = NULL;
|
||||||
#endif
|
|
||||||
|
|
||||||
*image = img;
|
*image = img;
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -142,17 +145,12 @@ void iso_image_unref(IsoImage *image)
|
|||||||
|
|
||||||
int iso_image_free_checksums(IsoImage *image, int flag)
|
int iso_image_free_checksums(IsoImage *image, int flag)
|
||||||
{
|
{
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
image->checksum_start_lba = 0;
|
image->checksum_start_lba = 0;
|
||||||
image->checksum_end_lba = 0;
|
image->checksum_end_lba = 0;
|
||||||
image->checksum_idx_count = 0;
|
image->checksum_idx_count = 0;
|
||||||
if (image->checksum_array != NULL)
|
if (image->checksum_array != NULL)
|
||||||
free(image->checksum_array);
|
free(image->checksum_array);
|
||||||
image->checksum_array = NULL;
|
image->checksum_array = NULL;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,13 +170,13 @@ int iso_image_free_checksums(IsoImage *image, int flag)
|
|||||||
*/
|
*/
|
||||||
int iso_image_attach_data(IsoImage *image, void *data, void (*give_up)(void*))
|
int iso_image_attach_data(IsoImage *image, void *data, void (*give_up)(void*))
|
||||||
{
|
{
|
||||||
if (image == NULL || (data != NULL && free == NULL)) {
|
if (image == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (image->user_data != NULL) {
|
if (image->user_data != NULL) {
|
||||||
/* free previously attached data */
|
/* free previously attached data */
|
||||||
if (image->user_data_free) {
|
if (image->user_data_free != NULL) {
|
||||||
image->user_data_free(image->user_data);
|
image->user_data_free(image->user_data);
|
||||||
}
|
}
|
||||||
image->user_data = NULL;
|
image->user_data = NULL;
|
||||||
@ -213,6 +211,8 @@ void iso_image_set_volset_id(IsoImage *image, const char *volset_id)
|
|||||||
|
|
||||||
const char *iso_image_get_volset_id(const IsoImage *image)
|
const char *iso_image_get_volset_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->volset_id == NULL)
|
||||||
|
return "";
|
||||||
return image->volset_id;
|
return image->volset_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,6 +224,8 @@ void iso_image_set_volume_id(IsoImage *image, const char *volume_id)
|
|||||||
|
|
||||||
const char *iso_image_get_volume_id(const IsoImage *image)
|
const char *iso_image_get_volume_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->volume_id == NULL)
|
||||||
|
return "";
|
||||||
return image->volume_id;
|
return image->volume_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -235,6 +237,8 @@ void iso_image_set_publisher_id(IsoImage *image, const char *publisher_id)
|
|||||||
|
|
||||||
const char *iso_image_get_publisher_id(const IsoImage *image)
|
const char *iso_image_get_publisher_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->publisher_id == NULL)
|
||||||
|
return "";
|
||||||
return image->publisher_id;
|
return image->publisher_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,6 +251,8 @@ void iso_image_set_data_preparer_id(IsoImage *image,
|
|||||||
|
|
||||||
const char *iso_image_get_data_preparer_id(const IsoImage *image)
|
const char *iso_image_get_data_preparer_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->data_preparer_id == NULL)
|
||||||
|
return "";
|
||||||
return image->data_preparer_id;
|
return image->data_preparer_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,6 +264,8 @@ void iso_image_set_system_id(IsoImage *image, const char *system_id)
|
|||||||
|
|
||||||
const char *iso_image_get_system_id(const IsoImage *image)
|
const char *iso_image_get_system_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->system_id == NULL)
|
||||||
|
return "";
|
||||||
return image->system_id;
|
return image->system_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -269,6 +277,8 @@ void iso_image_set_application_id(IsoImage *image, const char *application_id)
|
|||||||
|
|
||||||
const char *iso_image_get_application_id(const IsoImage *image)
|
const char *iso_image_get_application_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->application_id == NULL)
|
||||||
|
return "";
|
||||||
return image->application_id;
|
return image->application_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -281,6 +291,8 @@ void iso_image_set_copyright_file_id(IsoImage *image,
|
|||||||
|
|
||||||
const char *iso_image_get_copyright_file_id(const IsoImage *image)
|
const char *iso_image_get_copyright_file_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->copyright_file_id == NULL)
|
||||||
|
return "";
|
||||||
return image->copyright_file_id;
|
return image->copyright_file_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -293,6 +305,8 @@ void iso_image_set_abstract_file_id(IsoImage *image,
|
|||||||
|
|
||||||
const char *iso_image_get_abstract_file_id(const IsoImage *image)
|
const char *iso_image_get_abstract_file_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->abstract_file_id == NULL)
|
||||||
|
return "";
|
||||||
return image->abstract_file_id;
|
return image->abstract_file_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,6 +318,8 @@ void iso_image_set_biblio_file_id(IsoImage *image, const char *biblio_file_id)
|
|||||||
|
|
||||||
const char *iso_image_get_biblio_file_id(const IsoImage *image)
|
const char *iso_image_get_biblio_file_id(const IsoImage *image)
|
||||||
{
|
{
|
||||||
|
if (image->biblio_file_id == NULL)
|
||||||
|
return "";
|
||||||
return image->biblio_file_id;
|
return image->biblio_file_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -312,6 +328,16 @@ int iso_image_get_msg_id(IsoImage *image)
|
|||||||
return image->id;
|
return image->id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int iso_image_get_system_area(IsoImage *img, char system_area_data[32768],
|
||||||
|
int *options, int flag)
|
||||||
|
{
|
||||||
|
*options = img->system_area_options;
|
||||||
|
if (img->system_area_data == NULL)
|
||||||
|
return 0;
|
||||||
|
memcpy(system_area_data, img->system_area_data, 32768);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
int dir_update_size(IsoImage *image, IsoDir *dir)
|
int dir_update_size(IsoImage *image, IsoDir *dir)
|
||||||
{
|
{
|
||||||
@ -561,39 +587,23 @@ ex:;
|
|||||||
int iso_image_get_session_md5(IsoImage *image, uint32_t *start_lba,
|
int iso_image_get_session_md5(IsoImage *image, uint32_t *start_lba,
|
||||||
uint32_t *end_lba, char md5[16], int flag)
|
uint32_t *end_lba, char md5[16], int flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
if (image->checksum_array == NULL || image->checksum_idx_count < 1)
|
if (image->checksum_array == NULL || image->checksum_idx_count < 1)
|
||||||
return 0;
|
return 0;
|
||||||
*start_lba = image->checksum_start_lba;
|
*start_lba = image->checksum_start_lba;
|
||||||
*end_lba = image->checksum_end_lba;
|
*end_lba = image->checksum_end_lba;
|
||||||
memcpy(md5, image->checksum_array, 16);
|
memcpy(md5, image->checksum_array, 16);
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
#endif /* ! Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int iso_image_set_checksums(IsoImage *image, char *checksum_array,
|
int iso_image_set_checksums(IsoImage *image, char *checksum_array,
|
||||||
uint32_t start_lba, uint32_t end_lba,
|
uint32_t start_lba, uint32_t end_lba,
|
||||||
uint32_t idx_count, int flag)
|
uint32_t idx_count, int flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
iso_image_free_checksums(image, 0);
|
iso_image_free_checksums(image, 0);
|
||||||
image->checksum_array = checksum_array;
|
image->checksum_array = checksum_array;
|
||||||
image->checksum_start_lba = start_lba;
|
image->checksum_start_lba = start_lba;
|
||||||
image->checksum_end_lba = end_lba;
|
image->checksum_end_lba = end_lba;
|
||||||
image->checksum_idx_count = idx_count;
|
image->checksum_idx_count = idx_count;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_IMAGE_H_
|
#ifndef LIBISO_IMAGE_H_
|
||||||
#define LIBISO_IMAGE_H_
|
#define LIBISO_IMAGE_H_
|
||||||
@ -52,6 +53,11 @@ struct Iso_Image
|
|||||||
/* el-torito boot catalog */
|
/* el-torito boot catalog */
|
||||||
struct el_torito_boot_catalog *bootcat;
|
struct el_torito_boot_catalog *bootcat;
|
||||||
|
|
||||||
|
/* Eventually loaded system area data, or NULL */
|
||||||
|
char *system_area_data;
|
||||||
|
/* Prescribed/detected options, see iso_write_opts_set_system_area() */
|
||||||
|
int system_area_options;
|
||||||
|
|
||||||
/* image identifier, for message origin identifier */
|
/* image identifier, for message origin identifier */
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
@ -148,8 +154,6 @@ struct Iso_Image
|
|||||||
uint8_t *used_inodes;
|
uint8_t *used_inodes;
|
||||||
ino_t used_inodes_start;
|
ino_t used_inodes_start;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Array of MD5 checksums as announced by xattr "isofs.ca" of the
|
* Array of MD5 checksums as announced by xattr "isofs.ca" of the
|
||||||
* root node. Array element 0 contains an overall image checksum for the
|
* root node. Array element 0 contains an overall image checksum for the
|
||||||
@ -162,8 +166,6 @@ struct Iso_Image
|
|||||||
uint32_t checksum_idx_count;
|
uint32_t checksum_idx_count;
|
||||||
char *checksum_array;
|
char *checksum_array;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "iso1999.h"
|
#include "iso1999.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
#include "writer.h"
|
#include "writer.h"
|
||||||
@ -711,7 +716,7 @@ void write_one_dir_record(Ecma119Image *t, Iso1999Node *node, int file_id,
|
|||||||
iso_bb(rec->length, len, 4);
|
iso_bb(rec->length, len, 4);
|
||||||
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
||||||
rec->flags[0] = ((node->type == ISO1999_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
rec->flags[0] = ((node->type == ISO1999_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
||||||
iso_bb(rec->vol_seq_number, 1, 2);
|
iso_bb(rec->vol_seq_number, (uint32_t) 1, 2);
|
||||||
rec->len_fi[0] = len_fi;
|
rec->len_fi[0] = len_fi;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -762,9 +767,9 @@ int iso1999_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
strncpy_pad((char*)vol.volume_id, vol_id, 32);
|
strncpy_pad((char*)vol.volume_id, vol_id, 32);
|
||||||
|
|
||||||
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
||||||
iso_bb(vol.vol_set_size, 1, 2);
|
iso_bb(vol.vol_set_size, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.vol_seq_number, 1, 2);
|
iso_bb(vol.vol_seq_number, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.block_size, BLOCK_SIZE, 2);
|
iso_bb(vol.block_size, (uint32_t) BLOCK_SIZE, 2);
|
||||||
iso_bb(vol.path_table_size, t->iso1999_path_table_size, 4);
|
iso_bb(vol.path_table_size, t->iso1999_path_table_size, 4);
|
||||||
iso_lsb(vol.l_path_table_pos, t->iso1999_l_path_table_pos, 4);
|
iso_lsb(vol.l_path_table_pos, t->iso1999_l_path_table_pos, 4);
|
||||||
iso_msb(vol.m_path_table_pos, t->iso1999_m_path_table_pos, 4);
|
iso_msb(vol.m_path_table_pos, t->iso1999_m_path_table_pos, 4);
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2007 Mario Danic
|
* Copyright (c) 2007 Mario Danic
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "joliet.h"
|
#include "joliet.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
#include "writer.h"
|
#include "writer.h"
|
||||||
@ -42,7 +47,7 @@ int get_joliet_name(Ecma119Image *t, IsoNode *iso, uint16_t **name)
|
|||||||
if (iso->type == LIBISO_DIR) {
|
if (iso->type == LIBISO_DIR) {
|
||||||
jname = iso_j_dir_id(ucs_name);
|
jname = iso_j_dir_id(ucs_name);
|
||||||
} else {
|
} else {
|
||||||
jname = iso_j_file_id(ucs_name);
|
jname = iso_j_file_id(ucs_name, !!(t->no_force_dots & 2));
|
||||||
}
|
}
|
||||||
free(ucs_name);
|
free(ucs_name);
|
||||||
if (jname != NULL) {
|
if (jname != NULL) {
|
||||||
@ -573,7 +578,7 @@ size_t calc_dirent_len(Ecma119Image *t, JolietNode *n)
|
|||||||
{
|
{
|
||||||
/* note than name len is always even, so we always need the pad byte */
|
/* note than name len is always even, so we always need the pad byte */
|
||||||
int ret = n->name ? ucslen(n->name) * 2 + 34 : 34;
|
int ret = n->name ? ucslen(n->name) * 2 + 34 : 34;
|
||||||
if (n->type == JOLIET_FILE && !t->omit_version_numbers) {
|
if (n->type == JOLIET_FILE && !(t->omit_version_numbers & 3)) {
|
||||||
/* take into account version numbers */
|
/* take into account version numbers */
|
||||||
ret += 4;
|
ret += 4;
|
||||||
}
|
}
|
||||||
@ -721,7 +726,7 @@ void write_one_dir_record(Ecma119Image *t, JolietNode *node, int file_id,
|
|||||||
|
|
||||||
memcpy(rec->file_id, name, len_fi);
|
memcpy(rec->file_id, name, len_fi);
|
||||||
|
|
||||||
if (node->type == JOLIET_FILE && !t->omit_version_numbers) {
|
if (node->type == JOLIET_FILE && !(t->omit_version_numbers & 3)) {
|
||||||
len_dr += 4;
|
len_dr += 4;
|
||||||
rec->file_id[len_fi++] = 0;
|
rec->file_id[len_fi++] = 0;
|
||||||
rec->file_id[len_fi++] = ';';
|
rec->file_id[len_fi++] = ';';
|
||||||
@ -757,7 +762,7 @@ void write_one_dir_record(Ecma119Image *t, JolietNode *node, int file_id,
|
|||||||
iso_bb(rec->length, len, 4);
|
iso_bb(rec->length, len, 4);
|
||||||
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
iso_datetime_7(rec->recording_time, t->now, t->always_gmt);
|
||||||
rec->flags[0] = ((node->type == JOLIET_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
rec->flags[0] = ((node->type == JOLIET_DIR) ? 2 : 0) | (multi_extend ? 0x80 : 0);
|
||||||
iso_bb(rec->vol_seq_number, 1, 2);
|
iso_bb(rec->vol_seq_number, (uint32_t) 1, 2);
|
||||||
rec->len_fi[0] = len_fi;
|
rec->len_fi[0] = len_fi;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -832,9 +837,9 @@ int joliet_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
memcpy(vol.esc_sequences, "%/E", 3);
|
memcpy(vol.esc_sequences, "%/E", 3);
|
||||||
|
|
||||||
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
iso_bb(vol.vol_space_size, t->vol_space_size, 4);
|
||||||
iso_bb(vol.vol_set_size, 1, 2);
|
iso_bb(vol.vol_set_size, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.vol_seq_number, 1, 2);
|
iso_bb(vol.vol_seq_number, (uint32_t) 1, 2);
|
||||||
iso_bb(vol.block_size, BLOCK_SIZE, 2);
|
iso_bb(vol.block_size, (uint32_t) BLOCK_SIZE, 2);
|
||||||
iso_bb(vol.path_table_size, t->joliet_path_table_size, 4);
|
iso_bb(vol.path_table_size, t->joliet_path_table_size, 4);
|
||||||
iso_lsb(vol.l_path_table_pos, t->joliet_l_path_table_pos, 4);
|
iso_lsb(vol.l_path_table_pos, t->joliet_l_path_table_pos, 4);
|
||||||
iso_msb(vol.m_path_table_pos, t->joliet_m_path_table_pos, 4);
|
iso_msb(vol.m_path_table_pos, t->joliet_m_path_table_pos, 4);
|
||||||
@ -898,7 +903,7 @@ int write_one_dir(Ecma119Image *t, JolietNode *dir)
|
|||||||
/* compute len of directory entry */
|
/* compute len of directory entry */
|
||||||
fi_len = ucslen(child->name) * 2;
|
fi_len = ucslen(child->name) * 2;
|
||||||
len = fi_len + 34;
|
len = fi_len + 34;
|
||||||
if (child->type == JOLIET_FILE && !t->omit_version_numbers) {
|
if (child->type == JOLIET_FILE && !(t->omit_version_numbers & 3)) {
|
||||||
len += 4;
|
len += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2007 Mario Danic
|
* Copyright (c) 2007 Mario Danic
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2,9 +2,13 @@
|
|||||||
/* libiso_msgs (generated from libdax_msgs : Fri Feb 22 19:42:52 CET 2008)
|
/* libiso_msgs (generated from libdax_msgs : Fri Feb 22 19:42:52 CET 2008)
|
||||||
Message handling facility of libisofs.
|
Message handling facility of libisofs.
|
||||||
Copyright (C) 2006 - 2008 Thomas Schmitt <scdbackup@gmx.net>,
|
Copyright (C) 2006 - 2008 Thomas Schmitt <scdbackup@gmx.net>,
|
||||||
provided under GPL version 2
|
provided under GPL version 2 or later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/* libiso_msgs (generated from libdax_msgs : Fri Feb 22 19:42:52 CET 2008)
|
/* libiso_msgs (generated from libdax_msgs : Fri Feb 22 19:42:52 CET 2008)
|
||||||
Message handling facility of libisofs.
|
Message handling facility of libisofs.
|
||||||
Copyright (C) 2006-2008 Thomas Schmitt <scdbackup@gmx.net>,
|
Copyright (C) 2006-2008 Thomas Schmitt <scdbackup@gmx.net>,
|
||||||
provided under GPL version 2
|
provided under GPL version 2 or later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,15 +1,16 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007-2008 Vreixo Formoso, Mario Danic
|
* Copyright (c) 2007-2008 Vreixo Formoso, Mario Danic
|
||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009-2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Applications must use 64 bit off_t, e.g. on 32-bit Linux by defining
|
* Applications must use 64 bit off_t, e.g. on 32-bit GNU/Linux by defining
|
||||||
* #define _LARGEFILE_SOURCE
|
* #define _LARGEFILE_SOURCE
|
||||||
* #define _FILE_OFFSET_BITS 64
|
* #define _FILE_OFFSET_BITS 64
|
||||||
* or take special precautions to interface with the library by 64 bit integers
|
* or take special precautions to interface with the library by 64 bit integers
|
||||||
@ -167,7 +168,17 @@ enum IsoHideNodeFlag {
|
|||||||
/** Hide the node in the Joliet tree, if Joliet extension are enabled */
|
/** Hide the node in the Joliet tree, if Joliet extension are enabled */
|
||||||
LIBISO_HIDE_ON_JOLIET = 1 << 1,
|
LIBISO_HIDE_ON_JOLIET = 1 << 1,
|
||||||
/** Hide the node in the ISO-9660:1999 tree, if that format is enabled */
|
/** Hide the node in the ISO-9660:1999 tree, if that format is enabled */
|
||||||
LIBISO_HIDE_ON_1999 = 1 << 2
|
LIBISO_HIDE_ON_1999 = 1 << 2,
|
||||||
|
|
||||||
|
/** With IsoNode and IsoBoot: Write data content even if the node is
|
||||||
|
* not visible in any tree.
|
||||||
|
* With directory nodes : Write data content of IsoNode and IsoBoot
|
||||||
|
* in the directory's tree unless they are
|
||||||
|
* explicitely marked LIBISO_HIDE_ON_RR
|
||||||
|
* without LIBISO_HIDE_BUT_WRITE.
|
||||||
|
* @since 0.6.34
|
||||||
|
*/
|
||||||
|
LIBISO_HIDE_BUT_WRITE = 1 << 3
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -373,7 +384,7 @@ extern unsigned int iso_fs_global_id;
|
|||||||
* access and read file contents. Note that this doesn't need to be tied
|
* access and read file contents. Note that this doesn't need to be tied
|
||||||
* to the disc filesystem used in the partition being accessed. For example,
|
* to the disc filesystem used in the partition being accessed. For example,
|
||||||
* we have an IsoFilesystem implementation to access any mounted filesystem,
|
* we have an IsoFilesystem implementation to access any mounted filesystem,
|
||||||
* using standard Linux functions. It is also legal, of course, to implement
|
* using standard POSIX functions. It is also legal, of course, to implement
|
||||||
* an IsoFilesystem to deal with a specific filesystem over raw partitions.
|
* an IsoFilesystem to deal with a specific filesystem over raw partitions.
|
||||||
* That is what we do, for example, to access an ISO Image.
|
* That is what we do, for example, to access an ISO Image.
|
||||||
*
|
*
|
||||||
@ -483,7 +494,7 @@ struct IsoFileSource_Iface
|
|||||||
int version;
|
int version;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the path, relative to the filesystem this file source belongs to.
|
* Get the absolute path in the filesystem this file source belongs to.
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* the path of the FileSource inside the filesystem, it should be
|
* the path of the FileSource inside the filesystem, it should be
|
||||||
@ -784,6 +795,7 @@ struct IsoStream_Iface
|
|||||||
/**
|
/**
|
||||||
* Type of Stream.
|
* Type of Stream.
|
||||||
* "fsrc" -> Read from file source
|
* "fsrc" -> Read from file source
|
||||||
|
* "cout" -> Cut out interval from disk file
|
||||||
* "mem " -> Read from memory
|
* "mem " -> Read from memory
|
||||||
* "boot" -> Boot catalog
|
* "boot" -> Boot catalog
|
||||||
* "extf" -> External filter program
|
* "extf" -> External filter program
|
||||||
@ -1090,7 +1102,7 @@ int iso_lib_is_compatible(int major, int minor, int micro);
|
|||||||
*/
|
*/
|
||||||
#define iso_lib_header_version_major 0
|
#define iso_lib_header_version_major 0
|
||||||
#define iso_lib_header_version_minor 6
|
#define iso_lib_header_version_minor 6
|
||||||
#define iso_lib_header_version_micro 22
|
#define iso_lib_header_version_micro 34
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Usage discussion:
|
* Usage discussion:
|
||||||
@ -1285,7 +1297,9 @@ int iso_write_opts_set_aaip(IsoWriteOpts *opts, int enable);
|
|||||||
* Omit the version number (";1") at the end of the ISO-9660 identifiers.
|
* Omit the version number (";1") at the end of the ISO-9660 identifiers.
|
||||||
* This breaks ECMA-119 specification, but version numbers are usually not
|
* This breaks ECMA-119 specification, but version numbers are usually not
|
||||||
* used, so it should work on most systems. Use with caution.
|
* used, so it should work on most systems. Use with caution.
|
||||||
*
|
* @param omit
|
||||||
|
* bit0= omit version number with ECMA-119 and Joliet
|
||||||
|
* bit1= omit version number with Joliet alone (@since 0.6.30)
|
||||||
* @since 0.6.2
|
* @since 0.6.2
|
||||||
*/
|
*/
|
||||||
int iso_write_opts_set_omit_version_numbers(IsoWriteOpts *opts, int omit);
|
int iso_write_opts_set_omit_version_numbers(IsoWriteOpts *opts, int omit);
|
||||||
@ -1323,6 +1337,9 @@ int iso_write_opts_set_max_37_char_filenames(IsoWriteOpts *opts, int allow);
|
|||||||
* extension. libisofs adds it if original filename doesn't has one. Set
|
* extension. libisofs adds it if original filename doesn't has one. Set
|
||||||
* this to 1 to prevent this behavior.
|
* this to 1 to prevent this behavior.
|
||||||
* This breaks ECMA-119 specification. Use with caution.
|
* This breaks ECMA-119 specification. Use with caution.
|
||||||
|
* @param no
|
||||||
|
* bit0= no forced dot with ECMA-119
|
||||||
|
* bit1= no forced dot with Joliet (@since 0.6.30)
|
||||||
*
|
*
|
||||||
* @since 0.6.2
|
* @since 0.6.2
|
||||||
*/
|
*/
|
||||||
@ -1446,11 +1463,38 @@ int iso_write_opts_set_sort_files(IsoWriteOpts *opts, int sort);
|
|||||||
*/
|
*/
|
||||||
int iso_write_opts_set_record_md5(IsoWriteOpts *opts, int session, int files);
|
int iso_write_opts_set_record_md5(IsoWriteOpts *opts, int session, int files);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the parameters "name" and "timestamp" for a scdbackup checksum tag.
|
||||||
|
* It will be appended to the libisofs session tag if the image starts at
|
||||||
|
* LBA 0 (see iso_write_opts_set_ms_block()). The scdbackup tag can be used
|
||||||
|
* to verify the image by command scdbackup_verify <device> -auto_end.
|
||||||
|
* See scdbackup/README appendix VERIFY for its inner details.
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* A word of up to 80 characters. Typically <volno>_<totalno> telling
|
||||||
|
* that this is volume <volno> of a total of <totalno> volumes.
|
||||||
|
* @param timestamp
|
||||||
|
* A string of 13 characters YYMMDD.hhmmss (e.g. A90831.190324).
|
||||||
|
* A9 = 2009, B0 = 2010, B1 = 2011, ... C0 = 2020, ...
|
||||||
|
* @param tag_written
|
||||||
|
* Either NULL or the address of an array with at least 512 characters.
|
||||||
|
* In the latter case the eventually produced scdbackup tag will be
|
||||||
|
* copied to this array when the image gets written. This call sets
|
||||||
|
* scdbackup_tag_written[0] = 0 to mark its preliminary invalidity.
|
||||||
|
* @return
|
||||||
|
* 1 indicates success, <0 is error
|
||||||
|
*
|
||||||
|
* @since 0.6.24
|
||||||
|
*/
|
||||||
|
int iso_write_opts_set_scdbackup_tag(IsoWriteOpts *opts,
|
||||||
|
char *name, char *timestamp,
|
||||||
|
char *tag_written);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to set default values for files and directory permissions, gid and
|
* Whether to set default values for files and directory permissions, gid and
|
||||||
* uid. All these take one of three values: 0, 1 or 2.
|
* uid. All these take one of three values: 0, 1 or 2.
|
||||||
*
|
*
|
||||||
* If 0, the corresponding attribute will be kept as setted in the IsoNode.
|
* If 0, the corresponding attribute will be kept as set in the IsoNode.
|
||||||
* Unless you have changed it, it corresponds to the value on disc, so it
|
* Unless you have changed it, it corresponds to the value on disc, so it
|
||||||
* is suitable for backup purposes. If set to 1, the corresponding attrib.
|
* is suitable for backup purposes. If set to 1, the corresponding attrib.
|
||||||
* will be changed by a default suitable value. Finally, if you set it to
|
* will be changed by a default suitable value. Finally, if you set it to
|
||||||
@ -1652,6 +1696,75 @@ int iso_write_opts_set_overwrite_buf(IsoWriteOpts *opts, uint8_t *overwrite);
|
|||||||
*/
|
*/
|
||||||
int iso_write_opts_set_fifo_size(IsoWriteOpts *opts, size_t fifo_size);
|
int iso_write_opts_set_fifo_size(IsoWriteOpts *opts, size_t fifo_size);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Attach 32 kB of binary data which shall get written to the first 32 kB
|
||||||
|
* of the ISO image, the ECMA-119 System Area. This space is intended for
|
||||||
|
* system dependent boot software, e.g. a Master Boot Record which allows to
|
||||||
|
* boot from USB sticks or hard disks. ECMA-119 makes no own assumptions or
|
||||||
|
* prescriptions about the byte content.
|
||||||
|
*
|
||||||
|
* If system area data are given or options bit0 is set, then bit1 of
|
||||||
|
* el_torito_set_isolinux_options() is automatically disabled.
|
||||||
|
* @param data
|
||||||
|
* Either NULL or 32 kB of data. Do not submit less bytes !
|
||||||
|
* @param options
|
||||||
|
* Can cause manipulations of submitted data before they get written:
|
||||||
|
* bit0= apply a --protective-msdos-label as of grub-mkisofs.
|
||||||
|
* This means to patch bytes 446 to 512 of the system area so
|
||||||
|
* that one partition is defined which begins at the second
|
||||||
|
* 512-byte block of the image and ends where the image ends.
|
||||||
|
* This works with and without system_area_data.
|
||||||
|
* bit1= apply isohybrid MBR patching to the system area.
|
||||||
|
* This works only with system area data from SYSLINUX plus an
|
||||||
|
* ISOLINUX boot image (see iso_image_set_boot_image()) and
|
||||||
|
* only if not bit0 is set.
|
||||||
|
* @param flag
|
||||||
|
* bit0 = invalidate any attached system area data. Same as data == NULL
|
||||||
|
* (This re-activates eventually loaded image System Area data.
|
||||||
|
* To erase those, submit 32 kB of zeros without flag bit0.)
|
||||||
|
* bit1 = keep data unaltered
|
||||||
|
* bit2 = keep options unaltered
|
||||||
|
* @return
|
||||||
|
* ISO_SUCCESS or error
|
||||||
|
* @since 0.6.30
|
||||||
|
*/
|
||||||
|
int iso_write_opts_set_system_area(IsoWriteOpts *opts, char data[32768],
|
||||||
|
int options, int flag);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Explicitely set the four timestamps of the emerging Primary Volume
|
||||||
|
* Descriptor. Default with all parameters is 0.
|
||||||
|
* ECMA-119 defines them as:
|
||||||
|
* @param vol_creation_time
|
||||||
|
* When "the information in the volume was created."
|
||||||
|
* A value of 0 means that the timepoint of write start is to be used.
|
||||||
|
* @param vol_modification_time
|
||||||
|
* When "the information in the volume was last modified."
|
||||||
|
* A value of 0 means that the timepoint of write start is to be used.
|
||||||
|
* @param vol_expiration_time
|
||||||
|
* When "the information in the volume may be regarded as obsolete."
|
||||||
|
* A value of 0 means that the information never shall expire.
|
||||||
|
* @param vol_effective_time
|
||||||
|
* When "the information in the volume may be used."
|
||||||
|
* A value of 0 means that not such retention is intended.
|
||||||
|
* @param uuid
|
||||||
|
* If this text is not empty, then it overrides vol_creation_time and
|
||||||
|
* vol_modification_time by copying the first 16 decimal digits from
|
||||||
|
* uuid, eventually padding up with decimal '1', and writing a NUL-byte
|
||||||
|
* as timezone.
|
||||||
|
* Other than with vol_*_time the resulting string in the ISO image
|
||||||
|
* is fully predictable and free of timezone pitfalls.
|
||||||
|
* It should express a reasonable time in form YYYYMMDDhhmmsscc
|
||||||
|
* E.g.: "2010040711405800" = 7 Apr 2010 11:40:58 (+0 centiseconds)
|
||||||
|
*
|
||||||
|
* @since 0.6.30
|
||||||
|
*/
|
||||||
|
int iso_write_opts_set_pvd_times(IsoWriteOpts *opts,
|
||||||
|
time_t vol_creation_time, time_t vol_modification_time,
|
||||||
|
time_t vol_expiration_time, time_t vol_effective_time,
|
||||||
|
char *vol_uuid);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Inquire the start address of the file data blocks after having used
|
* Inquire the start address of the file data blocks after having used
|
||||||
* IsoWriteOpts with iso_image_create_burn_source().
|
* IsoWriteOpts with iso_image_create_burn_source().
|
||||||
@ -1894,6 +2007,20 @@ int iso_read_opts_set_input_charset(IsoReadOpts *opts, const char *charset);
|
|||||||
*/
|
*/
|
||||||
int iso_read_opts_auto_input_charset(IsoReadOpts *opts, int mode);
|
int iso_read_opts_auto_input_charset(IsoReadOpts *opts, int mode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable or disable loading of the first 32768 bytes of the session.
|
||||||
|
*
|
||||||
|
* @param mode
|
||||||
|
* Bitfield for control purposes:
|
||||||
|
* bit0= Load System Area data and attach them to the image so that they
|
||||||
|
* get written by the next session, if not overridden by
|
||||||
|
* iso_write_opts_set_system_area().
|
||||||
|
* Submit any other bits with value 0.
|
||||||
|
*
|
||||||
|
* @since 0.6.30
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
int iso_read_opts_load_system_area(IsoReadOpts *opts, int mode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Import a previous session or image, for growing or modify.
|
* Import a previous session or image, for growing or modify.
|
||||||
@ -2167,16 +2294,15 @@ void iso_image_set_biblio_file_id(IsoImage *image, const char *biblio_file_id);
|
|||||||
const char *iso_image_get_biblio_file_id(const IsoImage *image);
|
const char *iso_image_get_biblio_file_id(const IsoImage *image);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a bootable image by adding a El-Torito boot image.
|
* Create a new set of El-Torito bootable images by adding a boot catalog
|
||||||
*
|
* and the default boot image.
|
||||||
* This also add a catalog boot node to the image filesystem tree.
|
* Further boot images may then be added by iso_image_add_boot_image().
|
||||||
*
|
*
|
||||||
* @param image
|
* @param image
|
||||||
* The image to make bootable. If it was already bootable this function
|
* The image to make bootable. If it was already bootable this function
|
||||||
* returns an error and the image remains unmodified.
|
* returns an error and the image remains unmodified.
|
||||||
* @param image_path
|
* @param image_path
|
||||||
* The path on the image tree of a regular file to use as default boot
|
* The absolute path of a IsoFile to be used as default boot image.
|
||||||
* image.
|
|
||||||
* @param type
|
* @param type
|
||||||
* The boot media type. This can be one of 3 types:
|
* The boot media type. This can be one of 3 types:
|
||||||
* - Floppy emulation: Boot image file must be exactly
|
* - Floppy emulation: Boot image file must be exactly
|
||||||
@ -2186,9 +2312,9 @@ const char *iso_image_get_biblio_file_id(const IsoImage *image);
|
|||||||
* - No emulation. You should specify load segment and load size
|
* - No emulation. You should specify load segment and load size
|
||||||
* of image.
|
* of image.
|
||||||
* @param catalog_path
|
* @param catalog_path
|
||||||
* The path on the image tree where the catalog will be stored. The
|
* The absolute path in the image tree where the catalog will be stored.
|
||||||
* directory component of this path must be a directory existent on the
|
* The directory component of this path must be a directory existent on
|
||||||
* image tree, and the filename component must be unique among all
|
* the image tree, and the filename component must be unique among all
|
||||||
* children of that directory on image. Otherwise a correspodent error
|
* children of that directory on image. Otherwise a correspodent error
|
||||||
* code will be returned. This function will add an IsoBoot node that acts
|
* code will be returned. This function will add an IsoBoot node that acts
|
||||||
* as a placeholder for the real catalog, that will be generated at image
|
* as a placeholder for the real catalog, that will be generated at image
|
||||||
@ -2209,10 +2335,36 @@ int iso_image_set_boot_image(IsoImage *image, const char *image_path,
|
|||||||
const char *catalog_path,
|
const char *catalog_path,
|
||||||
ElToritoBootImage **boot);
|
ElToritoBootImage **boot);
|
||||||
|
|
||||||
/* TODO #00026 : add support for "hidden" bootable images. */
|
/**
|
||||||
|
* Add a further boot image to the set of El-Torito bootable images.
|
||||||
|
* This set has already to be created by iso_image_set_boot_image().
|
||||||
|
* Up to 31 further boot images may be added.
|
||||||
|
*
|
||||||
|
* @param image
|
||||||
|
* The image to which the boot image shall be added.
|
||||||
|
* returns an error and the image remains unmodified.
|
||||||
|
* @param image_path
|
||||||
|
* The absolute path of a IsoFile to be used as default boot image.
|
||||||
|
* @param type
|
||||||
|
* The boot media type. See iso_image_set_boot_image
|
||||||
|
* @param flag
|
||||||
|
* Bitfield for control purposes. Unused yet. Submit 0.
|
||||||
|
* @param boot
|
||||||
|
* Location where a pointer to the added boot image will be stored.
|
||||||
|
* See iso_image_set_boot_image
|
||||||
|
* @return
|
||||||
|
* 1 on success, < 0 on error
|
||||||
|
* ISO_BOOT_NO_CATALOG means iso_image_set_boot_image()
|
||||||
|
* was not called first.
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int iso_image_add_boot_image(IsoImage *image, const char *image_path,
|
||||||
|
enum eltorito_boot_media_type type, int flag,
|
||||||
|
ElToritoBootImage **boot);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get El-Torito boot image of an ISO image, if any.
|
* Get the El-Torito boot catalog and the default boot image of an ISO image.
|
||||||
*
|
*
|
||||||
* This can be useful, for example, to check if a volume read from a previous
|
* This can be useful, for example, to check if a volume read from a previous
|
||||||
* session or an existing image is bootable. It can also be useful to get
|
* session or an existing image is bootable. It can also be useful to get
|
||||||
@ -2220,7 +2372,7 @@ int iso_image_set_boot_image(IsoImage *image, const char *image_path,
|
|||||||
* example, to prevent the user removing it.
|
* example, to prevent the user removing it.
|
||||||
*
|
*
|
||||||
* Both nodes are owned by libisofs and should not be freed. You can get your
|
* Both nodes are owned by libisofs and should not be freed. You can get your
|
||||||
* own ref with iso_node_ref(). You can can also check if the node is already
|
* own ref with iso_node_ref(). You can also check if the node is already
|
||||||
* on the tree by getting its parent (note that when reading El-Torito info
|
* on the tree by getting its parent (note that when reading El-Torito info
|
||||||
* from a previous image, the nodes might not be on the tree even if you haven't
|
* from a previous image, the nodes might not be on the tree even if you haven't
|
||||||
* removed them). Remember that you'll need to get a new ref
|
* removed them). Remember that you'll need to get a new ref
|
||||||
@ -2250,7 +2402,35 @@ int iso_image_get_boot_image(IsoImage *image, ElToritoBootImage **boot,
|
|||||||
IsoFile **imgnode, IsoBoot **catnode);
|
IsoFile **imgnode, IsoBoot **catnode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes the El-Torito bootable image.
|
* Get all El-Torito boot images of an ISO image.
|
||||||
|
*
|
||||||
|
* The first of these boot images is the same as returned by
|
||||||
|
* iso_image_get_boot_image(). The others are alternative boot images.
|
||||||
|
*
|
||||||
|
* @param image
|
||||||
|
* The image from which to get the boot images.
|
||||||
|
* @param num_boots
|
||||||
|
* The number of available array elements in boots and bootnodes.
|
||||||
|
* @param boots
|
||||||
|
* Returns NULL or an allocated array of pointers to boot images.
|
||||||
|
* Apply system call free(boots) to dispose it.
|
||||||
|
* @param bootnodes
|
||||||
|
* Returns NULL or an allocated array of pointers to the IsoFile nodes
|
||||||
|
* which bear the content of the boot images in boots.
|
||||||
|
* @param flag
|
||||||
|
* Bitfield for control purposes. Unused yet. Submit 0.
|
||||||
|
* @return
|
||||||
|
* 1 on success, 0 no El-Torito catalog and boot image attached,
|
||||||
|
* < 0 error.
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int iso_image_get_all_boot_imgs(IsoImage *image, int *num_boots,
|
||||||
|
ElToritoBootImage ***boots, IsoFile ***bootnodes, int flag);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes all El-Torito boot images from the ISO image.
|
||||||
*
|
*
|
||||||
* The IsoBoot node that acts as placeholder for the catalog is also removed
|
* The IsoBoot node that acts as placeholder for the catalog is also removed
|
||||||
* for the image tree, if there.
|
* for the image tree, if there.
|
||||||
@ -2261,6 +2441,93 @@ int iso_image_get_boot_image(IsoImage *image, ElToritoBootImage **boot,
|
|||||||
*/
|
*/
|
||||||
void iso_image_remove_boot_image(IsoImage *image);
|
void iso_image_remove_boot_image(IsoImage *image);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the sort weight of the boot catalog that is attached to an IsoImage.
|
||||||
|
*
|
||||||
|
* For the meaning of sort weights see iso_node_set_sort_weight().
|
||||||
|
* That function cannot be applied to the emerging boot catalog because
|
||||||
|
* it is not represented by an IsoFile.
|
||||||
|
*
|
||||||
|
* @param image
|
||||||
|
* The image to manipulate.
|
||||||
|
* @param sort_weight
|
||||||
|
* The larger this value, the lower will be the block address of the
|
||||||
|
* boot catalog record.
|
||||||
|
* @return
|
||||||
|
* 0= no boot catalog attached , 1= ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int iso_image_set_boot_catalog_weight(IsoImage *image, int sort_weight);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hides the boot catalog file from directory trees.
|
||||||
|
*
|
||||||
|
* For the meaning of hiding files see iso_node_set_hidden().
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param image
|
||||||
|
* The image to manipulate.
|
||||||
|
* @param hide_attrs
|
||||||
|
* Or-combination of values from enum IsoHideNodeFlag to set the trees
|
||||||
|
* in which the record.
|
||||||
|
* @return
|
||||||
|
* 0= no boot catalog attached , 1= ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.34
|
||||||
|
*/
|
||||||
|
int iso_image_set_boot_catalog_hidden(IsoImage *image, int hide_attrs);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the boot media type as of parameter "type" of iso_image_set_boot_image()
|
||||||
|
* resp. iso_image_add_boot_image().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @param media_type
|
||||||
|
* Returns the media type
|
||||||
|
* @return
|
||||||
|
* 1 = ok , < 0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_boot_media_type(ElToritoBootImage *bootimg,
|
||||||
|
enum eltorito_boot_media_type *media_type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the platform ID of the boot image.
|
||||||
|
*
|
||||||
|
* The Platform ID gets written into the boot catalog at byte 1 of the
|
||||||
|
* Validation Entry, or at byte 1 of a Section Header Entry.
|
||||||
|
* If Platform ID and ID String of two consequtive bootimages are the same
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to manipulate.
|
||||||
|
* @param id
|
||||||
|
* A Platform ID as of
|
||||||
|
* El Torito 1.0 : 0x00= 80x86, 0x01= PowerPC, 0x02= Mac
|
||||||
|
* Others : 0xef= EFI
|
||||||
|
* @return
|
||||||
|
* 1 ok , <=0 error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_set_boot_platform_id(ElToritoBootImage *bootimg, uint8_t id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the platform ID value. See el_torito_set_boot_platform_id().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @return
|
||||||
|
* 0 - 255 : The platform ID
|
||||||
|
* < 0 : error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_boot_platform_id(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the load segment for the initial boot image. This is only for
|
* Sets the load segment for the initial boot image. This is only for
|
||||||
* no emulation boot images, and is a NOP for other image types.
|
* no emulation boot images, and is a NOP for other image types.
|
||||||
@ -2269,6 +2536,19 @@ void iso_image_remove_boot_image(IsoImage *image);
|
|||||||
*/
|
*/
|
||||||
void el_torito_set_load_seg(ElToritoBootImage *bootimg, short segment);
|
void el_torito_set_load_seg(ElToritoBootImage *bootimg, short segment);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the load segment value. See el_torito_set_load_seg().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @return
|
||||||
|
* 0 - 65535 : The load segment value
|
||||||
|
* < 0 : error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_load_seg(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the number of sectors (512b) to be load at load segment during
|
* Sets the number of sectors (512b) to be load at load segment during
|
||||||
* the initial boot procedure. This is only for
|
* the initial boot procedure. This is only for
|
||||||
@ -2278,6 +2558,19 @@ void el_torito_set_load_seg(ElToritoBootImage *bootimg, short segment);
|
|||||||
*/
|
*/
|
||||||
void el_torito_set_load_size(ElToritoBootImage *bootimg, short sectors);
|
void el_torito_set_load_size(ElToritoBootImage *bootimg, short sectors);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the load size. See el_torito_set_load_size().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @return
|
||||||
|
* 0 - 65535 : The load size value
|
||||||
|
* < 0 : error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_load_size(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Marks the specified boot image as not bootable
|
* Marks the specified boot image as not bootable
|
||||||
*
|
*
|
||||||
@ -2286,30 +2579,131 @@ void el_torito_set_load_size(ElToritoBootImage *bootimg, short sectors);
|
|||||||
void el_torito_set_no_bootable(ElToritoBootImage *bootimg);
|
void el_torito_set_no_bootable(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Specifies that this image needs to be patched. This involves the writing
|
* Get the bootability flag. See el_torito_set_no_bootable().
|
||||||
* of a 56 bytes boot information table at offset 8 of the boot image file.
|
|
||||||
* The original boot image file won't be modified.
|
|
||||||
* This is needed for isolinux boot images.
|
|
||||||
*
|
*
|
||||||
* @since 0.6.2
|
* @param bootimg
|
||||||
* @deprecated Use el_torito_set_isolinux_options() instead
|
* The image to inquire
|
||||||
|
* @return
|
||||||
|
* 0 = not bootable, 1 = bootable , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
*/
|
*/
|
||||||
void el_torito_patch_isolinux_image(ElToritoBootImage *bootimg);
|
int el_torito_get_bootable(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Specifies options for IsoLinux boot images. This should only be used with
|
* Set the id_string of the Validation Entry resp. Sector Header Entry which
|
||||||
* isolinux boot images.
|
* will govern the boot image Section Entry in the El Torito Catalog.
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to manipulate.
|
||||||
|
* @param id_string
|
||||||
|
* The first boot image puts 24 bytes of ID string into the Validation
|
||||||
|
* Entry, where they shall "identify the manufacturer/developer of
|
||||||
|
* the CD-ROM".
|
||||||
|
* Further boot images put 28 bytes into their Section Header.
|
||||||
|
* El Torito 1.0 states that "If the BIOS understands the ID string, it
|
||||||
|
* may choose to boot the * system using one of these entries in place
|
||||||
|
* of the INITIAL/DEFAULT entry." (The INITIAL/DEFAULT entry points to the
|
||||||
|
* first boot image.)
|
||||||
|
* @return
|
||||||
|
* 1 = ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_set_id_string(ElToritoBootImage *bootimg, uint8_t id_string[28]);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the id_string as of el_torito_set_id_string().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @param id_string
|
||||||
|
* Returns 28 bytes of id string
|
||||||
|
* @return
|
||||||
|
* 1 = ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_id_string(ElToritoBootImage *bootimg, uint8_t id_string[28]);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the Selection Criteria of a boot image.
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to manipulate.
|
||||||
|
* @param crit
|
||||||
|
* The first boot image has no selection criteria. They will be ignored.
|
||||||
|
* Further boot images put 1 byte of Selection Criteria Type and 19
|
||||||
|
* bytes of data into their Section Entry.
|
||||||
|
* El Torito 1.0 states that "The format of the selection criteria is
|
||||||
|
* a function of the BIOS vendor. In the case of a foreign language
|
||||||
|
* BIOS three bytes would be used to identify the language".
|
||||||
|
* Type byte == 0 means "no criteria",
|
||||||
|
* type byte == 1 means "Language and Version Information (IBM)".
|
||||||
|
* @return
|
||||||
|
* 1 = ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_set_selection_crit(ElToritoBootImage *bootimg, uint8_t crit[20]);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the Selection Criteria bytes as of el_torito_set_selection_crit().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @param id_string
|
||||||
|
* Returns 20 bytes of type and data
|
||||||
|
* @return
|
||||||
|
* 1 = ok , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_selection_crit(ElToritoBootImage *bootimg, uint8_t crit[20]);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes a guess whether the boot image was patched by a boot information
|
||||||
|
* table. It is advisable to patch such boot images if their content gets
|
||||||
|
* copied to a new location. See el_torito_set_isolinux_options().
|
||||||
|
* Note: The reply can be positive only if the boot image was imported
|
||||||
|
* from an existing ISO image.
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @return
|
||||||
|
* 1 = seems to contain oot info table , 0 = quite surely not
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_seems_boot_info_table(ElToritoBootImage *bootimg, int flag);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Specifies options for ISOLINUX or GRUB boot images. This should only be used
|
||||||
|
* if the type of boot image is known.
|
||||||
*
|
*
|
||||||
* @param options
|
* @param options
|
||||||
* bitmask style flag. The following values are defined:
|
* bitmask style flag. The following values are defined:
|
||||||
*
|
*
|
||||||
* bit 0 -> 1 to path the image, 0 to not
|
* bit 0 -> 1 to patch the boot info table of the boot image.
|
||||||
* Patching the image involves the writing of a 56 bytes
|
* 1 does the same as mkisofs option -boot-info-table.
|
||||||
* boot information table at offset 8 of the boot image file.
|
* Needed for ISOLINUX or GRUB boot images with platform ID 0.
|
||||||
* The original boot image file will not be modified. This is
|
* The table is located at byte 8 of the boot image file.
|
||||||
* needed to allow isolinux images to be bootable.
|
* Its size is 56 bytes.
|
||||||
* bit 1 -> 1 to generate an hybrid image with MBR, 0 to not
|
* The original boot image file on disk will not be modified.
|
||||||
* An hybrid image is a boot image that boots from either
|
*
|
||||||
|
* One may use el_torito_seems_boot_info_table() for a
|
||||||
|
* qualified guess whether a boot info table is present in
|
||||||
|
* the boot image. If the result is 1 then it should get bit0
|
||||||
|
* set if its content gets copied to a new LBA.
|
||||||
|
*
|
||||||
|
* bit 1 -> 1 to generate a ISOLINUX isohybrid image with MBR.
|
||||||
|
* ----------------------------------------------------------
|
||||||
|
* @deprecated since 31 Mar 2010:
|
||||||
|
* The author of syslinux, H. Peter Anvin requested that this
|
||||||
|
* feature shall not be used any more. He intends to cease
|
||||||
|
* support for the MBR template that is included in libisofs.
|
||||||
|
* ----------------------------------------------------------
|
||||||
|
* A hybrid image is a boot image that boots from either
|
||||||
* CD/DVD media or from disk-like media, e.g. USB stick.
|
* CD/DVD media or from disk-like media, e.g. USB stick.
|
||||||
* For that you need isolinux.bin from SYSLINUX 3.72 or later.
|
* For that you need isolinux.bin from SYSLINUX 3.72 or later.
|
||||||
* IMPORTANT: The application has to take care that the image
|
* IMPORTANT: The application has to take care that the image
|
||||||
@ -2320,7 +2714,55 @@ void el_torito_patch_isolinux_image(ElToritoBootImage *bootimg);
|
|||||||
* 1 success, < 0 on error
|
* 1 success, < 0 on error
|
||||||
* @since 0.6.12
|
* @since 0.6.12
|
||||||
*/
|
*/
|
||||||
int el_torito_set_isolinux_options(ElToritoBootImage *bootimg, int options, int flag);
|
int el_torito_set_isolinux_options(ElToritoBootImage *bootimg,
|
||||||
|
int options, int flag);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the options as of el_torito_set_isolinux_options().
|
||||||
|
*
|
||||||
|
* @param bootimg
|
||||||
|
* The image to inquire
|
||||||
|
* @param flag
|
||||||
|
* Reserved for future usage, set to 0.
|
||||||
|
* @return
|
||||||
|
* >= 0 returned option bits , <0 = error
|
||||||
|
*
|
||||||
|
* @since 0.6.32
|
||||||
|
*/
|
||||||
|
int el_torito_get_isolinux_options(ElToritoBootImage *bootimg, int flag);
|
||||||
|
|
||||||
|
/** Deprecated:
|
||||||
|
* Specifies that this image needs to be patched. This involves the writing
|
||||||
|
* of a 16 bytes boot information table at offset 8 of the boot image file.
|
||||||
|
* The original boot image file won't be modified.
|
||||||
|
* This is needed for isolinux boot images.
|
||||||
|
*
|
||||||
|
* @since 0.6.2
|
||||||
|
* @deprecated Use el_torito_set_isolinux_options() instead
|
||||||
|
*/
|
||||||
|
void el_torito_patch_isolinux_image(ElToritoBootImage *bootimg);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Obtain a copy of the eventually loaded first 32768 bytes of the imported
|
||||||
|
* session, the System Area.
|
||||||
|
* It will be written to the start of the next session unless it gets
|
||||||
|
* overwritten by iso_write_opts_set_system_area().
|
||||||
|
*
|
||||||
|
* @param img
|
||||||
|
* The image to be inquired.
|
||||||
|
* @param data
|
||||||
|
* A byte array of at least 32768 bytesi to take the loaded bytes.
|
||||||
|
* @param options
|
||||||
|
* The option bits which will be applied if not overridden by
|
||||||
|
* iso_write_opts_set_system_area(). See there.
|
||||||
|
* @param flag
|
||||||
|
* Bitfield for control purposes, unused yet, submit 0
|
||||||
|
* @return
|
||||||
|
* 1 on success, 0 if no System Area was loaded, < 0 error.
|
||||||
|
* @since 0.6.30
|
||||||
|
*/
|
||||||
|
int iso_image_get_system_area(IsoImage *img, char data[32768],
|
||||||
|
int *options, int flag);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Increments the reference counting of the given node.
|
* Increments the reference counting of the given node.
|
||||||
@ -2546,26 +2988,40 @@ void iso_node_set_ctime(IsoNode *node, time_t time);
|
|||||||
time_t iso_node_get_ctime(const IsoNode *node);
|
time_t iso_node_get_ctime(const IsoNode *node);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set if the node will be hidden in RR/ISO tree, Joliet tree or both.
|
* Set whether the node will be hidden in the directory trees of RR/ISO 9660,
|
||||||
|
* or of Joliet (if enabled at all), or of ISO-9660:1999 (if enabled at all).
|
||||||
*
|
*
|
||||||
* If the file is set as hidden in one tree, it won't be included there, so
|
* A hidden file does not show up by name in the affected directory tree.
|
||||||
* it won't be visible in a OS accessing CD using that tree. For example,
|
* For example, if a file is hidden only in Joliet, it will normally
|
||||||
* GNU/Linux systems access to Rock Ridge / ISO9960 tree in order to see
|
* not be visible on Windows systems, while being shown on GNU/Linux.
|
||||||
* what is recorded on CD, while MS Windows make use of the Joliet tree. If a
|
|
||||||
* file is hidden only in Joliet, it won't be visible in Windows systems,
|
|
||||||
* while still visible in Linux.
|
|
||||||
*
|
*
|
||||||
* If a file is hidden in both trees, it won't be written to image.
|
* If a file is not shown in any of the enabled trees, then its content will
|
||||||
|
* not be written to the image, unless LIBISO_HIDE_BUT_WRITE is given (which
|
||||||
|
* is available only since release 0.6.34).
|
||||||
*
|
*
|
||||||
* @param node
|
* @param node
|
||||||
* The node that is to be hidden.
|
* The node that is to be hidden.
|
||||||
* @param hide_attrs
|
* @param hide_attrs
|
||||||
* IsoHideNodeFlag's to set the trees in which file will be hidden.
|
* Or-combination of values from enum IsoHideNodeFlag to set the trees
|
||||||
|
* in which the node's name shall be hidden.
|
||||||
*
|
*
|
||||||
* @since 0.6.2
|
* @since 0.6.2
|
||||||
*/
|
*/
|
||||||
void iso_node_set_hidden(IsoNode *node, int hide_attrs);
|
void iso_node_set_hidden(IsoNode *node, int hide_attrs);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the hide_attrs as eventually set by iso_node_set_hidden().
|
||||||
|
*
|
||||||
|
* @param node
|
||||||
|
* The node to inquire.
|
||||||
|
* @return
|
||||||
|
* Or-combination of values from enum IsoHideNodeFlag which are
|
||||||
|
* currently set for the node.
|
||||||
|
*
|
||||||
|
* @since 0.6.34
|
||||||
|
*/
|
||||||
|
int iso_node_get_hidden(IsoNode *node);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Compare two nodes whether they are based on the same input and
|
* Compare two nodes whether they are based on the same input and
|
||||||
* can be considered as hardlinks to the same file objects.
|
* can be considered as hardlinks to the same file objects.
|
||||||
@ -3006,8 +3462,8 @@ const char *iso_symlink_get_dest(const IsoSymlink *link);
|
|||||||
int iso_symlink_set_dest(IsoSymlink *link, const char *dest);
|
int iso_symlink_set_dest(IsoSymlink *link, const char *dest);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the order in which a node will be written on image. High weihted files
|
* Sets the order in which a node will be written on image. The data content
|
||||||
* will be written first, so in a disc them will be written near the center.
|
* of files with high weight will be written to low block addresses.
|
||||||
*
|
*
|
||||||
* @param node
|
* @param node
|
||||||
* The node which weight will be changed. If it's a dir, this function
|
* The node which weight will be changed. If it's a dir, this function
|
||||||
@ -3016,6 +3472,7 @@ int iso_symlink_set_dest(IsoSymlink *link, const char *dest);
|
|||||||
* @param w
|
* @param w
|
||||||
* The weight as a integer number, the greater this value is, the
|
* The weight as a integer number, the greater this value is, the
|
||||||
* closer from the begining of image the file will be written.
|
* closer from the begining of image the file will be written.
|
||||||
|
* Default value at IsoNode creation is 0.
|
||||||
*
|
*
|
||||||
* @since 0.6.2
|
* @since 0.6.2
|
||||||
*/
|
*/
|
||||||
@ -3262,8 +3719,13 @@ void iso_tree_set_follow_symlinks(IsoImage *image, int follow);
|
|||||||
int iso_tree_get_follow_symlinks(IsoImage *image);
|
int iso_tree_get_follow_symlinks(IsoImage *image);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set whether to skip or not hidden files when adding a directory recursibely.
|
* Set whether to skip or not disk files with names beginning by '.'
|
||||||
* Default behavior is to not ignore them, i.e., to add hidden files to image.
|
* when adding a directory recursively.
|
||||||
|
* Default behavior is to not ignore them.
|
||||||
|
*
|
||||||
|
* Clarification: This is not related to the IsoNode property to be hidden
|
||||||
|
* in one or more of the resulting image trees as of
|
||||||
|
* IsoHideNodeFlag and iso_node_set_hidden().
|
||||||
*
|
*
|
||||||
* @since 0.6.2
|
* @since 0.6.2
|
||||||
*/
|
*/
|
||||||
@ -3319,8 +3781,8 @@ void iso_tree_set_ignore_special(IsoImage *image, int skip);
|
|||||||
int iso_tree_get_ignore_special(IsoImage *image);
|
int iso_tree_get_ignore_special(IsoImage *image);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a excluded path. These are paths that won't never added to image,
|
* Add a excluded path. These are paths that won't never added to image, and
|
||||||
* and will be excluded even when adding recursively its parent directory.
|
* will be excluded even when adding recursively its parent directory.
|
||||||
*
|
*
|
||||||
* For example, in
|
* For example, in
|
||||||
*
|
*
|
||||||
@ -3412,7 +3874,9 @@ void iso_tree_set_report_callback(IsoImage *image,
|
|||||||
* @param parent
|
* @param parent
|
||||||
* The directory in the image tree where the node will be added.
|
* The directory in the image tree where the node will be added.
|
||||||
* @param path
|
* @param path
|
||||||
* The path of the file to add in the filesystem.
|
* The absolute path of the file in the local filesystem.
|
||||||
|
* The node will have the same leaf name as the file on disk.
|
||||||
|
* Its directory path depends on the parent node.
|
||||||
* @param node
|
* @param node
|
||||||
* place where to store a pointer to the newly added file. No
|
* place where to store a pointer to the newly added file. No
|
||||||
* extra ref is addded, so you will need to call iso_node_ref() if you
|
* extra ref is addded, so you will need to call iso_node_ref() if you
|
||||||
@ -3442,9 +3906,10 @@ int iso_tree_add_node(IsoImage *image, IsoDir *parent, const char *path,
|
|||||||
* @param parent
|
* @param parent
|
||||||
* The directory in the image tree where the node will be added.
|
* The directory in the image tree where the node will be added.
|
||||||
* @param name
|
* @param name
|
||||||
* The name that the node will have on image.
|
* The leaf name that the node will have on image.
|
||||||
|
* Its directory path depends on the parent node.
|
||||||
* @param path
|
* @param path
|
||||||
* The path of the file to add in the filesystem.
|
* The absolute path of the file in the local filesystem.
|
||||||
* @param node
|
* @param node
|
||||||
* place where to store a pointer to the newly added file. No
|
* place where to store a pointer to the newly added file. No
|
||||||
* extra ref is addded, so you will need to call iso_node_ref() if you
|
* extra ref is addded, so you will need to call iso_node_ref() if you
|
||||||
@ -3463,24 +3928,25 @@ int iso_tree_add_new_node(IsoImage *image, IsoDir *parent, const char *name,
|
|||||||
const char *path, IsoNode **node);
|
const char *path, IsoNode **node);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a new node to the image tree, from an existing file, and with the
|
* Add a new node to the image tree with the given name that must not exist
|
||||||
* given name, that must not exist on dir. The node will be cut-out to the
|
* on dir. The node data content will be a byte interval out of the data
|
||||||
* submitted size, and its contents will be read from the given offset. This
|
* content of a file in the local filesystem.
|
||||||
* function is thus suitable for adding only a piece of a file to the image.
|
|
||||||
*
|
*
|
||||||
* @param image
|
* @param image
|
||||||
* The image
|
* The image
|
||||||
* @param parent
|
* @param parent
|
||||||
* The directory in the image tree where the node will be added.
|
* The directory in the image tree where the node will be added.
|
||||||
* @param name
|
* @param name
|
||||||
* The name that the node will have on image.
|
* The leaf name that the node will have on image.
|
||||||
|
* Its directory path depends on the parent node.
|
||||||
* @param path
|
* @param path
|
||||||
* The path of the file to add in the filesystem. For now only regular
|
* The absolute path of the file in the local filesystem. For now
|
||||||
* files and symlinks to regular files are supported.
|
* only regular files and symlinks to regular files are supported.
|
||||||
* @param offset
|
* @param offset
|
||||||
* Offset on the given file from where to start reading data.
|
* Byte number in the given file from where to start reading data.
|
||||||
* @param size
|
* @param size
|
||||||
* Max size of the file.
|
* Max size of the file. This may be more than actually available from
|
||||||
|
* byte offset to the end of the file in the local filesystem.
|
||||||
* @param node
|
* @param node
|
||||||
* place where to store a pointer to the newly added file. No
|
* place where to store a pointer to the newly added file. No
|
||||||
* extra ref is addded, so you will need to call iso_node_ref() if you
|
* extra ref is addded, so you will need to call iso_node_ref() if you
|
||||||
@ -3523,7 +3989,7 @@ int iso_tree_add_new_cut_out_node(IsoImage *image, IsoDir *parent,
|
|||||||
int iso_tree_add_dir_rec(IsoImage *image, IsoDir *parent, const char *dir);
|
int iso_tree_add_dir_rec(IsoImage *image, IsoDir *parent, const char *dir);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Locate a node by its path on image.
|
* Locate a node by its absolute path on image.
|
||||||
*
|
*
|
||||||
* @param node
|
* @param node
|
||||||
* Location for a pointer to the node, it will filled with NULL if the
|
* Location for a pointer to the node, it will filled with NULL if the
|
||||||
@ -3540,7 +4006,7 @@ int iso_tree_add_dir_rec(IsoImage *image, IsoDir *parent, const char *dir);
|
|||||||
int iso_tree_path_to_node(IsoImage *image, const char *path, IsoNode **node);
|
int iso_tree_path_to_node(IsoImage *image, const char *path, IsoNode **node);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the path on image of the given node.
|
* Get the absolute path on image of the given node.
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* The path on the image, that must be freed when no more needed. If the
|
* The path on the image, that must be freed when no more needed. If the
|
||||||
@ -3566,11 +4032,10 @@ void iso_data_source_unref(IsoDataSource *src);
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new IsoDataSource from a local file. This is suitable for
|
* Create a new IsoDataSource from a local file. This is suitable for
|
||||||
* accessing regular .iso images, or to acces drives via its block device
|
* accessing regular files or block devices with ISO images.
|
||||||
* and standard POSIX I/O calls.
|
|
||||||
*
|
*
|
||||||
* @param path
|
* @param path
|
||||||
* The path of the file
|
* The absolute path of the file
|
||||||
* @param src
|
* @param src
|
||||||
* Will be filled with the pointer to the newly created data source.
|
* Will be filled with the pointer to the newly created data source.
|
||||||
* @return
|
* @return
|
||||||
@ -3805,8 +4270,7 @@ void iso_file_source_unref(IsoFileSource *src);
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the path, relative to the filesystem this file source
|
* Get the absolute path in the filesystem this file source belongs to.
|
||||||
* belongs to.
|
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
* the path of the FileSource inside the filesystem, it should be
|
* the path of the FileSource inside the filesystem, it should be
|
||||||
@ -4334,7 +4798,7 @@ int aaip_xinfo_func(void *data, int flag);
|
|||||||
* @param default_text
|
* @param default_text
|
||||||
* Will return a pointer to the eventual "default" ACL or NULL if it
|
* Will return a pointer to the eventual "default" ACL or NULL if it
|
||||||
* is not available.
|
* is not available.
|
||||||
* (Linux directories can have a "default" ACL which influences
|
* (GNU/Linux directories can have a "default" ACL which influences
|
||||||
* the permissions of newly created files.)
|
* the permissions of newly created files.)
|
||||||
* @param flag
|
* @param flag
|
||||||
* Bitfield for control purposes
|
* Bitfield for control purposes
|
||||||
@ -4371,7 +4835,7 @@ int iso_node_get_acl_text(IsoNode *node,
|
|||||||
* @param default_text
|
* @param default_text
|
||||||
* The text to be set into effect as "default" ACL. NULL will delete an
|
* The text to be set into effect as "default" ACL. NULL will delete an
|
||||||
* eventually existing "default" ACL of the node.
|
* eventually existing "default" ACL of the node.
|
||||||
* (Linux directories can have a "default" ACL which influences
|
* (GNU/Linux directories can have a "default" ACL which influences
|
||||||
* the permissions of newly created files.)
|
* the permissions of newly created files.)
|
||||||
* @param flag
|
* @param flag
|
||||||
* Bitfield for control purposes
|
* Bitfield for control purposes
|
||||||
@ -4522,7 +4986,7 @@ int iso_node_set_attrs(IsoNode *node, size_t num_attrs, char **names,
|
|||||||
* Get an ACL of the given file in the local filesystem in long text form.
|
* Get an ACL of the given file in the local filesystem in long text form.
|
||||||
*
|
*
|
||||||
* @param disk_path
|
* @param disk_path
|
||||||
* Path to the file
|
* Absolute path to the file
|
||||||
* @param text
|
* @param text
|
||||||
* Will return a pointer to the ACL text. If not NULL the text will be
|
* Will return a pointer to the ACL text. If not NULL the text will be
|
||||||
* 0 terminated and finally has to be disposed by a call to this function
|
* 0 terminated and finally has to be disposed by a call to this function
|
||||||
@ -4537,7 +5001,7 @@ int iso_node_set_attrs(IsoNode *node, size_t num_attrs, char **names,
|
|||||||
* @return
|
* @return
|
||||||
* 1 ok
|
* 1 ok
|
||||||
* 2 ok, trivial ACL found while bit4 is set, *text is NULL
|
* 2 ok, trivial ACL found while bit4 is set, *text is NULL
|
||||||
* 0 no ACL manipulation adapter available
|
* 0 no ACL manipulation adapter available / ACL not supported on fs
|
||||||
* -1 failure of system ACL service (see errno)
|
* -1 failure of system ACL service (see errno)
|
||||||
* -2 attempt to inquire ACL of a symbolic link without bit4 or bit5
|
* -2 attempt to inquire ACL of a symbolic link without bit4 or bit5
|
||||||
* resp. with no suitable link target
|
* resp. with no suitable link target
|
||||||
@ -4552,7 +5016,7 @@ int iso_local_get_acl_text(char *disk_path, char **text, int flag);
|
|||||||
* in long text form.
|
* in long text form.
|
||||||
*
|
*
|
||||||
* @param disk_path
|
* @param disk_path
|
||||||
* Path to the file
|
* Absolute path to the file
|
||||||
* @param text
|
* @param text
|
||||||
* The input text (0 terminated, ACL long text form)
|
* The input text (0 terminated, ACL long text form)
|
||||||
* @param flag
|
* @param flag
|
||||||
@ -4577,7 +5041,7 @@ int iso_local_set_acl_text(char *disk_path, char *text, int flag);
|
|||||||
* necessary if the permissions of a disk file with ACL shall be copied to
|
* necessary if the permissions of a disk file with ACL shall be copied to
|
||||||
* an object which has no ACL.
|
* an object which has no ACL.
|
||||||
* @param disk_path
|
* @param disk_path
|
||||||
* Path to the local file which may have an "access" ACL or not.
|
* Absolute path to the local file which may have an "access" ACL or not.
|
||||||
* @param flag
|
* @param flag
|
||||||
* Bitfield for control purposes
|
* Bitfield for control purposes
|
||||||
* bit5= in case of symbolic link: inquire link target
|
* bit5= in case of symbolic link: inquire link target
|
||||||
@ -4602,7 +5066,7 @@ int iso_local_get_perms_wo_acl(char *disk_path, mode_t *st_mode, int flag);
|
|||||||
* will not be put into the result.
|
* will not be put into the result.
|
||||||
*
|
*
|
||||||
* @param disk_path
|
* @param disk_path
|
||||||
* Path to the file
|
* Absolute path to the file
|
||||||
* @param num_attrs
|
* @param num_attrs
|
||||||
* Will return the number of name-value pairs
|
* Will return the number of name-value pairs
|
||||||
* @param names
|
* @param names
|
||||||
@ -4635,7 +5099,7 @@ int iso_local_get_attrs(char *disk_path, size_t *num_attrs, char ***names,
|
|||||||
* Eventual ACLs have to be encoded as attribute pair with empty name.
|
* Eventual ACLs have to be encoded as attribute pair with empty name.
|
||||||
*
|
*
|
||||||
* @param disk_path
|
* @param disk_path
|
||||||
* Path to the file
|
* Absolute path to the file
|
||||||
* @param num_attrs
|
* @param num_attrs
|
||||||
* Number of attributes
|
* Number of attributes
|
||||||
* @param names
|
* @param names
|
||||||
@ -4660,6 +5124,11 @@ int iso_local_set_attrs(char *disk_path, size_t num_attrs, char **names,
|
|||||||
size_t *value_lengths, char **values, int flag);
|
size_t *value_lengths, char **values, int flag);
|
||||||
|
|
||||||
|
|
||||||
|
/* Default in case that the compile environment has no macro PATH_MAX.
|
||||||
|
*/
|
||||||
|
#define Libisofs_default_path_maX 4096
|
||||||
|
|
||||||
|
|
||||||
/* --------------------------- Filters in General -------------------------- */
|
/* --------------------------- Filters in General -------------------------- */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -5287,6 +5756,13 @@ int iso_md5_match(char first_md5[16], char second_md5[16]);
|
|||||||
/** Trying to use an invalid file as boot image (FAILURE,HIGH, -68) */
|
/** Trying to use an invalid file as boot image (FAILURE,HIGH, -68) */
|
||||||
#define ISO_BOOT_IMAGE_NOT_VALID 0xE830FFBB
|
#define ISO_BOOT_IMAGE_NOT_VALID 0xE830FFBB
|
||||||
|
|
||||||
|
/** Too many boot images (FAILURE,HIGH, -69) */
|
||||||
|
#define ISO_BOOT_IMAGE_OVERFLOW 0xE830FFBA
|
||||||
|
|
||||||
|
/** No boot catalog created yet ((FAILURE,HIGH, -70) */ /* @since 0.6.34 */
|
||||||
|
#define ISO_BOOT_NO_CATALOG 0xE830FFB9
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Error on file operation (FAILURE,HIGH, -128)
|
* Error on file operation (FAILURE,HIGH, -128)
|
||||||
* (take a look at more specified error codes below)
|
* (take a look at more specified error codes below)
|
||||||
@ -5388,11 +5864,11 @@ int iso_md5_match(char first_md5[16], char second_md5[16]);
|
|||||||
/** Unsupported ECMA-119 feature (FAILURE,HIGH, -324) */
|
/** Unsupported ECMA-119 feature (FAILURE,HIGH, -324) */
|
||||||
#define ISO_UNSUPPORTED_ECMA119 0xE830FEBC
|
#define ISO_UNSUPPORTED_ECMA119 0xE830FEBC
|
||||||
|
|
||||||
/** Wrong or damaged El-Torito catalog (SORRY,HIGH, -325) */
|
/** Wrong or damaged El-Torito catalog (WARN,HIGH, -325) */
|
||||||
#define ISO_WRONG_EL_TORITO 0xE030FEBB
|
#define ISO_WRONG_EL_TORITO 0xD030FEBB
|
||||||
|
|
||||||
/** Unsupported El-Torito feature (SORRY,HIGH, -326) */
|
/** Unsupported El-Torito feature (WARN,HIGH, -326) */
|
||||||
#define ISO_UNSUPPORTED_EL_TORITO 0xE030FEBA
|
#define ISO_UNSUPPORTED_EL_TORITO 0xD030FEBA
|
||||||
|
|
||||||
/** Can't patch an isolinux boot image (SORRY,HIGH, -327) */
|
/** Can't patch an isolinux boot image (SORRY,HIGH, -327) */
|
||||||
#define ISO_ISOLINUX_CANT_PATCH 0xE030FEB9
|
#define ISO_ISOLINUX_CANT_PATCH 0xE030FEB9
|
||||||
@ -5522,6 +5998,13 @@ int iso_md5_match(char first_md5[16], char second_md5[16]);
|
|||||||
*/
|
*/
|
||||||
#define ISO_MD5_STREAM_CHANGE 0xE430FE9A
|
#define ISO_MD5_STREAM_CHANGE 0xE430FE9A
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Session does not start at LBA 0. scdbackup checksum tag not written.
|
||||||
|
* (WARNING, HIGH, -359)
|
||||||
|
* @since 0.6.24
|
||||||
|
*/
|
||||||
|
#define ISO_SCDBACKUP_TAG_NOT_0 0xD030FE99
|
||||||
|
|
||||||
|
|
||||||
/* ! PLACE NEW ERROR CODES HERE ! */
|
/* ! PLACE NEW ERROR CODES HERE ! */
|
||||||
|
|
||||||
@ -5730,13 +6213,7 @@ struct burn_source {
|
|||||||
|
|
||||||
/* ---------------------------- Improvements --------------------------- */
|
/* ---------------------------- Improvements --------------------------- */
|
||||||
|
|
||||||
|
/* currently none being tested */
|
||||||
/* Checksums : During image writing equip IsoFile objects with MD5 checksums
|
|
||||||
and compute an overall checksum of the session. Store them in
|
|
||||||
a separate checksum block area after the data area of the
|
|
||||||
session.
|
|
||||||
*/
|
|
||||||
#define Libisofs_with_checksumS yes
|
|
||||||
|
|
||||||
|
|
||||||
/* ---------------------------- Experiments ---------------------------- */
|
/* ---------------------------- Experiments ---------------------------- */
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -10,6 +15,7 @@
|
|||||||
/* for gettimeofday() */
|
/* for gettimeofday() */
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
|
|
||||||
/* This code stems from syslinux-3.72/utils/isohybrid, a perl script
|
/* This code stems from syslinux-3.72/utils/isohybrid, a perl script
|
||||||
under GPL which is Copyright 2002-2008 H. Peter Anvin.
|
under GPL which is Copyright 2002-2008 H. Peter Anvin.
|
||||||
|
|
||||||
@ -25,13 +31,13 @@ and is now under the licenses to which H.Peter Anvin agreed:
|
|||||||
or both, at your option.
|
or both, at your option.
|
||||||
Sincerely, H. Peter Anvin
|
Sincerely, H. Peter Anvin
|
||||||
|
|
||||||
In the context of xorriso-standalone, this code is under GPLv2 derived from
|
In the context of GNU xorriso, this code is under GPLv3+ derived from LGPL.
|
||||||
LGPL. In the context of libisofs this code derives its matching open source
|
In the context of libisofs this code derives its matching free software
|
||||||
license from above stem licenses, typically from LGPL.
|
license from above stem licenses, typically from LGPL.
|
||||||
In case its generosity is needed, here is the 2-clause BSD license:
|
In case its generosity is needed, here is the 2-clause BSD license:
|
||||||
|
|
||||||
make_isohybrid_mbr.c is copyright 2002-2008 H. Peter Anvin
|
make_isohybrid_mbr.c is copyright 2002-2008 H. Peter Anvin
|
||||||
and 2008-2009 libburnia project.
|
and 2008-2010 Thomas Schmitt
|
||||||
|
|
||||||
1. Redistributions of source code must retain the above copyright notice,
|
1. Redistributions of source code must retain the above copyright notice,
|
||||||
this list of conditions and the following disclaimer.
|
this list of conditions and the following disclaimer.
|
||||||
@ -51,8 +57,9 @@ ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/* A helper function. One could replace it by one or two macros. */
|
/* A helper function. One could replace it by one or two macros. */
|
||||||
static int lsb_to_buf(char **wpt, int value, int bits, int flag)
|
static int lsb_to_buf(char **wpt, uint32_t value, int bits, int flag)
|
||||||
{
|
{
|
||||||
int b;
|
int b;
|
||||||
|
|
||||||
@ -61,6 +68,11 @@ static int lsb_to_buf(char **wpt, int value, int bits, int flag)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ====================================================================== */
|
||||||
|
/* Deprecated Function */
|
||||||
|
/* ====================================================================== */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a MBR for an isohybrid enabled ISOLINUX boot image.
|
* Create a MBR for an isohybrid enabled ISOLINUX boot image.
|
||||||
*
|
*
|
||||||
@ -228,3 +240,214 @@ int make_isohybrid_mbr(int bin_lba, int *img_blocks, char *mbr, int flag)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ====================================================================== */
|
||||||
|
/* The New MBR Producer */
|
||||||
|
/* ====================================================================== */
|
||||||
|
|
||||||
|
/* The new MBR producer for isohybrid is a slightly generalized version of
|
||||||
|
the deprecated function make_isohybrid_mbr(). It complies to the urge
|
||||||
|
of H.Peter Anvin not to hardcode MBR templates but rather to read a
|
||||||
|
file from the Syslinux tree, and to patch it as was done with the old
|
||||||
|
MBR producer.
|
||||||
|
|
||||||
|
The old algorithm was clarified publicly by the following mail.
|
||||||
|
Changes towards the old algorithm:
|
||||||
|
- 512-byte LBA of boot image is extended to 64 bit (we stay with 32)
|
||||||
|
- check for a magic number is now gone
|
||||||
|
|
||||||
|
The new implementation tries to use similar terms as the mail in order
|
||||||
|
to facilitate its future discussion with Syslinux developers.
|
||||||
|
|
||||||
|
From hpa@zytor.com Thu Apr 1 08:32:52 2010
|
||||||
|
Date: Wed, 31 Mar 2010 14:53:51 -0700
|
||||||
|
From: H. Peter Anvin <hpa@zytor.com>
|
||||||
|
To: For discussion of Syslinux and tftp-hpa <syslinux@zytor.com>
|
||||||
|
Cc: Thomas Schmitt <scdbackup@gmx.net>
|
||||||
|
Subject: Re: [syslinux] port syslinux isohybrid perl script to C
|
||||||
|
|
||||||
|
[...]
|
||||||
|
|
||||||
|
[me:]
|
||||||
|
> Currently i lack of blob and prescriptions.
|
||||||
|
|
||||||
|
The blobs are available in the Syslinux build tree under the names:
|
||||||
|
|
||||||
|
mbr/isohdp[fp]x*.bin
|
||||||
|
|
||||||
|
The default probably should be mbr/isohdppx.bin, but it's ultimately up
|
||||||
|
to the user.
|
||||||
|
|
||||||
|
User definable parameters:
|
||||||
|
|
||||||
|
-> MBR ID (default random 32-bit number,
|
||||||
|
or preserved from previous instance)
|
||||||
|
-> Sector count (default 32, range 1-63)
|
||||||
|
-> Head count (default 64, range 1-256)
|
||||||
|
-> Partition offset (default 0, range 0-64)
|
||||||
|
-> Partition number (default 1, range 1-4)
|
||||||
|
-> Filesystem type (default 0x17, range 1-255)
|
||||||
|
|
||||||
|
Note: the filesystem type is largely arbitrary, in theory it can be any
|
||||||
|
value other than 0x00, 0x05, 0x0f, 0x85, 0xee, or 0xef. 0x17 ("Windows
|
||||||
|
IFS Hidden") seems safeish, some people believe 0x83 (Linux) is better.
|
||||||
|
|
||||||
|
Here is the prescriptions for how to install it:
|
||||||
|
|
||||||
|
All numbers are littleendian. "word" means 16 bits, "dword" means 32
|
||||||
|
bits, "qword" means 64 bits.
|
||||||
|
|
||||||
|
Common subroutine LBA_to_CHS():
|
||||||
|
s = (lba % sector_count) + 1
|
||||||
|
t = (lba / sector_count)
|
||||||
|
h = (t % head_count)
|
||||||
|
c = (t / head_count)
|
||||||
|
|
||||||
|
if (c >= 1024):
|
||||||
|
c = 1023
|
||||||
|
h = head_count
|
||||||
|
s = sector_count
|
||||||
|
|
||||||
|
s = s | ((c & 0x300) >> 2)
|
||||||
|
c = c & 0xff
|
||||||
|
|
||||||
|
write byte h
|
||||||
|
write byte s
|
||||||
|
write byte c
|
||||||
|
|
||||||
|
Main:
|
||||||
|
Pad image_size to a multiple of sector_count*head_count
|
||||||
|
Use the input file unmodified for bytes 0..431
|
||||||
|
write qword boot_lba # Offset 432
|
||||||
|
write dword mbr_id # Offset 440
|
||||||
|
write word 0 # Offset 444
|
||||||
|
|
||||||
|
# Offset 446
|
||||||
|
For each partition entry 1..4:
|
||||||
|
if this_partition != partition_number:
|
||||||
|
write 16 zero bytes
|
||||||
|
else:
|
||||||
|
write byte 0x80
|
||||||
|
write LBA_to_CHS(partition_offset)
|
||||||
|
write byte filesystem_type
|
||||||
|
write LBA_to_CHS(image_size-1)
|
||||||
|
write dword partition_offset
|
||||||
|
write dword image_size
|
||||||
|
|
||||||
|
# Offset 510
|
||||||
|
write word 0xaa55
|
||||||
|
|
||||||
|
Use the input file unmodified for bytes 512..32767
|
||||||
|
(pad with zero as necessary)
|
||||||
|
|
||||||
|
[...]
|
||||||
|
|
||||||
|
-hpa
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
static
|
||||||
|
int lba512chs_to_buf(char **wpt, off_t lba, int head_count, int sector_count)
|
||||||
|
{
|
||||||
|
int s, t, h, c;
|
||||||
|
|
||||||
|
s = (lba % sector_count) + 1;
|
||||||
|
t = (lba / sector_count);
|
||||||
|
h = (t % head_count);
|
||||||
|
c = (t / head_count);
|
||||||
|
if (c >= 1024) {
|
||||||
|
c = 1023;
|
||||||
|
h = head_count; /* >>> not -1 ? Limits head_count to 255 */
|
||||||
|
s = sector_count;
|
||||||
|
}
|
||||||
|
s = s | ((c & 0x300) >> 2);
|
||||||
|
c = c & 0xff;
|
||||||
|
(*((unsigned char **) wpt))[0] = h;
|
||||||
|
(*((unsigned char **) wpt))[1] = s;
|
||||||
|
(*((unsigned char **) wpt))[2] = c;
|
||||||
|
(*wpt)+= 3;
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @param flag bit0= make own random MBR Id from current time
|
||||||
|
*/
|
||||||
|
int make_isolinux_mbr(int32_t *img_blocks, uint32_t boot_lba,
|
||||||
|
uint32_t mbr_id, int head_count, int sector_count,
|
||||||
|
int part_offset, int part_number, int fs_type,
|
||||||
|
uint8_t *buf, int flag)
|
||||||
|
{
|
||||||
|
uint32_t spc, id, part, nominal_part_size;
|
||||||
|
off_t hd_img_blocks, hd_boot_lba;
|
||||||
|
char *wpt;
|
||||||
|
/* For generating a weak random number */
|
||||||
|
struct timeval tv;
|
||||||
|
struct timezone tz;
|
||||||
|
|
||||||
|
/* Pad image_size to a multiple of sector_count*head_count
|
||||||
|
*/
|
||||||
|
spc = head_count * sector_count;
|
||||||
|
hd_img_blocks = ((off_t) *img_blocks) * (off_t) 4;
|
||||||
|
if (hd_img_blocks % spc) {
|
||||||
|
hd_img_blocks += spc - (hd_img_blocks % spc);
|
||||||
|
*img_blocks = hd_img_blocks / 4 + !!(hd_img_blocks % 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
wpt = (char *) buf + 432;
|
||||||
|
|
||||||
|
/* write qword boot_lba # Offset 432
|
||||||
|
*/
|
||||||
|
hd_boot_lba = ((off_t) boot_lba) * (off_t) 4;
|
||||||
|
lsb_to_buf(&wpt, hd_boot_lba & 0xffffffff, 32, 0);
|
||||||
|
lsb_to_buf(&wpt, hd_boot_lba >> 32, 32, 0);
|
||||||
|
|
||||||
|
/* write dword mbr_id # Offset 440
|
||||||
|
(here some 32-bit random value with no crypto strength)
|
||||||
|
*/
|
||||||
|
if (flag & 1) {
|
||||||
|
gettimeofday(&tv, &tz);
|
||||||
|
id = 0xffffffff & (tv.tv_sec ^ (tv.tv_usec * 2000));
|
||||||
|
lsb_to_buf(&wpt, id, 32, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* write word 0 # Offset 444
|
||||||
|
*/
|
||||||
|
lsb_to_buf(&wpt, 0, 16, 0);
|
||||||
|
|
||||||
|
/* # Offset 446
|
||||||
|
*/
|
||||||
|
for (part = 1 ; part <= 4; part++) {
|
||||||
|
if (part != part_number) {
|
||||||
|
/* if this_partition != partition_number: write 16 zero bytes */
|
||||||
|
memset(wpt, 0, 16);
|
||||||
|
wpt+= 16;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/* write byte 0x80
|
||||||
|
write LBA_to_CHS(partition_offset)
|
||||||
|
write byte filesystem_type
|
||||||
|
write LBA_to_CHS(image_size-1)
|
||||||
|
write dword partition_offset
|
||||||
|
write dword image_size
|
||||||
|
*/
|
||||||
|
lsb_to_buf(&wpt, 0x80, 8, 0);
|
||||||
|
lba512chs_to_buf(&wpt, part_offset, head_count, sector_count);
|
||||||
|
lsb_to_buf(&wpt, fs_type, 8, 0);
|
||||||
|
lba512chs_to_buf(&wpt, hd_img_blocks - 1, head_count, sector_count);
|
||||||
|
lsb_to_buf(&wpt, part_offset, 32, 0);
|
||||||
|
if (hd_img_blocks - (off_t) part_offset > (off_t) 0xffffffff)
|
||||||
|
nominal_part_size = 0xffffffff;
|
||||||
|
else
|
||||||
|
nominal_part_size = hd_img_blocks - (off_t) part_offset;
|
||||||
|
lsb_to_buf(&wpt, nominal_part_size, 32, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* write word 0xaa55 # Offset 510
|
||||||
|
*/
|
||||||
|
lsb_to_buf(&wpt, 0xaa55, 16, 0);
|
||||||
|
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
131
libisofs/md5.c
131
libisofs/md5.c
@ -2,11 +2,16 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -429,8 +434,6 @@ int checksum_md5_xinfo_func(void *data, int flag)
|
|||||||
|
|
||||||
/* MD5 checksum image writer */
|
/* MD5 checksum image writer */
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@flag bit0= recursion
|
@flag bit0= recursion
|
||||||
bit1= session will be appended to an existing image
|
bit1= session will be appended to an existing image
|
||||||
@ -507,15 +510,10 @@ int checksum_copy_old_nodes(Ecma119Image *target, IsoNode *node, int flag)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
|
||||||
static
|
static
|
||||||
int checksum_writer_compute_data_blocks(IsoImageWriter *writer)
|
int checksum_writer_compute_data_blocks(IsoImageWriter *writer)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
size_t size;
|
size_t size;
|
||||||
Ecma119Image *t;
|
Ecma119Image *t;
|
||||||
int ret;
|
int ret;
|
||||||
@ -556,9 +554,6 @@ int checksum_writer_compute_data_blocks(IsoImageWriter *writer)
|
|||||||
t->checksum_idx_counter + 2, 16, "MD5", 0);
|
t->checksum_idx_counter + 2, 16, "MD5", 0);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -579,9 +574,6 @@ int checksum_writer_write_vol_desc(IsoImageWriter *writer)
|
|||||||
static
|
static
|
||||||
int checksum_writer_write_data(IsoImageWriter *writer)
|
int checksum_writer_write_data(IsoImageWriter *writer)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
int wres, res;
|
int wres, res;
|
||||||
size_t i, size;
|
size_t i, size;
|
||||||
Ecma119Image *t;
|
Ecma119Image *t;
|
||||||
@ -648,12 +640,6 @@ ex:;
|
|||||||
if (ctx != NULL)
|
if (ctx != NULL)
|
||||||
iso_md5_end(&ctx, md5);
|
iso_md5_end(&ctx, md5);
|
||||||
return(res);
|
return(res);
|
||||||
|
|
||||||
#else /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
|
||||||
|
|
||||||
#endif /* ! Libisofs_with_checksumS */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -683,21 +669,69 @@ int checksum_writer_create(Ecma119Image *target)
|
|||||||
|
|
||||||
/* add this writer to image */
|
/* add this writer to image */
|
||||||
target->writers[target->nwriters++] = writer;
|
target->writers[target->nwriters++] = writer;
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
/* Account for superblock checksum tag */
|
/* Account for superblock checksum tag */
|
||||||
if (target->md5_session_checksum) {
|
if (target->md5_session_checksum) {
|
||||||
target->checksum_sb_tag_pos = target->curblock;
|
target->checksum_sb_tag_pos = target->curblock;
|
||||||
target->curblock++;
|
target->curblock++;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static
|
||||||
|
int iso_md5_write_scdbackup_tag(Ecma119Image *t, char *tag_block, int flag)
|
||||||
|
{
|
||||||
|
void *ctx = NULL;
|
||||||
|
off_t pos = 0, line_start;
|
||||||
|
int record_len, block_len, res, i;
|
||||||
|
char postext[40], md5[16], record[160];
|
||||||
|
|
||||||
|
line_start = strlen(tag_block);
|
||||||
|
iso_md5_compute(t->checksum_ctx, tag_block, line_start);
|
||||||
|
res = iso_md5_clone(t->checksum_ctx, &ctx);
|
||||||
|
if (res < 0)
|
||||||
|
goto ex;
|
||||||
|
res = iso_md5_end(&ctx, md5);
|
||||||
|
|
||||||
|
pos = (off_t) t->checksum_tag_pos * (off_t) 2048 + line_start;
|
||||||
|
if(pos >= 1000000000)
|
||||||
|
sprintf(postext, "%u%9.9u", (unsigned int) (pos / 1000000000),
|
||||||
|
(unsigned int) (pos % 1000000000));
|
||||||
|
else
|
||||||
|
sprintf(postext, "%u", (unsigned int) pos);
|
||||||
|
sprintf(record, "%s %s ", t->scdbackup_tag_parm, postext);
|
||||||
|
record_len = strlen(record);
|
||||||
|
for (i = 0; i < 16; i++)
|
||||||
|
sprintf(record + record_len + 2 * i,
|
||||||
|
"%2.2x", ((unsigned char *) md5)[i]);
|
||||||
|
record_len += 32;
|
||||||
|
|
||||||
|
res = iso_md5_start(&ctx);
|
||||||
|
if (res < 0)
|
||||||
|
goto ex;
|
||||||
|
iso_md5_compute(ctx, record, record_len);
|
||||||
|
iso_md5_end(&ctx, md5);
|
||||||
|
|
||||||
|
sprintf(tag_block + line_start, "scdbackup_checksum_tag_v0.1 %s %d %s ",
|
||||||
|
postext, record_len, record);
|
||||||
|
block_len = strlen(tag_block);
|
||||||
|
for (i = 0; i < 16; i++)
|
||||||
|
sprintf(tag_block + block_len + 2 * i,
|
||||||
|
"%2.2x", ((unsigned char *) md5)[i]);
|
||||||
|
block_len+= 32;
|
||||||
|
tag_block[block_len++]= '\n';
|
||||||
|
|
||||||
|
if (t->scdbackup_tag_written != NULL)
|
||||||
|
strncpy(t->scdbackup_tag_written, tag_block + line_start,
|
||||||
|
block_len - line_start);
|
||||||
|
res = ISO_SUCCESS;
|
||||||
|
ex:;
|
||||||
|
if (ctx != NULL)
|
||||||
|
iso_md5_end(&ctx, md5);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Write stream detectable checksum tag to extra block.
|
/* Write stream detectable checksum tag to extra block.
|
||||||
* @flag bit0-7= tag type
|
* @flag bit0-7= tag type
|
||||||
* 1= session tag (End checksumming.)
|
* 1= session tag (End checksumming.)
|
||||||
@ -708,9 +742,6 @@ int checksum_writer_create(Ecma119Image *target)
|
|||||||
*/
|
*/
|
||||||
int iso_md5_write_tag(Ecma119Image *t, int flag)
|
int iso_md5_write_tag(Ecma119Image *t, int flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
int res, mode, l, i, wres, tag_id_len;
|
int res, mode, l, i, wres, tag_id_len;
|
||||||
void *ctx = NULL;
|
void *ctx = NULL;
|
||||||
char md5[16], tag_block[2048], *tag_id;
|
char md5[16], tag_block[2048], *tag_id;
|
||||||
@ -719,11 +750,16 @@ int iso_md5_write_tag(Ecma119Image *t, int flag)
|
|||||||
start = t->checksum_range_start;
|
start = t->checksum_range_start;
|
||||||
memset(tag_block, 0, 2048);
|
memset(tag_block, 0, 2048);
|
||||||
mode = flag & 255;
|
mode = flag & 255;
|
||||||
|
if (mode < 1 || mode > 4)
|
||||||
|
return ISO_WRONG_ARG_VALUE;
|
||||||
|
res = iso_md5_clone(t->checksum_ctx, &ctx);
|
||||||
|
if (res < 0)
|
||||||
|
return res;
|
||||||
|
res = iso_md5_end(&ctx, md5);
|
||||||
if (mode == 1) {
|
if (mode == 1) {
|
||||||
res = iso_md5_end(&(t->checksum_ctx), md5);
|
|
||||||
size = t->checksum_range_size;
|
size = t->checksum_range_size;
|
||||||
pos = t->checksum_tag_pos;
|
pos = t->checksum_tag_pos;
|
||||||
} else if (mode >= 2 && mode <= 4) {
|
} else {
|
||||||
if (mode == 2) {
|
if (mode == 2) {
|
||||||
pos = t->checksum_sb_tag_pos;
|
pos = t->checksum_sb_tag_pos;
|
||||||
} else if (mode == 3) {
|
} else if (mode == 3) {
|
||||||
@ -733,17 +769,12 @@ int iso_md5_write_tag(Ecma119Image *t, int flag)
|
|||||||
start = pos - (pos % 32);
|
start = pos - (pos % 32);
|
||||||
}
|
}
|
||||||
size = pos - start;
|
size = pos - start;
|
||||||
res = iso_md5_clone(t->checksum_ctx, &ctx);
|
|
||||||
if (res < 0)
|
|
||||||
return res;
|
|
||||||
res = iso_md5_end(&ctx, md5);
|
|
||||||
} else {
|
|
||||||
return ISO_WRONG_ARG_VALUE;
|
|
||||||
}
|
}
|
||||||
if (res > 0) {
|
if (res < 0)
|
||||||
|
goto ex;
|
||||||
|
|
||||||
iso_util_tag_magic(mode, &tag_id, &tag_id_len, 0);
|
iso_util_tag_magic(mode, &tag_id, &tag_id_len, 0);
|
||||||
sprintf(tag_block,
|
sprintf(tag_block, "%s pos=%u range_start=%u range_size=%u",
|
||||||
"%s pos=%u range_start=%u range_size=%u",
|
|
||||||
tag_id, pos, start, size);
|
tag_id, pos, start, size);
|
||||||
|
|
||||||
l = strlen(tag_block);
|
l = strlen(tag_block);
|
||||||
@ -772,7 +803,17 @@ int iso_md5_write_tag(Ecma119Image *t, int flag)
|
|||||||
((unsigned char *) md5)[i]);
|
((unsigned char *) md5)[i]);
|
||||||
}
|
}
|
||||||
tag_block[l + 32] = '\n';
|
tag_block[l + 32] = '\n';
|
||||||
|
|
||||||
|
if (mode == 1 && t->scdbackup_tag_parm[0]) {
|
||||||
|
if (t->ms_block > 0) {
|
||||||
|
iso_msg_submit(t->image->id, ISO_SCDBACKUP_TAG_NOT_0, 0, NULL);
|
||||||
|
} else {
|
||||||
|
res = iso_md5_write_scdbackup_tag(t, tag_block, 0);
|
||||||
|
if (res < 0)
|
||||||
|
goto ex;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (mode == 4) {
|
if (mode == 4) {
|
||||||
if (t->opts_overwrite != NULL)
|
if (t->opts_overwrite != NULL)
|
||||||
memcpy(t->opts_overwrite + pos * 2048, tag_block, 2048);
|
memcpy(t->opts_overwrite + pos * 2048, tag_block, 2048);
|
||||||
@ -783,18 +824,12 @@ int iso_md5_write_tag(Ecma119Image *t, int flag)
|
|||||||
goto ex;
|
goto ex;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
res = ISO_SUCCESS;
|
res = ISO_SUCCESS;
|
||||||
ex:;
|
ex:;
|
||||||
if (ctx != NULL)
|
if (ctx != NULL)
|
||||||
iso_md5_end(&ctx, md5);
|
iso_md5_end(&ctx, md5);
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
#else /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
return ISO_SUCCESS;
|
|
||||||
|
|
||||||
#endif /* ! Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_MD5_H_
|
#ifndef LIBISO_MD5_H_
|
||||||
|
@ -2,9 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -152,6 +158,8 @@ const char *iso_error_to_msg(int errcode)
|
|||||||
return "Try to set the boot image of an already bootable image";
|
return "Try to set the boot image of an already bootable image";
|
||||||
case ISO_BOOT_IMAGE_NOT_VALID:
|
case ISO_BOOT_IMAGE_NOT_VALID:
|
||||||
return "Trying to use an invalid file as boot image";
|
return "Trying to use an invalid file as boot image";
|
||||||
|
case ISO_BOOT_IMAGE_OVERFLOW:
|
||||||
|
return "Too many boot images added";
|
||||||
case ISO_FILE_ERROR:
|
case ISO_FILE_ERROR:
|
||||||
return "Error on file operation";
|
return "Error on file operation";
|
||||||
case ISO_FILE_ALREADY_OPENED:
|
case ISO_FILE_ALREADY_OPENED:
|
||||||
@ -274,6 +282,10 @@ const char *iso_error_to_msg(int errcode)
|
|||||||
return "Checksum tag with unexpected address range encountered";
|
return "Checksum tag with unexpected address range encountered";
|
||||||
case ISO_MD5_STREAM_CHANGE:
|
case ISO_MD5_STREAM_CHANGE:
|
||||||
return "Detected file content changes while it was written into the image";
|
return "Detected file content changes while it was written into the image";
|
||||||
|
case ISO_SCDBACKUP_TAG_NOT_0:
|
||||||
|
return "Session does not start at LBA 0. scdbackup checksum tag not written.";
|
||||||
|
case ISO_BOOT_NO_CATALOG:
|
||||||
|
return "No boot catalog created yet";
|
||||||
default:
|
default:
|
||||||
return "Unknown error";
|
return "Unknown error";
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "image.h"
|
#include "image.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
@ -22,6 +27,12 @@
|
|||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
struct dir_iter_data
|
struct dir_iter_data
|
||||||
{
|
{
|
||||||
/* points to the last visited child, to NULL before start */
|
/* points to the last visited child, to NULL before start */
|
||||||
@ -201,6 +212,7 @@ int iso_node_get_xinfo(IsoNode *node, iso_node_xinfo_func proc, void **data)
|
|||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*data = NULL;
|
||||||
pos = node->xinfo;
|
pos = node->xinfo;
|
||||||
while (pos != NULL) {
|
while (pos != NULL) {
|
||||||
if (pos->process == proc) {
|
if (pos->process == proc) {
|
||||||
@ -420,6 +432,12 @@ void iso_node_set_hidden(IsoNode *node, int hide_attrs)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int iso_node_get_hidden(IsoNode *node)
|
||||||
|
{
|
||||||
|
return node->hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a new node to a dir. Note that this function don't add a new ref to
|
* Add a new node to a dir. Note that this function don't add a new ref to
|
||||||
* the node, so you don't need to free it, it will be automatically freed
|
* the node, so you don't need to free it, it will be automatically freed
|
||||||
@ -1276,6 +1294,7 @@ int iso_node_new_file(char *name, IsoStream *stream, IsoFile **file)
|
|||||||
new->node.type = LIBISO_FILE;
|
new->node.type = LIBISO_FILE;
|
||||||
new->node.name = name;
|
new->node.name = name;
|
||||||
new->node.mode = S_IFREG;
|
new->node.mode = S_IFREG;
|
||||||
|
new->sort_weight = 0;
|
||||||
new->stream = stream;
|
new->stream = stream;
|
||||||
|
|
||||||
*file = new;
|
*file = new;
|
||||||
@ -2651,9 +2670,6 @@ ex:;
|
|||||||
/* API */
|
/* API */
|
||||||
int iso_file_get_md5(IsoImage *image, IsoFile *file, char md5[16], int flag)
|
int iso_file_get_md5(IsoImage *image, IsoFile *file, char md5[16], int flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
int ret, i;
|
int ret, i;
|
||||||
size_t value_len;
|
size_t value_len;
|
||||||
char *value = NULL;
|
char *value = NULL;
|
||||||
@ -2693,21 +2709,12 @@ ex:;
|
|||||||
if (value != NULL)
|
if (value != NULL)
|
||||||
free(value);
|
free(value);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
#endif /* ! Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* API */
|
/* API */
|
||||||
int iso_file_make_md5(IsoFile *file, int flag)
|
int iso_file_make_md5(IsoFile *file, int flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
int ret, dig = 0;
|
int ret, dig = 0;
|
||||||
char *md5 = NULL;
|
char *md5 = NULL;
|
||||||
|
|
||||||
@ -2728,13 +2735,6 @@ int iso_file_make_md5(IsoFile *file, int flag)
|
|||||||
ret = 1;
|
ret = 1;
|
||||||
ex:;
|
ex:;
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
return ISO_ERROR;
|
|
||||||
|
|
||||||
#endif /* ! Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_NODE_H_
|
#ifndef LIBISO_NODE_H_
|
||||||
#define LIBISO_NODE_H_
|
#define LIBISO_NODE_H_
|
||||||
|
@ -4,10 +4,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "rockridge.h"
|
#include "rockridge.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
#include "ecma119_tree.h"
|
#include "ecma119_tree.h"
|
||||||
@ -108,12 +113,12 @@ int rrip_add_PX(Ecma119Image *t, Ecma119Node *n, struct susp_info *susp)
|
|||||||
PX[2] = 36;
|
PX[2] = 36;
|
||||||
}
|
}
|
||||||
PX[3] = 1;
|
PX[3] = 1;
|
||||||
iso_bb(&PX[4], px_get_mode(t, n), 4);
|
iso_bb(&PX[4], (uint32_t) px_get_mode(t, n), 4);
|
||||||
iso_bb(&PX[12], n->nlink, 4);
|
iso_bb(&PX[12], (uint32_t) n->nlink, 4);
|
||||||
iso_bb(&PX[20], px_get_uid(t, n), 4);
|
iso_bb(&PX[20], (uint32_t) px_get_uid(t, n), 4);
|
||||||
iso_bb(&PX[28], px_get_gid(t, n), 4);
|
iso_bb(&PX[28], (uint32_t) px_get_gid(t, n), 4);
|
||||||
if (t->rrip_1_10_px_ino || !t->rrip_version_1_10) {
|
if (t->rrip_1_10_px_ino || !t->rrip_version_1_10) {
|
||||||
iso_bb(&PX[36], n->ino, 4);
|
iso_bb(&PX[36], (uint32_t) n->ino, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
return susp_append(t, susp, PX);
|
return susp_append(t, susp, PX);
|
||||||
@ -242,10 +247,10 @@ int rrip_add_PN(Ecma119Image *t, Ecma119Node *n, struct susp_info *susp)
|
|||||||
*/
|
*/
|
||||||
if (sizeof(node->dev) > 4) {
|
if (sizeof(node->dev) > 4) {
|
||||||
high_shift = 32;
|
high_shift = 32;
|
||||||
iso_bb(&PN[4], node->dev >> high_shift, 4);
|
iso_bb(&PN[4], (uint32_t) (node->dev >> high_shift), 4);
|
||||||
} else
|
} else
|
||||||
iso_bb(&PN[4], 0, 4);
|
iso_bb(&PN[4], 0, 4);
|
||||||
iso_bb(&PN[12], node->dev & 0xffffffff, 4);
|
iso_bb(&PN[12], (uint32_t) (node->dev & 0xffffffff), 4);
|
||||||
return susp_append(t, susp, PN);
|
return susp_append(t, susp, PN);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -694,7 +699,7 @@ int susp_add_CE(Ecma119Image *t, size_t ce_len, struct susp_info *susp)
|
|||||||
CE[3] = 1;
|
CE[3] = 1;
|
||||||
iso_bb(&CE[4], susp->ce_block, 4);
|
iso_bb(&CE[4], susp->ce_block, 4);
|
||||||
iso_bb(&CE[12], susp->ce_len, 4);
|
iso_bb(&CE[12], susp->ce_len, 4);
|
||||||
iso_bb(&CE[20], ce_len, 4);
|
iso_bb(&CE[20], (uint32_t) ce_len, 4);
|
||||||
|
|
||||||
return susp_append(t, susp, CE);
|
return susp_append(t, susp, CE);
|
||||||
}
|
}
|
||||||
|
@ -4,8 +4,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -12,6 +13,10 @@
|
|||||||
* Rock Ridge and AAIP extensions on an ECMA-119 image.
|
* Rock Ridge and AAIP extensions on an ECMA-119 image.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "ecma119.h"
|
#include "ecma119.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
@ -302,7 +307,7 @@ int read_rr_NM(struct susp_sys_user_entry *nm, char **name, int *cont)
|
|||||||
*name = realloc(*name, strlen(*name) + nm->len_sue[0] - 5 + 1);
|
*name = realloc(*name, strlen(*name) + nm->len_sue[0] - 5 + 1);
|
||||||
strncat(*name, (char*)nm->data.NM.name, nm->len_sue[0] - 5);
|
strncat(*name, (char*)nm->data.NM.name, nm->len_sue[0] - 5);
|
||||||
} else {
|
} else {
|
||||||
*name = strcopy((char*)nm->data.NM.name, nm->len_sue[0] - 5);
|
*name = iso_util_strcopy((char*)nm->data.NM.name, nm->len_sue[0] - 5);
|
||||||
}
|
}
|
||||||
if (*name == NULL) {
|
if (*name == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
@ -380,7 +385,7 @@ int read_rr_SL(struct susp_sys_user_entry *sl, char **dest, int *cont)
|
|||||||
/* we don't have to add the '/' */
|
/* we don't have to add the '/' */
|
||||||
strncat(*dest, comp, len);
|
strncat(*dest, comp, len);
|
||||||
} else {
|
} else {
|
||||||
*dest = strcopy(comp, len);
|
*dest = iso_util_strcopy(comp, len);
|
||||||
}
|
}
|
||||||
if (*dest == NULL) {
|
if (*dest == NULL) {
|
||||||
return ISO_OUT_OF_MEM;
|
return ISO_OUT_OF_MEM;
|
||||||
|
@ -3,10 +3,15 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "stream.h"
|
#include "stream.h"
|
||||||
#include "fsource.h"
|
#include "fsource.h"
|
||||||
@ -17,6 +22,12 @@
|
|||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
ino_t serial_id = (ino_t)1;
|
ino_t serial_id = (ino_t)1;
|
||||||
ino_t mem_serial_id = (ino_t)1;
|
ino_t mem_serial_id = (ino_t)1;
|
||||||
ino_t cut_out_serial_id = (ino_t)1;
|
ino_t cut_out_serial_id = (ino_t)1;
|
||||||
@ -857,9 +868,6 @@ int iso_stream_read_buffer(IsoStream *stream, char *buf, size_t count,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef Libisofs_with_checksumS
|
|
||||||
|
|
||||||
|
|
||||||
/* @param flag bit0= dig out most original stream (e.g. because from old image)
|
/* @param flag bit0= dig out most original stream (e.g. because from old image)
|
||||||
@return 1=ok, md5 is valid,
|
@return 1=ok, md5 is valid,
|
||||||
0= not ok,
|
0= not ok,
|
||||||
@ -916,6 +924,3 @@ ex:;
|
|||||||
iso_md5_end(&ctx, md5);
|
iso_md5_end(&ctx, md5);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* Libisofs_with_checksumS */
|
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
* Copyright (c) 2009 Thomas Schmitt
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_STREAM_H_
|
#ifndef LIBISO_STREAM_H_
|
||||||
#define LIBISO_STREAM_H_
|
#define LIBISO_STREAM_H_
|
||||||
|
@ -1,38 +1,130 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2008 Vreixo Formoso
|
* Copyright (c) 2008 Vreixo Formoso
|
||||||
|
* Copyright (c) 2010 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "system_area.h"
|
#include "system_area.h"
|
||||||
#include "eltorito.h"
|
#include "eltorito.h"
|
||||||
#include "filesrc.h"
|
#include "filesrc.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a MBR for an isohybrid enabled ISOLINUX boot image.
|
* Create a MBR for an isohybrid enabled ISOLINUX boot image.
|
||||||
*
|
* See libisofs/make_isohybrid_mbr.c
|
||||||
* It is assumed that the caller has verified the readiness of the boot image
|
* Deprecated.
|
||||||
* by checking for 0xfb 0xc0 0x78 0x70 at bytes 0x40 to 0x43 of isolinux.bin.
|
|
||||||
*
|
|
||||||
* @param bin_lba The predicted LBA of isolinux.bin within the emerging ISO.
|
|
||||||
* @param img_blocks The predicted number of 2048 byte blocks in the ISO.
|
|
||||||
* It will get rounded up to full MBs and that many blocks
|
|
||||||
* must really be written as ISO 9660 image.
|
|
||||||
* @param mbr A buffer of at least 512 bytes to take the result which is
|
|
||||||
* to be written as the very beginning of the ISO.
|
|
||||||
* @param flag unused yet, submit 0
|
|
||||||
* @return <0 = fatal, 0 = failed , 1 = ok , 2 = ok with size warning
|
|
||||||
*/
|
*/
|
||||||
int make_isohybrid_mbr(int bin_lba, int *img_blocks, char *mbr, int flag);
|
int make_isohybrid_mbr(int bin_lba, int *img_blocks, char *mbr, int flag);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The New ISOLINUX MBR Producer.
|
||||||
|
* Be cautious with changing parameters. Only few combinations are tested.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
int make_isolinux_mbr(int32_t *img_blocks, uint32_t boot_lba,
|
||||||
|
uint32_t mbr_id, int head_count, int sector_count,
|
||||||
|
int part_offset, int part_number, int fs_type,
|
||||||
|
uint8_t *buf, int flag);
|
||||||
|
|
||||||
|
|
||||||
|
/* This is the gesture of grub-mkisofs --protective-msdos-label as explained by
|
||||||
|
Vladimir Serbinenko <phcoder@gmail.com>, 2 April 2010, on grub-devel@gnu.org
|
||||||
|
"Currently we use first and not last entry. You need to:
|
||||||
|
1) Zero-fill 446-510
|
||||||
|
2) Put 0x55, 0xAA into 510-512
|
||||||
|
3) Put 0x80 (for bootable partition), 0, 2, 0 (C/H/S of the start), 0xcd
|
||||||
|
(partition type), [3 bytes of C/H/S end], 0x01, 0x00, 0x00, 0x00 (LBA
|
||||||
|
start in little endian), [LBA end in little endian] at 446-462
|
||||||
|
"
|
||||||
|
|
||||||
|
"C/H/S end" means the CHS address of the last block in the partition.
|
||||||
|
It seems that not "[LBA end in little endian]" but "number of blocks"
|
||||||
|
should go into bytes 458-461. But with a start lba of 1, this is the
|
||||||
|
same number.
|
||||||
|
See also http://en.wikipedia.org/wiki/Master_boot_record
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
int make_grub_msdos_label(int img_blocks, uint8_t *buf, int flag)
|
||||||
|
{
|
||||||
|
uint8_t *wpt;
|
||||||
|
unsigned long end_lba, secs, end_sec, end_head, end_cyl;
|
||||||
|
int sph = 63, hpc = 255, i;
|
||||||
|
|
||||||
|
/* Partition table unit is 512 bytes per sector, ECMA-119 unit is 2048 */
|
||||||
|
if (img_blocks >= 0x40000000)
|
||||||
|
img_blocks = 0x40000000 - 1; /* truncate rather than roll over */
|
||||||
|
secs = end_lba = img_blocks * 4 - 1; /* last valid 512-lba */
|
||||||
|
end_cyl = secs / (sph * hpc);
|
||||||
|
secs -= end_cyl * sph * hpc;
|
||||||
|
end_head = secs / sph;
|
||||||
|
end_sec = secs - end_head * sph + 1; /* Sector count starts by 1 */
|
||||||
|
if (end_cyl >= 1024) {
|
||||||
|
end_cyl = 1023;
|
||||||
|
end_head = hpc - 1;
|
||||||
|
end_sec = sph;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 1) Zero-fill 446-510 */
|
||||||
|
wpt = buf + 446;
|
||||||
|
memset(wpt, 0, 64);
|
||||||
|
|
||||||
|
/* 2) Put 0x55, 0xAA into 510-512 (actually 510-511) */
|
||||||
|
buf[510] = 0x55;
|
||||||
|
buf[511] = 0xAA;
|
||||||
|
|
||||||
|
/* 3) Put 0x80 (for bootable partition), */
|
||||||
|
*(wpt++) = 0x80;
|
||||||
|
|
||||||
|
/* 0, 2, 0 (C/H/S of the start), */
|
||||||
|
*(wpt++) = 0;
|
||||||
|
*(wpt++) = 2;
|
||||||
|
*(wpt++) = 0;
|
||||||
|
|
||||||
|
/* 0xcd (partition type) */
|
||||||
|
*(wpt++) = 0xcd;
|
||||||
|
|
||||||
|
/* [3 bytes of C/H/S end], */
|
||||||
|
*(wpt++) = end_head;
|
||||||
|
*(wpt++) = end_sec | ((end_cyl & 0x300) >> 2);
|
||||||
|
*(wpt++) = end_cyl & 0xff;
|
||||||
|
|
||||||
|
|
||||||
|
/* 0x01, 0x00, 0x00, 0x00 (LBA start in little endian), */
|
||||||
|
*(wpt++) = 0x01;
|
||||||
|
*(wpt++) = 0x00;
|
||||||
|
*(wpt++) = 0x00;
|
||||||
|
*(wpt++) = 0x00;
|
||||||
|
|
||||||
|
/* [LBA end in little endian] */
|
||||||
|
for (i = 0; i < 4; i++)
|
||||||
|
*(wpt++) = (end_lba >> (8 * i)) & 0xff;
|
||||||
|
|
||||||
|
/* at 446-462 */
|
||||||
|
if (wpt - buf != 462) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"libisofs: program error in make_grub_msdos_label: \"assert 462\"\n");
|
||||||
|
return ISO_ASSERT_FAILURE;
|
||||||
|
}
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int iso_write_system_area(Ecma119Image *t, uint8_t *buf)
|
int iso_write_system_area(Ecma119Image *t, uint8_t *buf)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
int img_blocks;
|
||||||
|
|
||||||
if ((t == NULL) || (buf == NULL)) {
|
if ((t == NULL) || (buf == NULL)) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
}
|
}
|
||||||
@ -40,26 +132,41 @@ int iso_write_system_area(Ecma119Image *t, uint8_t *buf)
|
|||||||
/* set buf to 0s */
|
/* set buf to 0s */
|
||||||
memset(buf, 0, 16 * BLOCK_SIZE);
|
memset(buf, 0, 16 * BLOCK_SIZE);
|
||||||
|
|
||||||
if (t->catalog != NULL && t->catalog->image->isolinux_options & 0x02) {
|
|
||||||
/* We need to write a MBR for an hybrid image */
|
|
||||||
int ret;
|
|
||||||
int img_blocks;
|
|
||||||
|
|
||||||
img_blocks = t->curblock;
|
img_blocks = t->curblock;
|
||||||
ret = make_isohybrid_mbr(t->bootimg->sections[0].block, &img_blocks, (char*)buf, 0);
|
if (t->system_area_data != NULL) {
|
||||||
|
/* Write more or less opaque boot image */
|
||||||
/*
|
memcpy(buf, t->system_area_data, 16 * BLOCK_SIZE);
|
||||||
API description of el_torito_set_isolinux_options() prescribes
|
|
||||||
to pad to full MB.
|
|
||||||
So this is not urgent any more :
|
|
||||||
|
|
||||||
// FIXME the new img_blocks size should be taken into account
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
} else if (t->catalog != NULL &&
|
||||||
|
(t->catalog->bootimages[0]->isolinux_options & 0x0a) == 0x02) {
|
||||||
|
/* Check for isolinux image with magic number of 3.72 and produce
|
||||||
|
an MBR from our built-in template. (Deprecated since 31 Mar 2010)
|
||||||
|
*/
|
||||||
|
ret = make_isohybrid_mbr(t->bootsrc[0]->sections[0].block,
|
||||||
|
&img_blocks, (char*)buf, 0);
|
||||||
if (ret != 1) {
|
if (ret != 1) {
|
||||||
/* error, it should never happen */
|
/* error, it should never happen */
|
||||||
return ISO_ASSERT_FAILURE;
|
return ISO_ASSERT_FAILURE;
|
||||||
}
|
}
|
||||||
|
return ISO_SUCCESS;
|
||||||
|
}
|
||||||
|
if (t->system_area_options & 1) {
|
||||||
|
/* Write GRUB protective msdos label, i.e. a isimple partition table */
|
||||||
|
ret = make_grub_msdos_label(img_blocks, buf, 0);
|
||||||
|
if (ret != 1) /* error should never happen */
|
||||||
|
return ISO_ASSERT_FAILURE;
|
||||||
|
} else if(t->system_area_options & 2) {
|
||||||
|
/* Patch externally provided system area as isohybrid MBR */
|
||||||
|
if (t->catalog == NULL || t->system_area_data == NULL) {
|
||||||
|
/* isohybrid makes only sense together with ISOLINUX boot image
|
||||||
|
and externally provided System Area.
|
||||||
|
*/
|
||||||
|
return ISO_ISOLINUX_CANT_PATCH;
|
||||||
|
}
|
||||||
|
ret = make_isolinux_mbr(&img_blocks, t->bootsrc[0]->sections[0].block,
|
||||||
|
(uint32_t) 0, 64, 32, 0, 1, 0x17, buf, 1);
|
||||||
|
if (ret != 1)
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2008 Vreixo Formoso
|
* Copyright (c) 2008 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2,14 +2,19 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Functions that act on the iso tree.
|
* Functions that act on the iso tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
#include "image.h"
|
#include "image.h"
|
||||||
@ -25,6 +30,12 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <fnmatch.h>
|
#include <fnmatch.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PATH_MAX
|
||||||
|
#define PATH_MAX Libisofs_default_path_maX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a new directory to the iso tree.
|
* Add a new directory to the iso tree.
|
||||||
*
|
*
|
||||||
@ -914,7 +925,7 @@ int iso_tree_path_to_node(IsoImage *image, const char *path, IsoNode **node)
|
|||||||
int result;
|
int result;
|
||||||
IsoNode *n;
|
IsoNode *n;
|
||||||
IsoDir *dir;
|
IsoDir *dir;
|
||||||
char *ptr, *brk_info, *component;
|
char *ptr, *brk_info = NULL, *component;
|
||||||
|
|
||||||
if (image == NULL || path == NULL) {
|
if (image == NULL || path == NULL) {
|
||||||
return ISO_NULL_POINTER;
|
return ISO_NULL_POINTER;
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_IMAGE_TREE_H_
|
#ifndef LIBISO_IMAGE_TREE_H_
|
||||||
#define LIBISO_IMAGE_TREE_H_
|
#define LIBISO_IMAGE_TREE_H_
|
||||||
|
@ -1,12 +1,18 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
* Copyright (c) 2007 Mario Danic
|
* Copyright (c) 2007 Mario Danic
|
||||||
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
@ -906,7 +912,10 @@ ex:;
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t *iso_j_file_id(const uint16_t *src)
|
/*
|
||||||
|
bit0= no_force_dots
|
||||||
|
*/
|
||||||
|
uint16_t *iso_j_file_id(const uint16_t *src, int flag)
|
||||||
{
|
{
|
||||||
uint16_t *dot;
|
uint16_t *dot;
|
||||||
size_t lname, lext, lnname, lnext, pos, i;
|
size_t lname, lext, lnname, lnext, pos, i;
|
||||||
@ -952,6 +961,10 @@ uint16_t *iso_j_file_id(const uint16_t *src)
|
|||||||
pos++;
|
pos++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((flag & 1) && lnext <= 0)
|
||||||
|
goto is_done;
|
||||||
|
|
||||||
set_ucsbe(dest + pos, '.');
|
set_ucsbe(dest + pos, '.');
|
||||||
pos++;
|
pos++;
|
||||||
|
|
||||||
@ -965,6 +978,8 @@ uint16_t *iso_j_file_id(const uint16_t *src)
|
|||||||
pos++;
|
pos++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
is_done:;
|
||||||
set_ucsbe(dest + pos, '\0');
|
set_ucsbe(dest + pos, '\0');
|
||||||
return ucsdup(dest);
|
return ucsdup(dest);
|
||||||
}
|
}
|
||||||
@ -1204,7 +1219,7 @@ void iso_datetime_7(unsigned char *buf, time_t t, int always_gmt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
memset(&tm, 0, sizeof(tm));
|
memset(&tm, 0, sizeof(tm));
|
||||||
tm.tm_isdst = -1; /* some Linuxes change tm_isdst only if it is -1 */
|
tm.tm_isdst = -1; /* some OSes change tm_isdst only if it is -1 */
|
||||||
localtime_r(&t, &tm);
|
localtime_r(&t, &tm);
|
||||||
|
|
||||||
#ifdef HAVE_TM_GMTOFF
|
#ifdef HAVE_TM_GMTOFF
|
||||||
@ -1248,7 +1263,7 @@ void iso_datetime_17(unsigned char *buf, time_t t, int always_gmt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
memset(&tm, 0, sizeof(tm));
|
memset(&tm, 0, sizeof(tm));
|
||||||
tm.tm_isdst = -1; /* some Linuxes change tm_isdst only if it is -1 */
|
tm.tm_isdst = -1; /* some OSes change tm_isdst only if it is -1 */
|
||||||
localtime_r(&t, &tm);
|
localtime_r(&t, &tm);
|
||||||
|
|
||||||
localtime_r(&t, &tm);
|
localtime_r(&t, &tm);
|
||||||
@ -1381,21 +1396,33 @@ int iso_eaccess(const char *path)
|
|||||||
return ISO_SUCCESS;
|
return ISO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *strcopy(const char *buf, size_t len)
|
char *iso_util_strcopy(const char *buf, size_t len)
|
||||||
{
|
{
|
||||||
char *str;
|
char *str;
|
||||||
|
|
||||||
str = malloc((len + 1) * sizeof(char));
|
str = calloc(len + 1, 1);
|
||||||
if (str == NULL) {
|
if (str == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
strncpy(str, buf, len);
|
strncpy(str, buf, len);
|
||||||
str[len] = '\0';
|
str[len] = '\0';
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *iso_util_strcopy_untail(const char *buf, size_t len)
|
||||||
|
{
|
||||||
|
char *str;
|
||||||
|
|
||||||
|
str = iso_util_strcopy(buf, len);
|
||||||
|
if (str == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
/* remove trailing spaces */
|
/* remove trailing spaces */
|
||||||
for (len = len-1; str[len] == ' ' && len > 0; --len)
|
for (len = len-1; len >= 0; --len) {
|
||||||
str[len] = '\0';
|
if (str[len] != ' ')
|
||||||
|
break;
|
||||||
|
str[len] = 0;
|
||||||
|
}
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
|
* Copyright (c) 2009 Thomas Schmitt
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBISO_UTIL_H_
|
#ifndef LIBISO_UTIL_H_
|
||||||
@ -149,11 +151,12 @@ char *iso_r_fileid(const char *src, size_t len, int relaxed, int forcedot);
|
|||||||
* 2 bytes and the resulting string is NULL-terminated by a 2-byte NULL.
|
* 2 bytes and the resulting string is NULL-terminated by a 2-byte NULL.
|
||||||
*
|
*
|
||||||
* Note that version number and (;1) is not appended.
|
* Note that version number and (;1) is not appended.
|
||||||
*
|
* @param flag
|
||||||
|
* bit0= no_force_dots
|
||||||
* @return
|
* @return
|
||||||
* NULL if the original name and extension both are of length 0.
|
* NULL if the original name and extension both are of length 0.
|
||||||
*/
|
*/
|
||||||
uint16_t *iso_j_file_id(const uint16_t *src);
|
uint16_t *iso_j_file_id(const uint16_t *src, int flag);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a Joliet directory identifier that consists of name and optionally
|
* Create a Joliet directory identifier that consists of name and optionally
|
||||||
@ -250,7 +253,14 @@ int iso_eaccess(const char *path);
|
|||||||
* Copy up to \p len chars from \p buf and return this newly allocated
|
* Copy up to \p len chars from \p buf and return this newly allocated
|
||||||
* string. The new string is null-terminated.
|
* string. The new string is null-terminated.
|
||||||
*/
|
*/
|
||||||
char *strcopy(const char *buf, size_t len);
|
char *iso_util_strcopy(const char *buf, size_t len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy up to \p len chars from \p buf and return this newly allocated
|
||||||
|
* string. The new string is null-terminated.
|
||||||
|
* Any trailing blanks will be removed.
|
||||||
|
*/
|
||||||
|
char *iso_util_strcopy_untail(const char *buf, size_t len);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copy up to \p max characters from \p src to \p dest. If \p src has less than
|
* Copy up to \p max characters from \p src to \p dest. If \p src has less than
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
|
||||||
|
@ -2,10 +2,15 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "../config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "libisofs.h"
|
#include "libisofs.h"
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
* Copyright (c) 2007 Vreixo Formoso
|
* Copyright (c) 2007 Vreixo Formoso
|
||||||
*
|
*
|
||||||
* This file is part of the libisofs project; you can redistribute it and/or
|
* This file is part of the libisofs project; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License version 2 as
|
* modify it under the terms of the GNU General Public License version 2
|
||||||
* published by the Free Software Foundation. See COPYING file for details.
|
* or later as published by the Free Software Foundation.
|
||||||
|
* See COPYING file for details.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBISO_IMAGE_WRITER_H_
|
#ifndef LIBISO_IMAGE_WRITER_H_
|
||||||
#define LIBISO_IMAGE_WRITER_H_
|
#define LIBISO_IMAGE_WRITER_H_
|
||||||
|
Reference in New Issue
Block a user