Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp344647ybi; Fri, 21 Jun 2019 00:22:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqwaQb+XOfhyGC0+yJ3Dq9pQgT7O09qPuCw4qzklUTWp3PLU0HTye/hc+eCvDYI1pGBlfDIT X-Received: by 2002:a63:d354:: with SMTP id u20mr16310805pgi.129.1561101746350; Fri, 21 Jun 2019 00:22:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561101746; cv=none; d=google.com; s=arc-20160816; b=lhUFRa4nJsIQancWVK6PeSBDo1E9YCJuJqJep+2llkJCRmh5SHq1A7e6hS2l8PqM33 aoRn3urjUo3xZzrUil9rQzpd2xidiUE2lEQY5+kLn67/bJ82n2IAMW8sMsY5kyzkXXpM 37eKBZt15ko7rI5aahvMHR3ZfpzzZlHIuQjNXc1OU3SWC77eN6+xuKThnafANRCLWQPF oa8N8kO7ed85+ZTrKyF/bdQwL6Wvh/Gs4NUF63p/d08CnyoZu5oXmND8qkBJbum1Cx4J iUuAMMtCytVdow7P9Bwn5KC36sfyxNtBNsA3Qu4G3tBgF8d9J23hevfvpcq8pd1Or3B+ ebLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=lYVD5LTKfAZlKAzXfnuLkNsDxpipdv/Y4DHZAZrnzeQ=; b=YtrVNommHRMTrDqYfNEwJLCxPDII/k0Slce9jWbOCDiAcRfzJBRIpoZeLC/o1Lan5Y vpnVjZScCeuNGmzaryTSHVvHpJLX4+wARUcqJTOwyzuMQ9MJEWPkFirDR1HT209iq4/H b5Fqp0CjylMFa5e4xklfp1licLPNxtAmT62hbgF077CmeSeTnE394+tUsoacf16pB446 KZ5C7wLkZLCy7OMHxlHJhY2bGYDpT8G5vUORwqvWz0xGb70lr8RG4domhHGHXgaZVi2D RxW0k+9RnnreEU9uT8HFrzFxdBgqnc5k90ffHHscHFOny1riU+j8nRO3lurS++Y4OrCh 41bw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=TWKaDNQi; 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 k15si1802394pgh.331.2019.06.21.00.22.11; Fri, 21 Jun 2019 00:22:26 -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=@kernel.org header.s=default header.b=TWKaDNQi; 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 S1726290AbfFUHV5 (ORCPT + 99 others); Fri, 21 Jun 2019 03:21:57 -0400 Received: from mail.kernel.org ([198.145.29.99]:45940 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726025AbfFUHV4 (ORCPT ); Fri, 21 Jun 2019 03:21:56 -0400 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 B2A1A206E0; Fri, 21 Jun 2019 07:21:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1561101715; bh=BEm/q++STfaV62as0+wcSgtLxmizISkWXiUqnVMMcA8=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=TWKaDNQi0vZQLYHOjm5oSwQZDBExUBu0mcyVTTIIuKM2dcRnN/k5wl3PN+CJ0PYTa 3/PkfR0ytMUNdyjY8JcoS9yasedMvXB5336kHhrolzA41NbVrRIfXH2fEM2jCQMx0f HSxIHzcVBegtI8YwRWqMAJ0jKObS+aICiRmMc3M0= Date: Fri, 21 Jun 2019 09:21:52 +0200 From: Greg Kroah-Hartman To: Mauro Carvalho Chehab Cc: Johan Hovold , Linux Doc Mailing List , Mauro Carvalho Chehab , Mauro Carvalho Chehab , linux-kernel@vger.kernel.org, Jonathan Corbet , Stefan Achatz Subject: Re: [PATCH 04/14] ABI: better identificate tables Message-ID: <20190621072152.GA21300@kroah.com> References: <6bc45c0d5d464d25d4d16eceac48a2f407166944.1560477540.git.mchehab+samsung@kernel.org> <20190619125135.GG25248@localhost> <20190619105633.7f7315a5@coco.lan> <20190619150207.GA19346@kroah.com> <20190619131408.26b45c3b@coco.lan> <20190620112749.5e3fb4e9@coco.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190620112749.5e3fb4e9@coco.lan> User-Agent: Mutt/1.12.1 (2019-06-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 20, 2019 at 11:27:49AM -0300, Mauro Carvalho Chehab wrote: > Em Wed, 19 Jun 2019 13:14:08 -0300 > Mauro Carvalho Chehab escreveu: > > > Em Wed, 19 Jun 2019 17:02:07 +0200 > > Greg Kroah-Hartman escreveu: > > > > > On Wed, Jun 19, 2019 at 10:56:33AM -0300, Mauro Carvalho Chehab wrote: > > > > Hi Johan, > > > > > > > > Em Wed, 19 Jun 2019 14:51:35 +0200 > > > > Johan Hovold escreveu: > > > > > > > > > On Thu, Jun 13, 2019 at 11:04:10PM -0300, Mauro Carvalho Chehab wrote: > > > > > > From: Mauro Carvalho Chehab > > > > > > > > > > > > When parsing via script, it is important to know if the script > > > > > > should consider a description as a literal block that should > > > > > > be displayed as-is, or if the description can be considered > > > > > > as a normal text. > > > > > > > > > > > > Change descriptions to ensure that the preceding line of a table > > > > > > ends with a colon. That makes easy to identify the need of a > > > > > > literal block. > > > > > > > > > > In the cover letter you say that the first four patches of this series, > > > > > including this one, "fix some ABI descriptions that are violating the > > > > > syntax described at Documentation/ABI/README". This seems a bit harsh, > > > > > given that it's you that is now *introducing* a new syntax requirement > > > > > to assist your script. > > > > > > > > Yeah, what's there at the cover letter doesn't apply to this specific > > > > patch. The thing is that I wrote this series a lot of time ago (2016/17). > > > > > > > > I revived those per a request at KS ML, as we still need to expose the > > > > ABI content on some book that will be used by userspace people. > > > > > > > > So, I just rebased it on the top of curent Kernel, add a cover letter > > > > with the things I remembered and re-sent. > > > > > > > > In the specific case of this patch, the ":" there actually makes sense > > > > for someone that it is reading it as a text file, and it is an easy > > > > hack to make it parse better. > > > > > > > > > Specifically, this new requirement isn't documented anywhere AFAICT, so > > > > > how will anyone adding new ABI descriptions learn about it? > > > > > > > > Yeah, either that or provide an alternative to "Description" tag, to be > > > > used with more complex ABI descriptions. > > > > > > > > One of the things that occurred to me, back on 2017, is that we should > > > > have a way to to specify that an specific ABI description would have > > > > a rich format. Something like: > > > > > > > > What: /sys/bus/usb/devices/-:./::./pyra/roccatpyra/actual_cpi > > > > Date: August 2010 > > > > Contact: Stefan Achatz > > > > RST-Description: > > > > It is possible to switch the cpi setting of the mouse with the > > > > press of a button. > > > > When read, this file returns the raw number of the actual cpi > > > > setting reported by the mouse. This number has to be further > > > > processed to receive the real dpi value: > > > > > > > > ===== ===== > > > > VALUE DPI > > > > ===== ===== > > > > 1 400 > > > > 2 800 > > > > 4 1600 > > > > ===== ===== > > > > > > > > With that, the script will know that the description contents will be using > > > > the ReST markup, and parse it accordingly. Right now, what it does, instead, > > > > is to place the description on a code-block, e. g. it will produce this > > > > output for the description: > > > > > > > > :: > > > > > > > > It is possible to switch the cpi setting of the mouse with the > > > > press of a button. > > > > When read, this file returns the raw number of the actual cpi > > > > setting reported by the mouse. This number has to be further > > > > processed to receive the real dpi value: > > > > > > > > VALUE DPI > > > > 1 400 > > > > 2 800 > > > > 4 1600 > > > > > > > > > > > > Greg, > > > > > > > > what do you think? > > > > > > I don't know when "Description" and "RST-Description" would be used. > > > Why not just parse "Description" like rst text and if things are "messy" > > > we fix them up as found, like you did with the ":" here? It doesn't > > > have to be complex, we can always fix them up after-the-fact if new > > > stuff gets added that doesn't quite parse properly. > > > > > > Just like we do for most kernel-doc formatting :) > > > > Works for me. Yet, I guess I tried that, back on 2017. > > > > If I'm not mistaken, the initial patchset to solve the broken things > > won't be small, and will be require a lot of attention in order to > > identify what's broken and where. > > > > Btw, one thing is to pass at ReST validation. Another thing is to > > produce something that people can read. > > > > Right now, the pertinent logic at the script I wrote (scripts/get_abi.pl) > > is here: > > > > if (!($desc =~ /^\s*$/)) { > > if ($desc =~ m/\:\n/ || $desc =~ m/\n[\t ]+/ || $desc =~ m/[\x00-\x08\x0b-\x1f\x7b-\xff]/) { > > # put everything inside a code block > > $desc =~ s/\n/\n /g; > > > > print "::\n\n"; > > print " $desc\n\n"; > > } else { > > # Escape any special chars from description > > $desc =~s/([\x00-\x08\x0b-\x1f\x21-\x2a\x2d\x2f\x3c-\x40\x5c\x5e-\x60\x7b-\xff])/\\$1/g; > > > > print "$desc\n\n"; > > } > > } > > > > If it discovers something weird enough, it just places everything > > into a comment block. Otherwise, it assumes that it is a plain > > text and that any special characters should be escaped. > > > > If the above block is replaced by a simple: > > > > print "$desc\n\n"; > > > > The description content will be handled as a ReST file. > > > > I don't have any time right now to do this change and to handle the > > warnings that will start to popup. > > > > Btw, a single replace there is enough to show the amount of problems that > > it will rise, as it will basically break Sphinx build with: > > > > reading sources... [ 1%] admin-guide/abi-testing > > reST markup error: > > get_abi.pl rest --dir $srctree/Documentation/ABI/testing:45261: (SEVERE/4) Missing matching underline for section title overline. > > > > ========================== > > PCIe Device AER statistics > > These attributes show up under all the devices that are AER capable. These > > To be clear here: the problem with the above is that ReST has zero > tolerance and actually behaves like a crash, if it receives something like: > > ========================== > PCIe Device AER statistics > ========================== > > For it to work, it has to have zero spaces before ===..=== line, e. g.: > > ========================== > PCIe Device AER statistics > ========================== > > Ok, maybe we could try to teach the parser a way to identify the initial > spacing of the first description line and remove that amount of > spaces/tabs for the following lines, but it may require some heuristics. Or we can clean this type of thing up by hand :) Let's see how bad this gets, the documentation in these files should not be very complex as they _should_ only be one-value-per-file, but as you have shown in this very example, that rule is violated :( thanks, greg k-h