From mboxrd@z Thu Jan 1 00:00:00 1970 From: Asias He Subject: Re: [patch] virtio-blk: fix NULL checking in virtblk_alloc_req() Date: Thu, 06 Sep 2012 11:02:48 +0800 Message-ID: <50481258.3080203@redhat.com> References: <20120905123252.GE6128@elgon.mountain> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <20120905123252.GE6128@elgon.mountain> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: virtualization-bounces@lists.linux-foundation.org Errors-To: virtualization-bounces@lists.linux-foundation.org To: Dan Carpenter Cc: kernel-janitors@vger.kernel.org, virtualization@lists.linux-foundation.org, "Michael S. Tsirkin" List-Id: virtualization@lists.linuxfoundation.org Hello Dan, On 09/05/2012 08:32 PM, Dan Carpenter wrote: > Smatch complains about the inconsistent NULL checking here. Fix it to > return NULL on failure. > > Signed-off-by: Dan Carpenter Thanks for catching this. > --- > This is only needed in linux-next. > > diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c > index 2edfb5c..457db0c 100644 > --- a/drivers/block/virtio_blk.c > +++ b/drivers/block/virtio_blk.c > @@ -90,10 +90,11 @@ static inline struct virtblk_req *virtblk_alloc_req(struct virtio_blk *vblk, > struct virtblk_req *vbr; > > vbr = mempool_alloc(vblk->pool, gfp_mask); > - if (vbr && use_bio) > - sg_init_table(vbr->sg, vblk->sg_elems); > + if (!vbr) > + return NULL; > > - vbr->vblk = vblk; The assignment of vbr->vblk is needed. > + if (use_bio) > + sg_init_table(vbr->sg, vblk->sg_elems); > > return vbr; > } -- Asias