2003-03-24 19:01:09 +00:00
|
|
|
|
/*
|
2004-04-25 14:07:23 +00:00
|
|
|
|
$Id: types.h,v 1.13 2004/04/25 14:07:23 rocky Exp $
|
2003-03-24 19:01:09 +00:00
|
|
|
|
|
|
|
|
|
|
Copyright (C) 2000 Herbert Valerio Riedel <hvr@gnu.org>
|
2004-03-13 03:32:49 +00:00
|
|
|
|
Copyright (C) 2002, 2003, 2004 Rocky Bernstein <rocky@panix.com>
|
2003-03-24 19:01:09 +00:00
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
*/
|
2003-11-17 12:06:56 +00:00
|
|
|
|
|
|
|
|
|
|
/** \file types.h
|
|
|
|
|
|
* \brief Common type definitions used pervasively in libcdio.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
|
|
|
|
|
|
#ifndef __CDIO_TYPES_H__
|
|
|
|
|
|
#define __CDIO_TYPES_H__
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* provide some C99 definitions */
|
|
|
|
|
|
|
2003-05-27 02:55:58 +00:00
|
|
|
|
#if defined(HAVE_SYS_TYPES_H)
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if defined(HAVE_STDINT_H)
|
|
|
|
|
|
# include <stdint.h>
|
|
|
|
|
|
#elif defined(HAVE_INTTYPES_H)
|
|
|
|
|
|
# include <inttypes.h>
|
2003-05-27 02:55:58 +00:00
|
|
|
|
#elif defined(AMIGA) || defined(__linux__)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
typedef u_int8_t uint8_t;
|
|
|
|
|
|
typedef u_int16_t uint16_t;
|
|
|
|
|
|
typedef u_int32_t uint32_t;
|
|
|
|
|
|
typedef u_int64_t uint64_t;
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#else
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* warning ISO/IEC 9899:1999 <stdint.h> was missing and even <inttypes.h> */
|
|
|
|
|
|
/* fixme */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#endif /* HAVE_STDINT_H */
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/* default HP/UX macros are broken */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if defined(__hpux__)
|
|
|
|
|
|
# undef UINT16_C
|
|
|
|
|
|
# undef UINT32_C
|
|
|
|
|
|
# undef UINT64_C
|
|
|
|
|
|
# undef INT64_C
|
|
|
|
|
|
#endif
|
2003-06-07 10:44:14 +00:00
|
|
|
|
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* if it's still not defined, take a good guess... should work for
|
|
|
|
|
|
most 32bit and 64bit archs */
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifndef UINT16_C
|
|
|
|
|
|
# define UINT16_C(c) c ## U
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifndef UINT32_C
|
|
|
|
|
|
# if defined (SIZEOF_INT) && SIZEOF_INT == 4
|
|
|
|
|
|
# define UINT32_C(c) c ## U
|
|
|
|
|
|
# elif defined (SIZEOF_LONG) && SIZEOF_LONG == 4
|
|
|
|
|
|
# define UINT32_C(c) c ## UL
|
|
|
|
|
|
# else
|
|
|
|
|
|
# define UINT32_C(c) c ## U
|
|
|
|
|
|
# endif
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifndef UINT64_C
|
|
|
|
|
|
# if defined (SIZEOF_LONG) && SIZEOF_LONG == 8
|
|
|
|
|
|
# define UINT64_C(c) c ## UL
|
|
|
|
|
|
# elif defined (SIZEOF_INT) && SIZEOF_INT == 8
|
|
|
|
|
|
# define UINT64_C(c) c ## U
|
|
|
|
|
|
# else
|
|
|
|
|
|
# define UINT64_C(c) c ## ULL
|
|
|
|
|
|
# endif
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifndef INT64_C
|
|
|
|
|
|
# if defined (SIZEOF_LONG) && SIZEOF_LONG == 8
|
|
|
|
|
|
# define INT64_C(c) c ## L
|
|
|
|
|
|
# elif defined (SIZEOF_INT) && SIZEOF_INT == 8
|
|
|
|
|
|
# define INT64_C(c) c
|
|
|
|
|
|
# else
|
|
|
|
|
|
# define INT64_C(c) c ## LL
|
|
|
|
|
|
# endif
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if defined(HAVE_STDBOOL_H)
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
#else
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* ISO/IEC 9899:1999 <stdbool.h> missing -- enabling workaround */
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
# ifndef __cplusplus
|
2003-04-07 11:29:06 +00:00
|
|
|
|
typedef enum
|
|
|
|
|
|
{
|
|
|
|
|
|
false = 0,
|
|
|
|
|
|
true = 1
|
|
|
|
|
|
} _Bool;
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
# define false false
|
|
|
|
|
|
# define true true
|
|
|
|
|
|
# define bool _Bool
|
|
|
|
|
|
# endif
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/* some GCC optimizations -- gcc 2.5+ */
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 4)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_PRINTF( format_idx, arg_idx ) \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((format (printf, format_idx, arg_idx)))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_SCANF( format_idx, arg_idx ) \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((format (scanf, format_idx, arg_idx)))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_FORMAT( arg_idx ) \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((format_arg (arg_idx)))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_NORETURN \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((noreturn))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_CONST \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((const))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_UNUSED \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((unused))
|
2003-04-07 11:29:06 +00:00
|
|
|
|
#define GNUC_PACKED \
|
2003-03-24 19:01:09 +00:00
|
|
|
|
__attribute__((packed))
|
|
|
|
|
|
#else /* !__GNUC__ */
|
|
|
|
|
|
#define GNUC_PRINTF( format_idx, arg_idx )
|
|
|
|
|
|
#define GNUC_SCANF( format_idx, arg_idx )
|
|
|
|
|
|
#define GNUC_FORMAT( arg_idx )
|
|
|
|
|
|
#define GNUC_NORETURN
|
|
|
|
|
|
#define GNUC_CONST
|
|
|
|
|
|
#define GNUC_UNUSED
|
|
|
|
|
|
#define GNUC_PACKED
|
|
|
|
|
|
#endif /* !__GNUC__ */
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if defined(__GNUC__)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* for GCC we try to use GNUC_PACKED */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
# define PRAGMA_BEGIN_PACKED
|
|
|
|
|
|
# define PRAGMA_END_PACKED
|
|
|
|
|
|
#elif defined(HAVE_ISOC99_PRAGMA)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* should work with most EDG-frontend based compilers */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
# define PRAGMA_BEGIN_PACKED _Pragma("pack(1)")
|
|
|
|
|
|
# define PRAGMA_END_PACKED _Pragma("pack()")
|
|
|
|
|
|
#else /* neither gcc nor _Pragma() available... */
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* ...so let's be naive and hope the regression testsuite is run... */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
# define PRAGMA_BEGIN_PACKED
|
|
|
|
|
|
# define PRAGMA_END_PACKED
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
* user directed static branch prediction gcc 2.96+
|
|
|
|
|
|
*/
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 95)
|
|
|
|
|
|
# define GNUC_LIKELY(x) __builtin_expect((x),true)
|
|
|
|
|
|
# define GNUC_UNLIKELY(x) __builtin_expect((x),false)
|
|
|
|
|
|
#else
|
|
|
|
|
|
# define GNUC_LIKELY(x) (x)
|
|
|
|
|
|
# define GNUC_UNLIKELY(x) (x)
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifndef NULL
|
|
|
|
|
|
# define NULL ((void*) 0)
|
|
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/* our own offsetof()-like macro */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#define __cd_offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-11-18 03:35:19 +00:00
|
|
|
|
/*!
|
|
|
|
|
|
\brief MSF (minute/second/frame) structure
|
|
|
|
|
|
|
|
|
|
|
|
One CD-ROMs addressing scheme especially used in audio formats
|
|
|
|
|
|
(Red Book) is an address by minute, sector and frame which
|
|
|
|
|
|
BCD-encoded in three bytes. An alternative format is an lba_t.
|
|
|
|
|
|
|
|
|
|
|
|
@see lba_t
|
|
|
|
|
|
*/
|
2003-04-07 11:29:06 +00:00
|
|
|
|
PRAGMA_BEGIN_PACKED
|
2003-11-18 03:35:19 +00:00
|
|
|
|
struct msf_rec {
|
2003-04-07 11:29:06 +00:00
|
|
|
|
uint8_t m, s, f;
|
2003-11-18 03:35:19 +00:00
|
|
|
|
} GNUC_PACKED;
|
2003-04-07 11:29:06 +00:00
|
|
|
|
PRAGMA_END_PACKED
|
|
|
|
|
|
|
2003-11-18 03:35:19 +00:00
|
|
|
|
typedef struct msf_rec msf_t;
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#define msf_t_SIZEOF 3
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/* type used for bit-fields in structs (1 <= bits <= 8) */
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#if defined(__GNUC__)
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* this is strict ISO C99 which allows only 'unsigned int', 'signed
|
|
|
|
|
|
int' and '_Bool' explicitly as bit-field type */
|
|
|
|
|
|
typedef unsigned int bitfield_t;
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#else
|
2003-04-07 11:29:06 +00:00
|
|
|
|
/* other compilers might increase alignment requirements to match the
|
|
|
|
|
|
'unsigned int' type -- fixme: find out how unalignment accesses can
|
|
|
|
|
|
be pragma'ed on non-gcc compilers */
|
|
|
|
|
|
typedef uint8_t bitfield_t;
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#endif
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-11-18 03:35:19 +00:00
|
|
|
|
/*! The type of a Logical Block Address.
|
|
|
|
|
|
|
|
|
|
|
|
@see msf_t
|
|
|
|
|
|
*/
|
2003-04-07 11:29:06 +00:00
|
|
|
|
typedef uint32_t lba_t;
|
|
|
|
|
|
|
2003-11-18 03:35:19 +00:00
|
|
|
|
/*! The type of an Logical Sector Number. */
|
2003-04-07 11:29:06 +00:00
|
|
|
|
typedef uint32_t lsn_t;
|
|
|
|
|
|
|
2003-11-18 03:35:19 +00:00
|
|
|
|
/*! The type of an track number 0..99. */
|
2003-04-07 11:29:06 +00:00
|
|
|
|
typedef uint8_t track_t;
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
|
|
Constant for invalid track number
|
|
|
|
|
|
*/
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#define CDIO_INVALID_TRACK 0xFF
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
|
|
Constant for invalid LBA
|
|
|
|
|
|
*/
|
2003-03-29 17:32:00 +00:00
|
|
|
|
#define CDIO_INVALID_LBA 0xFFFFFFFF
|
2003-04-07 11:29:06 +00:00
|
|
|
|
|
2003-04-10 04:10:38 +00:00
|
|
|
|
/*!
|
|
|
|
|
|
Constant for invalid LSN
|
|
|
|
|
|
*/
|
|
|
|
|
|
#define CDIO_INVALID_LSN 0xFFFFFFFF
|
2003-08-17 05:31:19 +00:00
|
|
|
|
|
2003-09-28 17:14:20 +00:00
|
|
|
|
typedef int cdio_fs_anal_t;
|
|
|
|
|
|
|
2004-04-25 00:46:34 +00:00
|
|
|
|
/*! The type of an drive capability bit mask. See below for values*/
|
|
|
|
|
|
typedef uint32_t cdio_drive_cap_t;
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
|
|
\brief Drive types returned by cdio_get_drive_cap()
|
|
|
|
|
|
|
|
|
|
|
|
Most are copied from the GNU/Linux the uniform CD-ROM driver header
|
|
|
|
|
|
linux/cdrom.h> NOTE: Setting a bit here means the presence of
|
|
|
|
|
|
a capability.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_CLOSE_TRAY 0x00001 /**< caddy systems can't
|
|
|
|
|
|
close... */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_OPEN_TRAY 0x00002 /**< but can eject. */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_LOCK 0x00004 /**< disable manual eject */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_SELECT_SPEED 0x00008 /**< programmable speed */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_SELECT_DISC 0x00010 /**< select disc from juke-box */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_MULTI_SESSION 0x00020 /**< read sessions>1 */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_MCN 0x00040 /**< Medium Catalog Number */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_MEDIA_CHANGED 0x00080 /**< media changed */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_CD_AUDIO 0x00100 /**< drive can play CD audio */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_RESET 0x00200 /**< hard reset device */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_IOCTLS 0x00400 /**< driver has non-standard
|
|
|
|
|
|
ioctls */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_DRIVE_STATUS 0x00800 /**< driver implements drive
|
2004-04-25 00:46:34 +00:00
|
|
|
|
status */
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_GENERIC_PACKET 0x01000 /**< driver implements generic
|
|
|
|
|
|
packets */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_CD_R 0x02000 /**< drive can write CD-R */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_CD_RW 0x04000 /**< drive can write CD-RW */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_DVD 0x08000 /**< drive can read DVD */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_DVD_R 0x10000 /**< drive can write DVD-R */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_DVD_RAM 0x20000 /**< drive can write DVD-RAM */
|
2004-04-25 00:46:34 +00:00
|
|
|
|
|
|
|
|
|
|
/**< These are not taken by GNU/Linux cdrom.h (yet) */
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_ERROR 0x00000 /**< Error */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_FILE 0x40000 /**< drive is really a file, i.e
|
|
|
|
|
|
a CD file image */
|
|
|
|
|
|
#define CDIO_DRIVE_CAP_UNKNOWN 0x80000 /**< Dunno. It can be on if we
|
2004-04-25 00:46:34 +00:00
|
|
|
|
have only partial information
|
|
|
|
|
|
or are not completely certain
|
|
|
|
|
|
*/
|
|
|
|
|
|
/**< Masks derived from above... */
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_CD_WRITER \
|
|
|
|
|
|
(CDIO_DRIVE_CAP_CD_R|CDIO_DRIVE_CAP_CD_RW)
|
2004-04-25 00:46:34 +00:00
|
|
|
|
/**< Has some sort of CD writer ability */
|
|
|
|
|
|
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_CD \
|
|
|
|
|
|
(CDIO_DRIVE_CAP_CD_AUDIO|CDIO_DRIVE_CAP_CD_WRITER)
|
2004-04-25 00:46:34 +00:00
|
|
|
|
/**< Has some sort of CD ability */
|
|
|
|
|
|
|
2004-04-25 14:07:23 +00:00
|
|
|
|
#define CDIO_DRIVE_CAP_DVD_WRITER \
|
|
|
|
|
|
(CDIO_DRIVE_CAP_DVD_R|CDIO_DRIVE_CAP_DVD_RAM)
|
2004-04-25 00:46:34 +00:00
|
|
|
|
/**< Has some sort of DVD writer ability */
|
|
|
|
|
|
|
2003-03-24 19:01:09 +00:00
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* __CDIO_TYPES_H__ */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
* Local variables:
|
|
|
|
|
|
* c-file-style: "gnu"
|
|
|
|
|
|
* tab-width: 8
|
|
|
|
|
|
* indent-tabs-mode: nil
|
|
|
|
|
|
* End:
|
|
|
|
|
|
*/
|