libcdio 2.1.1
Macros | Typedefs | Enumerations | Functions | Variables
sector.h File Reference

Things related to CD-ROM layout: tracks, sector sizes, MSFs, LBAs. More...

#include <cdio/types.h>

Go to the source code of this file.

Macros

#define CDIO_PREGAP_SECTORS   150
 
#define CDIO_POSTGAP_SECTORS   150
 
#define CDIO_CD_MINS   74
 
#define CDIO_CD_SECS_PER_MIN   60
 
#define CDIO_CD_FRAMES_PER_SEC   75
 
#define CDIO_CD_SYNC_SIZE   12
 
#define CDIO_CD_CHUNK_SIZE   24
 
#define CDIO_CD_NUM_OF_CHUNKS   98
 
#define CDIO_CD_FRAMESIZE_SUB   96
 
#define CDIO_CD_HEADER_SIZE   4
 
#define CDIO_CD_SUBHEADER_SIZE   8
 
#define CDIO_CD_EDC_SIZE   4
 
#define CDIO_CD_M1F1_ZERO_SIZE   8
 
#define CDIO_CD_ECC_SIZE   276
 
#define CDIO_CD_FRAMESIZE   2048
 
#define CDIO_CD_FRAMESIZE_RAW   2352
 
#define CDIO_CD_FRAMESIZE_RAWER   2646
 
#define CDIO_CD_FRAMESIZE_RAW1   (CDIO_CD_FRAMESIZE_RAW-CDIO_CD_SYNC_SIZE) /*2340*/
 
#define CDIO_CD_FRAMESIZE_RAW0   (CDIO_CD_FRAMESIZE_RAW-CDIO_CD_SYNC_SIZE-CDIO_CD_HEADER_SIZE) /*2336*/
 
#define CDIO_CD_XA_HEADER   (CDIO_CD_HEADER_SIZE+CDIO_CD_SUBHEADER_SIZE)
 
#define CDIO_CD_XA_TAIL   (CDIO_CD_EDC_SIZE+CDIO_CD_ECC_SIZE)
 
#define CDIO_CD_XA_SYNC_HEADER   (CDIO_CD_SYNC_SIZE+CDIO_CD_XA_HEADER)
 
#define M2F2_SECTOR_SIZE   2324
 
#define M2SUB_SECTOR_SIZE   2332
 
#define M2RAW_SECTOR_SIZE   2336
 
#define CDIO_CD_MAX_SESSIONS   99
 
#define CDIO_CD_MIN_SESSION_NO   1
 
#define CDIO_CD_MAX_LSN   450150
 
#define CDIO_CD_MIN_LSN   -450150
 
#define CDIO_CD_FRAMES_PER_MIN    (CDIO_CD_FRAMES_PER_SEC*CDIO_CD_SECS_PER_MIN)
 
#define msf_t_SIZEOF   3
 
#define CD_FRAMESIZE_RAW   CDIO_CD_FRAMESIZE_RAW
 

Typedefs

typedef enum cdio_subchannel cdio_subchannel
 
typedef enum cdio_cd_minutes_sectors cdio_cd_minutes_sectors
 

Enumerations

enum  cdio_subchannel { CDIO_SUBCHANNEL_SUBQ_DATA = 0 , CDIO_SUBCHANNEL_CURRENT_POSITION = 1 , CDIO_SUBCHANNEL_MEDIA_CATALOG = 2 , CDIO_SUBCHANNEL_TRACK_ISRC = 3 }
 
enum  flag_t {
  NONE = 0x00 , PRE_EMPHASIS = 0x01 , COPY_PERMITTED = 0x02 , DATA = 0x04 ,
  FOUR_CHANNEL_AUDIO = 0x08 , SCMS = 0x10
}
 
enum  cdio_cd_enums {
  CDIO_CD_MINS = 74 , CDIO_CD_SECS_PER_MIN = 60 , CDIO_CD_FRAMES_PER_SEC = 75 , CDIO_CD_SYNC_SIZE = 12 ,
  CDIO_CD_CHUNK_SIZE = 24 , CDIO_CD_NUM_OF_CHUNKS = 98 , CDIO_CD_FRAMESIZE_SUB = 96 , CDIO_CD_HEADER_SIZE = 4 ,
  CDIO_CD_SUBHEADER_SIZE = 8 , CDIO_CD_ECC_SIZE = 276 , CDIO_CD_FRAMESIZE = 2048 , CDIO_CD_FRAMESIZE_RAW = 2352 ,
  CDIO_CD_FRAMESIZE_RAWER = 2646 , CDIO_CD_FRAMESIZE_RAW1 = 2340 , CDIO_CD_FRAMESIZE_RAW0 = 2336 , CDIO_CD_MAX_SESSIONS = 99 ,
  CDIO_CD_MIN_SESSION_NO = 1 , CDIO_CD_MAX_LSN = 450150 , CDIO_CD_MIN_LSN = -450150
}
 
enum  m2_sector_enums { M2F2_SECTOR_SIZE = 2324 , M2SUB_SECTOR_SIZE = 2332 , M2RAW_SECTOR_SIZE = 2336 }
 
enum  cdio_cd_minutes_sectors { CDIO_CD_74MIN_SECTORS = UINT32_C(74) * CDIO_CD_FRAMES_PER_MIN , CDIO_CD_80MIN_SECTORS = UINT32_C(80) * CDIO_CD_FRAMES_PER_MIN , CDIO_CD_90MIN_SECTORS = UINT32_C(90) * CDIO_CD_FRAMES_PER_MIN , CDIO_CD_MAX_SECTORS = UINT32_C(100) * CDIO_CD_FRAMES_PER_MIN - CDIO_PREGAP_SECTORS }
 

Functions

char * cdio_lba_to_msf_str (lba_t i_lba)
 
char * cdio_msf_to_str (const msf_t *p_msf)
 
lba_t cdio_lba_to_lsn (lba_t i_lba)
 
void cdio_lba_to_msf (lba_t i_lba, msf_t *p_msf)
 
lba_t cdio_lsn_to_lba (lsn_t i_lsn)
 
void cdio_lsn_to_msf (lsn_t i_lsn, msf_t *p_msf)
 
lba_t cdio_msf_to_lba (const msf_t *p_msf)
 
lsn_t cdio_msf_to_lsn (const msf_t *p_msf)
 
lba_t cdio_msf3_to_lba (unsigned int minutes, unsigned int seconds, unsigned int frames)
 
lba_t cdio_mmssff_to_lba (const char *psz_mmssff)
 

Variables

enum cdio_cd_enums cdio_cd_enums
 
const uint8_t CDIO_SECTOR_SYNC_HEADER [CDIO_CD_SYNC_SIZE]
 
enum m2_sector_enums m2_sector_enums
 

Detailed Description

Things related to CD-ROM layout: tracks, sector sizes, MSFs, LBAs.

A CD-ROM physical sector size is 2048, 2052, 2056, 2324, 2332, 2336, 2340, or 2352 bytes long.

Sector types of the standard CD-ROM data formats:

  format   sector type               user data size (bytes)
  -----------------------------------------------------------------------------
    1     (Red Book)    CD-DA          2352    (CDIO_CD_FRAMESIZE_RAW)
    2     (Yellow Book) Mode1 Form1    2048    (CDIO_CD_FRAMESIZE)
    3     (Yellow Book) Mode1 Form2    2336    (M2RAW_SECTOR_SIZE)
    4     (Green Book)  Mode2 Form1    2048    (CDIO_CD_FRAMESIZE)
    5     (Green Book)  Mode2 Form2    2328    (2324+4 spare bytes)
 
 
        The layout of the standard CD-ROM data formats:
  -----------------------------------------------------------------------------
  - audio (red):                  | audio_sample_bytes |
                                  |        2352        |
 
  - data (yellow, mode1):         | sync - head - data - EDC - zero - ECC |
                                  |  12  -   4  - 2048 -  4  -   8  - 276 |
 
  - data (yellow, mode2):         | sync - head - data |
                                 |  12  -   4  - 2336 |
 
  - XA data (green, mode2 form1): | sync - head - sub - data - EDC - ECC |
                                  |  12  -   4  -  8  - 2048 -  4  - 276 |
 
  - XA data (green, mode2 form2): | sync - head - sub - data - Spare |
                                  |  12  -   4  -  8  - 2324 -  4    |

Macro Definition Documentation

◆ CD_FRAMESIZE_RAW

#define CD_FRAMESIZE_RAW   CDIO_CD_FRAMESIZE_RAW

For compatibility with good ol' paranoia

◆ CDIO_CD_CHUNK_SIZE

#define CDIO_CD_CHUNK_SIZE   24

lowest-level "data bytes piece"

◆ CDIO_CD_ECC_SIZE

#define CDIO_CD_ECC_SIZE   276

bytes ECC per most raw data frame types

◆ CDIO_CD_EDC_SIZE

#define CDIO_CD_EDC_SIZE   4

bytes EDC per most raw data frame types

◆ CDIO_CD_FRAMES_PER_MIN

#define CDIO_CD_FRAMES_PER_MIN    (CDIO_CD_FRAMES_PER_SEC*CDIO_CD_SECS_PER_MIN)

◆ CDIO_CD_FRAMES_PER_SEC

#define CDIO_CD_FRAMES_PER_SEC   75

frames per second

◆ CDIO_CD_FRAMESIZE

#define CDIO_CD_FRAMESIZE   2048

bytes per frame, "cooked" mode

◆ CDIO_CD_FRAMESIZE_RAW

#define CDIO_CD_FRAMESIZE_RAW   2352

bytes per frame, "raw" mode

◆ CDIO_CD_FRAMESIZE_RAW0

#define CDIO_CD_FRAMESIZE_RAW0   (CDIO_CD_FRAMESIZE_RAW-CDIO_CD_SYNC_SIZE-CDIO_CD_HEADER_SIZE) /*2336*/

◆ CDIO_CD_FRAMESIZE_RAW1

#define CDIO_CD_FRAMESIZE_RAW1   (CDIO_CD_FRAMESIZE_RAW-CDIO_CD_SYNC_SIZE) /*2340*/

◆ CDIO_CD_FRAMESIZE_RAWER

#define CDIO_CD_FRAMESIZE_RAWER   2646

The maximum possible returned bytes

◆ CDIO_CD_FRAMESIZE_SUB

#define CDIO_CD_FRAMESIZE_SUB   96

subchannel data "frame" size

◆ CDIO_CD_HEADER_SIZE

#define CDIO_CD_HEADER_SIZE   4

header (address) bytes per raw data frame

◆ CDIO_CD_M1F1_ZERO_SIZE

#define CDIO_CD_M1F1_ZERO_SIZE   8

bytes zero per yellow book mode 1 frame

◆ CDIO_CD_MAX_LSN

#define CDIO_CD_MAX_LSN   450150

Largest LSN in a CD

◆ CDIO_CD_MAX_SESSIONS

#define CDIO_CD_MAX_SESSIONS   99

Largest CD session number

◆ CDIO_CD_MIN_LSN

#define CDIO_CD_MIN_LSN   -450150

Smallest LSN in a CD

◆ CDIO_CD_MIN_SESSION_NO

#define CDIO_CD_MIN_SESSION_NO   1

Smallest CD session number

◆ CDIO_CD_MINS

#define CDIO_CD_MINS   74

Some generally useful CD-ROM information – mostly based on the above. This is from linux.h - not to slight other OS's. This was the first place I came across such useful stuff. max. minutes per CD, not really a limit

◆ CDIO_CD_NUM_OF_CHUNKS

#define CDIO_CD_NUM_OF_CHUNKS   98

chunks per frame

◆ CDIO_CD_SECS_PER_MIN

#define CDIO_CD_SECS_PER_MIN   60

seconds per minute

◆ CDIO_CD_SUBHEADER_SIZE

#define CDIO_CD_SUBHEADER_SIZE   8

subheader bytes per raw XA data frame

◆ CDIO_CD_SYNC_SIZE

#define CDIO_CD_SYNC_SIZE   12

12 sync bytes per raw data frame

◆ CDIO_CD_XA_HEADER

#define CDIO_CD_XA_HEADER   (CDIO_CD_HEADER_SIZE+CDIO_CD_SUBHEADER_SIZE)

"before data" part of raw XA (green, mode2) frame

◆ CDIO_CD_XA_SYNC_HEADER

#define CDIO_CD_XA_SYNC_HEADER   (CDIO_CD_SYNC_SIZE+CDIO_CD_XA_HEADER)

"before data" sync bytes + header of XA (green, mode2) frame

◆ CDIO_CD_XA_TAIL

#define CDIO_CD_XA_TAIL   (CDIO_CD_EDC_SIZE+CDIO_CD_ECC_SIZE)

"after data" part of raw XA (green, mode2 form1) frame

◆ CDIO_POSTGAP_SECTORS

#define CDIO_POSTGAP_SECTORS   150

◆ CDIO_PREGAP_SECTORS

#define CDIO_PREGAP_SECTORS   150

◆ M2F2_SECTOR_SIZE

#define M2F2_SECTOR_SIZE   2324

◆ M2RAW_SECTOR_SIZE

#define M2RAW_SECTOR_SIZE   2336

◆ M2SUB_SECTOR_SIZE

#define M2SUB_SECTOR_SIZE   2332

◆ msf_t_SIZEOF

#define msf_t_SIZEOF   3

Typedef Documentation

◆ cdio_cd_minutes_sectors

◆ cdio_subchannel

Information that can be obtained through a Read Subchannel command.

Enumeration Type Documentation

◆ cdio_cd_enums

An enumeration for some of the CDIO_CD #defines below. This isn't really an enumeration one would really use in a program it is to be helpful in debuggers where wants just to refer to the CDIO_CD_ names and get something.

Enumerator
CDIO_CD_MINS 

max. minutes per CD, not really a limit

CDIO_CD_SECS_PER_MIN 

seconds per minute

CDIO_CD_FRAMES_PER_SEC 

frames per second

CDIO_CD_SYNC_SIZE 

12 sync bytes per raw data frame

CDIO_CD_CHUNK_SIZE 

lowest-level "data bytes piece"

CDIO_CD_NUM_OF_CHUNKS 

chunks per frame

CDIO_CD_FRAMESIZE_SUB 

subchannel data "frame" size

CDIO_CD_HEADER_SIZE 

header (address) bytes per raw frame

CDIO_CD_SUBHEADER_SIZE 

subheader bytes per raw XA data frame

CDIO_CD_ECC_SIZE 

bytes ECC per most raw data frame types

CDIO_CD_FRAMESIZE 

bytes per frame, "cooked" mode

CDIO_CD_FRAMESIZE_RAW 

bytes per frame, "raw" mode

CDIO_CD_FRAMESIZE_RAWER 

The maximum possible returned

CDIO_CD_FRAMESIZE_RAW1 
CDIO_CD_FRAMESIZE_RAW0 
CDIO_CD_MAX_SESSIONS 
CDIO_CD_MIN_SESSION_NO 

, Smallest CD session number

CDIO_CD_MAX_LSN 

Largest LSN in a CD

CDIO_CD_MIN_LSN 

Smallest LSN in a CD

◆ cdio_cd_minutes_sectors

Enumerator
CDIO_CD_74MIN_SECTORS 
CDIO_CD_80MIN_SECTORS 
CDIO_CD_90MIN_SECTORS 
CDIO_CD_MAX_SECTORS 

◆ cdio_subchannel

Information that can be obtained through a Read Subchannel command.

Enumerator
CDIO_SUBCHANNEL_SUBQ_DATA 
CDIO_SUBCHANNEL_CURRENT_POSITION 
CDIO_SUBCHANNEL_MEDIA_CATALOG 
CDIO_SUBCHANNEL_TRACK_ISRC 

◆ flag_t

enum flag_t

track flags Q Sub-channel Control Field (4.2.3.3)

Enumerator
NONE 
PRE_EMPHASIS 
COPY_PERMITTED 
DATA 
FOUR_CHANNEL_AUDIO 
SCMS 

◆ m2_sector_enums

An enumeration for some of the M2*_SECTOR_SIZE #defines below. This isn't really an enumeration one would really use in a program it is to be helpful in debuggers where wants just to refer to the M2*_SECTOR_SIZE names and get something.

Enumerator
M2F2_SECTOR_SIZE 
M2SUB_SECTOR_SIZE 
M2RAW_SECTOR_SIZE 

Function Documentation

◆ cdio_lba_to_lsn()

lba_t cdio_lba_to_lsn ( lba_t  i_lba)

Convert an LBA into the corresponding LSN.

◆ cdio_lba_to_msf()

void cdio_lba_to_msf ( lba_t  i_lba,
msf_t p_msf 
)

Convert an LBA into the corresponding MSF.

◆ cdio_lba_to_msf_str()

char * cdio_lba_to_msf_str ( lba_t  i_lba)

Convert an LBA into a string representation of the MSF.

Warning
cdio_lba_to_msf_str returns new allocated string

◆ cdio_lsn_to_lba()

lba_t cdio_lsn_to_lba ( lsn_t  i_lsn)

Convert an LSN into the corresponding LBA. CDIO_INVALID_LBA is returned if there is an error.

◆ cdio_lsn_to_msf()

void cdio_lsn_to_msf ( lsn_t  i_lsn,
msf_t p_msf 
)

Convert an LSN into the corresponding MSF.

◆ cdio_mmssff_to_lba()

lba_t cdio_mmssff_to_lba ( const char *  psz_mmssff)

Convert a string of the form MM:SS:FF into the corresponding LBA. CDIO_INVALID_LBA is returned if there is an error.

◆ cdio_msf3_to_lba()

lba_t cdio_msf3_to_lba ( unsigned int  minutes,
unsigned int  seconds,
unsigned int  frames 
)

Convert a MSF - broken out as 3 integer components into the corresponding LBA.
CDIO_INVALID_LBA is returned if there is an error.

◆ cdio_msf_to_lba()

lba_t cdio_msf_to_lba ( const msf_t p_msf)

Convert a MSF into the corresponding LBA. CDIO_INVALID_LBA is returned if there is an error.

◆ cdio_msf_to_lsn()

lsn_t cdio_msf_to_lsn ( const msf_t p_msf)

Convert a MSF into the corresponding LSN. CDIO_INVALID_LSN is returned if there is an error.

◆ cdio_msf_to_str()

char * cdio_msf_to_str ( const msf_t p_msf)

Convert an MSF into a string representation of the MSF.

Warning
cdio_msf_to_msf_str returns new allocated string

Variable Documentation

◆ cdio_cd_enums

◆ CDIO_SECTOR_SYNC_HEADER

const uint8_t CDIO_SECTOR_SYNC_HEADER[CDIO_CD_SYNC_SIZE]
extern

String of bytes used to identify the beginning of a Mode 1 or Mode 2 sector. {0, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0};

◆ m2_sector_enums