Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp752022imm; Wed, 11 Jul 2018 10:19:01 -0700 (PDT) X-Google-Smtp-Source: AAOMgpeCFx/mmvtfKzBAvNi/S4TaxlPg/qizZCQGwXhVqjAx5Qnz3zE3/WhCRoI1NDqNKv497oNB X-Received: by 2002:a65:448a:: with SMTP id l10-v6mr27660483pgq.382.1531329541225; Wed, 11 Jul 2018 10:19:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531329541; cv=none; d=google.com; s=arc-20160816; b=v+o9HbEZutYQC3PgGY+p2TgIvY+ZNwF1QExdY9BvvdmhqC4GdTt0IQNr2kkwqDCJaA 92ZsgDin2axdgYQlS8Kfm6FGSzZwobJOfoO+bOddH/m/SluxM5kUJUROBbKAkBximtJA 4FumDOpPhrMhKVwO48ZXyDk5mGUZybKp6rFM9IbIHpfUDZzrHZDoRp2beOtTOdepHmOr b979Bi+NgqVxHZQotpuJZvru0ycVsKqQJ77CqhIKZ01zUXWKbwiNCsBfaZN0qf1Jtno1 /MHRKVJKrbn7aGHfXfG/Stoifs88m2Nnyz7b/YdXWYBDpQ1E+xdSxyVD7E/izBR/zAW6 quEA== 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:subject:cc:to:from:date :arc-authentication-results; bh=zgxywdvgRpU84jUL4MNC63VhpkurxwpLKNJZhKYGZtI=; b=Bx79yEdRTZ9Qvpop//xI5zMtwNcrK66/mMMwhCV67pxa9sN+QLTUP0sPHbLbKHsY5T 73yUGSovBjFkHuNeEoTdGzP/gYWH8g6JaO/K/PODmvE7zTW5akMlTPKCw9X742pDMtfy 8HikjWUX5Sm0NBI93okxXJjXls7MKwx0xE3B+Sv71K7iPjSbvTHDJPzcs8uZLV/SOPsH bDrxwXGkLYQeqje4GOdfgYvFMvuTjcK3/90Moh2+LE0Ej+1FfENP580A61GhyZO/zBmW G5NGRifMugoWFXY9RFPCMDLEvL7k+TfhmNT/ehPCQsBIOEF7xY+1wJrgbVvVjpi4iuvs kcbg== 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 1-v6si19089356pgj.128.2018.07.11.10.18.45; Wed, 11 Jul 2018 10:19:01 -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 S1732724AbeGKO5l (ORCPT + 99 others); Wed, 11 Jul 2018 10:57:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:42908 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732321AbeGKO5k (ORCPT ); Wed, 11 Jul 2018 10:57:40 -0400 Received: from gandalf.local.home (cpe-66-24-56-78.stny.res.rr.com [66.24.56.78]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4575220C0D; Wed, 11 Jul 2018 14:52:57 +0000 (UTC) Date: Wed, 11 Jul 2018 10:52:55 -0400 From: Steven Rostedt To: Thomas Zimmermann Cc: Hans de Goede , Bartlomiej Zolnierkiewicz , Petr Mladek , Sergey Senozhatsky , linux-fbdev@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v5 2/3] fbcon: Call WARN_CONSOLE_UNLOCKED() where applicable Message-ID: <20180711105255.32803a3c@gandalf.local.home> In-Reply-To: <717e6337-e7a6-7a92-1c1b-8929a25696b5@suse.de> References: <20180628090351.15581-1-hdegoede@redhat.com> <20180628090351.15581-3-hdegoede@redhat.com> <717e6337-e7a6-7a92-1c1b-8929a25696b5@suse.de> X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 11 Jul 2018 16:46:11 +0200 Thomas Zimmermann wrote: > Hi > > Am 28.06.2018 um 11:03 schrieb Hans de Goede: > > Replace comments about places where the console lock should be held with > > calls to WARN_CONSOLE_UNLOCKED() to assert that it is actually held. > > Debugging fbcon sometimes requires to not take the console lock. This > patch breaks the debugging workaround provided by > 'fb.lockless_register_fb'. The dmesg is now filled with warnings about > the missing lock. > What if you make lockless_register_fb visible to fbcon, and then we can have a macro: #define WARN_FB_CONSOLE_UNLOCKED() \ do { \ if (unlikely(!lockless_register_fb)) \ WARN_CONSOLE_UNLOCKED(); \ } while (0) And use that instead? -- Steve > Best regards > Thomas > > > Acked-by: Steven Rostedt (VMware) > > Reviewed-by: Daniel Vetter > > Reviewed-by: Sergey Senozhatsky > > Signed-off-by: Hans de Goede > > --- > > Changes in v3: > > -New patch in v3 of this patchset > > > > Changes in v4: > > -Keep the comments about which fbcon functions need locks in place > > --- > > drivers/video/fbdev/core/fbcon.c | 11 +++++++++++ > > 1 file changed, 11 insertions(+) > > > > diff --git a/drivers/video/fbdev/core/fbcon.c b/drivers/video/fbdev/core/fbcon.c > > index c910e74d46ff..cd8d52a967aa 100644 > > --- a/drivers/video/fbdev/core/fbcon.c > > +++ b/drivers/video/fbdev/core/fbcon.c > > @@ -828,6 +828,8 @@ static int set_con2fb_map(int unit, int newidx, int user) > > struct fb_info *oldinfo = NULL; > > int found, err = 0; > > > > + WARN_CONSOLE_UNLOCKED(); > > + > > if (oldidx == newidx) > > return 0; > > > > @@ -3044,6 +3046,8 @@ static int fbcon_fb_unbind(int idx) > > { > > int i, new_idx = -1, ret = 0; > > > > + WARN_CONSOLE_UNLOCKED(); > > + > > if (!fbcon_has_console_bind) > > return 0; > > > > @@ -3094,6 +3098,8 @@ static int fbcon_fb_unregistered(struct fb_info *info) > > { > > int i, idx; > > > > + WARN_CONSOLE_UNLOCKED(); > > + > > idx = info->node; > > for (i = first_fb_vc; i <= last_fb_vc; i++) { > > if (con2fb_map[i] == idx) > > @@ -3131,6 +3137,9 @@ static int fbcon_fb_unregistered(struct fb_info *info) > > static void fbcon_remap_all(int idx) > > { > > int i; > > + > > + WARN_CONSOLE_UNLOCKED(); > > + > > for (i = first_fb_vc; i <= last_fb_vc; i++) > > set_con2fb_map(i, idx, 0); > > > > @@ -3177,6 +3186,8 @@ static int fbcon_fb_registered(struct fb_info *info) > > { > > int ret = 0, i, idx; > > > > + WARN_CONSOLE_UNLOCKED(); > > + > > idx = info->node; > > fbcon_select_primary(info); > > >