diff options
Diffstat (limited to 'drivers/mmc/mmc_block.c')
| -rw-r--r-- | drivers/mmc/mmc_block.c | 60 |
1 files changed, 7 insertions, 53 deletions
diff --git a/drivers/mmc/mmc_block.c b/drivers/mmc/mmc_block.c index 115cc21094b9..a0e0dad1b419 100644 --- a/drivers/mmc/mmc_block.c +++ b/drivers/mmc/mmc_block.c | |||
| @@ -30,6 +30,7 @@ | |||
| 30 | #include <linux/mutex.h> | 30 | #include <linux/mutex.h> |
| 31 | 31 | ||
| 32 | #include <linux/mmc/card.h> | 32 | #include <linux/mmc/card.h> |
| 33 | #include <linux/mmc/host.h> | ||
| 33 | #include <linux/mmc/protocol.h> | 34 | #include <linux/mmc/protocol.h> |
| 34 | 35 | ||
| 35 | #include <asm/system.h> | 36 | #include <asm/system.h> |
| @@ -171,8 +172,6 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
| 171 | 172 | ||
| 172 | brq.cmd.arg = req->sector << 9; | 173 | brq.cmd.arg = req->sector << 9; |
| 173 | brq.cmd.flags = MMC_RSP_R1 | MMC_CMD_ADTC; | 174 | brq.cmd.flags = MMC_RSP_R1 | MMC_CMD_ADTC; |
| 174 | brq.data.timeout_ns = card->csd.tacc_ns * 10; | ||
| 175 | brq.data.timeout_clks = card->csd.tacc_clks * 10; | ||
| 176 | brq.data.blksz_bits = md->block_bits; | 175 | brq.data.blksz_bits = md->block_bits; |
| 177 | brq.data.blksz = 1 << md->block_bits; | 176 | brq.data.blksz = 1 << md->block_bits; |
| 178 | brq.data.blocks = req->nr_sectors >> (md->block_bits - 9); | 177 | brq.data.blocks = req->nr_sectors >> (md->block_bits - 9); |
| @@ -180,6 +179,8 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
| 180 | brq.stop.arg = 0; | 179 | brq.stop.arg = 0; |
| 181 | brq.stop.flags = MMC_RSP_R1B | MMC_CMD_AC; | 180 | brq.stop.flags = MMC_RSP_R1B | MMC_CMD_AC; |
| 182 | 181 | ||
| 182 | mmc_set_data_timeout(&brq.data, card, rq_data_dir(req) != READ); | ||
| 183 | |||
| 183 | if (rq_data_dir(req) == READ) { | 184 | if (rq_data_dir(req) == READ) { |
| 184 | brq.cmd.opcode = brq.data.blocks > 1 ? MMC_READ_MULTIPLE_BLOCK : MMC_READ_SINGLE_BLOCK; | 185 | brq.cmd.opcode = brq.data.blocks > 1 ? MMC_READ_MULTIPLE_BLOCK : MMC_READ_SINGLE_BLOCK; |
| 185 | brq.data.flags |= MMC_DATA_READ; | 186 | brq.data.flags |= MMC_DATA_READ; |
| @@ -187,12 +188,6 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
| 187 | brq.cmd.opcode = MMC_WRITE_BLOCK; | 188 | brq.cmd.opcode = MMC_WRITE_BLOCK; |
| 188 | brq.data.flags |= MMC_DATA_WRITE; | 189 | brq.data.flags |= MMC_DATA_WRITE; |
| 189 | brq.data.blocks = 1; | 190 | brq.data.blocks = 1; |
| 190 | |||
| 191 | /* | ||
| 192 | * Scale up the timeout by the r2w factor | ||
| 193 | */ | ||
| 194 | brq.data.timeout_ns <<= card->csd.r2w_factor; | ||
| 195 | brq.data.timeout_clks <<= card->csd.r2w_factor; | ||
| 196 | } | 191 | } |
| 197 | 192 | ||
| 198 | if (brq.data.blocks > 1) { | 193 | if (brq.data.blocks > 1) { |
| @@ -324,52 +319,11 @@ static struct mmc_blk_data *mmc_blk_alloc(struct mmc_card *card) | |||
| 324 | md->read_only = mmc_blk_readonly(card); | 319 | md->read_only = mmc_blk_readonly(card); |
| 325 | 320 | ||
| 326 | /* | 321 | /* |
| 327 | * Figure out a workable block size. MMC cards have: | 322 | * Both SD and MMC specifications state (although a bit |
| 328 | * - two block sizes, one for read and one for write. | 323 | * unclearly in the MMC case) that a block size of 512 |
| 329 | * - may support partial reads and/or writes | 324 | * bytes must always be supported by the card. |
| 330 | * (allows block sizes smaller than specified) | ||
| 331 | */ | ||
| 332 | md->block_bits = card->csd.read_blkbits; | ||
| 333 | if (card->csd.write_blkbits != card->csd.read_blkbits) { | ||
| 334 | if (card->csd.write_blkbits < card->csd.read_blkbits && | ||
| 335 | card->csd.read_partial) { | ||
| 336 | /* | ||
| 337 | * write block size is smaller than read block | ||
| 338 | * size, but we support partial reads, so choose | ||
| 339 | * the smaller write block size. | ||
| 340 | */ | ||
| 341 | md->block_bits = card->csd.write_blkbits; | ||
| 342 | } else if (card->csd.write_blkbits > card->csd.read_blkbits && | ||
| 343 | card->csd.write_partial) { | ||
| 344 | /* | ||
| 345 | * read block size is smaller than write block | ||
| 346 | * size, but we support partial writes. Use read | ||
| 347 | * block size. | ||
| 348 | */ | ||
| 349 | } else { | ||
| 350 | /* | ||
| 351 | * We don't support this configuration for writes. | ||
| 352 | */ | ||
| 353 | printk(KERN_ERR "%s: unable to select block size for " | ||
| 354 | "writing (rb%u wb%u rp%u wp%u)\n", | ||
| 355 | mmc_card_id(card), | ||
| 356 | 1 << card->csd.read_blkbits, | ||
| 357 | 1 << card->csd.write_blkbits, | ||
| 358 | card->csd.read_partial, | ||
| 359 | card->csd.write_partial); | ||
| 360 | md->read_only = 1; | ||
| 361 | } | ||
| 362 | } | ||
| 363 | |||
| 364 | /* | ||
| 365 | * Refuse to allow block sizes smaller than 512 bytes. | ||
| 366 | */ | 325 | */ |
| 367 | if (md->block_bits < 9) { | 326 | md->block_bits = 9; |
| 368 | printk(KERN_ERR "%s: unable to support block size %u\n", | ||
| 369 | mmc_card_id(card), 1 << md->block_bits); | ||
| 370 | ret = -EINVAL; | ||
| 371 | goto err_kfree; | ||
| 372 | } | ||
| 373 | 327 | ||
| 374 | md->disk = alloc_disk(1 << MMC_SHIFT); | 328 | md->disk = alloc_disk(1 << MMC_SHIFT); |
| 375 | if (md->disk == NULL) { | 329 | if (md->disk == NULL) { |
