Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp1130489ybg; Wed, 23 Oct 2019 10:48:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqzBAbom6vPNc62CTpM503AnXMGVzl0RxIKroHlAL6jH7Q4Dr7yp2L8NxUx5UNTYNsFQRaWj X-Received: by 2002:aa7:d3c4:: with SMTP id o4mr11107615edr.194.1571852898466; Wed, 23 Oct 2019 10:48:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571852898; cv=none; d=google.com; s=arc-20160816; b=MTnmB5XHkSmQ0Ejlc2QbBzIk4RsXKosVlcA7Aj9JxtBFCFuilioHPT2jXlsqD4UuWA mrH5VS5hb/Z2t5REZIa956G0wNHyd+dsgYdXB4G7fUHnT6OaCgQqh9f7uLPo17vdTNEC zPVSmKwi3kyyw5GfZFCf2CXTjnXNDI+Fezk8EeoIG0fJbArsTfYsvHB0JnFe3yKEqI43 AMeKhFsOv21lMAzQxvx8lu2WBcU6fbQiBparY6EcI0K5gRhdJicmyTqWshUr+MliF+/1 SkpycU1meR6xPhzVQiwl70A3vQlOM8YtqOEm0ZUs44Ml/sfGUR3JDm2eb7FWbCRgLbC1 7Amg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=9PpZmC611RoRJMuT8m5kiKi08XSmkqBOnWiV/AvUCxM=; b=ZM6DPY+adE5hjv6ttCPjrEDPFiw9mqDkND5l1CLAOvudSf4LfUNE5QgTCS+tgi6ErX MHJj15Zta9VqPxwlFjfIVkemaYT8eQXARvccnhpRMK0TbGIlxeVE14fJscV+lRwAsK5X oO2P1FCsuggzeLOqeZYPfQu06OmUv3CFkZ6GobAWoZ6yCIxTztkZ15rzGqaUc+I58A1A BrjPjyETwKlGU22PaIHON8ojDHBHbPAHajPgmuzHnBQ+e/3setdhJZ5jIR7n6ep9y9QF uArz9MWB+5+dLtCE5+9bgTllr+B/tjx1v3m4pu0lOZTCmriNdAYkcgvE581gEdLgRwoK j4gg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s2si11078726edi.413.2019.10.23.10.47.54; Wed, 23 Oct 2019 10:48:18 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391913AbfJWMxT (ORCPT + 99 others); Wed, 23 Oct 2019 08:53:19 -0400 Received: from mx2.suse.de ([195.135.220.15]:49374 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2391880AbfJWMxQ (ORCPT ); Wed, 23 Oct 2019 08:53:16 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id CECD2B67E; Wed, 23 Oct 2019 12:53:14 +0000 (UTC) From: Michal Suchanek To: linux-scsi@vger.kernel.org Cc: Michal Suchanek , Jonathan Corbet , Jens Axboe , "James E.J. Bottomley" , "Martin K. Petersen" , Alexander Viro , Mauro Carvalho Chehab , Eric Biggers , "J. Bruce Fields" , Benjamin Coddington , Hannes Reinecke , Omar Sandoval , Ming Lei , Damien Le Moal , Bart Van Assche , Tejun Heo , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v2 8/8] scsi: sr: wait for the medium to become ready Date: Wed, 23 Oct 2019 14:52:47 +0200 Message-Id: <94dc98dc67b1d183d04c338c7978efa0556db6ac.1571834862.git.msuchanek@suse.de> X-Mailer: git-send-email 2.23.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use the autoclose IOCLT provided by cdrom driver to wait for drive to close in open_finish, and attempt to open once more after the door closes. Signed-off-by: Michal Suchanek --- drivers/scsi/sr.c | 54 ++++++++++++++++++++++++++++++++++++----------- 1 file changed, 42 insertions(+), 12 deletions(-) diff --git a/drivers/scsi/sr.c b/drivers/scsi/sr.c index 8090c5bdec09..34d9a818b9e0 100644 --- a/drivers/scsi/sr.c +++ b/drivers/scsi/sr.c @@ -521,29 +521,58 @@ static blk_status_t sr_init_command(struct scsi_cmnd *SCpnt) return ret; } -static int sr_block_open(struct block_device *bdev, fmode_t mode) +static int __sr_block_open(struct block_device *bdev, fmode_t mode) { - struct scsi_cd *cd; - struct scsi_device *sdev; - int ret = -ENXIO; - - cd = scsi_cd_get(bdev->bd_disk); - if (!cd) - goto out; + struct scsi_cd *cd = scsi_cd(bdev->bd_disk); + int ret; - sdev = cd->device; - scsi_autopm_get_device(sdev); check_disk_change(bdev); mutex_lock(&sr_mutex); ret = cdrom_open(&cd->cdi, bdev, mode); mutex_unlock(&sr_mutex); + return ret; +} + +static int sr_block_open(struct block_device *bdev, fmode_t mode) +{ + struct scsi_cd *cd = scsi_cd_get(bdev->bd_disk); + struct scsi_device *sdev; + int ret; + + if (!cd) + return -ENXIO; + + sdev = cd->device; + scsi_autopm_get_device(sdev); + ret = __sr_block_open(bdev, mode); scsi_autopm_put_device(sdev); - if (ret) + + if (ret == -ERESTARTSYS) scsi_cd_put(cd); -out: + return ret; +} + +static int sr_block_open_finish(struct block_device *bdev, fmode_t mode, + int ret) +{ + struct scsi_cd *cd = scsi_cd(bdev->bd_disk); + + /* wait for drive to get ready */ + if ((ret == -ENOMEDIUM) && !(mode & FMODE_NDELAY)) { + struct scsi_device *sdev = cd->device; + /* + * Cannot use sr_block_ioctl because it locks sr_mutex blocking + * out any processes trying to access the drive + */ + scsi_autopm_get_device(sdev); + cdrom_ioctl(&cd->cdi, bdev, mode, CDROM_AUTOCLOSE, 0); + ret = __sr_block_open(bdev, mode); + scsi_autopm_put_device(sdev); + } + return ret; } @@ -639,6 +668,7 @@ static const struct block_device_operations sr_bdops = { .owner = THIS_MODULE, .open = sr_block_open, + .open_finish = sr_block_open_finish, .release = sr_block_release, .ioctl = sr_block_ioctl, .check_events = sr_block_check_events, -- 2.23.0