Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757595AbbLCIDQ (ORCPT ); Thu, 3 Dec 2015 03:03:16 -0500 Received: from mail-lf0-f41.google.com ([209.85.215.41]:33310 "EHLO mail-lf0-f41.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753649AbbLCIDP convert rfc822-to-8bit (ORCPT ); Thu, 3 Dec 2015 03:03:15 -0500 From: Rasmus Villemoes To: yalin wang Cc: Vlastimil Babka , "open list\:MEMORY MANAGEMENT" , linux-kernel , Andrew Morton , Joonsoo Kim , Minchan Kim , Sasha Levin , "Kirill A. Shutemov" , Mel Gorman , Michal Hocko Subject: Re: [PATCH 1/2] mm, printk: introduce new format string for flags Organization: D03 References: <20151125143010.GI27283@dhcp22.suse.cz> <1448899821-9671-1-git-send-email-vbabka@suse.cz> <4EAD2C33-D0E4-4DEB-92E5-9C0457E8635C@gmail.com> <565F5CD9.9080301@suse.cz> <1F60C207-1CC2-4B28-89AC-58C72D95A39D@gmail.com> X-Hashcash: 1:20:151203:sasha.levin@oracle.com::JTbzY2Hi0ZO+zBZR:0000000000000000000000000000000000000000HZo X-Hashcash: 1:20:151203:akpm@linux-foundation.org::R/VEjxVO9rJFNvhn:000000000000000000000000000000000000048x X-Hashcash: 1:20:151203:vbabka@suse.cz::9/JrhC2ZKSPO9Kc7:0000vPd X-Hashcash: 1:20:151203:kirill.shutemov@linux.intel.com::z4lEp4v+Gmm1wNQR:0000000000000000000000000000000Y9Z X-Hashcash: 1:20:151203:linux-kernel@vger.kernel.org::OFTMg9stcsjqNvd0:0000000000000000000000000000000001Fyh X-Hashcash: 1:20:151203:iamjoonsoo.kim@lge.com::E2fUYaxOhBzRzJw8:0000000000000000000000000000000000000001Qvp X-Hashcash: 1:20:151203:minchan@kernel.org::kdZ6eF3gWmbsEAoF:00000000000000000000000000000000000000000002Fxs X-Hashcash: 1:20:151203:linux-mm@kvack.org::vFv6YJ48JABhYLEk:00000000000000000000000000000000000000000004VsK X-Hashcash: 1:20:151203:mgorman@suse.de::aDJHRsx+EEg9iFZT:004Awv X-Hashcash: 1:20:151203:yalin.wang2010@gmail.com::a5zRn/WToO2H5P8E:00000000000000000000000000000000000006BlY X-Hashcash: 1:20:151203:mhocko@suse.cz::nxsWI18I3qgZh/3f:0008Dm6 Date: Thu, 03 Dec 2015 09:03:09 +0100 In-Reply-To: <1F60C207-1CC2-4B28-89AC-58C72D95A39D@gmail.com> (yalin wang's message of "Wed, 2 Dec 2015 16:11:58 -0800") Message-ID: <87a8psq7r6.fsf@rasmusvillemoes.dk> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/24.3 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2672 Lines: 68 On Thu, Dec 03 2015, yalin wang wrote: >> On Dec 2, 2015, at 13:04, Vlastimil Babka wrote: >> >> On 12/02/2015 06:40 PM, yalin wang wrote: >> >> (please trim your reply next time, no need to quote whole patch here) >> >>> i am thinking why not make %pg* to be more generic ? >>> not restricted to only GFP / vma flags / page flags . >>> so could we change format like this ? >>> define a flag spec struct to include flag and trace_print_flags and some other option : >>> typedef struct { >>> unsigned long flag; >>> structtrace_print_flags *flags; >>> unsigned long option; } flag_sec; >>> flag_sec my_flag; >>> in printk we only pass like this : >>> printk(ā€œ%pg\nā€, &my_flag) ; >>> then it can print any flags defined by user . >>> more useful for other drivers to use . >> >> I don't know, it sounds quite complicated Agreed, I think this would be premature generalization. There's also some value in having the individual %pgX specifiers, as that allows individual tweaks such as the mask_out for page flags. given that we had no flags printing >> for years and now there's just three kinds of them. The extra struct flag_sec is >> IMHO nuissance. No other printk format needs such thing AFAIK? For example, if I >> were to print page flags from several places, each would have to define the >> struct flag_sec instance, or some header would have to provide it? > this can be avoided by provide a macro in header file . > we can add a new struct to declare trace_print_flags : > for example: > #define DECLARE_FLAG_PRINTK_FMT(name, flags_array) flag_spec name = { .flags = flags_array}; > #define FLAG_PRINTK_FMT(name, flag) ({ name.flag = flag; &name}) > > in source code : > DECLARE_FLAG_PRINTK_FMT(my_flag, vmaflags_names); > printk(ā€œ%pg\nā€, FLAG_PRINTK_FMT(my_flag, vma->flag)); > Compared to printk("%pgv\n", &vma->flag), I know which I'd prefer to read. > i am not if DECLARE_FLAG_PRINTK_FMT and FLAG_PRINTK_FMT macro > can be defined into one macro ? > maybe need some trick here . > > is it possible ? Technically, I think the answer is yes, at least in C99 (and I suppose gcc would accept it in gnu89 mode as well). printk("%pg\n", &(struct flag_printer){.flags = my_flags, .names = vmaflags_names}); Not tested, and I still don't think it would be particularly readable even when macroized printk("%pg\n", PRINTF_VMAFLAGS(my_flags)); Rasmus -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/