mirror of
https://github.com/vivier/EMILE.git
synced 2025-02-26 15:29:12 +00:00
add all stuff to set firt level, second level and boot block, change exit values
This commit is contained in:
parent
3275b7c941
commit
1d7a624f7d
274
tools/emile.c
274
tools/emile.c
@ -25,9 +25,17 @@ static char *second_path = PREFIX "/boot/emile/second_scsi";
|
|||||||
static char *kernel_path = PREFIX "/boot/vmlinuz";
|
static char *kernel_path = PREFIX "/boot/vmlinuz";
|
||||||
static char *backup_path = NULL;
|
static char *backup_path = NULL;
|
||||||
static char *partition = NULL;
|
static char *partition = NULL;
|
||||||
|
static char *append_string = NULL;
|
||||||
static int buffer_size = 0;
|
static int buffer_size = 0;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
ARG_NONE = 0,
|
||||||
|
ARG_SCANBUS,
|
||||||
|
ARG_SET_HFS,
|
||||||
|
ARG_SET_STARTUP,
|
||||||
|
ARG_BACKUP,
|
||||||
|
ARG_TEST,
|
||||||
|
ARG_APPEND,
|
||||||
ARG_VERBOSE ='v',
|
ARG_VERBOSE ='v',
|
||||||
ARG_FIRST = 'f',
|
ARG_FIRST = 'f',
|
||||||
ARG_SECOND = 's',
|
ARG_SECOND = 's',
|
||||||
@ -35,28 +43,24 @@ enum {
|
|||||||
ARG_BUFFER = 'b',
|
ARG_BUFFER = 'b',
|
||||||
ARG_PARTITION = 'p',
|
ARG_PARTITION = 'p',
|
||||||
ARG_HELP = 'h',
|
ARG_HELP = 'h',
|
||||||
ARG_SCANBUS = 1,
|
|
||||||
ARG_SET_HFS = 2,
|
|
||||||
ARG_SET_STARTUP = 3,
|
|
||||||
ARG_BACKUP_BOOTBLOCK = 4,
|
|
||||||
ARG_TEST = 5,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct option long_options[] =
|
static struct option long_options[] =
|
||||||
{
|
{
|
||||||
{"verbose", 0, NULL, ARG_VERBOSE},
|
{"verbose", 0, NULL, ARG_VERBOSE },
|
||||||
{"first", 1, NULL, ARG_FIRST},
|
{"first", 1, NULL, ARG_FIRST },
|
||||||
{"second", 1, NULL, ARG_SECOND},
|
{"second", 1, NULL, ARG_SECOND },
|
||||||
{"kernel", 1, NULL, ARG_KERNEL},
|
{"kernel", 1, NULL, ARG_KERNEL },
|
||||||
{"buffer", 1, NULL, ARG_BUFFER},
|
{"buffer", 1, NULL, ARG_BUFFER },
|
||||||
{"partition", 1, NULL, ARG_PARTITION},
|
{"partition", 1, NULL, ARG_PARTITION },
|
||||||
{"help", 0, NULL, ARG_HELP},
|
{"help", 0, NULL, ARG_HELP },
|
||||||
{"scanbus", 0, NULL, ARG_SCANBUS},
|
{"scanbus", 0, NULL, ARG_SCANBUS },
|
||||||
{"set-hfs", 1, NULL, ARG_SET_HFS },
|
{"set-hfs", 1, NULL, ARG_SET_HFS },
|
||||||
{"set-startup", 0, NULL, ARG_SET_STARTUP },
|
{"set-startup", 0, NULL, ARG_SET_STARTUP },
|
||||||
{"backup-bootblock", 2, NULL, ARG_BACKUP_BOOTBLOCK },
|
{"backup", 2, NULL, ARG_BACKUP },
|
||||||
{"test", 0, NULL, ARG_TEST },
|
{"test", 0, NULL, ARG_TEST },
|
||||||
{NULL, 0, NULL, 0}
|
{"append", 0, NULL, ARG_APPEND },
|
||||||
|
{NULL, 0, NULL, 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
static void usage(int argc, char** argv)
|
static void usage(int argc, char** argv)
|
||||||
@ -213,6 +217,44 @@ static int backup_bootblock(char *dev_name, char *filename)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int copy_file_to_bootblock(char* first_path, char* dev_name)
|
||||||
|
{
|
||||||
|
emile_map_t *map;
|
||||||
|
int ret;
|
||||||
|
int partition;
|
||||||
|
char bootblock[BOOTBLOCK_SIZE];
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
/* read first level */
|
||||||
|
|
||||||
|
fd = open(first_path, O_RDONLY);
|
||||||
|
if (fd == -1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
ret = read(fd, bootblock, BOOTBLOCK_SIZE);
|
||||||
|
if (ret != BOOTBLOCK_SIZE)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
/* write bootblock to partition */
|
||||||
|
|
||||||
|
ret = open_map_of(dev_name, O_RDWR, &map, &partition);
|
||||||
|
if (ret == -1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
ret = emile_map_read(map, partition - 1);
|
||||||
|
if (ret == -1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
ret = emile_map_bootblock_write(map, bootblock);
|
||||||
|
if (ret == -1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
emile_map_close(map);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
@ -225,6 +267,8 @@ int main(int argc, char **argv)
|
|||||||
int action_set_buffer = 0;
|
int action_set_buffer = 0;
|
||||||
int action_test = 0;
|
int action_test = 0;
|
||||||
char tmp_partition[16];
|
char tmp_partition[16];
|
||||||
|
char tmp_append[512];
|
||||||
|
int fd;
|
||||||
|
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
@ -264,13 +308,16 @@ int main(int argc, char **argv)
|
|||||||
case ARG_SET_STARTUP:
|
case ARG_SET_STARTUP:
|
||||||
action_set_startup = 1;
|
action_set_startup = 1;
|
||||||
break;
|
break;
|
||||||
case ARG_BACKUP_BOOTBLOCK:
|
case ARG_BACKUP:
|
||||||
action_backup_bootblock = 1;
|
action_backup_bootblock = 1;
|
||||||
if (optarg != NULL)
|
if (optarg != NULL)
|
||||||
backup_path = optarg;
|
backup_path = optarg;
|
||||||
else
|
else
|
||||||
backup_path = PREFIX "/boot/emile/bootblock.backup";
|
backup_path = PREFIX "/boot/emile/bootblock.backup";
|
||||||
break;
|
break;
|
||||||
|
case ARG_APPEND:
|
||||||
|
append_string = optarg;
|
||||||
|
break;
|
||||||
case ARG_TEST:
|
case ARG_TEST:
|
||||||
action_test = 1;
|
action_test = 1;
|
||||||
break;
|
break;
|
||||||
@ -278,23 +325,42 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (action_scanbus) {
|
if (action_scanbus) {
|
||||||
|
|
||||||
|
if (action_test) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: \"--scanbus\" cannot be used with \"--test\"\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
scanbus();
|
scanbus();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (partition == NULL)
|
if (partition == NULL)
|
||||||
{
|
{
|
||||||
if (partition == NULL)
|
int fd;
|
||||||
{
|
fd = open(second_path, O_RDONLY);
|
||||||
int fd;
|
if (fd == -1)
|
||||||
fd = open(second_path, O_RDONLY);
|
return 2;
|
||||||
if (fd == -1)
|
ret = emile_scsi_get_dev(tmp_partition, fd);
|
||||||
return -1;
|
if (ret != -1)
|
||||||
ret = emile_scsi_get_dev(tmp_partition, fd);
|
partition = tmp_partition;
|
||||||
if (ret != -1)
|
close(fd);
|
||||||
partition = tmp_partition;
|
}
|
||||||
close(fd);
|
|
||||||
}
|
if (partition == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: you must specify a partition to set EMILE bootblock\n");
|
||||||
|
fprintf(stderr,
|
||||||
|
" you can have the list of available partitions with \"--scanbus\".\n");
|
||||||
|
return 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (append_string == NULL)
|
||||||
|
{
|
||||||
|
sprintf(tmp_append, "root=%s", partition);
|
||||||
|
append_string = tmp_append;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = check_has_apple_driver(partition);
|
ret = check_has_apple_driver(partition);
|
||||||
@ -303,7 +369,7 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr, "ERROR: cannot check if Apple_Driver exists\n");
|
fprintf(stderr, "ERROR: cannot check if Apple_Driver exists\n");
|
||||||
fprintf(stderr, " you should try as root\n");
|
fprintf(stderr, " you should try as root\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 4;
|
||||||
}
|
}
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
{
|
{
|
||||||
@ -314,7 +380,7 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
" or wait a release of EMILE allowing you to add this driver\n");
|
" or wait a release of EMILE allowing you to add this driver\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 5;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = check_is_hfs(partition);
|
ret = check_is_hfs(partition);
|
||||||
@ -324,7 +390,7 @@ int main(int argc, char **argv)
|
|||||||
"ERROR: cannot check if partition is Apple_HFS\n");
|
"ERROR: cannot check if partition is Apple_HFS\n");
|
||||||
fprintf(stderr, " you should try as root\n");
|
fprintf(stderr, " you should try as root\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 6;
|
||||||
}
|
}
|
||||||
if ( (ret == 0) && (action_set_hfs == 0) )
|
if ( (ret == 0) && (action_set_hfs == 0) )
|
||||||
{
|
{
|
||||||
@ -333,7 +399,7 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
" you can change it to Apple_HFS using \"--set-hfs\" argument\n");
|
" you can change it to Apple_HFS using \"--set-hfs\" argument\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 7;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = check_is_EMILE_bootblock(partition);
|
ret = check_is_EMILE_bootblock(partition);
|
||||||
@ -342,16 +408,16 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr, "ERROR: cannot check bootblock type\n");
|
fprintf(stderr, "ERROR: cannot check bootblock type\n");
|
||||||
fprintf(stderr, " you should try as root\n");
|
fprintf(stderr, " you should try as root\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 8;
|
||||||
}
|
}
|
||||||
if ( (ret == 0) && (action_backup_bootblock == 0) )
|
if ( (ret == 0) && (action_backup_bootblock == 0) )
|
||||||
{
|
{
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"ERROR: there is already a bootblock on \"%s\"\n", partition);
|
"ERROR: there is already a bootblock on \"%s\"\n", partition);
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
" you must use \"--backup-bootblock\" to save it\n");
|
" you must use \"--backup\" to save it\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 9;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = check_is_startup(partition);
|
ret = check_is_startup(partition);
|
||||||
@ -361,7 +427,7 @@ int main(int argc, char **argv)
|
|||||||
"ERROR: cannot check if it is startup partition\n");
|
"ERROR: cannot check if it is startup partition\n");
|
||||||
fprintf(stderr, " you should try as root\n");
|
fprintf(stderr, " you should try as root\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 10;
|
||||||
}
|
}
|
||||||
if ( (ret == 0) && (action_set_startup == 0) )
|
if ( (ret == 0) && (action_set_startup == 0) )
|
||||||
{
|
{
|
||||||
@ -372,7 +438,7 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
" you can use later \"emile-set-startup\" to change it\n");
|
" you can use later \"emile-set-startup\" to change it\n");
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 11;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action_set_buffer == 0)
|
if (action_set_buffer == 0)
|
||||||
@ -387,7 +453,7 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
" or check \"%s\" can be read\n", kernel_path);
|
" or check \"%s\" can be read\n", kernel_path);
|
||||||
if (action_test == 0)
|
if (action_test == 0)
|
||||||
return -1;
|
return 12;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -396,8 +462,8 @@ int main(int argc, char **argv)
|
|||||||
if (action_test)
|
if (action_test)
|
||||||
{
|
{
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"ERROR: \"--backup-bootblock\" cannot be used with \"--test\"\n");
|
"ERROR: \"--backup\" cannot be used with \"--test\"\n");
|
||||||
return -1;
|
return 13;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = backup_bootblock(partition, backup_path);
|
ret = backup_bootblock(partition, backup_path);
|
||||||
@ -406,59 +472,99 @@ int main(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"ERROR: cannot backup bootblock %s to %s\n",
|
"ERROR: cannot backup bootblock %s to %s\n",
|
||||||
partition, backup_path);
|
partition, backup_path);
|
||||||
return -1;
|
return 14;
|
||||||
}
|
}
|
||||||
printf("Bootblock backup successfully done.\n");
|
printf("Bootblock backup successfully done.\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printf("partition: %s\n", partition);
|
||||||
printf("first: %s\n", first_path);
|
printf("first: %s\n", first_path);
|
||||||
printf("second: %s\n", second_path);
|
printf("second: %s\n", second_path);
|
||||||
printf("kernel: %s\n", kernel_path);
|
printf("kernel: %s\n", kernel_path);
|
||||||
|
printf("append: %s\n", append_string);
|
||||||
printf("buffer size: %d\n", buffer_size);
|
printf("buffer size: %d\n", buffer_size);
|
||||||
printf("partition: %s\n", partition);
|
|
||||||
#if 0
|
|
||||||
int fd;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* set kernel info in second level */
|
if (action_test == 0)
|
||||||
|
|
||||||
fd = open(argv[2], O_RDWR); /* second */
|
|
||||||
if (fd == -1)
|
|
||||||
{
|
{
|
||||||
perror("Cannot open second stage");
|
/* set kernel info into second level */
|
||||||
return 1;
|
|
||||||
|
fd = open(second_path, O_RDWR);
|
||||||
|
if (fd == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "ERROR: cannot open \"%s\"\n",
|
||||||
|
second_path);
|
||||||
|
return 15;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set kernel info */
|
||||||
|
|
||||||
|
ret = emile_second_set_kernel_scsi(fd, kernel_path);
|
||||||
|
if (ret == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot set \"%s\" information in \"%s\".\n",
|
||||||
|
kernel_path, second_path);
|
||||||
|
return 16;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set buffer size */
|
||||||
|
|
||||||
|
lseek(fd, 0, SEEK_SET);
|
||||||
|
ret = emile_second_set_buffer_size(fd, buffer_size);
|
||||||
|
if (ret == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot set buffer size in \"%s\".\n", second_path);
|
||||||
|
return 17;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set cmdline */
|
||||||
|
|
||||||
|
lseek(fd, 0, SEEK_SET);
|
||||||
|
ret = emile_second_set_cmdline(fd, append_string);
|
||||||
|
if (ret == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot set append string \"%s\" in \"%s\".\n",
|
||||||
|
append_string, second_path);
|
||||||
|
return 18;
|
||||||
|
}
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
/* set second info in first level */
|
||||||
|
|
||||||
|
fd = open(first_path, O_RDWR);
|
||||||
|
if (fd == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot open \"%s\".\n", first_path);
|
||||||
|
return 19;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = emile_first_set_param_scsi(fd, second_path);
|
||||||
|
if (ret == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot set \"%s\" information into \"%s\".\n",
|
||||||
|
second_path, first_path);
|
||||||
|
return 20;
|
||||||
|
}
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
/* copy first level to boot block */
|
||||||
|
|
||||||
|
ret = copy_file_to_bootblock(first_path, partition);
|
||||||
|
if (ret == -1)
|
||||||
|
{
|
||||||
|
fprintf(stderr,
|
||||||
|
"ERROR: cannot write \"%s\" to bootblock of \"%s\".\n",
|
||||||
|
first_path, partition);
|
||||||
|
fprintf(stderr,
|
||||||
|
" %s\n", strerror(errno));
|
||||||
|
return 21;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* set buffer size */
|
|
||||||
|
|
||||||
printf("Setting buffer size to %d\n", atoi(argv[4]));
|
|
||||||
ret = emile_second_set_buffer_size(fd, atoi(argv[4]));
|
|
||||||
|
|
||||||
/* set cmdline */
|
|
||||||
|
|
||||||
lseek(fd, 0, SEEK_SET);
|
|
||||||
printf("Setting command line to %s\n", argv[5]);
|
|
||||||
ret = emile_second_set_cmdline(fd, argv[5]);
|
|
||||||
|
|
||||||
/* set kernel info */
|
|
||||||
|
|
||||||
lseek(fd, 0, SEEK_SET);
|
|
||||||
ret = emile_second_set_kernel_scsi(fd, argv[3]);
|
|
||||||
|
|
||||||
close(fd);
|
|
||||||
|
|
||||||
/* set second info in first level */
|
|
||||||
|
|
||||||
fd = open(argv[1], O_RDWR);
|
|
||||||
if (fd == -1)
|
|
||||||
{
|
|
||||||
perror("Cannot open first stage");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = emile_first_set_param_scsi(fd, argv[2]);
|
|
||||||
close(fd);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user