On Tue, 10 Sep 2013 15:19:17 -0500 Mark Langsdorf <mark.langsd...@calxeda.com> wrote: ... > diff --git a/drivers/block/ahci.c b/drivers/block/ahci.c > index 8cc9379..c5c942f 100644 > --- a/drivers/block/ahci.c > +++ b/drivers/block/ahci.c
... > @@ -689,10 +696,13 @@ static int ata_scsiop_read_write(ccb *pccb, u8 is_write) > * > * WARNING: one or two older ATA drives treat 0 as 0... > */ > - blocks = (((u16)pccb->cmd[7]) << 8) | ((u16) pccb->cmd[8]); > + if (pccb->cmd[0] == SCSI_READ16) > + blocks = (((u16)pccb->cmd[13]) << 8) | ((u16) pccb->cmd[14]); > + else > + blocks = (((u16)pccb->cmd[7]) << 8) | ((u16) pccb->cmd[8]); > > - debug("scsi_ahci: %s %d blocks starting from lba 0x%x\n", > - is_write ? "write" : "read", (unsigned)lba, blocks); > + debug("scsi_ahci: %s %u blocks starting from lba 0x" LBAFU "\n", > + is_write ? "write" : "read", blocks, lba); LBAFU is defined as "%llu" or "%lu", so " 0x" in the debug string will suggest that the lba value is in hexadecimal notation, but the format specifier outputs as decimal. Please remove "0x" when applying this patch. Thanks! Anatolij _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot