cciss: fix flush cache transfer length
authorStephen M. Cameron <scameron@beardog.cce.hp.com>
Mon, 28 Nov 2011 19:12:05 +0000 (20:12 +0100)
committerJens Axboe <axboe@kernel.dk>
Mon, 28 Nov 2011 19:12:05 +0000 (20:12 +0100)
We weren't filling in the transfer length of the
flush cache command (it transfers 4 bytes of zeroes).
Firmware didn't seem to be bothered by this, but it
should be fixed.

Signed-off-by: Stephen M. Cameron <scameron@beardog.cce.hp.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/cciss.c

index 6f22ed0dab651ae1ccbac13884b7459be372d647..587cce57adae23fcddb22270de69ae9ce2bff76b 100644 (file)
@@ -2601,6 +2601,8 @@ static int fill_cmd(ctlr_info_t *h, CommandList_struct *c, __u8 cmd, void *buff,
                        c->Request.Timeout = 0;
                        c->Request.CDB[0] = BMIC_WRITE;
                        c->Request.CDB[6] = BMIC_CACHE_FLUSH;
+                       c->Request.CDB[7] = (size >> 8) & 0xFF;
+                       c->Request.CDB[8] = size & 0xFF;
                        break;
                case TEST_UNIT_READY:
                        c->Request.CDBLen = 6;