2004-12-09 22:57:09 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* (c) 2004 Laurent Vivier <LaurentVivier@wanadoo.fr>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LIBEMILE_H
|
|
|
|
#define _LIBEMILE_H
|
|
|
|
|
2004-12-14 23:48:07 +00:00
|
|
|
#include <sys/types.h>
|
2004-12-10 00:22:06 +00:00
|
|
|
#include <sys/stat.h>
|
|
|
|
|
2004-12-09 22:57:09 +00:00
|
|
|
static __attribute__((used)) char* libemile_header = "$CVSHeader$";
|
|
|
|
|
|
|
|
#define SCSI_SUPPORT
|
|
|
|
|
|
|
|
#include "../second/head.h"
|
|
|
|
|
|
|
|
#define EMILE_FIRST_TUNE_DRIVE 0x0001
|
|
|
|
#define EMILE_FIRST_TUNE_OFFSET 0x0002
|
|
|
|
#define EMILE_FIRST_TUNE_SIZE 0x0004
|
|
|
|
|
2004-12-10 00:22:06 +00:00
|
|
|
#define FLOPPY_SECTOR_SIZE 512
|
|
|
|
#define FIRST_LEVEL_SIZE (FLOPPY_SECTOR_SIZE * 2)
|
2004-12-14 23:48:07 +00:00
|
|
|
#define BOOTBLOCK_SIZE (FLOPPY_SECTOR_SIZE * 2)
|
2004-12-10 00:22:06 +00:00
|
|
|
|
2004-12-12 22:57:59 +00:00
|
|
|
enum {
|
|
|
|
EEMILE_CANNOT_READ_FIRST = -2,
|
|
|
|
EEMILE_UNKNOWN_FIRST = -3,
|
|
|
|
EEMILE_CANNOT_WRITE_FIRST = -4,
|
|
|
|
EEMILE_MALLOC_ERROR = -5,
|
|
|
|
EEMILE_CANNOT_OPEN_FILE = -6,
|
|
|
|
EEMILE_CANNOT_WRITE_SECOND = -7,
|
|
|
|
EEMILE_CANNOT_WRITE_KERNEL = -8,
|
|
|
|
EEMILE_CANNOT_WRITE_RAMDISK = -9,
|
|
|
|
EEMILE_CANNOT_WRITE_PAD = -10,
|
|
|
|
EEMILE_CANNOT_CREATE_IMAGE = -11,
|
|
|
|
EEMILE_MISSING_FIRST = -12,
|
|
|
|
EEMILE_MISSING_SECOND = -13,
|
|
|
|
EEMILE_CANNOT_READ_SECOND = -14,
|
|
|
|
EEMILE_INVALID_SECOND = -15,
|
|
|
|
EEMILE_CANNOT_READ_KERNEL = -16,
|
|
|
|
};
|
|
|
|
|
2004-12-14 23:48:07 +00:00
|
|
|
#ifndef _PARTITION_H
|
|
|
|
typedef void emile_map_t;
|
|
|
|
#endif
|
|
|
|
|
2004-12-10 00:22:06 +00:00
|
|
|
static inline unsigned long emile_file_get_size(char* file)
|
|
|
|
{
|
|
|
|
struct stat result;
|
|
|
|
|
|
|
|
stat(file, &result);
|
|
|
|
|
|
|
|
return (result.st_size + FLOPPY_SECTOR_SIZE - 1)
|
|
|
|
/ FLOPPY_SECTOR_SIZE * FLOPPY_SECTOR_SIZE;
|
|
|
|
}
|
|
|
|
|
2004-12-09 22:57:09 +00:00
|
|
|
extern int emile_first_set_param(int fd, unsigned short tune_mask,
|
2004-12-10 00:22:06 +00:00
|
|
|
int drive_num, int second_offset,
|
|
|
|
int second_size);
|
|
|
|
extern int emile_first_get_param(int fd, int *drive_num, int *second_offset,
|
|
|
|
int *second_size);
|
2004-12-09 22:57:09 +00:00
|
|
|
extern int emile_first_set_param_scsi(int fd, char *second_name);
|
|
|
|
extern int emile_second_get_output(int fd, unsigned int *console_mask,
|
|
|
|
unsigned int *bitrate0, int *datasize0,
|
|
|
|
int *parity0, int *stopbits0,
|
|
|
|
unsigned int *bitrate1, int *datasize1,
|
|
|
|
int *parity1, int *stopbits1,
|
|
|
|
int *gestaltid);
|
|
|
|
extern int emile_second_set_output(int fd,
|
|
|
|
unsigned int enable_mask,
|
|
|
|
unsigned int disable_mask,
|
|
|
|
unsigned int bitrate0, int datasize0,
|
|
|
|
int parity0, int stopbits0,
|
|
|
|
unsigned int bitrate1, int datasize1,
|
|
|
|
int parity1, int stopbits1, int gestaltid);
|
|
|
|
extern int emile_second_set_cmdline(int fd, char* cmdline);
|
|
|
|
extern int emile_second_get_cmdline(int fd, char* cmdline);
|
|
|
|
extern int emile_second_set_kernel(int fd, char *kernel_image,
|
2004-12-14 23:48:07 +00:00
|
|
|
unsigned int kernel_offset, char* ramdisk);
|
2004-12-09 22:57:09 +00:00
|
|
|
extern int emile_second_get_kernel(int fd, unsigned int *kernel_offset,
|
|
|
|
unsigned int *kernel_image_size,
|
|
|
|
unsigned int *ramdisk_offset,
|
|
|
|
unsigned int *ramdisk_size);
|
2004-12-14 23:48:07 +00:00
|
|
|
extern int emile_second_set_buffer_size(int fd, unsigned int buffer_size);
|
|
|
|
extern int emile_second_get_buffer_size(int fd, unsigned int *buffer_size);
|
2004-12-10 00:22:06 +00:00
|
|
|
extern int emile_second_set_kernel_scsi(int fd, char *kernel_name);
|
|
|
|
extern int emile_floppy_create_image(char* first_level, char* second_level,
|
|
|
|
char* kernel_image, char* ramdisk,
|
|
|
|
unsigned long buffer_size, char* image);
|
2004-12-09 22:57:09 +00:00
|
|
|
extern int emile_scsi_create_container(int fd,
|
|
|
|
struct emile_container* container);
|
2004-12-14 23:48:07 +00:00
|
|
|
extern emile_map_t* emile_map_open(char* dev, int flags);
|
|
|
|
extern void emile_map_close(emile_map_t *map);
|
|
|
|
extern int emile_map_read(emile_map_t *map, int part);
|
|
|
|
extern int emile_map_write(emile_map_t *map, int part);
|
|
|
|
extern int emile_map_partition_is_valid(emile_map_t *map);
|
|
|
|
extern int emile_map_get_partition_geometry(emile_map_t *map, int *start, int *count);
|
|
|
|
extern int emile_map_get_partition_type(emile_map_t *map, char** type);
|
|
|
|
extern int emile_map_get_partition_name(emile_map_t *map, char** name);
|
|
|
|
extern int emile_map_partition_is_bootable(emile_map_t *map);
|
|
|
|
extern int emile_map_partition_is_startup(emile_map_t *map);
|
|
|
|
extern int emile_map_set_partition_type(emile_map_t *map, char* type);
|
|
|
|
extern int emile_map_set_partition_name(emile_map_t *map, char* name);
|
|
|
|
extern int emile_map_partition_set_bootable(emile_map_t *map, int enable);
|
|
|
|
extern int emile_map_partition_set_startup(emile_map_t *map, int enable);
|
|
|
|
extern int emile_map_is_valid(emile_map_t *map);
|
|
|
|
extern int emile_map_geometry(emile_map_t *map, int *block_size,
|
|
|
|
int *block_count);
|
|
|
|
extern int emile_map_get_driver_number(emile_map_t *map);
|
|
|
|
extern int emile_map_get_driver_info(emile_map_t *map, int number,
|
|
|
|
int *block, int *size, int* type);
|
|
|
|
extern int emile_map_read_bootblock(emile_map_t* map, char* bootblock);
|
|
|
|
extern int emile_map_write_bootblock(emile_map_t* map, char* bootblock);
|
|
|
|
extern int emile_map_bootblock_is_valid(char *bootblock);
|
2004-12-09 22:57:09 +00:00
|
|
|
#endif
|