From mboxrd@z Thu Jan 1 00:00:00 1970 From: Hannes Reinecke Subject: Re: [PATCH V5] Save command pool address of Scsi_Host Date: Wed, 13 Aug 2014 08:38:11 +0200 Message-ID: <53EB07D3.2060708@suse.de> References: <1407151802-27198-1-git-send-email-jgross@suse.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: QUOTED-PRINTABLE Return-path: In-Reply-To: <1407151802-27198-1-git-send-email-jgross@suse.com> Sender: linux-kernel-owner@vger.kernel.org To: jgross@suse.com, James.Bottomley@HansenPartnership.com, hch@infradead.org, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: linux-scsi@vger.kernel.org On 08/04/2014 01:30 PM, jgross@suse.com wrote: > From: Juergen Gross > > If a scsi host driver specifies .cmd_len in it's scsi_host_template, = a driver's > private command pool is needed. scsi_find_host_cmd_pool() will locate= it, but > scsi_alloc_host_cmd_pool() isn't saving the pool address in the host = template. > > This will result in an access error when the host is removed. > > Avoid the problem by saving the address of a new allocated command po= ol where > it is expected. > > Signed-off-by: Juergen Gross > --- > drivers/scsi/scsi.c | 12 ++++++++++-- > 1 file changed, 10 insertions(+), 2 deletions(-) > > diff --git a/drivers/scsi/scsi.c b/drivers/scsi/scsi.c > index 88d46fe..b0cef5b 100644 > --- a/drivers/scsi/scsi.c > +++ b/drivers/scsi/scsi.c > @@ -380,6 +380,10 @@ scsi_alloc_host_cmd_pool(struct Scsi_Host *shost= ) > pool->slab_flags |=3D SLAB_CACHE_DMA; > pool->gfp_mask =3D __GFP_DMA; > } > + > + if (hostt->cmd_size) > + hostt->cmd_pool =3D pool; > + > return pool; > } > > @@ -424,8 +428,10 @@ out: > out_free_slab: > kmem_cache_destroy(pool->cmd_slab); > out_free_pool: > - if (hostt->cmd_size) > + if (hostt->cmd_size) { > scsi_free_host_cmd_pool(pool); > + hostt->cmd_pool =3D NULL; > + } > goto out; > } > > @@ -447,8 +453,10 @@ static void scsi_put_host_cmd_pool(struct Scsi_H= ost *shost) > if (!--pool->users) { > kmem_cache_destroy(pool->cmd_slab); > kmem_cache_destroy(pool->sense_slab); > - if (hostt->cmd_size) > + if (hostt->cmd_size) { > scsi_free_host_cmd_pool(pool); > + hostt->cmd_pool =3D NULL; > + } > } > mutex_unlock(&host_cmd_pool_mutex); > } > Reviewed-by: Hannes Reinecke Cheers, Hannes --=20 Dr. Hannes Reinecke zSeries & Storage hare@suse.de +49 911 74053 688 SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 N=FCrnberg GF: J. Hawn, J. Guild, F. Imend=F6rffer, HRB 16746 (AG N=FCrnberg)