Merge branch 'master' of git+ssh://vda@busybox.net/var/lib/git/busybox
This commit is contained in:
commit
d8aeba4eed
@ -633,15 +633,14 @@ static int busybox_main(char **argv)
|
|||||||
if (!argv[1]) {
|
if (!argv[1]) {
|
||||||
/* Called without arguments */
|
/* Called without arguments */
|
||||||
const char *a;
|
const char *a;
|
||||||
unsigned col, output_width;
|
int col;
|
||||||
|
unsigned output_width;
|
||||||
help:
|
help:
|
||||||
output_width = 80;
|
output_width = 80;
|
||||||
if (ENABLE_FEATURE_AUTOWIDTH) {
|
if (ENABLE_FEATURE_AUTOWIDTH) {
|
||||||
/* Obtain the terminal width */
|
/* Obtain the terminal width */
|
||||||
get_terminal_width_height(0, &output_width, NULL);
|
get_terminal_width_height(0, &output_width, NULL);
|
||||||
}
|
}
|
||||||
/* leading tab and room to wrap */
|
|
||||||
output_width -= MAX_APPLET_NAME_LEN + 8;
|
|
||||||
|
|
||||||
dup2(1, 2);
|
dup2(1, 2);
|
||||||
full_write2_str(bb_banner); /* reuse const string... */
|
full_write2_str(bb_banner); /* reuse const string... */
|
||||||
@ -661,17 +660,23 @@ static int busybox_main(char **argv)
|
|||||||
"Currently defined functions:\n");
|
"Currently defined functions:\n");
|
||||||
col = 0;
|
col = 0;
|
||||||
a = applet_names;
|
a = applet_names;
|
||||||
|
/* prevent last comma to be in the very last pos */
|
||||||
|
output_width--;
|
||||||
while (*a) {
|
while (*a) {
|
||||||
int len;
|
int len2 = strlen(a) + 2;
|
||||||
if (col > output_width) {
|
if (col >= (int)output_width - len2) {
|
||||||
full_write2_str(",\n");
|
full_write2_str(",\n");
|
||||||
col = 0;
|
col = 0;
|
||||||
}
|
}
|
||||||
full_write2_str(col ? ", " : "\t");
|
if (col == 0) {
|
||||||
|
col = 6;
|
||||||
|
full_write2_str("\t");
|
||||||
|
} else {
|
||||||
|
full_write2_str(", ");
|
||||||
|
}
|
||||||
full_write2_str(a);
|
full_write2_str(a);
|
||||||
len = strlen(a);
|
col += len2;
|
||||||
col += len + 2;
|
a += len2 - 1;
|
||||||
a += len + 1;
|
|
||||||
}
|
}
|
||||||
full_write2_str("\n\n");
|
full_write2_str("\n\n");
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -11,7 +11,6 @@
|
|||||||
* hdparm.c - Command line interface to get/set hard disk parameters
|
* hdparm.c - Command line interface to get/set hard disk parameters
|
||||||
* - by Mark Lord (C) 1994-2002 -- freely distributable
|
* - by Mark Lord (C) 1994-2002 -- freely distributable
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
#include <linux/hdreg.h>
|
#include <linux/hdreg.h>
|
||||||
|
|
||||||
@ -232,6 +231,10 @@
|
|||||||
#undef DO_FLUSHCACHE /* under construction: force cache flush on -W0 */
|
#undef DO_FLUSHCACHE /* under construction: force cache flush on -W0 */
|
||||||
|
|
||||||
|
|
||||||
|
#define IS_GET 1
|
||||||
|
#define IS_SET 2
|
||||||
|
|
||||||
|
|
||||||
enum { fd = 3 };
|
enum { fd = 3 };
|
||||||
|
|
||||||
|
|
||||||
@ -241,19 +244,16 @@ struct globals {
|
|||||||
smallint do_ctimings, do_timings;
|
smallint do_ctimings, do_timings;
|
||||||
smallint reread_partn;
|
smallint reread_partn;
|
||||||
smallint set_piomode, noisy_piomode;
|
smallint set_piomode, noisy_piomode;
|
||||||
smallint set_readahead, get_readahead;
|
smallint getset_readahead;
|
||||||
smallint set_readonly, get_readonly;
|
smallint getset_readonly;
|
||||||
smallint set_unmask, get_unmask;
|
smallint getset_unmask;
|
||||||
smallint set_mult, get_mult;
|
smallint getset_mult;
|
||||||
#ifdef HDIO_GET_QDMA
|
#ifdef HDIO_GET_QDMA
|
||||||
smallint get_dma_q;
|
smallint getset_dma_q;
|
||||||
#ifdef HDIO_SET_QDMA
|
|
||||||
smallint set_dma_q;
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
smallint getset_nowerr;
|
||||||
smallint set_nowerr, get_nowerr;
|
smallint getset_keep;
|
||||||
smallint set_keep, get_keep;
|
smallint getset_io32bit;
|
||||||
smallint set_io32bit, get_io32bit;
|
|
||||||
int piomode;
|
int piomode;
|
||||||
unsigned long Xreadahead;
|
unsigned long Xreadahead;
|
||||||
unsigned long readonly;
|
unsigned long readonly;
|
||||||
@ -267,22 +267,22 @@ struct globals {
|
|||||||
unsigned long io32bit;
|
unsigned long io32bit;
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
||||||
unsigned long dma;
|
unsigned long dma;
|
||||||
smallint set_dma, get_dma;
|
smallint getset_dma;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HDIO_DRIVE_CMD
|
#ifdef HDIO_DRIVE_CMD
|
||||||
smallint set_xfermode, get_xfermode;
|
smallint set_xfermode, get_xfermode;
|
||||||
smallint set_dkeep, get_dkeep;
|
smallint getset_dkeep;
|
||||||
smallint set_standby, get_standby;
|
smallint getset_standby;
|
||||||
smallint set_lookahead, get_lookahead;
|
smallint getset_lookahead;
|
||||||
smallint set_prefetch, get_prefetch;
|
smallint getset_prefetch;
|
||||||
smallint set_defects, get_defects;
|
smallint getset_defects;
|
||||||
smallint set_wcache, get_wcache;
|
smallint getset_wcache;
|
||||||
smallint set_doorlock, get_doorlock;
|
smallint getset_doorlock;
|
||||||
smallint set_seagate, get_seagate;
|
smallint set_seagate;
|
||||||
smallint set_standbynow, get_standbynow;
|
smallint set_standbynow;
|
||||||
smallint set_sleepnow, get_sleepnow;
|
smallint set_sleepnow;
|
||||||
smallint get_powermode;
|
smallint get_powermode;
|
||||||
smallint set_apmmode, get_apmmode;
|
smallint getset_apmmode;
|
||||||
int xfermode_requested;
|
int xfermode_requested;
|
||||||
unsigned long dkeep;
|
unsigned long dkeep;
|
||||||
unsigned long standby_requested; /* 0..255 */
|
unsigned long standby_requested; /* 0..255 */
|
||||||
@ -294,7 +294,7 @@ struct globals {
|
|||||||
unsigned long apmmode;
|
unsigned long apmmode;
|
||||||
#endif
|
#endif
|
||||||
IF_FEATURE_HDPARM_GET_IDENTITY( smallint get_IDentity;)
|
IF_FEATURE_HDPARM_GET_IDENTITY( smallint get_IDentity;)
|
||||||
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF( smallint set_busstate, get_busstate;)
|
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF( smallint getset_busstate;)
|
||||||
IF_FEATURE_HDPARM_HDIO_DRIVE_RESET( smallint perform_reset;)
|
IF_FEATURE_HDPARM_HDIO_DRIVE_RESET( smallint perform_reset;)
|
||||||
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF( smallint perform_tristate;)
|
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF( smallint perform_tristate;)
|
||||||
IF_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF(smallint unregister_hwif;)
|
IF_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF(smallint unregister_hwif;)
|
||||||
@ -323,22 +323,14 @@ struct BUG_G_too_big {
|
|||||||
#define reread_partn (G.reread_partn )
|
#define reread_partn (G.reread_partn )
|
||||||
#define set_piomode (G.set_piomode )
|
#define set_piomode (G.set_piomode )
|
||||||
#define noisy_piomode (G.noisy_piomode )
|
#define noisy_piomode (G.noisy_piomode )
|
||||||
#define set_readahead (G.set_readahead )
|
#define getset_readahead (G.getset_readahead )
|
||||||
#define get_readahead (G.get_readahead )
|
#define getset_readonly (G.getset_readonly )
|
||||||
#define set_readonly (G.set_readonly )
|
#define getset_unmask (G.getset_unmask )
|
||||||
#define get_readonly (G.get_readonly )
|
#define getset_mult (G.getset_mult )
|
||||||
#define set_unmask (G.set_unmask )
|
#define getset_dma_q (G.getset_dma_q )
|
||||||
#define get_unmask (G.get_unmask )
|
#define getset_nowerr (G.getset_nowerr )
|
||||||
#define set_mult (G.set_mult )
|
#define getset_keep (G.getset_keep )
|
||||||
#define get_mult (G.get_mult )
|
#define getset_io32bit (G.getset_io32bit )
|
||||||
#define set_dma_q (G.set_dma_q )
|
|
||||||
#define get_dma_q (G.get_dma_q )
|
|
||||||
#define set_nowerr (G.set_nowerr )
|
|
||||||
#define get_nowerr (G.get_nowerr )
|
|
||||||
#define set_keep (G.set_keep )
|
|
||||||
#define get_keep (G.get_keep )
|
|
||||||
#define set_io32bit (G.set_io32bit )
|
|
||||||
#define get_io32bit (G.get_io32bit )
|
|
||||||
#define piomode (G.piomode )
|
#define piomode (G.piomode )
|
||||||
#define Xreadahead (G.Xreadahead )
|
#define Xreadahead (G.Xreadahead )
|
||||||
#define readonly (G.readonly )
|
#define readonly (G.readonly )
|
||||||
@ -349,33 +341,21 @@ struct BUG_G_too_big {
|
|||||||
#define keep (G.keep )
|
#define keep (G.keep )
|
||||||
#define io32bit (G.io32bit )
|
#define io32bit (G.io32bit )
|
||||||
#define dma (G.dma )
|
#define dma (G.dma )
|
||||||
#define set_dma (G.set_dma )
|
#define getset_dma (G.getset_dma )
|
||||||
#define get_dma (G.get_dma )
|
|
||||||
#define set_xfermode (G.set_xfermode )
|
#define set_xfermode (G.set_xfermode )
|
||||||
#define get_xfermode (G.get_xfermode )
|
#define get_xfermode (G.get_xfermode )
|
||||||
#define set_dkeep (G.set_dkeep )
|
#define getset_dkeep (G.getset_dkeep )
|
||||||
#define get_dkeep (G.get_dkeep )
|
#define getset_standby (G.getset_standby )
|
||||||
#define set_standby (G.set_standby )
|
#define getset_lookahead (G.getset_lookahead )
|
||||||
#define get_standby (G.get_standby )
|
#define getset_prefetch (G.getset_prefetch )
|
||||||
#define set_lookahead (G.set_lookahead )
|
#define getset_defects (G.getset_defects )
|
||||||
#define get_lookahead (G.get_lookahead )
|
#define getset_wcache (G.getset_wcache )
|
||||||
#define set_prefetch (G.set_prefetch )
|
#define getset_doorlock (G.getset_doorlock )
|
||||||
#define get_prefetch (G.get_prefetch )
|
|
||||||
#define set_defects (G.set_defects )
|
|
||||||
#define get_defects (G.get_defects )
|
|
||||||
#define set_wcache (G.set_wcache )
|
|
||||||
#define get_wcache (G.get_wcache )
|
|
||||||
#define set_doorlock (G.set_doorlock )
|
|
||||||
#define get_doorlock (G.get_doorlock )
|
|
||||||
#define set_seagate (G.set_seagate )
|
#define set_seagate (G.set_seagate )
|
||||||
#define get_seagate (G.get_seagate )
|
|
||||||
#define set_standbynow (G.set_standbynow )
|
#define set_standbynow (G.set_standbynow )
|
||||||
#define get_standbynow (G.get_standbynow )
|
|
||||||
#define set_sleepnow (G.set_sleepnow )
|
#define set_sleepnow (G.set_sleepnow )
|
||||||
#define get_sleepnow (G.get_sleepnow )
|
|
||||||
#define get_powermode (G.get_powermode )
|
#define get_powermode (G.get_powermode )
|
||||||
#define set_apmmode (G.set_apmmode )
|
#define getset_apmmode (G.getset_apmmode )
|
||||||
#define get_apmmode (G.get_apmmode )
|
|
||||||
#define xfermode_requested (G.xfermode_requested )
|
#define xfermode_requested (G.xfermode_requested )
|
||||||
#define dkeep (G.dkeep )
|
#define dkeep (G.dkeep )
|
||||||
#define standby_requested (G.standby_requested )
|
#define standby_requested (G.standby_requested )
|
||||||
@ -386,8 +366,7 @@ struct BUG_G_too_big {
|
|||||||
#define doorlock (G.doorlock )
|
#define doorlock (G.doorlock )
|
||||||
#define apmmode (G.apmmode )
|
#define apmmode (G.apmmode )
|
||||||
#define get_IDentity (G.get_IDentity )
|
#define get_IDentity (G.get_IDentity )
|
||||||
#define set_busstate (G.set_busstate )
|
#define getset_busstate (G.getset_busstate )
|
||||||
#define get_busstate (G.get_busstate )
|
|
||||||
#define perform_reset (G.perform_reset )
|
#define perform_reset (G.perform_reset )
|
||||||
#define perform_tristate (G.perform_tristate )
|
#define perform_tristate (G.perform_tristate )
|
||||||
#define unregister_hwif (G.unregister_hwif )
|
#define unregister_hwif (G.unregister_hwif )
|
||||||
@ -870,16 +849,27 @@ static void identify(uint16_t *val)
|
|||||||
} else {
|
} else {
|
||||||
/* addressing...CHS? See section 6.2 of ATA specs 4 or 5 */
|
/* addressing...CHS? See section 6.2 of ATA specs 4 or 5 */
|
||||||
ll = (uint32_t)val[LBA_SECTS_MSB] << 16 | val[LBA_SECTS_LSB];
|
ll = (uint32_t)val[LBA_SECTS_MSB] << 16 | val[LBA_SECTS_LSB];
|
||||||
mm = 0; bbbig = 0;
|
mm = 0;
|
||||||
|
bbbig = 0;
|
||||||
if ((ll > 0x00FBFC10) && (!val[LCYLS]))
|
if ((ll > 0x00FBFC10) && (!val[LCYLS]))
|
||||||
printf("\tCHS addressing not supported\n");
|
printf("\tCHS addressing not supported\n");
|
||||||
else {
|
else {
|
||||||
jj = val[WHATS_VALID] & OK_W54_58;
|
jj = val[WHATS_VALID] & OK_W54_58;
|
||||||
printf("\tLogical\t\tmax\tcurrent\n\tcylinders\t%u\t%u\n\theads\t\t%u\t%u\n\tsectors/track\t%u\t%u\n\t--\n",
|
printf("\tLogical\t\tmax\tcurrent\n"
|
||||||
val[LCYLS],jj?val[LCYLS_CUR]:0, val[LHEADS],jj?val[LHEADS_CUR]:0, val[LSECTS],jj?val[LSECTS_CUR]:0);
|
"\tcylinders\t%u\t%u\n"
|
||||||
|
"\theads\t\t%u\t%u\n"
|
||||||
|
"\tsectors/track\t%u\t%u\n"
|
||||||
|
"\t--\n",
|
||||||
|
val[LCYLS],
|
||||||
|
jj ? val[LCYLS_CUR] : 0,
|
||||||
|
val[LHEADS],
|
||||||
|
jj ? val[LHEADS_CUR] : 0,
|
||||||
|
val[LSECTS],
|
||||||
|
jj ? val[LSECTS_CUR] : 0);
|
||||||
|
|
||||||
if ((min_std == 1) && (val[TRACK_BYTES] || val[SECT_BYTES]))
|
if ((min_std == 1) && (val[TRACK_BYTES] || val[SECT_BYTES]))
|
||||||
printf("\tbytes/track: %u\tbytes/sector: %u\n", val[TRACK_BYTES], val[SECT_BYTES]);
|
printf("\tbytes/track: %u\tbytes/sector: %u\n",
|
||||||
|
val[TRACK_BYTES], val[SECT_BYTES]);
|
||||||
|
|
||||||
if (jj) {
|
if (jj) {
|
||||||
mm = (uint32_t)val[CAPACITY_MSB] << 16 | val[CAPACITY_LSB];
|
mm = (uint32_t)val[CAPACITY_MSB] << 16 | val[CAPACITY_LSB];
|
||||||
@ -921,22 +911,24 @@ static void identify(uint16_t *val)
|
|||||||
printf("Capabilities:\n\t");
|
printf("Capabilities:\n\t");
|
||||||
|
|
||||||
if (dev == ATAPI_DEV) {
|
if (dev == ATAPI_DEV) {
|
||||||
if (eqpt != CDROM && (val[CAPAB_0] & CMD_Q_SUP)) printf("Cmd queuing, ");
|
if (eqpt != CDROM && (val[CAPAB_0] & CMD_Q_SUP))
|
||||||
if (val[CAPAB_0] & OVLP_SUP) printf("Cmd overlap, ");
|
printf("Cmd queuing, ");
|
||||||
|
if (val[CAPAB_0] & OVLP_SUP)
|
||||||
|
printf("Cmd overlap, ");
|
||||||
}
|
}
|
||||||
if (val[CAPAB_0] & LBA_SUP) printf("LBA, ");
|
if (val[CAPAB_0] & LBA_SUP) printf("LBA, ");
|
||||||
|
|
||||||
if (like_std != 1) {
|
if (like_std != 1) {
|
||||||
printf("IORDY%s(can%s be disabled)\n",
|
printf("IORDY%s(can%s be disabled)\n",
|
||||||
!(val[CAPAB_0] & IORDY_SUP) ? "(may be)" : "",
|
!(val[CAPAB_0] & IORDY_SUP) ? "(may be)" : "",
|
||||||
(val[CAPAB_0] & IORDY_OFF) ? "" :"not");
|
(val[CAPAB_0] & IORDY_OFF) ? "" :"not");
|
||||||
} else
|
} else
|
||||||
printf("no IORDY\n");
|
printf("no IORDY\n");
|
||||||
|
|
||||||
if ((like_std == 1) && val[BUF_TYPE]) {
|
if ((like_std == 1) && val[BUF_TYPE]) {
|
||||||
printf("\tBuffer type: %04x: %s%s\n", val[BUF_TYPE],
|
printf("\tBuffer type: %04x: %s%s\n", val[BUF_TYPE],
|
||||||
(val[BUF_TYPE] < 2) ? "single port, single-sector" : "dual port, multi-sector",
|
(val[BUF_TYPE] < 2) ? "single port, single-sector" : "dual port, multi-sector",
|
||||||
(val[BUF_TYPE] > 2) ? " with read caching ability" : "");
|
(val[BUF_TYPE] > 2) ? " with read caching ability" : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((min_std == 1) && (val[BUFFER__SIZE] && (val[BUFFER__SIZE] != NOVAL_1))) {
|
if ((min_std == 1) && (val[BUFFER__SIZE] && (val[BUFFER__SIZE] != NOVAL_1))) {
|
||||||
@ -953,9 +945,11 @@ static void identify(uint16_t *val)
|
|||||||
if (like_std == 1)
|
if (like_std == 1)
|
||||||
printf("\tCan%s perform double-word IO\n", (!val[DWORD_IO]) ? "not" : "");
|
printf("\tCan%s perform double-word IO\n", (!val[DWORD_IO]) ? "not" : "");
|
||||||
else {
|
else {
|
||||||
printf("\tStandby timer values: spec'd by %s", (val[CAPAB_0] & STD_STBY) ? "Standard" : "Vendor");
|
printf("\tStandby timer values: spec'd by %s",
|
||||||
|
(val[CAPAB_0] & STD_STBY) ? "standard" : "vendor");
|
||||||
if ((like_std > 3) && ((val[CAPAB_1] & VALID) == VALID_VAL))
|
if ((like_std > 3) && ((val[CAPAB_1] & VALID) == VALID_VAL))
|
||||||
printf(", %s device specific minimum\n", (val[CAPAB_1] & MIN_STANDBY_TIMER) ? "with" : "no");
|
printf(", %s device specific minimum\n",
|
||||||
|
(val[CAPAB_1] & MIN_STANDBY_TIMER) ? "with" : "no");
|
||||||
else
|
else
|
||||||
bb_putchar('\n');
|
bb_putchar('\n');
|
||||||
}
|
}
|
||||||
@ -983,7 +977,8 @@ static void identify(uint16_t *val)
|
|||||||
}
|
}
|
||||||
if (like_std > 5 && val[ACOUSTIC]) {
|
if (like_std > 5 && val[ACOUSTIC]) {
|
||||||
printf("\tRecommended acoustic management value: %u, current value: %u\n",
|
printf("\tRecommended acoustic management value: %u, current value: %u\n",
|
||||||
(val[ACOUSTIC] >> 8) & 0x00ff, val[ACOUSTIC] & 0x00ff);
|
(val[ACOUSTIC] >> 8) & 0x00ff,
|
||||||
|
val[ACOUSTIC] & 0x00ff);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* ATAPI */
|
/* ATAPI */
|
||||||
@ -992,8 +987,11 @@ static void identify(uint16_t *val)
|
|||||||
|
|
||||||
if (val[PKT_REL] || val[SVC_NBSY]) {
|
if (val[PKT_REL] || val[SVC_NBSY]) {
|
||||||
printf("\tOverlap support:");
|
printf("\tOverlap support:");
|
||||||
if (val[PKT_REL]) printf(" %uus to release bus.", val[PKT_REL]);
|
if (val[PKT_REL])
|
||||||
if (val[SVC_NBSY]) printf(" %uus to clear BSY after SERVICE cmd.", val[SVC_NBSY]);
|
printf(" %uus to release bus.", val[PKT_REL]);
|
||||||
|
if (val[SVC_NBSY])
|
||||||
|
printf(" %uus to clear BSY after SERVICE cmd.",
|
||||||
|
val[SVC_NBSY]);
|
||||||
bb_putchar('\n');
|
bb_putchar('\n');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1057,14 +1055,17 @@ static void identify(uint16_t *val)
|
|||||||
if (val[WHATS_VALID] & OK_W64_70) {
|
if (val[WHATS_VALID] & OK_W64_70) {
|
||||||
if (val[PIO_NO_FLOW] || val[PIO_FLOW]) {
|
if (val[PIO_NO_FLOW] || val[PIO_FLOW]) {
|
||||||
printf("\t\tCycle time:");
|
printf("\t\tCycle time:");
|
||||||
if (val[PIO_NO_FLOW]) printf(" no flow control=%uns", val[PIO_NO_FLOW]);
|
if (val[PIO_NO_FLOW])
|
||||||
if (val[PIO_FLOW]) printf(" IORDY flow control=%uns", val[PIO_FLOW]);
|
printf(" no flow control=%uns", val[PIO_NO_FLOW]);
|
||||||
|
if (val[PIO_FLOW])
|
||||||
|
printf(" IORDY flow control=%uns", val[PIO_FLOW]);
|
||||||
bb_putchar('\n');
|
bb_putchar('\n');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((val[CMDS_SUPP_1] & VALID) == VALID_VAL) {
|
if ((val[CMDS_SUPP_1] & VALID) == VALID_VAL) {
|
||||||
printf("Commands/features:\n\tEnabled\tSupported:\n");
|
printf("Commands/features:\n"
|
||||||
|
"\tEnabled\tSupported:\n");
|
||||||
jj = val[CMDS_SUPP_0];
|
jj = val[CMDS_SUPP_0];
|
||||||
kk = val[CMDS_EN_0];
|
kk = val[CMDS_EN_0];
|
||||||
for (ii = 0; ii < NUM_CMD_FEAT_STR; ii++) {
|
for (ii = 0; ii < NUM_CMD_FEAT_STR; ii++) {
|
||||||
@ -1098,11 +1099,14 @@ static void identify(uint16_t *val)
|
|||||||
jj = val[SECU_STATUS];
|
jj = val[SECU_STATUS];
|
||||||
if (jj) {
|
if (jj) {
|
||||||
for (ii = 0; ii < NUM_SECU_STR; ii++) {
|
for (ii = 0; ii < NUM_SECU_STR; ii++) {
|
||||||
printf("\t%s\t%s\n", (!(jj & 0x0001)) ? "not" : "", nth_string(secu_str, ii));
|
printf("\t%s\t%s\n",
|
||||||
|
(!(jj & 0x0001)) ? "not" : "",
|
||||||
|
nth_string(secu_str, ii));
|
||||||
jj >>=1;
|
jj >>=1;
|
||||||
}
|
}
|
||||||
if (val[SECU_STATUS] & SECU_ENABLED) {
|
if (val[SECU_STATUS] & SECU_ENABLED) {
|
||||||
printf("\tSecurity level %s\n", (val[SECU_STATUS] & SECU_LEVEL) ? "maximum" : "high");
|
printf("\tSecurity level %s\n",
|
||||||
|
(val[SECU_STATUS] & SECU_LEVEL) ? "maximum" : "high");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
jj = val[ERASE_TIME] & ERASE_BITS;
|
jj = val[ERASE_TIME] & ERASE_BITS;
|
||||||
@ -1127,16 +1131,20 @@ static void identify(uint16_t *val)
|
|||||||
strng = " determined by CSEL";
|
strng = " determined by CSEL";
|
||||||
else
|
else
|
||||||
strng = "";
|
strng = "";
|
||||||
printf("HW reset results:\n\tCBLID- %s Vih\n\tDevice num = %i%s\n",
|
printf("HW reset results:\n"
|
||||||
(val[HWRST_RSLT] & CBLID) ? "above" : "below", !(oo), strng);
|
"\tCBLID- %s Vih\n"
|
||||||
|
"\tDevice num = %i%s\n",
|
||||||
|
(val[HWRST_RSLT] & CBLID) ? "above" : "below",
|
||||||
|
!(oo), strng);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* more stuff from std 5 */
|
/* more stuff from std 5 */
|
||||||
if ((like_std > 4) && (eqpt != CDROM)) {
|
if ((like_std > 4) && (eqpt != CDROM)) {
|
||||||
if (val[CFA_PWR_MODE] & VALID_W160) {
|
if (val[CFA_PWR_MODE] & VALID_W160) {
|
||||||
printf("CFA power mode 1:\n\t%s%s\n", (val[CFA_PWR_MODE] & PWR_MODE_OFF) ? "disabled" : "enabled",
|
printf("CFA power mode 1:\n"
|
||||||
(val[CFA_PWR_MODE] & PWR_MODE_REQ) ? " and required by some commands" : "");
|
"\t%s%s\n",
|
||||||
|
(val[CFA_PWR_MODE] & PWR_MODE_OFF) ? "disabled" : "enabled",
|
||||||
|
(val[CFA_PWR_MODE] & PWR_MODE_REQ) ? " and required by some commands" : "");
|
||||||
if (val[CFA_PWR_MODE] & MAX_AMPS)
|
if (val[CFA_PWR_MODE] & MAX_AMPS)
|
||||||
printf("\tMaximum current = %uma\n", val[CFA_PWR_MODE] & MAX_AMPS);
|
printf("\tMaximum current = %uma\n", val[CFA_PWR_MODE] & MAX_AMPS);
|
||||||
}
|
}
|
||||||
@ -1184,11 +1192,12 @@ static void dump_identity(const struct hd_driveid *id)
|
|||||||
printf(" %s", nth_string(cfg_str, i));
|
printf(" %s", nth_string(cfg_str, i));
|
||||||
}
|
}
|
||||||
printf(" }\n RawCHS=%u/%u/%u, TrkSize=%u, SectSize=%u, ECCbytes=%u\n"
|
printf(" }\n RawCHS=%u/%u/%u, TrkSize=%u, SectSize=%u, ECCbytes=%u\n"
|
||||||
" BuffType=(%u) %s, BuffSize=%ukB, MaxMultSect=%u",
|
" BuffType=(%u) %s, BuffSize=%ukB, MaxMultSect=%u",
|
||||||
id->cyls, id->heads, id->sectors, id->track_bytes,
|
id->cyls, id->heads, id->sectors, id->track_bytes,
|
||||||
id->sector_bytes, id->ecc_bytes,
|
id->sector_bytes, id->ecc_bytes,
|
||||||
id->buf_type, nth_string(BuffType, (id->buf_type > 3) ? 0 : id->buf_type),
|
id->buf_type,
|
||||||
id->buf_size/2, id->max_multsect);
|
nth_string(BuffType, (id->buf_type > 3) ? 0 : id->buf_type),
|
||||||
|
id->buf_size/2, id->max_multsect);
|
||||||
if (id->max_multsect) {
|
if (id->max_multsect) {
|
||||||
printf(", MultSect=");
|
printf(", MultSect=");
|
||||||
if (!(id->multsect_valid & 1))
|
if (!(id->multsect_valid & 1))
|
||||||
@ -1213,7 +1222,10 @@ static void dump_identity(const struct hd_driveid *id)
|
|||||||
if (id->capability & 2)
|
if (id->capability & 2)
|
||||||
printf(", LBAsects=%u", id->lba_capacity);
|
printf(", LBAsects=%u", id->lba_capacity);
|
||||||
|
|
||||||
printf("\n IORDY=%s", (id->capability & 8) ? (id->capability & 4) ? "on/off" : "yes" : "no");
|
printf("\n IORDY=%s",
|
||||||
|
(id->capability & 8)
|
||||||
|
? ((id->capability & 4) ? "on/off" : "yes")
|
||||||
|
: "no");
|
||||||
|
|
||||||
if (((id->capability & 8) || (id->field_valid & 2)) && (id->field_valid & 2))
|
if (((id->capability & 8) || (id->field_valid & 2)) && (id->field_valid & 2))
|
||||||
printf(", tPIO={min:%u,w/IORDY:%u}", id->eide_pio, id->eide_pio_iordy);
|
printf(", tPIO={min:%u,w/IORDY:%u}", id->eide_pio, id->eide_pio_iordy);
|
||||||
@ -1242,7 +1254,7 @@ static void dump_identity(const struct hd_driveid *id)
|
|||||||
"*\0""sdma0 \0""*\0""sdma1 \0""*\0""sdma2 \0""*\0""sdma? \0",
|
"*\0""sdma0 \0""*\0""sdma1 \0""*\0""sdma2 \0""*\0""sdma? \0",
|
||||||
id->dma_1word, NULL);
|
id->dma_1word, NULL);
|
||||||
print_flags_separated(dma_wmode_masks,
|
print_flags_separated(dma_wmode_masks,
|
||||||
"*\0""mdma0\0""*\0""mdma1\0""*\0""mdma2\0""*\0""mdma?\0",
|
"*\0""mdma0 \0""*\0""mdma1 \0""*\0""mdma2 \0""*\0""mdma? \0",
|
||||||
id->dma_mword, NULL);
|
id->dma_mword, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1285,12 +1297,14 @@ static void dump_identity(const struct hd_driveid *id)
|
|||||||
if ((id->minor_rev_num && id->minor_rev_num <= 31)
|
if ((id->minor_rev_num && id->minor_rev_num <= 31)
|
||||||
|| (id->major_rev_num && id->minor_rev_num <= 31)
|
|| (id->major_rev_num && id->minor_rev_num <= 31)
|
||||||
) {
|
) {
|
||||||
printf("\n Drive conforms to: %s: ", (id->minor_rev_num <= 31) ? nth_string(minor_str, id->minor_rev_num) : "unknown");
|
printf("\n Drive conforms to: %s: ",
|
||||||
if (id->major_rev_num != 0x0000 && /* NOVAL_0 */
|
(id->minor_rev_num <= 31) ? nth_string(minor_str, id->minor_rev_num) : "unknown");
|
||||||
id->major_rev_num != 0xFFFF) { /* NOVAL_1 */
|
if (id->major_rev_num != 0x0000 /* NOVAL_0 */
|
||||||
|
&& id->major_rev_num != 0xFFFF /* NOVAL_1 */
|
||||||
|
) {
|
||||||
for (i = 0; i <= 15; i++) {
|
for (i = 0; i <= 15; i++) {
|
||||||
if (id->major_rev_num & (1<<i))
|
if (id->major_rev_num & (1<<i))
|
||||||
printf(" ATA/ATAPI-%u", i);
|
printf(" ATA/ATAPI-%u", i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1450,10 +1464,10 @@ static void interpret_standby(uint8_t standby)
|
|||||||
printf("off");
|
printf("off");
|
||||||
} else if (standby <= 240 || standby == 252 || standby == 255) {
|
} else if (standby <= 240 || standby == 252 || standby == 255) {
|
||||||
/* standby is in 5 sec units */
|
/* standby is in 5 sec units */
|
||||||
printf("%u minutes %u seconds", standby / 12, (standby*5) % 60);
|
printf("%u minutes %u seconds", standby / (60/5), standby % (60/5));
|
||||||
} else if (standby <= 251) {
|
} else if (standby <= 251) {
|
||||||
unsigned t = (standby - 240); /* t is in 30 min units */;
|
unsigned t = (standby - 240); /* t is in 30 min units */;
|
||||||
printf("%u.%c hours", t / 2, (t & 1) ? '0' : '5');
|
printf("%u.%c hours", t / 2, (t & 1) ? '5' : '0');
|
||||||
}
|
}
|
||||||
if (standby == 253)
|
if (standby == 253)
|
||||||
printf("vendor-specific");
|
printf("vendor-specific");
|
||||||
@ -1536,8 +1550,8 @@ static void process_dev(char *devname)
|
|||||||
xmove_fd(xopen(devname, O_RDONLY | O_NONBLOCK), fd);
|
xmove_fd(xopen(devname, O_RDONLY | O_NONBLOCK), fd);
|
||||||
printf("\n%s:\n", devname);
|
printf("\n%s:\n", devname);
|
||||||
|
|
||||||
if (set_readahead) {
|
if (getset_readahead == IS_SET) {
|
||||||
print_flag(get_readahead, "fs readahead", Xreadahead);
|
print_flag(getset_readahead, "fs readahead", Xreadahead);
|
||||||
ioctl_or_warn(fd, BLKRASET, (int *)Xreadahead);
|
ioctl_or_warn(fd, BLKRASET, (int *)Xreadahead);
|
||||||
}
|
}
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF
|
#if ENABLE_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF
|
||||||
@ -1547,7 +1561,7 @@ static void process_dev(char *devname)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_SCAN_HWIF
|
#if ENABLE_FEATURE_HDPARM_HDIO_SCAN_HWIF
|
||||||
if (scan_hwif) {
|
if (scan_hwif == IS_SET) {
|
||||||
printf(" attempting to scan hwif (0x%lx, 0x%lx, %lu)\n", hwif_data, hwif_ctrl, hwif_irq);
|
printf(" attempting to scan hwif (0x%lx, 0x%lx, %lu)\n", hwif_data, hwif_ctrl, hwif_irq);
|
||||||
args[0] = hwif_data;
|
args[0] = hwif_data;
|
||||||
args[1] = hwif_ctrl;
|
args[1] = hwif_ctrl;
|
||||||
@ -1571,103 +1585,103 @@ static void process_dev(char *devname)
|
|||||||
}
|
}
|
||||||
ioctl_or_warn(fd, HDIO_SET_PIO_MODE, (int *)(unsigned long)piomode);
|
ioctl_or_warn(fd, HDIO_SET_PIO_MODE, (int *)(unsigned long)piomode);
|
||||||
}
|
}
|
||||||
if (set_io32bit) {
|
if (getset_io32bit == IS_SET) {
|
||||||
print_flag(get_io32bit, "32-bit IO_support flag", io32bit);
|
print_flag(getset_io32bit, "32-bit IO_support flag", io32bit);
|
||||||
ioctl_or_warn(fd, HDIO_SET_32BIT, (int *)io32bit);
|
ioctl_or_warn(fd, HDIO_SET_32BIT, (int *)io32bit);
|
||||||
}
|
}
|
||||||
if (set_mult) {
|
if (getset_mult == IS_SET) {
|
||||||
print_flag(get_mult, "multcount", mult);
|
print_flag(getset_mult, "multcount", mult);
|
||||||
#ifdef HDIO_DRIVE_CMD
|
#ifdef HDIO_DRIVE_CMD
|
||||||
ioctl_or_warn(fd, HDIO_SET_MULTCOUNT, (void *)mult);
|
ioctl_or_warn(fd, HDIO_SET_MULTCOUNT, (void *)mult);
|
||||||
#else
|
#else
|
||||||
force_operation |= (!ioctl_or_warn(fd, HDIO_SET_MULTCOUNT, (void *)mult));
|
force_operation |= (!ioctl_or_warn(fd, HDIO_SET_MULTCOUNT, (void *)mult));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (set_readonly) {
|
if (getset_readonly == IS_SET) {
|
||||||
print_flag_on_off(get_readonly, "readonly", readonly);
|
print_flag_on_off(getset_readonly, "readonly", readonly);
|
||||||
ioctl_or_warn(fd, BLKROSET, &readonly);
|
ioctl_or_warn(fd, BLKROSET, &readonly);
|
||||||
}
|
}
|
||||||
if (set_unmask) {
|
if (getset_unmask == IS_SET) {
|
||||||
print_flag_on_off(get_unmask, "unmaskirq", unmask);
|
print_flag_on_off(getset_unmask, "unmaskirq", unmask);
|
||||||
ioctl_or_warn(fd, HDIO_SET_UNMASKINTR, (int *)unmask);
|
ioctl_or_warn(fd, HDIO_SET_UNMASKINTR, (int *)unmask);
|
||||||
}
|
}
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
||||||
if (set_dma) {
|
if (getset_dma == IS_SET) {
|
||||||
print_flag_on_off(get_dma, "using_dma", dma);
|
print_flag_on_off(getset_dma, "using_dma", dma);
|
||||||
ioctl_or_warn(fd, HDIO_SET_DMA, (int *)dma);
|
ioctl_or_warn(fd, HDIO_SET_DMA, (int *)dma);
|
||||||
}
|
}
|
||||||
#endif /* FEATURE_HDPARM_HDIO_GETSET_DMA */
|
#endif /* FEATURE_HDPARM_HDIO_GETSET_DMA */
|
||||||
#ifdef HDIO_SET_QDMA
|
#ifdef HDIO_SET_QDMA
|
||||||
if (set_dma_q) {
|
if (getset_dma_q == IS_SET) {
|
||||||
print_flag_on_off(get_dma_q, "DMA queue_depth", dma_q);
|
print_flag_on_off(getset_dma_q, "DMA queue_depth", dma_q);
|
||||||
ioctl_or_warn(fd, HDIO_SET_QDMA, (int *)dma_q);
|
ioctl_or_warn(fd, HDIO_SET_QDMA, (int *)dma_q);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (set_nowerr) {
|
if (getset_nowerr == IS_SET) {
|
||||||
print_flag_on_off(get_nowerr, "nowerr", nowerr);
|
print_flag_on_off(getset_nowerr, "nowerr", nowerr);
|
||||||
ioctl_or_warn(fd, HDIO_SET_NOWERR, (int *)nowerr);
|
ioctl_or_warn(fd, HDIO_SET_NOWERR, (int *)nowerr);
|
||||||
}
|
}
|
||||||
if (set_keep) {
|
if (getset_keep == IS_SET) {
|
||||||
print_flag_on_off(get_keep, "keep_settings", keep);
|
print_flag_on_off(getset_keep, "keep_settings", keep);
|
||||||
ioctl_or_warn(fd, HDIO_SET_KEEPSETTINGS, (int *)keep);
|
ioctl_or_warn(fd, HDIO_SET_KEEPSETTINGS, (int *)keep);
|
||||||
}
|
}
|
||||||
#ifdef HDIO_DRIVE_CMD
|
#ifdef HDIO_DRIVE_CMD
|
||||||
if (set_doorlock) {
|
if (getset_doorlock == IS_SET) {
|
||||||
args[0] = doorlock ? WIN_DOORLOCK : WIN_DOORUNLOCK;
|
args[0] = doorlock ? WIN_DOORLOCK : WIN_DOORUNLOCK;
|
||||||
args[2] = 0;
|
args[2] = 0;
|
||||||
print_flag_on_off(get_doorlock, "drive doorlock", doorlock);
|
print_flag_on_off(getset_doorlock, "drive doorlock", doorlock);
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
args[0] = WIN_SETFEATURES;
|
args[0] = WIN_SETFEATURES;
|
||||||
}
|
}
|
||||||
if (set_dkeep) {
|
if (getset_dkeep == IS_SET) {
|
||||||
/* lock/unlock the drive's "feature" settings */
|
/* lock/unlock the drive's "feature" settings */
|
||||||
print_flag_on_off(get_dkeep, "drive keep features", dkeep);
|
print_flag_on_off(getset_dkeep, "drive keep features", dkeep);
|
||||||
args[2] = dkeep ? 0x66 : 0xcc;
|
args[2] = dkeep ? 0x66 : 0xcc;
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
}
|
}
|
||||||
if (set_defects) {
|
if (getset_defects == IS_SET) {
|
||||||
args[2] = defects ? 0x04 : 0x84;
|
args[2] = defects ? 0x04 : 0x84;
|
||||||
print_flag(get_defects, "drive defect-mgmt", defects);
|
print_flag(getset_defects, "drive defect-mgmt", defects);
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
}
|
}
|
||||||
if (set_prefetch) {
|
if (getset_prefetch == IS_SET) {
|
||||||
args[1] = prefetch;
|
args[1] = prefetch;
|
||||||
args[2] = 0xab;
|
args[2] = 0xab;
|
||||||
print_flag(get_prefetch, "drive prefetch", prefetch);
|
print_flag(getset_prefetch, "drive prefetch", prefetch);
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
args[1] = 0;
|
args[1] = 0;
|
||||||
}
|
}
|
||||||
if (set_xfermode) {
|
if (set_xfermode) {
|
||||||
args[1] = xfermode_requested;
|
args[1] = xfermode_requested;
|
||||||
args[2] = 3;
|
args[2] = 3;
|
||||||
if (get_xfermode) {
|
print_flag(1, "xfermode", xfermode_requested);
|
||||||
print_flag(1, "xfermode", xfermode_requested);
|
interpret_xfermode(xfermode_requested);
|
||||||
interpret_xfermode(xfermode_requested);
|
|
||||||
}
|
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
args[1] = 0;
|
args[1] = 0;
|
||||||
}
|
}
|
||||||
if (set_lookahead) {
|
if (getset_lookahead == IS_SET) {
|
||||||
args[2] = lookahead ? 0xaa : 0x55;
|
args[2] = lookahead ? 0xaa : 0x55;
|
||||||
print_flag_on_off(get_lookahead, "drive read-lookahead", lookahead);
|
print_flag_on_off(getset_lookahead, "drive read-lookahead", lookahead);
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
}
|
}
|
||||||
if (set_apmmode) {
|
if (getset_apmmode == IS_SET) {
|
||||||
args[2] = (apmmode == 255) ? 0x85 /* disable */ : 0x05 /* set */; /* feature register */
|
/* feature register */
|
||||||
|
args[2] = (apmmode == 255) ? 0x85 /* disable */ : 0x05 /* set */;
|
||||||
args[1] = apmmode; /* sector count register 1-255 */
|
args[1] = apmmode; /* sector count register 1-255 */
|
||||||
if (get_apmmode)
|
printf(" setting APM level to %s 0x%02lX (%ld)\n",
|
||||||
printf(" setting APM level to %s 0x%02lX (%ld)\n", (apmmode == 255) ? "disabled" : "", apmmode, apmmode);
|
(apmmode == 255) ? "disabled" : "",
|
||||||
|
apmmode, apmmode);
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
args[1] = 0;
|
args[1] = 0;
|
||||||
}
|
}
|
||||||
if (set_wcache) {
|
if (getset_wcache == IS_SET) {
|
||||||
#ifdef DO_FLUSHCACHE
|
#ifdef DO_FLUSHCACHE
|
||||||
#ifndef WIN_FLUSHCACHE
|
#ifndef WIN_FLUSHCACHE
|
||||||
#define WIN_FLUSHCACHE 0xe7
|
#define WIN_FLUSHCACHE 0xe7
|
||||||
#endif
|
#endif
|
||||||
#endif /* DO_FLUSHCACHE */
|
#endif /* DO_FLUSHCACHE */
|
||||||
args[2] = wcache ? 0x02 : 0x82;
|
args[2] = wcache ? 0x02 : 0x82;
|
||||||
print_flag_on_off(get_wcache, "drive write-caching", wcache);
|
print_flag_on_off(getset_wcache, "drive write-caching", wcache);
|
||||||
#ifdef DO_FLUSHCACHE
|
#ifdef DO_FLUSHCACHE
|
||||||
if (!wcache)
|
if (!wcache)
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &flushcache);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &flushcache);
|
||||||
@ -1690,7 +1704,7 @@ static void process_dev(char *devname)
|
|||||||
#ifndef WIN_STANDBYNOW2
|
#ifndef WIN_STANDBYNOW2
|
||||||
#define WIN_STANDBYNOW2 0x94
|
#define WIN_STANDBYNOW2 0x94
|
||||||
#endif
|
#endif
|
||||||
if (get_standbynow) printf(" issuing standby command\n");
|
printf(" issuing standby command\n");
|
||||||
args[0] = WIN_STANDBYNOW1;
|
args[0] = WIN_STANDBYNOW1;
|
||||||
ioctl_alt_or_warn(HDIO_DRIVE_CMD, args, WIN_STANDBYNOW2);
|
ioctl_alt_or_warn(HDIO_DRIVE_CMD, args, WIN_STANDBYNOW2);
|
||||||
}
|
}
|
||||||
@ -1701,22 +1715,20 @@ static void process_dev(char *devname)
|
|||||||
#ifndef WIN_SLEEPNOW2
|
#ifndef WIN_SLEEPNOW2
|
||||||
#define WIN_SLEEPNOW2 0x99
|
#define WIN_SLEEPNOW2 0x99
|
||||||
#endif
|
#endif
|
||||||
if (get_sleepnow) printf(" issuing sleep command\n");
|
printf(" issuing sleep command\n");
|
||||||
args[0] = WIN_SLEEPNOW1;
|
args[0] = WIN_SLEEPNOW1;
|
||||||
ioctl_alt_or_warn(HDIO_DRIVE_CMD, args, WIN_SLEEPNOW2);
|
ioctl_alt_or_warn(HDIO_DRIVE_CMD, args, WIN_SLEEPNOW2);
|
||||||
}
|
}
|
||||||
if (set_seagate) {
|
if (set_seagate) {
|
||||||
args[0] = 0xfb;
|
args[0] = 0xfb;
|
||||||
if (get_seagate) printf(" disabling Seagate auto powersaving mode\n");
|
printf(" disabling Seagate auto powersaving mode\n");
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
}
|
}
|
||||||
if (set_standby) {
|
if (getset_standby == IS_SET) {
|
||||||
args[0] = WIN_SETIDLE1;
|
args[0] = WIN_SETIDLE1;
|
||||||
args[1] = standby_requested;
|
args[1] = standby_requested;
|
||||||
if (get_standby) {
|
print_flag(1, "standby", standby_requested);
|
||||||
print_flag(1, "standby", standby_requested);
|
interpret_standby(standby_requested);
|
||||||
interpret_standby(standby_requested);
|
|
||||||
}
|
|
||||||
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
ioctl_or_warn(fd, HDIO_DRIVE_CMD, &args);
|
||||||
args[1] = 0;
|
args[1] = 0;
|
||||||
}
|
}
|
||||||
@ -1725,23 +1737,23 @@ static void process_dev(char *devname)
|
|||||||
char buf[512];
|
char buf[512];
|
||||||
flush_buffer_cache();
|
flush_buffer_cache();
|
||||||
if (-1 == read(fd, buf, sizeof(buf)))
|
if (-1 == read(fd, buf, sizeof(buf)))
|
||||||
bb_perror_msg("read(%d bytes) failed (rc=-1)", sizeof(buf));
|
bb_perror_msg("read of 512 bytes failed");
|
||||||
}
|
}
|
||||||
#endif /* HDIO_DRIVE_CMD */
|
#endif /* HDIO_DRIVE_CMD */
|
||||||
|
if (getset_mult || get_identity) {
|
||||||
if (get_mult || get_identity) {
|
|
||||||
multcount = -1;
|
multcount = -1;
|
||||||
if (ioctl(fd, HDIO_GET_MULTCOUNT, &multcount)) {
|
if (ioctl(fd, HDIO_GET_MULTCOUNT, &multcount)) {
|
||||||
if (get_mult && ENABLE_IOCTL_HEX2STR_ERROR) /* To be coherent with ioctl_or_warn. */
|
/* To be coherent with ioctl_or_warn. */
|
||||||
|
if (getset_mult && ENABLE_IOCTL_HEX2STR_ERROR)
|
||||||
bb_perror_msg("HDIO_GET_MULTCOUNT");
|
bb_perror_msg("HDIO_GET_MULTCOUNT");
|
||||||
else
|
else
|
||||||
bb_perror_msg("ioctl %#x failed", HDIO_GET_MULTCOUNT);
|
bb_perror_msg("ioctl %#x failed", HDIO_GET_MULTCOUNT);
|
||||||
} else if (get_mult) {
|
} else if (getset_mult) {
|
||||||
printf(fmt, "multcount", multcount);
|
printf(fmt, "multcount", multcount);
|
||||||
on_off(multcount != 0);
|
on_off(multcount != 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (get_io32bit) {
|
if (getset_io32bit) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_32BIT, &parm)) {
|
if (!ioctl_or_warn(fd, HDIO_GET_32BIT, &parm)) {
|
||||||
printf(" IO_support\t=%3ld (", parm);
|
printf(" IO_support\t=%3ld (", parm);
|
||||||
if (parm == 0)
|
if (parm == 0)
|
||||||
@ -1758,14 +1770,12 @@ static void process_dev(char *devname)
|
|||||||
printf("\?\?\?)\n");
|
printf("\?\?\?)\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (get_unmask) {
|
if (getset_unmask) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_UNMASKINTR, &parm))
|
if (!ioctl_or_warn(fd, HDIO_GET_UNMASKINTR, &parm))
|
||||||
print_value_on_off("unmaskirq", parm);
|
print_value_on_off("unmaskirq", parm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
#if ENABLE_FEATURE_HDPARM_HDIO_GETSET_DMA
|
||||||
if (get_dma) {
|
if (getset_dma) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_DMA, &parm)) {
|
if (!ioctl_or_warn(fd, HDIO_GET_DMA, &parm)) {
|
||||||
printf(fmt, "using_dma", parm);
|
printf(fmt, "using_dma", parm);
|
||||||
if (parm == 8)
|
if (parm == 8)
|
||||||
@ -1776,25 +1786,24 @@ static void process_dev(char *devname)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef HDIO_GET_QDMA
|
#ifdef HDIO_GET_QDMA
|
||||||
if (get_dma_q) {
|
if (getset_dma_q) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_QDMA, &parm))
|
if (!ioctl_or_warn(fd, HDIO_GET_QDMA, &parm))
|
||||||
print_value_on_off("queue_depth", parm);
|
print_value_on_off("queue_depth", parm);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (get_keep) {
|
if (getset_keep) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_KEEPSETTINGS, &parm))
|
if (!ioctl_or_warn(fd, HDIO_GET_KEEPSETTINGS, &parm))
|
||||||
print_value_on_off("keepsettings", parm);
|
print_value_on_off("keepsettings", parm);
|
||||||
}
|
}
|
||||||
|
if (getset_nowerr) {
|
||||||
if (get_nowerr) {
|
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_NOWERR, &parm))
|
if (!ioctl_or_warn(fd, HDIO_GET_NOWERR, &parm))
|
||||||
print_value_on_off("nowerr", parm);
|
print_value_on_off("nowerr", parm);
|
||||||
}
|
}
|
||||||
if (get_readonly) {
|
if (getset_readonly) {
|
||||||
if (!ioctl_or_warn(fd, BLKROGET, &parm))
|
if (!ioctl_or_warn(fd, BLKROGET, &parm))
|
||||||
print_value_on_off("readonly", parm);
|
print_value_on_off("readonly", parm);
|
||||||
}
|
}
|
||||||
if (get_readahead) {
|
if (getset_readahead) {
|
||||||
if (!ioctl_or_warn(fd, BLKRAGET, &parm))
|
if (!ioctl_or_warn(fd, BLKRAGET, &parm))
|
||||||
print_value_on_off("readahead", parm);
|
print_value_on_off("readahead", parm);
|
||||||
}
|
}
|
||||||
@ -1804,7 +1813,7 @@ static void process_dev(char *devname)
|
|||||||
|
|
||||||
if (!ioctl_or_warn(fd, HDIO_GETGEO, &g))
|
if (!ioctl_or_warn(fd, HDIO_GETGEO, &g))
|
||||||
printf(" geometry\t= %u/%u/%u, sectors = %ld, start = %ld\n",
|
printf(" geometry\t= %u/%u/%u, sectors = %ld, start = %ld\n",
|
||||||
g.cylinders, g.heads, g.sectors, parm, g.start);
|
g.cylinders, g.heads, g.sectors, parm, g.start);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef HDIO_DRIVE_CMD
|
#ifdef HDIO_DRIVE_CMD
|
||||||
@ -1872,14 +1881,12 @@ static void process_dev(char *devname)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_TRISTATE_HWIF
|
#if ENABLE_FEATURE_HDPARM_HDIO_TRISTATE_HWIF
|
||||||
if (set_busstate) {
|
if (getset_busstate == IS_SET) {
|
||||||
if (get_busstate) {
|
print_flag(1, "bus state", busstate);
|
||||||
print_flag(1, "bus state", busstate);
|
bus_state_value(busstate);
|
||||||
bus_state_value(busstate);
|
|
||||||
}
|
|
||||||
ioctl_or_warn(fd, HDIO_SET_BUSSTATE, (int *)(unsigned long)busstate);
|
ioctl_or_warn(fd, HDIO_SET_BUSSTATE, (int *)(unsigned long)busstate);
|
||||||
}
|
}
|
||||||
if (get_busstate) {
|
if (getset_busstate) {
|
||||||
if (!ioctl_or_warn(fd, HDIO_GET_BUSSTATE, &parm)) {
|
if (!ioctl_or_warn(fd, HDIO_GET_BUSSTATE, &parm)) {
|
||||||
printf(fmt, "bus state", parm);
|
printf(fmt, "bus state", parm);
|
||||||
bus_state_value(parm);
|
bus_state_value(parm);
|
||||||
@ -1935,21 +1942,31 @@ void identify_from_stdin(void);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* busybox specific stuff */
|
/* busybox specific stuff */
|
||||||
static void parse_opts(smallint *get, smallint *set, unsigned long *value, int min, int max)
|
static int parse_opts(unsigned long *value, int min, int max)
|
||||||
{
|
{
|
||||||
if (get) {
|
|
||||||
*get = 1;
|
|
||||||
}
|
|
||||||
if (optarg) {
|
if (optarg) {
|
||||||
*set = 1;
|
|
||||||
*value = xatol_range(optarg, min, max);
|
*value = xatol_range(optarg, min, max);
|
||||||
|
return IS_SET;
|
||||||
}
|
}
|
||||||
|
return IS_GET;
|
||||||
|
}
|
||||||
|
static int parse_opts_0_max(unsigned long *value, int max)
|
||||||
|
{
|
||||||
|
return parse_opts(value, 0, max);
|
||||||
|
}
|
||||||
|
static int parse_opts_0_1(unsigned long *value)
|
||||||
|
{
|
||||||
|
return parse_opts(value, 0, 1);
|
||||||
|
}
|
||||||
|
static int parse_opts_0_INTMAX(unsigned long *value)
|
||||||
|
{
|
||||||
|
return parse_opts(value, 0, INT_MAX);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_xfermode(int flag, smallint *get, smallint *set, int *value)
|
static void parse_xfermode(int flag, smallint *get, smallint *set, int *value)
|
||||||
{
|
{
|
||||||
if (flag) {
|
if (flag) {
|
||||||
*get = 1;
|
*get = IS_GET;
|
||||||
if (optarg) {
|
if (optarg) {
|
||||||
*value = translate_xfermode(optarg);
|
*value = translate_xfermode(optarg);
|
||||||
*set = (*value > -1);
|
*set = (*value > -1);
|
||||||
@ -1991,49 +2008,47 @@ int hdparm_main(int argc, char **argv)
|
|||||||
IF_FEATURE_HDPARM_GET_IDENTITY(get_identity |= (c == 'i'));
|
IF_FEATURE_HDPARM_GET_IDENTITY(get_identity |= (c == 'i'));
|
||||||
get_geom |= (c == 'g');
|
get_geom |= (c == 'g');
|
||||||
do_flush |= (c == 'f');
|
do_flush |= (c == 'f');
|
||||||
if (c == 'u') parse_opts(&get_unmask, &set_unmask, &unmask, 0, 1);
|
if (c == 'u') getset_unmask = parse_opts_0_1(&unmask);
|
||||||
IF_FEATURE_HDPARM_HDIO_GETSET_DMA(if (c == 'd') parse_opts(&get_dma, &set_dma, &dma, 0, 9));
|
IF_FEATURE_HDPARM_HDIO_GETSET_DMA(
|
||||||
if (c == 'n') parse_opts(&get_nowerr, &set_nowerr, &nowerr, 0, 1);
|
if (c == 'd') getset_dma = parse_opts_0_max(&dma, 9);
|
||||||
|
)
|
||||||
|
if (c == 'n') getset_nowerr = parse_opts_0_1(&nowerr);
|
||||||
parse_xfermode((c == 'p'), &noisy_piomode, &set_piomode, &piomode);
|
parse_xfermode((c == 'p'), &noisy_piomode, &set_piomode, &piomode);
|
||||||
if (c == 'r') parse_opts(&get_readonly, &set_readonly, &readonly, 0, 1);
|
if (c == 'r') getset_readonly = parse_opts_0_1(&readonly);
|
||||||
if (c == 'm') parse_opts(&get_mult, &set_mult, &mult, 0, INT_MAX /*32*/);
|
if (c == 'm') getset_mult = parse_opts_0_INTMAX(&mult /*32*/);
|
||||||
if (c == 'c') parse_opts(&get_io32bit, &set_io32bit, &io32bit, 0, INT_MAX /*8*/);
|
if (c == 'c') getset_io32bit = parse_opts_0_INTMAX(&io32bit /*8*/);
|
||||||
if (c == 'k') parse_opts(&get_keep, &set_keep, &keep, 0, 1);
|
if (c == 'k') getset_keep = parse_opts_0_1(&keep);
|
||||||
if (c == 'a') parse_opts(&get_readahead, &set_readahead, &Xreadahead, 0, INT_MAX);
|
if (c == 'a') getset_readahead = parse_opts_0_INTMAX(&Xreadahead);
|
||||||
if (c == 'B') parse_opts(&get_apmmode, &set_apmmode, &apmmode, 1, 255);
|
if (c == 'B') getset_apmmode = parse_opts(&apmmode, 1, 255);
|
||||||
do_flush |= do_timings |= (c == 't');
|
do_flush |= do_timings |= (c == 't');
|
||||||
do_flush |= do_ctimings |= (c == 'T');
|
do_flush |= do_ctimings |= (c == 'T');
|
||||||
#ifdef HDIO_DRIVE_CMD
|
#ifdef HDIO_DRIVE_CMD
|
||||||
if (c == 'S') parse_opts(&get_standby, &set_standby, &standby_requested, 0, 255);
|
if (c == 'S') getset_standby = parse_opts_0_max(&standby_requested, 255);
|
||||||
if (c == 'D') parse_opts(&get_defects, &set_defects, &defects, 0, INT_MAX);
|
if (c == 'D') getset_defects = parse_opts_0_INTMAX(&defects);
|
||||||
if (c == 'P') parse_opts(&get_prefetch, &set_prefetch, &prefetch, 0, INT_MAX);
|
if (c == 'P') getset_prefetch = parse_opts_0_INTMAX(&prefetch);
|
||||||
parse_xfermode((c == 'X'), &get_xfermode, &set_xfermode, &xfermode_requested);
|
parse_xfermode((c == 'X'), &get_xfermode, &set_xfermode, &xfermode_requested);
|
||||||
if (c == 'K') parse_opts(&get_dkeep, &set_dkeep, &prefetch, 0, 1);
|
if (c == 'K') getset_dkeep = parse_opts_0_1(&prefetch);
|
||||||
if (c == 'A') parse_opts(&get_lookahead, &set_lookahead, &lookahead, 0, 1);
|
if (c == 'A') getset_lookahead = parse_opts_0_1(&lookahead);
|
||||||
if (c == 'L') parse_opts(&get_doorlock, &set_doorlock, &doorlock, 0, 1);
|
if (c == 'L') getset_doorlock = parse_opts_0_1(&doorlock);
|
||||||
if (c == 'W') parse_opts(&get_wcache, &set_wcache, &wcache, 0, 1);
|
if (c == 'W') getset_wcache = parse_opts_0_1(&wcache);
|
||||||
get_powermode |= (c == 'C');
|
get_powermode |= (c == 'C');
|
||||||
get_standbynow = set_standbynow |= (c == 'y');
|
set_standbynow |= (c == 'y');
|
||||||
get_sleepnow = set_sleepnow |= (c == 'Y');
|
set_sleepnow |= (c == 'Y');
|
||||||
reread_partn |= (c == 'z');
|
reread_partn |= (c == 'z');
|
||||||
get_seagate = set_seagate |= (c == 'Z');
|
set_seagate |= (c == 'Z');
|
||||||
#endif
|
#endif
|
||||||
IF_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF(if (c == 'U') parse_opts(NULL, &unregister_hwif, &hwif, 0, INT_MAX));
|
IF_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF(if (c == 'U') unregister_hwif = parse_opts_0_INTMAX(&hwif));
|
||||||
#ifdef HDIO_GET_QDMA
|
#ifdef HDIO_GET_QDMA
|
||||||
if (c == 'Q') {
|
if (c == 'Q') {
|
||||||
#ifdef HDIO_SET_QDMA
|
getset_dma_q = parse_opts_0_INTMAX(&dma_q);
|
||||||
parse_opts(&get_dma_q, &set_dma_q, &dma_q, 0, INT_MAX);
|
|
||||||
#else
|
|
||||||
parse_opts(&get_dma_q, NULL, NULL, 0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
IF_FEATURE_HDPARM_HDIO_DRIVE_RESET(perform_reset = (c == 'r'));
|
IF_FEATURE_HDPARM_HDIO_DRIVE_RESET(perform_reset = (c == 'r'));
|
||||||
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF(if (c == 'x') parse_opts(NULL, &perform_tristate, &tristate, 0, 1));
|
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF(if (c == 'x') perform_tristate = parse_opts_0_1(&tristate));
|
||||||
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF(if (c == 'b') parse_opts(&get_busstate, &set_busstate, &busstate, 0, 2));
|
IF_FEATURE_HDPARM_HDIO_TRISTATE_HWIF(if (c == 'b') getset_busstate = parse_opts_0_max(&busstate, 2));
|
||||||
#if ENABLE_FEATURE_HDPARM_HDIO_SCAN_HWIF
|
#if ENABLE_FEATURE_HDPARM_HDIO_SCAN_HWIF
|
||||||
if (c == 'R') {
|
if (c == 'R') {
|
||||||
parse_opts(NULL, &scan_hwif, &hwif_data, 0, INT_MAX);
|
scan_hwif = parse_opts_0_INTMAX(&hwif_data);
|
||||||
hwif_ctrl = xatoi_u((argv[optind]) ? argv[optind] : "");
|
hwif_ctrl = xatoi_u((argv[optind]) ? argv[optind] : "");
|
||||||
hwif_irq = xatoi_u((argv[optind+1]) ? argv[optind+1] : "");
|
hwif_irq = xatoi_u((argv[optind+1]) ? argv[optind+1] : "");
|
||||||
/* Move past the 2 additional arguments */
|
/* Move past the 2 additional arguments */
|
||||||
@ -2044,8 +2059,8 @@ int hdparm_main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
/* When no flags are given (flagcount = 0), -acdgkmnru is assumed. */
|
/* When no flags are given (flagcount = 0), -acdgkmnru is assumed. */
|
||||||
if (!flagcount) {
|
if (!flagcount) {
|
||||||
get_mult = get_io32bit = get_unmask = get_keep = get_readonly = get_readahead = get_geom = 1;
|
getset_mult = getset_io32bit = getset_unmask = getset_keep = getset_readonly = getset_readahead = get_geom = IS_GET;
|
||||||
IF_FEATURE_HDPARM_HDIO_GETSET_DMA(get_dma = 1);
|
IF_FEATURE_HDPARM_HDIO_GETSET_DMA(getset_dma = IS_GET);
|
||||||
}
|
}
|
||||||
argv += optind;
|
argv += optind;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user