Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3365945ybl; Mon, 19 Aug 2019 17:34:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqziQTX89KG3y64Bsik7RiOJUXnnEzmzeh8bj4s7WPra14sUOjaNyTq8VURmkSbdH/RuwwCA X-Received: by 2002:aa7:8753:: with SMTP id g19mr8034536pfo.249.1566261275348; Mon, 19 Aug 2019 17:34:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566261275; cv=none; d=google.com; s=arc-20160816; b=fJ+IqmDLVb+gbqlK2PNyhKNeBoJR5yPdQg6aZ0vY++vbRL3SGTJCH1kNxe/R++PRP7 jHmMTyiCkXpL9bl9Pg0qeNGDK2h1nn3k12SZnfleqiOMQ45nm5ibEMJwZruFiXKZ5Wh9 WSHsNQnGVQoDolcu4IkoCZ7YhAem1/uN6H1/GMUxyRsRP2YJg2npdKXuEz/0nxXP3Cq7 CdT8XkCieYh0YRdFCMY9TBLzLlIQTpAVxHz/YA5b4DvFqCmEJ3b0EnIxOz6F5HOpBvvU /vkV2cwf8+wPNKvNUlF1sYQFOsRXvlGBG2dutHbD3iEIW23Z3U2FXmrmp2XrR1ffOv4T 9h6A== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=u8xujnXPvByvO77xUkBnJzhQKwD/i/4jy5/YnqYkj3w=; b=pRTa9i/bCWkcjK9gC24GS1u3wL/3jUToZenD1IgAX4qqTN6ySOn/HBK5jAQMDOhGuK TX3qEoucRuUDNQLNZgAW9V8J6JDEr5/rtOzM29DyHGGdpShRCGIyQ8Cwi3uiUxPORfUy pMyZZ1Pql52hWZ0QiO+CHA9JGsQmmS3ryaWANWAmTbmruRiBw3Pd4LvZZxw63qbPtNo4 LD7LtgrTpOEoW26tiT/zfQmr4HlmPJUvlKoMAMNybQ9PYBFG7pNLP0+1AizXt0Uue01j loUwwiOWyz9I+GhAxIyO7B/5KkyaOGNMrQIVjRoQRPYNJTPQQ3yCuMmAXoEbBZeBFZiI f9sg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bxqCDeCz; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w24si11933464pfi.80.2019.08.19.17.34.20; Mon, 19 Aug 2019 17:34:35 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bxqCDeCz; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728840AbfHTAdc (ORCPT + 99 others); Mon, 19 Aug 2019 20:33:32 -0400 Received: from mail-yb1-f195.google.com ([209.85.219.195]:46934 "EHLO mail-yb1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728580AbfHTAdb (ORCPT ); Mon, 19 Aug 2019 20:33:31 -0400 Received: by mail-yb1-f195.google.com with SMTP id x10so1253110ybs.13; Mon, 19 Aug 2019 17:33:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=u8xujnXPvByvO77xUkBnJzhQKwD/i/4jy5/YnqYkj3w=; b=bxqCDeCzUlSvA5GV+SnyfLf66N1QAGVzFlnRNU43Xtwv5yTj6/lyImJVyQ2Ux+aj1K +hllzNuiUfP38anrW1dkhTeWI6M9tZrwDqYQfHoRDVeUgEyVJP/WIKHFUhCU6RKCMsRT q4ItbNq7DTtwoRDcmua+SzHJivpxHzw7bghj62V2Qzi4vFZRSjK49XBE84/j2oBIWQhX ZAV3qyMIVAfZZwD7LUBPIWnji82wBVPiu10JxqdeOw/Yc+zedceHL8MpVTQfqUNMYrHE N1ZavKr8EhPKjc6GRo2F8YBuK3jY/XD5tAAhGFPoc4GdmFuDyfVFhdKuUx8OdFdEwFvE 4sAA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=u8xujnXPvByvO77xUkBnJzhQKwD/i/4jy5/YnqYkj3w=; b=MWsNOkCiXueK5S7p4HTMUUlcePfgxoH0UyY/Huu6bGG9TDCWyoBtPNPcnNLk8S6kAH 0AVqsscDm0nOJQrYlpgaZgpZVM7fbrkEyNLdhm0fvXBfaeZ35bfC8BVDUFDLVITBA6Iz BOu9/rUPJ36hhdyDM/XEwHjTzeCDuaRcd932PvNfyT5CWOI85AEPFP7428saTTy3jURd SymJrz53HAvEte3tU9sPwfT/yb2TSVLOygAIrJxFWycYyMuPE6lV23fD1SkynbN8Ukvs ztoVsUUzuDr6LcgnRhbSEcQGksLSYrgLxvFQg7mdLiJyIOcMTT6v2IvizxBtZt+nAI4b M+7A== X-Gm-Message-State: APjAAAVskiMdFauojw+/euQUaVGIF0FSAgs1Smw+lmy6kSEa7z79tFzR KB++GFAXLqLljOq7xRUdv4NOYmz1 X-Received: by 2002:a25:d8d3:: with SMTP id p202mr18859766ybg.512.1566261210027; Mon, 19 Aug 2019 17:33:30 -0700 (PDT) Received: from theseus.lan ([2604:2d80:b386:1f00::780]) by smtp.gmail.com with ESMTPSA id 193sm3658853ywh.89.2019.08.19.17.33.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 19 Aug 2019 17:33:29 -0700 (PDT) From: Clark Williams To: bigeasy@linutronix.com Cc: tglx@linutronix.com, linux-rt-users@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PREEMPT_RT PATCH 1/3] i915: do not call lockdep_assert_irqs_disabled() on PREEMPT_RT Date: Mon, 19 Aug 2019 19:33:17 -0500 Message-Id: <20190820003319.24135-2-clark.williams@gmail.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190820003319.24135-1-clark.williams@gmail.com> References: <20190820003319.24135-1-clark.williams@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Clark Williams The 'breadcrumb' code in the i915 driver calls lockdep_assert_irqs_disabled() when starting some operations. This is valid on a stock kernel but on a PREEMPT_RT kernel the spin_lock_irq*() calls to not disable interrupts and likewise the spin_unlock_irq*() calls to not enable interrupts. Conditionalize these calls based on whether PREEMPT_RT_FULL is enabled. Signed-off-by: Clark Williams --- drivers/gpu/drm/i915/intel_breadcrumbs.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/drivers/gpu/drm/i915/intel_breadcrumbs.c b/drivers/gpu/drm/i915/intel_breadcrumbs.c index 832cb6b1e9bd..3eef6010ebf6 100644 --- a/drivers/gpu/drm/i915/intel_breadcrumbs.c +++ b/drivers/gpu/drm/i915/intel_breadcrumbs.c @@ -101,7 +101,8 @@ __dma_fence_signal__notify(struct dma_fence *fence) struct dma_fence_cb *cur, *tmp; lockdep_assert_held(fence->lock); - lockdep_assert_irqs_disabled(); + if (!IS_ENABLED(CONFIG_PREEMPT_RT_FULL)) + lockdep_assert_irqs_disabled(); list_for_each_entry_safe(cur, tmp, &fence->cb_list, node) { INIT_LIST_HEAD(&cur->node); @@ -276,7 +277,8 @@ void intel_engine_fini_breadcrumbs(struct intel_engine_cs *engine) bool i915_request_enable_breadcrumb(struct i915_request *rq) { lockdep_assert_held(&rq->lock); - lockdep_assert_irqs_disabled(); + if (!IS_ENABLED(CONFIG_PREEMPT_RT_FULL)) + lockdep_assert_irqs_disabled(); if (test_bit(I915_FENCE_FLAG_ACTIVE, &rq->fence.flags)) { struct intel_breadcrumbs *b = &rq->engine->breadcrumbs; @@ -325,7 +327,8 @@ void i915_request_cancel_breadcrumb(struct i915_request *rq) struct intel_breadcrumbs *b = &rq->engine->breadcrumbs; lockdep_assert_held(&rq->lock); - lockdep_assert_irqs_disabled(); + if (!IS_ENABLED(CONFIG_PREEMPT_RT_FULL)) + lockdep_assert_irqs_disabled(); /* * We must wait for b->irq_lock so that we know the interrupt handler -- 2.21.0