Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1069047yba; Thu, 4 Apr 2019 03:41:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqw7xXtIl7iKWYMOFm7sH32pHtogUBWZrr6Zbrhjjkx6y+TLTGH7Vq3eTtzWnD+JhLyfxUe2 X-Received: by 2002:a63:cc0c:: with SMTP id x12mr5095638pgf.336.1554374487124; Thu, 04 Apr 2019 03:41:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554374487; cv=none; d=google.com; s=arc-20160816; b=znCNVqgqbRTZXAnznk+LyeG5tACturIxj+Q932P9HBwOvI+yteKLAwNTxs+IGoU8tD KD7kJmx/7f4wncRQi9ipeichHe5YSO4OCN2+YGuRotz42WcwRmSyUCQemDs8CWEv7iBu Jb97DCulaWUkpm44IdQslfjhnHn6KDmGx/2k69R0CKYxiLQTyEX5pK/t3Agd6uEvitOQ Y/omCQQ+ejbpgjoKqyG23M2ZDGE+ar1gE2yJLg/FopPO+IHrSdRPs1G4vT4e/SF0laie jDL0jxYVfxY6y5DwiO1cTdT5XNIUjkZPncuQS1R/aOPgI+yPHq9DStt7Krw5c5Quxzl8 DZRA== 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 :user-agent:organization:references:in-reply-to:date:cc:to:from :subject:message-id; bh=JeQvtStI+W3NA4AZSGrO/CIAf+UB12zwSkB7nSvdWGg=; b=V/Fg9zYHyWH9I8TsM/TlR4ruasDVhU1I2ql2seFeRkHaf7ok2jWwxaq6DhrrnpJjAp 1nYgpnQMjrH31DzLCbSR0spYl/MJsjKv7r3MJ3nZKkudHko9/j4+M8wUIm/QDJF1QHgv 4QCJ/bvuC1TaaiMddZ6SVb4GP60OgSbb9YbsaAnbDZizG9DTgaWaX5REGf23/Wr3iTcM 979dpGdiGAiuBGahm3W1bQ/+hNyxXMkN2NueW5SyAU9Naou4DswdQKGodZoNLb7jt3SG /GK2yoNGxZhfjseBUXrY7sYbZuv6ywno+9xwDQOmjHSSIwYoba29oMsEhn4Py+Yeg14w /G2Q== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 101si16210136pld.334.2019.04.04.03.41.11; Thu, 04 Apr 2019 03:41:27 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729064AbfDDKka (ORCPT + 99 others); Thu, 4 Apr 2019 06:40:30 -0400 Received: from mga02.intel.com ([134.134.136.20]:15960 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726269AbfDDKka (ORCPT ); Thu, 4 Apr 2019 06:40:30 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 04 Apr 2019 03:40:29 -0700 X-IronPort-AV: E=Sophos;i="5.60,308,1549958400"; d="scan'208";a="313079954" Received: from jkrzyszt-desk.igk.intel.com ([172.22.244.18]) by orsmga005-auth.jf.intel.com with ESMTP/TLS/AES256-GCM-SHA384; 04 Apr 2019 03:40:27 -0700 Message-ID: Subject: Re: [Intel-gfx] [PATCH] drm/i915: Fix context IDs not released on driver hot unbind From: Janusz Krzysztofik To: Chris Wilson Cc: David Airlie , intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Jani Nikula , Joonas Lahtinen , Rodrigo Vivi Date: Thu, 04 Apr 2019 12:40:24 +0200 In-Reply-To: <155437373474.7532.10868620123516507965@skylake-alporthouse-com> References: <20190404102445.12303-1-janusz.krzysztofik@linux.intel.com> <155437373474.7532.10868620123516507965@skylake-alporthouse-com> Organization: Intel Technology Poland sp. z o.o. - ul. Slowackiego 173, 80-298 Gdansk - KRS 101882 - NIP 957-07-52-316 Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.30.5 (3.30.5-1.fc29) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2019-04-04 at 11:28 +0100, Chris Wilson wrote: > Quoting Janusz Krzysztofik (2019-04-04 11:24:45) > > From: Janusz Krzysztofik > > > > In case the driver gets unbound while a device is open, kernel > > panic > > may be forced if a list of allocated context IDs is not empty. > > > > When a device is open, the list may happen to be not empty because > > a > > context ID, once allocated by a context ID allocator to a context > > assosiated with that open file descriptor, is released as late as > > on device close. > > > > On the other hand, there is a need to release all allocated context > > IDs > > and destroy the context ID allocator on driver unbind, even if a > > device > > is open, in order to free memory resources consumed and prevent > > from > > memory leaks. The purpose of the forced kernel panic was to > > protect > > the context ID allocator from being silently destroyed if not all > > allocated IDs had been released. > > Those open fd are still pointing into kernel memory where the driver > used to be. The panic is entirely correct, we should not be unloading > the module before those dangling pointers have been made safe. > > This is papering over the symptom. How is the module being unloaded > with > open fd? A user can play with the driver unbind or device remove sysfs interface. Thanks, Janusz > If all the fd have been closed, how have we failed to flush and > retire all requests (thereby unpinning the contexts and all other > pointers). > -Chris > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel