EMILE/tools/emile_scanbus.c

230 lines
4.9 KiB
C
Raw Normal View History

2004-12-16 23:25:03 +00:00
/*
*
* (c) 2004 Laurent Vivier <LaurentVivier@wanadoo.fr>
*
*/
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <getopt.h>
#include "libemile.h"
#define EMILE_MAX_DISK 16
#define EMILE_MAX_DEVNAME 16
typedef char device_name_t[EMILE_MAX_DEVNAME];
extern int verbose;
2004-12-21 15:16:11 +00:00
static void print_size(int nb_blocks, int block_size)
{
int B, GB, MB, kB;
B = (nb_blocks * block_size) % 1024;
if (block_size > 1024)
kB = nb_blocks * (block_size / 1024);
else
kB = nb_blocks / (1024 / block_size);
MB = kB / 1024;
kB = kB % 1024;
GB = MB / 1024;
MB = MB % 1024;
if (GB)
printf("%d.%03d GB", GB, MB * 1000 / 1024);
else if (MB)
printf("%d.%03d MB", MB, kB * 1000 / 1024);
else
printf("%d.%03d kB", kB, B * 1000 / 1024);
}
2004-12-22 00:28:24 +00:00
static int emile_scanbus(device_name_t devices[EMILE_MAX_DISK])
2004-12-16 23:25:03 +00:00
{
int i,j;
int fd;
device_name_t dev;
j = 0;
/* scan SCSI disks */
for(i = 0; (i < EMILE_MAX_DISK) && (j < EMILE_MAX_DISK); i++)
2004-12-16 23:25:03 +00:00
{
sprintf(dev, "/dev/sd%c", 'a' + i);
fd = open(dev, O_RDONLY);
if (fd == -1)
break;
2004-12-16 23:25:03 +00:00
close(fd);
strncpy(devices[j++], dev, EMILE_MAX_DEVNAME);
}
/* scan ATA disks: EMILE doesn't manage them, but this
* allows to have all information on all disks
*/
for(i = 0; (i < EMILE_MAX_DISK) && (j < EMILE_MAX_DISK); i++)
{
sprintf(dev, "/dev/hd%c", 'a' + i);
fd = open(dev, O_RDONLY);
if (fd == -1)
continue;
close(fd);
strncpy(devices[j++], dev, EMILE_MAX_DEVNAME);
}
2004-12-16 23:25:03 +00:00
return j;
}
void scanbus(void)
{
emile_map_t* map;
device_name_t devices[EMILE_MAX_DISK];
int count;
int i;
int j;
int boottype;
2004-12-16 23:25:03 +00:00
char bootblock[BOOTBLOCK_SIZE];
count = emile_scanbus(devices);
if (count == 0)
{
if (errno == EACCES)
{
fprintf(stderr,
"ERROR: cannot access to devices (you should try as root...)\n");
return;
}
printf("No disk found\n");
}
for (i = 0; i < count; i++)
{
int block_size, block_count;
2006-05-29 20:23:18 +00:00
int ret;
2004-12-16 23:25:03 +00:00
printf("%s:", devices[i]);
map = emile_map_open(devices[i], O_RDONLY);
2006-05-29 20:23:18 +00:00
ret = emile_map_geometry(map, &block_size, &block_count);
if ((ret != -1) && verbose)
2004-12-16 23:25:03 +00:00
{
2004-12-21 15:16:11 +00:00
printf(" block size: %d, blocks number: %d (",
block_size, block_count);
print_size(block_count, 512);
2004-12-21 15:16:11 +00:00
printf(")\n");
2004-12-16 23:25:03 +00:00
}
else putchar('\n');
if (map == NULL)
{
printf("\t<No information available>\n");
continue;
}
if (!emile_map_is_valid(map))
{
printf("\t<No valid partition map found>\n");
continue;
}
if (emile_map_get_driver_number(map) > 0)
printf(" Drivers\n");
for (j = 0; j < emile_map_get_driver_number(map); j++)
{
int block, size, type, part;
emile_map_get_driver_info(map, j,
&block, &size, &type);
printf(" %d: base: %d size: %d type: %d",
j, block * block_size / 512,
size * block_size / 512 , type);
part = emile_map_seek_driver_partition(map,
block * block_size / 512 );
2004-12-16 23:25:03 +00:00
if (part == -1)
printf(" <invalid>\n");
else
{
emile_map_read(map, part);
2004-12-21 15:16:11 +00:00
printf(" <%d: %s [%s]>\n", part + 1,
2004-12-16 23:25:03 +00:00
emile_map_get_partition_name(map),
emile_map_get_partition_type(map));
}
}
printf(" Partitions\n");
for (j = 0; j < emile_map_get_number(map); j++)
{
emile_map_read(map, j);
if (emile_map_partition_is_startup(map))
printf(" --> ");
else
printf(" ");
printf("%s%-2d: ", devices[i], j + 1);
printf("%16s [%-16s] ",
emile_map_get_partition_name(map),
emile_map_get_partition_type(map));
emile_map_bootblock_read(map, bootblock);
boottype = emile_map_bootblock_get_type(bootblock);
switch(boottype)
2004-12-16 23:25:03 +00:00
{
case INVALID_BOOTBLOCK:
break;
case APPLE_BOOTBLOCK:
printf(" <Apple bootblock>");
break;
case EMILE_BOOTBLOCK:
printf(" <EMILE bootblock>");
break;
default:
printf(" <unknown bootblock>");
break;
2004-12-16 23:25:03 +00:00
}
if (emile_map_partition_is_bootable(map))
printf(" *\n");
2004-12-16 23:25:03 +00:00
else
putchar('\n');
if (verbose)
{
int start, count;
2005-02-03 16:04:41 +00:00
int bootstart, bootsize, bootaddr, bootentry;
int checksum;
char processor[16];
2004-12-16 23:25:03 +00:00
2006-05-29 20:23:18 +00:00
ret = emile_map_get_partition_geometry(map,
&start,
&count);
if( ret != -1)
{
printf(" base:"
" %d, count: %d (",
start, count);
print_size(count, 512);
printf(")\n");
printf(" flags: 0x%08x\n",
emile_map_partition_get_flags(map));
emile_map_get_bootinfo(map, &bootstart,
&bootsize, &bootaddr,
&bootentry, &checksum,
processor);
printf(" "
"Bootstart: %d, Bootsize: %d\n",
bootstart, bootsize);
printf(" "
"Bootaddr: %d, Bootentry: %d\n",
bootaddr, bootentry);
printf(" "
"Checksum: 0x%04x, Processor: %s\n",
checksum, processor);
}
2004-12-16 23:25:03 +00:00
}
}
emile_map_close(map);
}
}