From: Alexander Stavitsky <astavitsky@yahoo.com>
To: Andries.Brouwer@cwi.nl, linux-kernel@vger.kernel.org
Subject: Re: Seagate ST340824A and (un)clipping max LBA: 2.2.19+ide04092001 patch
Date: Mon, 30 Apr 2001 11:12:34 -0400 [thread overview]
Message-ID: <20010430111232.A8825@eagle.zoo> (raw)
In-Reply-To: <UTC200104272222.AAA33242.aeb@vlet.cwi.nl>
In-Reply-To: <UTC200104272222.AAA33242.aeb@vlet.cwi.nl>; from Andries.Brouwer@cwi.nl on Sat, Apr 28, 2001 at 12:22:07AM +0200
[-- Attachment #1.1: Type: text/plain, Size: 2552 bytes --]
On Sat, Apr 28, 2001 at 12:22:07AM +0200, Andries.Brouwer@cwi.nl wrote:
> No. Maybe someone can tell us about its origin, but in your case
> of course this just works because 0xa intersects 0x306b. You might
> comment out this entire test.
If I comment out the entire test, it would try to unclip the capacity of all
drives. Is it safe? For my situation I would prefer to use "setmax"
or disk specific "seagate" (see later), but I do not know how to change
the kernel idea of drive geometry and capacity. I use 2.2.19 + ide patch.
Neither fdisk nor dd would not read past the clipped capacity before or after
software unclipping.
>
> In the case of this particular disk the manufacturer says:
> Use the Set Features command (EF) with subfunction F1.
> That tells the disk to report full capacity.
> (ATA-6 says that F1 is reserved for use by the Compact Flash Association)
>
> [Could you try that and report identify output before and after?]
Yes, I tried that and it does report unclipped capacity.
seagate.c is attached for reference.
stalex@eagle:~$ sudo hdparm -I /dev/hdb
/dev/hdb:
Model=TS438042 A , FwRev=.350 , SerialNo=H30E0186
Config={ HardSect NotMFM HdSw>15uSec Fixed DTR>10Mbs RotSpdTol>.5% }
RawCHS=16383/16/63, TrkSize=0, SectSize=0, ECCbytes=0
BuffType=unknown, BuffSize=2048kB, MaxMultSect=16, MultSect=?16?
CurCHS=16383/16/63, CurSects=16514064, LBA=yes, LBAsects=66055248
IORDY=on/off, tPIO={min:240,w/IORDY:120}, tDMA={min:120,rec:120}
PIO modes: pio0 pio1 pio2 pio3 pio4
DMA modes: mdma0 mdma1 mdma2 udma0 udma1 *udma2 udma3 udma4 udma5
stalex@eagle:~$ sudo /usr/src/seagate /dev/hdb
Using device /dev/hdb
Sending Set Features F1 subcommand
Done.
stalex@eagle:~$ sudo hdparm -I /dev/hdb
/dev/hdb:
Model=TS438042 A , FwRev=.350 , SerialNo=H30E0186
Config={ HardSect NotMFM HdSw>15uSec Fixed DTR>10Mbs RotSpdTol>.5% }
RawCHS=16383/16/63, TrkSize=0, SectSize=0, ECCbytes=0
BuffType=unknown, BuffSize=2048kB, MaxMultSect=16, MultSect=?16?
CurCHS=16383/16/63, CurSects=16514064, LBA=yes, LBAsects=78165360
IORDY=on/off, tPIO={min:240,w/IORDY:120}, tDMA={min:120,rec:120}
PIO modes: pio0 pio1 pio2 pio3 pio4
DMA modes: mdma0 mdma1 mdma2 udma0 udma1 *udma2 udma3 udma4 udma5
--
= mailto:astavitsky@yahoo.com
=== http://www.geocities.com/astavitsky
===== GPG Key 0xF7343C8B: 68DD 1E1B 2C98 D336 E31F C87B 91B9 5244 F734 3C8B
|_____Alexander Stavitsky
[-- Attachment #1.2: seagate.c --]
[-- Type: text/x-csrc, Size: 1577 bytes --]
#include <stdio.h>
#include <fcntl.h>
//#include <linux/ide.h>
#include <linux/hdreg.h>
#define SEAGATE_REPORT_FULL_CAPACITY 0xF1
int
get_identity(int fd) {
unsigned char args[4+512] = {WIN_IDENTIFY,0,0,1,};
struct hd_driveid *id = (struct hd_driveid *)&args[4];
if (ioctl(fd, HDIO_DRIVE_CMD, &args)) {
perror("HDIO_DRIVE_CMD");
fprintf(stderr,
"WIN_IDENTIFY failed - trying WIN_PIDENTIFY\n");
args[0] = WIN_PIDENTIFY;
if (ioctl(fd, HDIO_DRIVE_CMD, &args)) {
perror("HDIO_DRIVE_CMD");
fprintf(stderr,
"WIN_PIDENTIFY also failed - giving up\n");
exit(1);
}
}
printf("id->command_set_1: 0x%X\n", id->command_set_1);
printf("id->lba_capacity: %lu\n", id->lba_capacity);
}
/*
* result: in LBA mode precisely what is expected
* in CHS mode the correct H and S, and C mod 65536.
*/
int
set_feature(int fd) {
unsigned char args[4] = {WIN_SETFEATURES,0,0xf1,0};
int i;
if (ioctl(fd, HDIO_DRIVE_CMD, &args)) {
perror("HDIO_DRIVE_CMD failed WIN_SETFEATURES");
for (i=0; i<4; i++)
printf("%d = 0x%X\n", args[i], args[i]);
exit(1);
}
return 0;
}
main(int argc, char **argv){
int fd, c;
char *device = NULL; /* e.g. "/dev/hda" */
int slave = 0;
device = argv[1];
if (!device) {
fprintf(stderr, "no device specified - "
"use e.g. \"seagate /dev/hdb\"\n");
exit(1);
}
printf("Using device %s\n", device);
fd = open(device, O_RDONLY);
if (fd == -1) {
perror("open");
exit(1);
}
printf("Sending Set Features F1 subcommand\n");
set_feature(fd);
printf("Done.\n");
return 0;
}
[-- Attachment #2: Type: application/pgp-signature, Size: 232 bytes --]
prev parent reply other threads:[~2001-04-30 15:13 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2001-04-27 22:22 Seagate ST340824A and (un)clipping max LBA: 2.2.19+ide04092001 patch Andries.Brouwer
2001-04-30 15:12 ` Alexander Stavitsky [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20010430111232.A8825@eagle.zoo \
--to=astavitsky@yahoo.com \
--cc=Andries.Brouwer@cwi.nl \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox