Module Name: src
Committed By: phx
Date: Tue Jun 10 18:37:26 UTC 2014
Modified Files:
src/sys/arch/bebox/stand/boot: sd.c
src/sys/arch/prep/stand/boot: sd.c
Log Message:
Fix SCSI reads beyond block 0x1fffff, by writing the READ_10/READ_16 opcode
into the correct scsipi_rw_10/scsipi_rw_16 command structure.
To generate a diff of this commit:
cvs rdiff -u -r1.3 -r1.4 src/sys/arch/bebox/stand/boot/sd.c
cvs rdiff -u -r1.1 -r1.2 src/sys/arch/prep/stand/boot/sd.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/bebox/stand/boot/sd.c
diff -u src/sys/arch/bebox/stand/boot/sd.c:1.3 src/sys/arch/bebox/stand/boot/sd.c:1.4
--- src/sys/arch/bebox/stand/boot/sd.c:1.3 Wed Dec 19 13:53:47 2012
+++ src/sys/arch/bebox/stand/boot/sd.c Tue Jun 10 18:37:26 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: sd.c,v 1.3 2012/12/19 13:53:47 kiyohara Exp $ */
+/* $NetBSD: sd.c,v 1.4 2014/06/10 18:37:26 phx Exp $ */
/*
* Copyright (c) 2010 KIYOHARA Takashi
* All rights reserved.
@@ -713,7 +713,7 @@ sdstrategy(void *f, int rw, daddr_t dblk
} else if ((blkno & 0xffffffff) == blkno) {
/* 10-byte CDB */
memset(&cmd_big, 0, sizeof(cmd_big));
- cmd_small.opcode = READ_10;
+ cmd_big.opcode = READ_10;
_lto4b(blkno, cmd_big.addr);
_lto2b(1, cmd_big.length);
cmdlen = sizeof(cmd_big);
@@ -721,7 +721,7 @@ sdstrategy(void *f, int rw, daddr_t dblk
} else {
/* 16-byte CDB */
memset(&cmd16, 0, sizeof(cmd16));
- cmd_small.opcode = READ_16;
+ cmd16.opcode = READ_16;
_lto8b(blkno, cmd16.addr);
_lto4b(1, cmd16.length);
cmdlen = sizeof(cmd16);
Index: src/sys/arch/prep/stand/boot/sd.c
diff -u src/sys/arch/prep/stand/boot/sd.c:1.1 src/sys/arch/prep/stand/boot/sd.c:1.2
--- src/sys/arch/prep/stand/boot/sd.c:1.1 Sat May 19 14:40:13 2012
+++ src/sys/arch/prep/stand/boot/sd.c Tue Jun 10 18:37:26 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: sd.c,v 1.1 2012/05/19 14:40:13 kiyohara Exp $ */
+/* $NetBSD: sd.c,v 1.2 2014/06/10 18:37:26 phx Exp $ */
/*
* Copyright (c) 2010 KIYOHARA Takashi
* All rights reserved.
@@ -713,7 +713,7 @@ sdstrategy(void *f, int rw, daddr_t dblk
} else if ((blkno & 0xffffffff) == blkno) {
/* 10-byte CDB */
memset(&cmd_big, 0, sizeof(cmd_big));
- cmd_small.opcode = READ_10;
+ cmd_big.opcode = READ_10;
_lto4b(blkno, cmd_big.addr);
_lto2b(1, cmd_big.length);
cmdlen = sizeof(cmd_big);
@@ -721,7 +721,7 @@ sdstrategy(void *f, int rw, daddr_t dblk
} else {
/* 16-byte CDB */
memset(&cmd16, 0, sizeof(cmd16));
- cmd_small.opcode = READ_16;
+ cmd16.opcode = READ_16;
_lto8b(blkno, cmd16.addr);
_lto4b(1, cmd16.length);
cmdlen = sizeof(cmd16);