Fixed build of ideinfo, moved it into its own subdirectory.

Minor cleanup.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@13349 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2005-06-29 15:14:08 +00:00
parent f8f63bc7eb
commit d2f968ec96
2 changed files with 14 additions and 19 deletions

View File

@ -17,7 +17,6 @@ StdBinCommands
error.c error.c
finddir.c finddir.c
hd.c hd.c
ideinfo.c
idestatus.c idestatus.c
isvolume.cpp isvolume.cpp
listarea.c listarea.c
@ -117,6 +116,7 @@ SubInclude OBOS_TOP src bin flex ;
SubInclude OBOS_TOP src bin gawk ; SubInclude OBOS_TOP src bin gawk ;
SubInclude OBOS_TOP src bin gdb ; SubInclude OBOS_TOP src bin gdb ;
SubInclude OBOS_TOP src bin grep ; SubInclude OBOS_TOP src bin grep ;
SubInclude OBOS_TOP src bin ideinfo ;
SubInclude OBOS_TOP src bin keymap ; SubInclude OBOS_TOP src bin keymap ;
SubInclude OBOS_TOP src bin less ; SubInclude OBOS_TOP src bin less ;
SubInclude OBOS_TOP src bin listdev ; SubInclude OBOS_TOP src bin listdev ;

View File

@ -7,10 +7,9 @@
#include <string.h> #include <string.h>
// This one comes from Thomas Kurschel's Open IDE bus manager. // This one comes from Thomas Kurschel's Open IDE bus manager.
// "/current/src/add-ons/kernel/bus_managers/ide/ide_device_infoblock.h" #include <ide_device_infoblock.h>
//#include <ide_device_infoblock.h>
// FIXME: move that header !! extern const char *__progname;
#include "../../add-ons/kernel/bus_managers/ide/ide_device_infoblock.h"
/* why isn't that documented ? */ /* why isn't that documented ? */
#define IDE_GET_INFO 0x2710 #define IDE_GET_INFO 0x2710
@ -23,10 +22,13 @@ typedef struct {
uint8 dma_mode; uint8 dma_mode;
} _PACKED ide_status_t; } _PACKED ide_status_t;
#define kNotSupported "not supported" #define kNotSupported "not supported"
#define kSupported "supported" #define kSupported "supported"
int main(int argc, char **argv)
int
main(int argc, char **argv)
{ {
int fd; int fd;
ide_device_infoblock ide_info; ide_device_infoblock ide_info;
@ -35,7 +37,7 @@ int main(int argc, char **argv)
bool removable; bool removable;
if (argc < 2) { if (argc < 2) {
fprintf(stderr, "usage: %s devicename\n", argv[0]); fprintf(stderr, "usage: %s <device>\n", __progname);
return 1; return 1;
} }
@ -55,18 +57,13 @@ int main(int argc, char **argv)
printf("Firmware Version: %.8s\n", ide_info.firmware_version); printf("Firmware Version: %.8s\n", ide_info.firmware_version);
printf("\n"); printf("\n");
if (ide_info._48_bit_addresses_supported) if (ide_info._48_bit_addresses_supported) {
{
capacity = (float) ide_info.LBA48_total_sectors * capacity = (float) ide_info.LBA48_total_sectors *
512 / (1024 * 1024 * 1024); 512 / (1024 * 1024 * 1024);
} } else if (ide_info.LBA_supported) {
else if (ide_info.LBA_supported)
{
capacity = (float) ide_info.LBA_total_sectors * capacity = (float) ide_info.LBA_total_sectors *
512 / (1024 * 1024 * 1024); 512 / (1024 * 1024 * 1024);
} } else {
else
{
use_GB_units = false; use_GB_units = false;
capacity = (float) (ide_info.cylinders * ide_info.heads * capacity = (float) (ide_info.cylinders * ide_info.heads *
@ -79,12 +76,10 @@ int main(int argc, char **argv)
printf("DMA supported: %s\n", ide_info.DMA_supported ? "yes" : "no"); printf("DMA supported: %s\n", ide_info.DMA_supported ? "yes" : "no");
if (ide_info.DMA_supported) if (ide_info.DMA_supported) {
{
ide_status_t st = {0x01, 0x00, 0x00, 0x80}; /* God knows... */ ide_status_t st = {0x01, 0x00, 0x00, 0x80}; /* God knows... */
if (ioctl(fd, IDE_GET_STATUS, &st, sizeof(ide_status_t *)) < 0) if (ioctl(fd, IDE_GET_STATUS, &st, sizeof(ide_status_t *)) < 0) {
{
fprintf(stderr, "could not get ide status for %s\n", argv[1]); fprintf(stderr, "could not get ide status for %s\n", argv[1]);
return 3; return 3;
} }