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);

Reply via email to