Received: by 10.213.65.68 with SMTP id h4csp42009imn; Mon, 19 Mar 2018 18:56:14 -0700 (PDT) X-Google-Smtp-Source: AG47ELsZAksTp5QjPQuiEbdr0ULbmxEYoK9RAVg/q0CwqBXsOliXNF4gvqx5jlATIW/btsPeK2SJ X-Received: by 10.99.96.193 with SMTP id u184mr10915177pgb.103.1521510974587; Mon, 19 Mar 2018 18:56:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521510974; cv=none; d=google.com; s=arc-20160816; b=0rD+fNX8F6BOJz4DKMfbMLs4d5BfbxqWCP0jtTj+glxn8Re3svjjlzlkbnFL1f8dRh IWw0mJ3G8bXq5IDWpbt/G7mplZeras8BX6HX5HuFUPL1jpDIa5iidHXRnUvLdSI0UEGo HAES6YIyd//hl+YQ+R0gq8UJw/144JgP7eymVont0M97KFxNtoBjxWZ0ypLO+X/jDvyr Q8ezp+1b3glTXNg2UATxrFCj1sIZyMV/tATD4482r0wsejdUo2/ob11u0yT8TT/JD9Dp yhNY39zoy/BsfEDddBiQS9jmViuc+qnos0V8jnixj5fCvrfY3coQBtaMNPDomu42lx1B fxdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:subject:user-agent:message-id :references:cc:in-reply-to:from:to:content-transfer-encoding :mime-version:arc-authentication-results; bh=/JWshG4EGR+toMHbksLd+E5TH2B10cwWjbiSdsy6/C8=; b=ktHW8vt5JBH7QjloyHlneq5RK3Rods1MFNC7xN+3Mt2+fGixV0PonFSR7NfilcklsP 4lgRiiTon+rBWSMN/su16zfQhGrWyqkp7zE9dOT4cFYTUVKPDTZzHBANqzZgnfob0Oy1 4evNx61tDaUdss7pJtswDMKzvaDrclLvzzKOxCYcdlDp+/dj8dAFtdRbUNGFujXOML+T byRSKZmD3mhf+v0pY3uB4OHWruR9Tcgdmkjl3oO74J6uosbx2RC3ihu6ZsDTsIMBiZZL IxNlogs69g4t6TJ+1R6VdLIHO+4Zs4dQjreFuntlhBdiZLsuI6sAvPbYmcZtvB9gUc39 GCLA== 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 y30-v6si494318plh.441.2018.03.19.18.56.00; Mon, 19 Mar 2018 18:56:14 -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 S965274AbeCSVXW convert rfc822-to-8bit (ORCPT + 99 others); Mon, 19 Mar 2018 17:23:22 -0400 Received: from mail.fireflyinternet.com ([109.228.58.192]:54408 "EHLO fireflyinternet.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S934724AbeCSVXU (ORCPT ); Mon, 19 Mar 2018 17:23:20 -0400 X-Default-Received-SPF: pass (skip=forwardok (res=PASS)) x-ip-name=78.156.65.138; Received: from localhost (unverified [78.156.65.138]) by fireflyinternet.com (Firefly Internet (M1)) with ESMTP (TLS) id 11086638-1500050 for multiple; Mon, 19 Mar 2018 21:23:17 +0000 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8BIT To: "Gustavo A. R. Silva" , "Zhenyu Wang" , "Zhi Wang" , "Jani Nikula" , "Joonas Lahtinen" , "Rodrigo Vivi" , "David Airlie" From: Chris Wilson In-Reply-To: <8f70ff7b-9575-006b-2384-88899f24fda6@embeddedor.com> Cc: intel-gvt-dev@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20180319193053.GA7016@embeddedgus> <152149190651.3594.5036347331521892974@mail.alporthouse.com> <8f70ff7b-9575-006b-2384-88899f24fda6@embeddedor.com> Message-ID: <152149459549.3594.15219721825785440264@mail.alporthouse.com> User-Agent: alot/0.3.6 Subject: Re: [PATCH] drm/i915/gvt/scheduler: fix potential NULL pointer dereference Date: Mon, 19 Mar 2018 21:23:15 +0000 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Quoting Gustavo A. R. Silva (2018-03-19 20:50:12) > Hi Chris, > > On 03/19/2018 03:38 PM, Chris Wilson wrote: > > Quoting Gustavo A. R. Silva (2018-03-19 19:30:53) > >> _workload_ is being dereferenced before it is null checked, hence > >> there is a potential null pointer dereference. > >> > >> Fix this by moving the pointer dereference after _workload_ has > >> been null checked. > > > > The checks are misleading and not required. > > All of them? > > if (!workload || !reg_state || workload->ring_id != RCS) > return; workload can not be NULL (dereference in caller), reg_state can not be NULL (by construct from kmap()). It may be not an RCS ring through. -Chris