-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
Lal wrote:
> Reposting as first post didn't make to the list :)
>
>
> ATAPI block devices support a command READ_CAPACITY that returns "Last
> Logical Block Address" and "Block Length in Bytes".
>
> Given that "Block Length in Bytes" is returned 512 which is equal to
> kernel sector size; is value returned by "Last Logical Block Address"
> used in set_capacity function of the block device driver?
>
> My 512 MB mass storage device returns "Last Logical Block Address" as
> 0xF5FFF. But if I use this value as
>
> set_capacity(my_disk, 0xF5FFF);
>
> I get following kinds of error/warning messages:
> p1 exceeds device capacity
> attempt to access beyond end of device
> MY_DEVICE: rw=0, want=1007616, limit=1007615
>
> I tried to analyze kernel source code printing these messages. These
> messages are from fs/partitions/check.c file. In this file a piece of
> source code evaluates following expression:
>
> if (from + size > get_capacity(disk)) {
> printk(" %s: p%d exceeds device capacity\n", disk->disk_name, p);
> }
>
> 'from' and 'size' are sector start address and sector size
> respectively. These values are read from partition on the device
> (partition was created by a working driver on Linux). Since my device
> driver is able to find partition correctly, I believe 'from' and
> 'size' should also be read correctly. Therefore possibility is that
> get_capacity is returning lesser disk capacity than actual which was
> set by set_capacity.
>
> How to determine what argument value should be used in set_capacity function?
>
> Thanks
> -Lal
>
> --
> To unsubscribe from this list: send an email with
> "unsubscribe kernelnewbies" to [EMAIL PROTECTED]
> Please read the FAQ at http://kernelnewbies.org/FAQ
>
0xF5FFF is 1007615 in decimal, so it seems that setting capacity to 0xF5FFF-1
will solve the problem.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.6 (GNU/Linux)
iD8DBQFITjBh3LCeUQetfe4RAsH7AJ43ALAzQn6FDaEype6rBgQrl9nvxQCfenmB
lU/xGFjFO9noZ4LtVoGDG/M=
=6h2r
-----END PGP SIGNATURE-----
--
To unsubscribe from this list: send an email with
"unsubscribe kernelnewbies" to [EMAIL PROTECTED]
Please read the FAQ at http://kernelnewbies.org/FAQ