2006-10-30 05:32:33 +00:00
|
|
|
/* -*- indent-tabs-mode: t; tab-width: 8; c-basic-offset: 8; -*- */
|
|
|
|
|
|
|
|
#ifndef __DRIVE
|
|
|
|
#define __DRIVE
|
|
|
|
|
|
|
|
#include "libburn.h"
|
|
|
|
#include "toc.h"
|
|
|
|
#include "structure.h"
|
|
|
|
|
|
|
|
struct burn_drive;
|
|
|
|
struct command;
|
|
|
|
struct mempage;
|
2006-12-26 17:07:53 +00:00
|
|
|
struct scsi_mode_data;
|
|
|
|
struct burn_speed_descriptor;
|
2006-10-30 05:32:33 +00:00
|
|
|
|
|
|
|
#define LEAD_IN 1
|
|
|
|
#define GAP 2
|
|
|
|
#define USER_DATA 3
|
|
|
|
#define LEAD_OUT 4
|
|
|
|
#define SYNC 5
|
|
|
|
|
|
|
|
#define SESSION_LEADOUT_ENTRY(d,s) (d)->toc->session[(s)].leadout_entry
|
|
|
|
|
|
|
|
#define CURRENT_SESSION_START(d) \
|
|
|
|
burn_msf_to_lba(d->toc->session[d->currsession].start_m, \
|
|
|
|
d->toc->session[d->currsession].start_s, \
|
|
|
|
d->toc->session[d->currsession].start_f)
|
|
|
|
|
|
|
|
#define SESSION_END(d,s) \
|
|
|
|
TOC_ENTRY_PLBA((d)->toc, SESSION_LEADOUT_ENTRY((d), (s)))
|
|
|
|
|
|
|
|
#define PREVIOUS_SESSION_END(d) \
|
|
|
|
TOC_ENTRY_PLBA((d)->toc, SESSION_LEADOUT_ENTRY((d), (d)->currsession-1))
|
|
|
|
|
|
|
|
#define LAST_SESSION_END(d) \
|
|
|
|
TOC_ENTRY_PLBA((d)->toc, \
|
|
|
|
SESSION_LEADOUT_ENTRY((d), (d)->toc->sessions-1))
|
|
|
|
|
|
|
|
struct burn_drive *burn_drive_register(struct burn_drive *);
|
|
|
|
int burn_drive_unregister(struct burn_drive *d);
|
|
|
|
|
|
|
|
unsigned int burn_drive_count(void);
|
|
|
|
|
|
|
|
/* ts A61007 */
|
|
|
|
/* void burn_wait_all(void); */
|
2007-09-07 15:50:31 +00:00
|
|
|
/* @param flag bit0= demand freed drives (else released drives) */
|
|
|
|
int burn_drives_are_clear(int flag);
|
2006-10-30 05:32:33 +00:00
|
|
|
|
|
|
|
int burn_sector_length_write(struct burn_drive *d);
|
|
|
|
int burn_track_control(struct burn_drive *d, int);
|
|
|
|
void burn_write_empty_sector(int fd);
|
|
|
|
void burn_write_empty_subcode(int fd);
|
|
|
|
void burn_drive_free(struct burn_drive *d);
|
|
|
|
void burn_drive_free_all(void);
|
|
|
|
|
2007-09-07 16:45:37 +00:00
|
|
|
/* @param flag bit0= reset global drive list */
|
2006-10-30 05:32:33 +00:00
|
|
|
int burn_drive_scan_sync(struct burn_drive_info *drives[],
|
2007-09-07 16:45:37 +00:00
|
|
|
unsigned int *n_drives, int flag);
|
|
|
|
|
2006-10-30 05:32:33 +00:00
|
|
|
void burn_disc_erase_sync(struct burn_drive *d, int fast);
|
|
|
|
int burn_drive_get_block_types(struct burn_drive *d,
|
|
|
|
enum burn_write_types write_type);
|
|
|
|
|
|
|
|
int burn_drive_is_open(struct burn_drive *d);
|
|
|
|
int burn_drive_is_occupied(struct burn_drive *d);
|
|
|
|
int burn_drive_forget(struct burn_drive *d, int force);
|
|
|
|
int burn_drive_convert_fs_adr_sub(char *path, char adr[], int *rec_count);
|
|
|
|
|
|
|
|
/* ts A61021 : the unspecific part of sg.c:enumerate_common()
|
|
|
|
*/
|
|
|
|
int burn_setup_drive(struct burn_drive *d, char *fname);
|
|
|
|
|
|
|
|
/* ts A61021 : after-setup activities from sg.c:enumerate_common()
|
|
|
|
*/
|
|
|
|
struct burn_drive *burn_drive_finish_enum(struct burn_drive *d);
|
|
|
|
|
2006-11-25 15:26:35 +00:00
|
|
|
/* ts A61125 : media status aspects of burn_drive_grab() */
|
|
|
|
int burn_drive_inquire_media(struct burn_drive *d);
|
|
|
|
|
|
|
|
/* ts A61125 : model aspects of burn_drive_release */
|
|
|
|
int burn_drive_mark_unready(struct burn_drive *d);
|
2006-10-30 05:32:33 +00:00
|
|
|
|
2006-12-26 17:07:53 +00:00
|
|
|
|
|
|
|
/* ts A61226 */
|
|
|
|
int burn_speed_descriptor_new(struct burn_speed_descriptor **s,
|
|
|
|
struct burn_speed_descriptor *prev,
|
|
|
|
struct burn_speed_descriptor *next, int flag);
|
|
|
|
|
|
|
|
/* ts A61226 */
|
|
|
|
/* @param flag bit0= destroy whole next-chain of descriptors */
|
|
|
|
int burn_speed_descriptor_destroy(struct burn_speed_descriptor **s, int flag);
|
|
|
|
|
|
|
|
|
|
|
|
/* ts A61226 : free dynamically allocated sub data of struct scsi_mode_data */
|
|
|
|
int burn_mdata_free_subs(struct scsi_mode_data *m);
|
|
|
|
|
2007-01-01 17:10:54 +00:00
|
|
|
|
|
|
|
/* ts A61230 */
|
2007-01-06 12:08:57 +00:00
|
|
|
void burn_disc_format_sync(struct burn_drive *d, off_t size, int flag);
|
2007-01-01 17:10:54 +00:00
|
|
|
|
2007-02-07 16:30:42 +00:00
|
|
|
|
|
|
|
/* ts A70207 : evaluate write mode related peculiarities of a disc */
|
|
|
|
struct burn_disc_mode_demands {
|
|
|
|
int multi_session;
|
|
|
|
int multi_track;
|
2007-02-19 22:51:39 +00:00
|
|
|
int unknown_track_size; /* 0=known, 1=unknown, 2=unknown+defaulted */
|
2007-02-07 16:30:42 +00:00
|
|
|
int mixed_mode;
|
|
|
|
int audio;
|
|
|
|
int exotic_track;
|
2007-02-19 22:51:39 +00:00
|
|
|
int block_types;
|
|
|
|
int will_append; /* because of media state or multi session disc */
|
2007-02-07 16:30:42 +00:00
|
|
|
};
|
|
|
|
int burn_disc_get_write_mode_demands(struct burn_disc *disc,
|
2007-02-19 22:51:39 +00:00
|
|
|
struct burn_write_opts *opts,
|
|
|
|
struct burn_disc_mode_demands *result, int flag);
|
2007-02-07 16:30:42 +00:00
|
|
|
|
2007-09-24 13:54:52 +00:00
|
|
|
|
|
|
|
/* ts A70924 : convert a special stdio address into fd number.
|
|
|
|
@return >0 is a valid fd , -1 indicates unsuitable address string.
|
|
|
|
*/
|
|
|
|
int burn_drive__fd_from_special_adr(char *adr);
|
|
|
|
|
|
|
|
|
2007-09-29 18:50:19 +00:00
|
|
|
/* ts A70929 : Find the drive which is being worked on by pid */
|
|
|
|
int burn_drive_find_by_thread_pid(struct burn_drive **d, pid_t pid);
|
|
|
|
|
|
|
|
|
2006-10-30 05:32:33 +00:00
|
|
|
#endif /* __DRIVE */
|