|
@@ -74,6 +74,9 @@ static void mmc_test_prepare_mrq(struct mmc_test_card *test,
|
|
}
|
|
}
|
|
|
|
|
|
mrq->cmd->arg = dev_addr;
|
|
mrq->cmd->arg = dev_addr;
|
|
|
|
+ if (!mmc_card_blockaddr(test->card))
|
|
|
|
+ mrq->cmd->arg <<= 9;
|
|
|
|
+
|
|
mrq->cmd->flags = MMC_RSP_R1 | MMC_CMD_ADTC;
|
|
mrq->cmd->flags = MMC_RSP_R1 | MMC_CMD_ADTC;
|
|
|
|
|
|
if (blocks == 1)
|
|
if (blocks == 1)
|
|
@@ -190,7 +193,7 @@ static int __mmc_test_prepare(struct mmc_test_card *test, int write)
|
|
}
|
|
}
|
|
|
|
|
|
for (i = 0;i < BUFFER_SIZE / 512;i++) {
|
|
for (i = 0;i < BUFFER_SIZE / 512;i++) {
|
|
- ret = mmc_test_buffer_transfer(test, test->buffer, i * 512, 512, 1);
|
|
|
|
|
|
+ ret = mmc_test_buffer_transfer(test, test->buffer, i, 512, 1);
|
|
if (ret)
|
|
if (ret)
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
@@ -219,7 +222,7 @@ static int mmc_test_cleanup(struct mmc_test_card *test)
|
|
memset(test->buffer, 0, 512);
|
|
memset(test->buffer, 0, 512);
|
|
|
|
|
|
for (i = 0;i < BUFFER_SIZE / 512;i++) {
|
|
for (i = 0;i < BUFFER_SIZE / 512;i++) {
|
|
- ret = mmc_test_buffer_transfer(test, test->buffer, i * 512, 512, 1);
|
|
|
|
|
|
+ ret = mmc_test_buffer_transfer(test, test->buffer, i, 512, 1);
|
|
if (ret)
|
|
if (ret)
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
@@ -426,7 +429,7 @@ static int mmc_test_transfer(struct mmc_test_card *test,
|
|
for (i = 0;i < sectors;i++) {
|
|
for (i = 0;i < sectors;i++) {
|
|
ret = mmc_test_buffer_transfer(test,
|
|
ret = mmc_test_buffer_transfer(test,
|
|
test->buffer + i * 512,
|
|
test->buffer + i * 512,
|
|
- dev_addr + i * 512, 512, 0);
|
|
|
|
|
|
+ dev_addr + i, 512, 0);
|
|
if (ret)
|
|
if (ret)
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|