diff --git a/[refs] b/[refs] index ed595ec49026..37a7e94e6240 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 9480c53e9b2aa13a06283ffb96bb8f1873ac4e9a +refs/heads/master: 4d48a542b42747c36a5937447d9c3de7c897ea50 diff --git a/trunk/drivers/block/nbd.c b/trunk/drivers/block/nbd.c index 34f80fa6fed1..8299e2d3b611 100644 --- a/trunk/drivers/block/nbd.c +++ b/trunk/drivers/block/nbd.c @@ -549,6 +549,15 @@ static void do_nbd_request(struct request_queue * q) BUG_ON(lo->magic != LO_MAGIC); + if (unlikely(!lo->sock)) { + printk(KERN_ERR "%s: Attempted send on closed socket\n", + lo->disk->disk_name); + req->errors++; + nbd_end_request(req); + spin_lock_irq(q->queue_lock); + continue; + } + spin_lock_irq(&lo->queue_lock); list_add_tail(&req->queuelist, &lo->waiting_queue); spin_unlock_irq(&lo->queue_lock);