diff options
author | Pierre Ossman <drzeus@drzeus.cx> | 2007-01-03 13:47:29 -0500 |
---|---|---|
committer | Pierre Ossman <drzeus@drzeus.cx> | 2007-05-01 07:04:18 -0400 |
commit | b855885e3b60cf6f9452848712a62517b94583eb (patch) | |
tree | 2e8a6fb8d8992ac8fb968a26c6db8778c2b5e791 /drivers/mmc/card/block.c | |
parent | b5af25bee2de2f6cd1ac74ba737cbc4f3d303e5d (diff) |
mmc: deprecate mmc bus topology
The classic MMC bus was defined as multi card bus
system, which is reflected in the design in the MMC
layer.
When SD showed up, the bus topology was abandoned
and a star topology (one card per host) was mandated.
MMC version 4 has followed this, officially deprecating
the bus topology.
As we do not have any known users of the bus
topology we can remove support for it. This will
simplify the code and rectify some incorrect
assumptions in the newer additions.
Signed-off-by: Pierre Ossman <drzeus@drzeus.cx>
Diffstat (limited to 'drivers/mmc/card/block.c')
-rw-r--r-- | drivers/mmc/card/block.c | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/drivers/mmc/card/block.c b/drivers/mmc/card/block.c index 8eba037a18e0..8a84e4dc1b2a 100644 --- a/drivers/mmc/card/block.c +++ b/drivers/mmc/card/block.c | |||
@@ -226,8 +226,7 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
226 | struct mmc_blk_request brq; | 226 | struct mmc_blk_request brq; |
227 | int ret = 1, sg_pos, data_size; | 227 | int ret = 1, sg_pos, data_size; |
228 | 228 | ||
229 | if (mmc_card_claim_host(card)) | 229 | mmc_claim_host(card->host); |
230 | goto flush_queue; | ||
231 | 230 | ||
232 | do { | 231 | do { |
233 | struct mmc_command cmd; | 232 | struct mmc_command cmd; |
@@ -357,7 +356,7 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
357 | spin_unlock_irq(&md->lock); | 356 | spin_unlock_irq(&md->lock); |
358 | } while (ret); | 357 | } while (ret); |
359 | 358 | ||
360 | mmc_card_release_host(card); | 359 | mmc_release_host(card->host); |
361 | 360 | ||
362 | return 1; | 361 | return 1; |
363 | 362 | ||
@@ -393,9 +392,7 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
393 | spin_unlock_irq(&md->lock); | 392 | spin_unlock_irq(&md->lock); |
394 | } | 393 | } |
395 | 394 | ||
396 | flush_queue: | 395 | mmc_release_host(card->host); |
397 | |||
398 | mmc_card_release_host(card); | ||
399 | 396 | ||
400 | spin_lock_irq(&md->lock); | 397 | spin_lock_irq(&md->lock); |
401 | while (ret) { | 398 | while (ret) { |
@@ -526,12 +523,12 @@ mmc_blk_set_blksize(struct mmc_blk_data *md, struct mmc_card *card) | |||
526 | if (mmc_card_blockaddr(card)) | 523 | if (mmc_card_blockaddr(card)) |
527 | return 0; | 524 | return 0; |
528 | 525 | ||
529 | mmc_card_claim_host(card); | 526 | mmc_claim_host(card->host); |
530 | cmd.opcode = MMC_SET_BLOCKLEN; | 527 | cmd.opcode = MMC_SET_BLOCKLEN; |
531 | cmd.arg = 1 << md->block_bits; | 528 | cmd.arg = 1 << md->block_bits; |
532 | cmd.flags = MMC_RSP_R1 | MMC_CMD_AC; | 529 | cmd.flags = MMC_RSP_R1 | MMC_CMD_AC; |
533 | err = mmc_wait_for_cmd(card->host, &cmd, 5); | 530 | err = mmc_wait_for_cmd(card->host, &cmd, 5); |
534 | mmc_card_release_host(card); | 531 | mmc_release_host(card->host); |
535 | 532 | ||
536 | if (err) { | 533 | if (err) { |
537 | printk(KERN_ERR "%s: unable to set block size to %d: %d\n", | 534 | printk(KERN_ERR "%s: unable to set block size to %d: %d\n", |