Chuck Guzis <cclist at sydex.com> wrote:
  On 12/10/2015 12:18 AM, Oliver Lehmann wrote:
  for LBA:
 while ( pata_bsy() ) {}
 write_io_register ( PATA_RW_SECTOR_COUNT_REGISTER, 1 );
 write_io_register ( PATA_RW_SECTOR_NUMBER_REGISTER, 0 );
 write_io_register ( PATA_RW_CYLINDER_LOW_REGISTER, 0 );
 write_io_register ( PATA_RW_CYLINDER_HIGH_REGISTER, 0 );
 write_io_register ( PATA_RW_DEVICE_HEAD_REGISTER, 0xa0 );
 write_io_register ( PATA_W_COMMAND_REGISTER, 0x21 );
 while ( pata_bsy() ) {} if 
  ( pata_err() ) { return; } while (
  !pata_drq() ) {} 
 If you're using LBA, should this be the setting:
  write_io_register ( PATA_RW_DEVICE_HEAD_REGISTER, 0xe0 );
 Bit 6 indicates LBA. 
right - This is what I do in the code - I was writing "from memory".
  Also, note that if you're using drives larger than
about 120GB, the
 PATA-6 protocol comes into effect with 48-bit sector addresses. 
OK - good to know. I only tested ranges 260MB - 80GB. Guess I'll just
not support it then?! How is it different regarding setting the
registers? But anyway... The host computer only supports 32bit
adressing of 512Byte Blocks. And I guess I could also use 500GB
IDE disks when using only lets say some hundrets of MB (plenty
enough - the original harddisk in the system had about 54MB)
Oliver