Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp5164197ybl; Wed, 22 Jan 2020 11:30:52 -0800 (PST) X-Google-Smtp-Source: APXvYqzxUX5FvMv02gI70KV+vh5I9ziFM3SN//aAEoEipJeMf6TOwlXFGdBgvy2L4diNlj1fvQCH X-Received: by 2002:a05:6830:114f:: with SMTP id x15mr8303718otq.291.1579721452071; Wed, 22 Jan 2020 11:30:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579721452; cv=none; d=google.com; s=arc-20160816; b=xWbLxAgI8JY1ZjW9TDShMTCVO/0knVNJAO/I2edNE84JByjpu0IOiYIrSl5TUD3a8X ClKiJZzWwagLoIjtsBLX+3b40ERDUnwZWEpQcFbed0hVrGkaFd6gCh0Bfu0CoPo5k7d9 g2+/IyWtUeqqz3/HoBem2oGi8X6EwfVH7UDpKbTi72Aa+WCOjsNsMK1srnltnZoQ+h3r ExOl7Zdq3W3H8thUTCAp+BdjeapggQ7LgblCZngs1TQl+ja6id+qocQFFyPnlV2c4F4r Pi87Ykr8+WBqy7QSA2JgpGeQ9gIOLpiXKcVzUmQQJ902VXQZHfly9DCazRpoNGs/3Kjr yXMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=9dcgG8pQ1MRAXe+mbqMM2djJ8oRKpd3rrWCiTSl/Hl4=; b=K96M0qzbrMPWPknZZVvAOKkZ7ELmQM9x4fkTxPbI9UuWE/WnrIJchw3H+LObXn6MTm eXdwwoIs8bRazfEkbB9phNd4nWrhBGzeUUNx3TqKriK/WNkq0LnzvFjGNO4R9gSUyNPt mJeDMJIBgz5L1nKcoErYWgNEAmkf/7H4YDLppmxqi6DlfEAMZfe851N4A8sDdm/gAEq2 gXHKGaiPyqkgh7RIQPPaBJaKGDJIbgFoo0wRKbfQksOJkbINB4LViCck235h2frpRsRF Awlp/WA+SFRXEVpZHu8ifx1skuDQVRj6fShBwS1V6zq5xBALLB4162W2pqshYcJMFPDU gzIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="hin/UKAg"; 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 b67si12573918oii.79.2020.01.22.11.30.40; Wed, 22 Jan 2020 11:30:52 -0800 (PST) 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=@kernel.org header.s=default header.b="hin/UKAg"; 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 S1726761AbgAVT3o (ORCPT + 99 others); Wed, 22 Jan 2020 14:29:44 -0500 Received: from mail.kernel.org ([198.145.29.99]:56424 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725928AbgAVT3n (ORCPT ); Wed, 22 Jan 2020 14:29:43 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 5E269217F4; Wed, 22 Jan 2020 19:29:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579721383; bh=6NuxuZkyu+WVLJEnImcrgufT4qeAk2lwtpujW9uIY/c=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=hin/UKAgycqMHfe41xUNa/nzxxBy+FHeLrUBLk0R3g7o49LNcJu4IE9YDd+s6kIO5 MXNCz5So7wTc7TPqa8jRH/Dpnr3+kc/HcESz9eqQkwPOomQaN6GrNfRCfWNAaAHj2r WVs6dagLPgi9IJ91BOkka+ZEUfRPz36XO1uS0eLg= Date: Wed, 22 Jan 2020 20:29:40 +0100 From: Greg Kroah-Hartman To: Jason Baron Cc: Will Deacon , linux-kernel@vger.kernel.org, kernel-team@android.com Subject: Re: [PATCH v2] dynamic_debug: allow to work if debugfs is disabled Message-ID: <20200122192940.GA88549@kroah.com> References: <20200122074343.GA2099098@kroah.com> <20200122080352.GA15354@willie-the-truck> <20200122081205.GA2227985@kroah.com> <20200122135352.GA9458@kroah.com> <8d68b75c-05b8-b403-0a10-d17b94a73ba7@akamai.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <8d68b75c-05b8-b403-0a10-d17b94a73ba7@akamai.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 22, 2020 at 01:56:48PM -0500, Jason Baron wrote: > > > On 1/22/20 8:53 AM, Greg Kroah-Hartman wrote: > > > > With the realization that having debugfs enabled on "production" systems is > > generally not a good idea, debugfs is being disabled from more and more > > platforms over time. However, the functionality of dynamic debugging still is > > needed at times, and since it relies on debugfs for its user api, having > > debugfs disabled also forces dynamic debug to be disabled. > > > > To get around this, move the "control" file for dynamic_debug to procfs IFF > > debugfs is disabled. This lets people turn on debugging as needed at runtime > > for individual driverfs and subsystems. > > > > Hi Greg, > > Thanks for updating this. Just a comment below. > > > > Reported-by: many different companies > > Cc: Jason Baron > > Signed-off-by: Greg Kroah-Hartman > > --- > > v2: Fix up octal permissions and add procfs reference to the Kconfig > > entry, thanks to Will for the review. > > > > .../admin-guide/dynamic-debug-howto.rst | 3 +++ > > lib/Kconfig.debug | 7 ++++--- > > lib/dynamic_debug.c | 17 ++++++++++++++--- > > 3 files changed, 21 insertions(+), 6 deletions(-) > > > > diff --git a/Documentation/admin-guide/dynamic-debug-howto.rst b/Documentation/admin-guide/dynamic-debug-howto.rst > > index 252e5ef324e5..41f43a373a6a 100644 > > --- a/Documentation/admin-guide/dynamic-debug-howto.rst > > +++ b/Documentation/admin-guide/dynamic-debug-howto.rst > > @@ -54,6 +54,9 @@ If you make a mistake with the syntax, the write will fail thus:: > > /dynamic_debug/control > > -bash: echo: write error: Invalid argument > > > > +Note, for systems without 'debugfs' enabled, the control file can be > > +also found in ``/proc/dynamic_debug/control``. > > + > > Viewing Dynamic Debug Behaviour > > =============================== > > > > diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug > > index 5ffe144c9794..49980eb8c18e 100644 > > --- a/lib/Kconfig.debug > > +++ b/lib/Kconfig.debug > > @@ -98,7 +98,7 @@ config DYNAMIC_DEBUG > > bool "Enable dynamic printk() support" > > default n > > depends on PRINTK > > - depends on DEBUG_FS > > + depends on (DEBUG_FS || PROC_FS) > > help > > > > Compiles debug level messages into the kernel, which would not > > @@ -116,8 +116,9 @@ config DYNAMIC_DEBUG > > Usage: > > > > Dynamic debugging is controlled via the 'dynamic_debug/control' file, > > - which is contained in the 'debugfs' filesystem. Thus, the debugfs > > - filesystem must first be mounted before making use of this feature. > > + which is contained in the 'debugfs' filesystem or procfs if > > + debugfs is not present. Thus, the debugfs or procfs filesystem > > + must first be mounted before making use of this feature. > > We refer the control file as: /dynamic_debug/control. This > > file contains a list of the debug statements that can be enabled. The > > format for each line of the file is: > > diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c > > index c60409138e13..0f1b26f10fb2 100644 > > --- a/lib/dynamic_debug.c > > +++ b/lib/dynamic_debug.c > > @@ -993,13 +993,24 @@ static __initdata int ddebug_init_success; > > > > static int __init dynamic_debug_init_debugfs(void) > > { > > The naming now is a little confusing - dynamic_debug_init_control ? Ah, good point. I'll go fix that up, and fix up the foolish build warning that I missed... thanks, greg k-h