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:
parent
f8f63bc7eb
commit
d2f968ec96
@ -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 ;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user