Search
lxdream.org :: lxdream/src/gdrom/gdrom.h
lxdream 0.9.1
released Jun 29
Download Now
filename src/gdrom/gdrom.h
changeset 142:2f631c3a3946
prev138:afabd7e6d26d
next143:9446fb6df0c5
author nkeynes
date Tue May 02 14:09:11 2006 +0000 (14 years ago)
permissions -rw-r--r--
last change Add packet.h
Implement read toc, request sense, test ready commands.
Fix failure to clear error status on new command
file annotate diff log raw
nkeynes@125
     1
/**
nkeynes@142
     2
 * $Id: gdrom.h,v 1.3 2006-05-02 14:09:11 nkeynes Exp $
nkeynes@125
     3
 *
nkeynes@125
     4
 * This file defines the structures and functions used by the GD-Rom
nkeynes@125
     5
 * disc driver. (ie, the modules that supply a CD image to be used by the
nkeynes@125
     6
 * system).
nkeynes@125
     7
 *
nkeynes@125
     8
 * Copyright (c) 2005 Nathan Keynes.
nkeynes@125
     9
 *
nkeynes@125
    10
 * This program is free software; you can redistribute it and/or modify
nkeynes@125
    11
 * it under the terms of the GNU General Public License as published by
nkeynes@125
    12
 * the Free Software Foundation; either version 2 of the License, or
nkeynes@125
    13
 * (at your option) any later version.
nkeynes@125
    14
 *
nkeynes@125
    15
 * This program is distributed in the hope that it will be useful,
nkeynes@125
    16
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
nkeynes@125
    17
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
nkeynes@125
    18
 * GNU General Public License for more details.
nkeynes@125
    19
 */
nkeynes@125
    20
nkeynes@125
    21
#ifndef dream_gdrom_H
nkeynes@125
    22
#define dream_gdrom_H 1
nkeynes@125
    23
nkeynes@125
    24
#include "dream.h"
nkeynes@125
    25
nkeynes@138
    26
struct gdrom_toc {
nkeynes@142
    27
    uint32_t track[99];
nkeynes@125
    28
    uint32_t first, last, leadout;
nkeynes@138
    29
};
nkeynes@138
    30
nkeynes@138
    31
#define GDROM_PREGAP 150  /* Sectors */
nkeynes@138
    32
nkeynes@138
    33
extern uint32_t gdrom_sector_size[];
nkeynes@138
    34
#define GDROM_SECTOR_SIZE(x) gdrom_sector_size[x]
nkeynes@138
    35
typedef enum {
nkeynes@138
    36
    GDROM_MODE1,
nkeynes@138
    37
    GDROM_MODE2,
nkeynes@138
    38
    GDROM_MODE2_XA1,
nkeynes@138
    39
    GDROM_MODE2_XA2,
nkeynes@138
    40
    GDROM_CDDA,
nkeynes@138
    41
    GDROM_GD
nkeynes@138
    42
} gdrom_track_mode_t;
nkeynes@138
    43
nkeynes@138
    44
/* The disc register indicates the current contents of the drive. When open
nkeynes@138
    45
 * contains 0x06.
nkeynes@138
    46
 */
nkeynes@138
    47
#define IDE_DISC_AUDIO 0x00
nkeynes@138
    48
#define IDE_DISC_NONE  0x06
nkeynes@138
    49
#define IDE_DISC_CDROM 0x20
nkeynes@138
    50
#define IDE_DISC_GDROM 0x80
nkeynes@138
    51
#define IDE_DISC_READY 0x01 /* ored with above */
nkeynes@138
    52
#define IDE_DISC_IDLE  0x02 /* ie spun-down */
nkeynes@138
    53
nkeynes@142
    54
#define TRACK_PRE_EMPHASIS   0x10
nkeynes@142
    55
#define TRACK_COPY_PERMITTED 0x20
nkeynes@142
    56
#define TRACK_DATA           0x40
nkeynes@142
    57
#define TRACK_FOUR_CHANNEL   0x80
nkeynes@142
    58
nkeynes@138
    59
struct gdrom_track {
nkeynes@138
    60
    gdrom_track_mode_t mode;
nkeynes@142
    61
    uint8_t flags;        /* Track flags */
nkeynes@138
    62
    int      session;     /* session # containing this track */
nkeynes@138
    63
    uint32_t lba;         /* start sector address */
nkeynes@138
    64
    uint32_t sector_size; /* For convenience, determined by mode */
nkeynes@138
    65
    uint32_t sector_count;
nkeynes@138
    66
    uint32_t offset; /* File offset of start of track - image files only */
nkeynes@138
    67
};
nkeynes@125
    68
nkeynes@125
    69
nkeynes@125
    70
typedef struct gdrom_disc {
nkeynes@138
    71
    int disc_type;
nkeynes@138
    72
    int track_count;
nkeynes@138
    73
    struct gdrom_track track[99];
nkeynes@138
    74
    gchar mcn[14]; /* Media catalogue number */
nkeynes@138
    75
    const gchar *filename; /* Image filename */
nkeynes@138
    76
    FILE *file; /* Stream, for image files */
nkeynes@138
    77
    uint32_t (*read_sectors)( struct gdrom_disc *disc,
nkeynes@138
    78
			      uint32_t lba, uint32_t sector_count,
nkeynes@138
    79
			      char *buf );
nkeynes@138
    80
    void (*close)( struct gdrom_disc *disc );
nkeynes@125
    81
} *gdrom_disc_t;
nkeynes@125
    82
nkeynes@138
    83
/**
nkeynes@138
    84
 * Construct a new image file using the default methods.
nkeynes@138
    85
 */
nkeynes@138
    86
gdrom_disc_t gdrom_image_new( FILE *file );
nkeynes@125
    87
nkeynes@138
    88
/**
nkeynes@138
    89
 * Open an image file
nkeynes@138
    90
 */
nkeynes@138
    91
gdrom_disc_t gdrom_image_open( const gchar *filename );
nkeynes@138
    92
gdrom_disc_t nrg_image_open( const gchar *filename );
nkeynes@138
    93
nkeynes@138
    94
/**
nkeynes@138
    95
 * Retrieve the disc table of contents, and write it into the buffer in the 
nkeynes@138
    96
 * format expected by the DC.
nkeynes@138
    97
 * @return TRUE on success, FALSE on failure (eg no disc mounted)
nkeynes@138
    98
 */
nkeynes@138
    99
gboolean gdrom_get_toc( char *buf );
nkeynes@138
   100
nkeynes@138
   101
/**
nkeynes@138
   102
 * Shortcut to open and mount an image file
nkeynes@138
   103
 */
nkeynes@138
   104
gdrom_disc_t gdrom_mount_image( const gchar *filename );
nkeynes@138
   105
nkeynes@138
   106
void gdrom_mount_disc( gdrom_disc_t disc );
nkeynes@138
   107
nkeynes@138
   108
void gdrom_unmount_disc( void );
nkeynes@138
   109
nkeynes@138
   110
gboolean gdrom_is_mounted( void );
nkeynes@138
   111
nkeynes@138
   112
uint32_t gdrom_read_sectors( uint32_t sector, uint32_t sector_count,
nkeynes@138
   113
			     char *buf );
nkeynes@125
   114
nkeynes@125
   115
#endif
.