mirror of
https://github.com/vivier/EMILE.git
synced 2025-01-09 07:30:05 +00:00
107 lines
2.7 KiB
C
107 lines
2.7 KiB
C
static __attribute__((used)) char* rcsid = "$CVSHeader$";
|
|
/*
|
|
*
|
|
* (c) 2004 Laurent Vivier <LaurentVivier@wanadoo.fr>
|
|
*
|
|
*/
|
|
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
#include <stdlib.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
#include <stdio.h>
|
|
|
|
#include "libemile.h"
|
|
#include "emile.h"
|
|
|
|
int emile_second_set_kernel_scsi(int fd, char *kernel_name)
|
|
{
|
|
int fd_kernel;
|
|
int ret;
|
|
emile_l2_header_t header;
|
|
off_t container_offset;
|
|
struct emile_container *container;
|
|
int max_blocks;
|
|
int i;
|
|
unsigned long kernel_image_size;
|
|
|
|
ret = read(fd, &header, sizeof(header));
|
|
if (ret != sizeof(header))
|
|
return EEMILE_CANNOT_READ_SECOND;
|
|
|
|
if (!EMILE_COMPAT(EMILE_04_SIGNATURE, read_long(&header.signature)))
|
|
return EEMILE_INVALID_SECOND;
|
|
|
|
container_offset = read_long(&header.kernel_image_offset);
|
|
if (container_offset == 0)
|
|
return -1;
|
|
|
|
ret = lseek(fd, container_offset, SEEK_SET);
|
|
if (ret != container_offset)
|
|
return EEMILE_CANNOT_READ_SECOND;
|
|
|
|
container = (struct emile_container*)
|
|
malloc(sizeof(struct emile_container));
|
|
if (container == NULL)
|
|
return EEMILE_MALLOC_ERROR;
|
|
|
|
ret = read(fd, container, sizeof(struct emile_container));
|
|
if (ret != sizeof(struct emile_container))
|
|
return EEMILE_CANNOT_READ_SECOND;
|
|
|
|
max_blocks = container->max_blocks;
|
|
|
|
free(container);
|
|
container = (struct emile_container*)
|
|
malloc(sizeof(struct emile_container)
|
|
+ max_blocks * sizeof(struct emile_block));
|
|
if (container == NULL)
|
|
return EEMILE_MALLOC_ERROR;
|
|
|
|
container->max_blocks = max_blocks;
|
|
fd_kernel = open(kernel_name, O_RDONLY);
|
|
if (fd_kernel == -1)
|
|
return EEMILE_CANNOT_READ_KERNEL;
|
|
|
|
ret = emile_scsi_create_container(fd_kernel, container);
|
|
if (ret != 0)
|
|
return ret;
|
|
close(fd_kernel);
|
|
|
|
kernel_image_size = 0;
|
|
for(i = 0; i < max_blocks; i++)
|
|
{
|
|
if (container->blocks[i].count == 0)
|
|
break;
|
|
printf("(%d, %d) ", container->blocks[i].offset,
|
|
container->blocks[i].count);
|
|
kernel_image_size += container->blocks[i].count;
|
|
}
|
|
putchar('\n');
|
|
kernel_image_size *= container->block_size;
|
|
printf("kernel image size: %ld\n", kernel_image_size);
|
|
|
|
ret = lseek(fd, container_offset, SEEK_SET);
|
|
if (ret != container_offset)
|
|
return EEMILE_CANNOT_WRITE_SECOND;
|
|
|
|
ret = write(fd, container, sizeof(struct emile_container)
|
|
+ max_blocks * sizeof(struct emile_block));
|
|
if (ret != sizeof(struct emile_container)
|
|
+ max_blocks * sizeof(struct emile_block))
|
|
return EEMILE_CANNOT_WRITE_SECOND;
|
|
|
|
ret = lseek(fd, 0, SEEK_SET);
|
|
if (ret != 0)
|
|
return -1;
|
|
|
|
header.kernel_image_size = kernel_image_size;
|
|
|
|
ret = write(fd, &header, sizeof(header));
|
|
if (ret != sizeof(header))
|
|
return EEMILE_CANNOT_WRITE_SECOND;
|
|
|
|
return 0;
|
|
}
|