1
0
mirror of https://github.com/vivier/EMILE.git synced 2025-01-14 10:29:48 +00:00
EMILE/tools/emile-install.c

252 lines
5.8 KiB
C
Raw Normal View History

2004-06-01 21:56:28 +00:00
/*
*
* (c) 2004 Laurent Vivier <LaurentVivier@wanadoo.fr>
*
*/
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <string.h>
#include <getopt.h>
2004-06-01 21:56:28 +00:00
2004-12-10 00:28:35 +00:00
#include "libemile.h"
2004-06-01 21:56:28 +00:00
enum {
ARG_NONE = 0,
ARG_HELP ='h',
ARG_VERBOSE = 'v',
ARG_FIRST = 'f',
ARG_SECOND = 's',
ARG_KERNEL = 'k',
ARG_RAMDISK = 'r',
ARG_BUFFER ='b',
2004-12-25 00:48:29 +00:00
ARG_GETINFO = 'g',
};
static struct option long_options[] =
{
{"help", 0, NULL, ARG_HELP },
{"verbose", 0, NULL, ARG_VERBOSE },
{"first", 1, NULL, ARG_FIRST },
{"second", 1, NULL, ARG_SECOND },
{"kernel", 1, NULL, ARG_KERNEL },
{"ramdisk", 1, NULL, ARG_RAMDISK },
{"buffer", 1, NULL, ARG_BUFFER },
2004-12-25 00:48:29 +00:00
{"getinfo", 1, NULL, ARG_GETINFO },
{NULL, 0, NULL, 0 },
};
2004-06-01 21:56:28 +00:00
static void usage(int argc, char** argv)
{
fprintf(stderr, "Usage: %s [OPTION] <image>\n", argv[0]);
fprintf(stderr, "Create an EMILE bootable floppy disk\n");
fprintf(stderr, "EMILE allows you to boot linux from a floppy disk\n");
fprintf(stderr, " -h, --help display this text\n");
fprintf(stderr, " -v, --verbose verbose mode\n");
fprintf(stderr, " -f, --first first level to copy to floppy\n");
fprintf(stderr, " -s, --second second level to copy to floppy\n");
fprintf(stderr, " -k, --kernel kernel to copy to floppy\n");
fprintf(stderr, " -r, --ramdisk ramdisk to copy to floppy\n");
fprintf(stderr, " -b, --buffer buffer size to decompress kernel\n");
2004-12-25 00:48:29 +00:00
fprintf(stderr, " -g, --getinfo get information from >image>\n");
2004-06-03 11:09:28 +00:00
fprintf(stderr, "\nbuild: \n%s\n", SIGNATURE);
2004-06-01 21:56:28 +00:00
}
int main(int argc, char** argv)
{
int verbose = 0;
int option_index = 0;
2004-06-01 21:56:28 +00:00
char* first_level = NULL;
char* second_level = NULL;
char* kernel_image = NULL;
char* ramdisk = NULL;
unsigned long buffer_size = 0;
char* image = NULL;
2004-12-25 00:48:29 +00:00
int action_getinfo = 0;
int c;
2004-06-01 21:56:28 +00:00
int ret;
while(1)
{
2004-12-25 00:48:29 +00:00
c = getopt_long(argc, argv, "hvf:s:k:r:b:g", long_options,
&option_index);
if (c == -1)
break;
switch(c)
{
case ARG_HELP:
usage(argc, argv);
return 0;
case ARG_VERBOSE:
verbose = 1;
break;
case ARG_FIRST:
first_level = optarg;
break;
case ARG_SECOND:
second_level = optarg;
break;
case ARG_KERNEL:
kernel_image = optarg;
break;
case ARG_RAMDISK:
ramdisk = optarg;
break;
case ARG_BUFFER:
buffer_size = atol(optarg);
break;
2004-12-25 00:48:29 +00:00
case ARG_GETINFO:
action_getinfo = 1;
break;
}
}
if (optind < argc)
image = argv[optind];
if (image == NULL)
2004-06-01 21:56:28 +00:00
{
fprintf(stderr,
"ERROR: you must provide an image file or a block device.\n");
2004-06-01 21:56:28 +00:00
usage(argc, argv);
return 1;
}
2004-12-25 00:48:29 +00:00
if (action_getinfo)
{
int fd;
int drive_num;
int second_offset;
int second_size;
int buffer_size;
int kernel_offset;
int kernel_image_size;
int ramdisk_offset;
int ramdisk_size;
fd = open(image, O_RDONLY);
if (fd == -1)
{
fprintf(stderr, "ERROR: cannot open \"%s\"\n",
image);
return 2;
}
/* first level info */
ret = emile_first_get_param(fd, &drive_num, &second_offset,
&second_size);
if (ret == 0)
{
printf("EMILE boot block identified\n\n");
printf("Drive number: %d\n", drive_num);
printf("Second level offset: %d\n", second_offset);
printf("Second level size: %d\n", second_size);
/* second level info */
ret = emile_second_get_kernel(fd, &kernel_offset,
&kernel_image_size,
&ramdisk_offset,
&ramdisk_size);
if (ret != 0)
{
fprintf(stderr, "ERROR: cannot read second level\n");
return 3;
}
printf("Kernel image offset: %d\n", kernel_offset);
printf("Kernel image size: %d\n", kernel_image_size);
printf("Ramdisk offset: %d\n", ramdisk_offset);
printf("Ramdisk size: %d\n", ramdisk_size);
lseek(fd, FIRST_LEVEL_SIZE, SEEK_SET);
ret = emile_second_get_buffer_size(fd, &buffer_size);
if (ret != 0)
{
fprintf(stderr, "ERROR: cannot read second level\n");
return 3;
}
printf("Buffer size: %d\n", buffer_size);
}
else
printf("EMILE is not installed in this bootblock\n");
close(fd);
return 0;
}
if (first_level == NULL)
first_level = PREFIX "/lib/emile/first_floppy";
if (second_level == NULL)
second_level = PREFIX "/lib/emile/second_floppy";
if (kernel_image == NULL)
kernel_image = PREFIX "/boot/vmlinuz";
if (buffer_size == 0)
2004-06-01 21:56:28 +00:00
{
buffer_size = emile_get_uncompressed_size(kernel_image);
if (buffer_size == -1)
2004-06-01 21:56:28 +00:00
{
fprintf(stderr,
"ERROR: cannot compute size of uncompressed kernel\n");
fprintf(stderr,
" use \"--buffer <size>\" to set it or set path of gzip in PATH\n");
fprintf(stderr,
" or check \"%s\" can be read\n", kernel_image);
return 2;
2004-06-01 21:56:28 +00:00
}
}
if (verbose)
{
printf("first: %s\n", first_level);
printf("second: %s\n", second_level);
printf("kernel: %s\n", kernel_image);
printf("buffer: %ld\n", buffer_size);
printf("ramdisk: %s\n", ramdisk);
printf("image: %s\n", image);
}
2004-12-10 00:28:35 +00:00
ret = emile_floppy_create_image(first_level, second_level,
kernel_image, ramdisk, buffer_size,
image);
switch(ret)
{
case 0:
break;
case EEMILE_CANNOT_WRITE_FIRST:
fprintf(stderr, "ERROR: cannot write first\n");
break;
case EEMILE_CANNOT_WRITE_SECOND:
fprintf(stderr, "ERROR: cannot write second\n");
break;
case EEMILE_CANNOT_WRITE_KERNEL:
fprintf(stderr, "ERROR: cannot write kernel\n");
break;
case EEMILE_CANNOT_WRITE_RAMDISK:
fprintf(stderr, "ERROR: cannot write ramdisk\n");
break;
case EEMILE_CANNOT_WRITE_PAD:
fprintf(stderr, "ERROR: cannot write padding\n");
break;
case EEMILE_CANNOT_CREATE_IMAGE:
fprintf(stderr, "ERROR: cannot create image\n");
break;
case EEMILE_CANNOT_OPEN_FILE:
fprintf(stderr, "ERROR: cannot open one of provided files\n");
break;
default:
fprintf(stderr, "ERROR: unknown error :-P\n");
break;
}
2004-06-01 21:56:28 +00:00
return ret;
}