The patch titled Subject: umem: fix up unplugging has been added to the -mm tree. Its filename is umem-fix-up-unplugging.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** The -mm tree is included into linux-next and is updated there every 3-4 working days ------------------------------------------------------ From: Tao Guo <glorioustao@xxxxxxxxx> Subject: umem: fix up unplugging Fix a regression introduced by 7eaceaccab5f40 ("block: remove per-queue plugging"). In that patch, Jens removed the whole mm_unplug_device() function, which used to be the trigger to make umem start to work. We need to implement unplugging to make umem start to work, or I/O will never be triggered. Signed-off-by: Tao Guo <Tao.Guo@xxxxxxx> Cc: Neil Brown <neilb@xxxxxxx> Cc: Jens Axboe <axboe@xxxxxxxxx> Cc: <stable@xxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- drivers/block/umem.c | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff -puN drivers/block/umem.c~umem-fix-up-unplugging drivers/block/umem.c --- a/drivers/block/umem.c~umem-fix-up-unplugging +++ a/drivers/block/umem.c @@ -111,7 +111,8 @@ struct cardinfo { int current_idx; sector_t current_sector; - struct request_queue *queue; + struct request_queue *queue; + struct blk_plug_cb plug_cb; struct mm_page { dma_addr_t page_dma; @@ -513,6 +514,33 @@ static void process_page(unsigned long d } } +static void mm_unplug(struct blk_plug_cb *cb) +{ + struct cardinfo *card = container_of(cb, struct cardinfo, plug_cb); + + spin_lock_irq(&card->lock); + activate(card); + spin_unlock_irq(&card->lock); +} + +int mm_check_plugged(struct cardinfo *card) +{ + struct blk_plug *plug = current->plug; + struct cardinfo *c; + + if (!plug) + return 0; + + list_for_each_entry(c, &plug->cb_list, plug_cb.list) { + if (c == card) + return 1; + } + + /* set up unplug callback */ + list_add(&card->plug_cb.list, &plug->cb_list); + return 1; +} + static void mm_make_request(struct request_queue *q, struct bio *bio) { struct cardinfo *card = q->queuedata; @@ -523,6 +551,8 @@ static void mm_make_request(struct reque *card->biotail = bio; bio->bi_next = NULL; card->biotail = &bio->bi_next; + if (bio->bi_rw & REQ_SYNC || !mm_check_plugged(card)) + activate(card); spin_unlock_irq(&card->lock); return; @@ -884,6 +914,7 @@ static int __devinit mm_pci_probe(struct blk_queue_make_request(card->queue, mm_make_request); card->queue->queue_lock = &card->lock; card->queue->queuedata = card; + card->plug_cb.callback = mm_unplug; tasklet_init(&card->tasklet, process_page, (unsigned long)card); _ Subject: Subject: umem: fix up unplugging Patches currently in -mm which might be from glorioustao@xxxxxxxxx are umem-fix-up-unplugging.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html