From mboxrd@z Thu Jan 1 00:00:00 1970 From: Lee Duncan Subject: Re: [PATCHv2 1/1] SCSI: update hosts module to use idr index management Date: Tue, 6 Oct 2015 10:14:48 -0700 Message-ID: <56140188.6070107@suse.com> References: <1a69690d615610c1dee725db7e6d81cf2db28266.1444085255.git.lduncan@suse.com> <20151006094040.GA24624@infradead.org> Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <20151006094040.GA24624@infradead.org> Sender: linux-kernel-owner@vger.kernel.org To: Christoph Hellwig Cc: linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org, James Bottomley , Tejun Heo , Hannes Reinecke , Johannes Thumshirn List-Id: linux-scsi@vger.kernel.org On 10/06/2015 02:40 AM, Christoph Hellwig wrote: >> struct Scsi_Host *scsi_host_lookup(unsigned short hostnum) >> { >> - struct device *cdev; >> - struct Scsi_Host *shost = NULL; >> - >> - cdev = class_find_device(&shost_class, NULL, &hostnum, >> - __scsi_host_match); >> - if (cdev) { >> - shost = scsi_host_get(class_to_shost(cdev)); >> - put_device(cdev); >> - } >> + struct Scsi_Host *shost; >> + >> + spin_lock(&host_index_lock); >> + shost = idr_find(&host_index_idr, hostnum); >> + spin_unlock(&host_index_lock); >> + >> return shost; > > How does this actually grab a reference to the host? Good catch -- I should have noticed that. I will resubmit the patch. -- Lee Duncan