public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: kernel test robot <lkp@intel.com>
To: Jim Cromie <jim.cromie@gmail.com>,
	jbaron@akamai.com, linux-kernel@vger.kernel.org,
	akpm@linuxfoundation.org, gregkh@linuxfoundation.org
Cc: kbuild-all@lists.01.org, linux@rasmusvillemoes.dk,
	Jim Cromie <jim.cromie@gmail.com>, Petr Mladek <pmladek@suse.com>,
	Sergey Senozhatsky <sergey.senozhatsky@gmail.com>,
	Steven Rostedt <rostedt@goodmis.org>
Subject: Re: [PATCH v2 21/24] dyndbg: adapt header macros to pass print-class
Date: Sun, 14 Jun 2020 04:25:36 +0800	[thread overview]
Message-ID: <202006140418.lbod7Dc7%lkp@intel.com> (raw)
In-Reply-To: <20200613155738.2249399-22-jim.cromie@gmail.com>

[-- Attachment #1: Type: text/plain, Size: 6011 bytes --]

Hi Jim,

I love your patch! Perhaps something to improve:

[auto build test WARNING on linus/master]
[also build test WARNING on next-20200613]
[cannot apply to jeyu/modules-next linux/master v5.7]
[if your patch is applied to the wrong git tree, please drop us a note to help
improve the system. BTW, we also suggest to use '--base' option to specify the
base tree in git format-patch, please see https://stackoverflow.com/a/37406982]

url:    https://github.com/0day-ci/linux/commits/Jim-Cromie/dynamic_debug-cleanups-query-features-WIP-print-classes/20200614-000302
base:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git df2fbf5bfa0e7fff8b4784507e4d68f200454318
config: arc-allyesconfig (attached as .config)
compiler: arc-elf-gcc (GCC) 9.3.0
reproduce (this is a W=1 build):
        wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        # save the attached .config to linux build tree
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 make.cross ARCH=arc 

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp@intel.com>

All warnings (new ones prefixed by >>, old ones prefixed by <<):

drivers/dma/iop-adma.c: In function 'iop_adma_alloc_chan_resources':
drivers/dma/iop-adma.c:448:13: warning: cast to pointer from integer of different size [-Wint-to-pointer-cast]
448 |   hw_desc = (char *) iop_chan->device->dma_desc_pool;
|             ^
drivers/dma/iop-adma.c:450:4: warning: cast from pointer to integer of different size [-Wpointer-to-int-cast]
450 |    (dma_addr_t) &hw_desc[idx * IOP_ADMA_SLOT_SIZE];
|    ^
In file included from include/linux/printk.h:404,
from include/linux/kernel.h:15,
from include/linux/list.h:9,
from include/linux/module.h:12,
from drivers/dma/iop-adma.c:13:
drivers/dma/iop-adma.c: In function 'iop_adma_probe':
drivers/dma/iop-adma.c:1302:3: warning: cast to pointer from integer of different size [-Wint-to-pointer-cast]
1302 |   (void *) adev->dma_desc_pool);
|   ^
include/linux/dynamic_debug.h:130:15: note: in definition of macro '__dynamic_func_call_cl'
130 |   func(&id, ##__VA_ARGS__);            |               ^~~~~~~~~~~
>> include/linux/dynamic_debug.h:170:2: note: in expansion of macro '_dynamic_func_call_cl'
170 |  _dynamic_func_call_cl(cl, fmt, __dynamic_dev_dbg,          |  ^~~~~~~~~~~~~~~~~~~~~
>> include/linux/dynamic_debug.h:184:2: note: in expansion of macro 'dynamic_dev_dbg_cl'
184 |  dynamic_dev_dbg_cl(0, ##__VA_ARGS__)
|  ^~~~~~~~~~~~~~~~~~
include/linux/dev_printk.h:115:2: note: in expansion of macro 'dynamic_dev_dbg'
115 |  dynamic_dev_dbg(dev, dev_fmt(fmt), ##__VA_ARGS__)
|  ^~~~~~~~~~~~~~~
drivers/dma/iop-adma.c:1300:2: note: in expansion of macro 'dev_dbg'
1300 |  dev_dbg(&pdev->dev, "%s: allocated descriptor pool virt %p phys %pn",
|  ^~~~~~~

vim +/_dynamic_func_call_cl +170 include/linux/dynamic_debug.h

   126	
   127	#define __dynamic_func_call_cl(cl, id, fmt, func, ...) do {	\
   128		DEFINE_DYNAMIC_DEBUG_METADATA_CL(cl, id, fmt);		\
   129		if (DYNAMIC_DEBUG_BRANCH(id))				\
   130			func(&id, ##__VA_ARGS__);			\
   131	} while (0)
   132	#define __dynamic_func_call(id, fmt, func, ...)			\
   133		__dynamic_func_call_cl(0, id, fmt, func, ...)
   134	
   135	#define __dynamic_func_call_no_desc_cl(cl, id, fmt, func, ...) do {	\
   136		DEFINE_DYNAMIC_DEBUG_METADATA_CL(cl, id, fmt);			\
   137		if (DYNAMIC_DEBUG_BRANCH(id))					\
   138			func(__VA_ARGS__);					\
   139	} while (0)
   140	#define __dynamic_func_call_no_desc(cl, id, fmt, func, ...)		\
   141		__dynamic_func_call_no_desc_cl(0, cl, id, fmt, func, ##__VA_ARGS__)
   142	
   143	/*
   144	 * "Factory macro" for generating a call to func, guarded by a
   145	 * DYNAMIC_DEBUG_BRANCH. The dynamic debug descriptor will be
   146	 * initialized using the fmt argument. The function will be called with
   147	 * the address of the descriptor as first argument, followed by all
   148	 * the varargs. Note that fmt is repeated in invocations of this
   149	 * macro.
   150	 */
   151	#define _dynamic_func_call_cl(cl, fmt, func, ...)		\
   152		__dynamic_func_call_cl(cl, __UNIQUE_ID(ddebug), fmt, func, ##__VA_ARGS__)
   153	#define _dynamic_func_call(fmt, func, ...)			\
   154		_dynamic_func_call_cl(0, fmt, func, ##__VA_ARGS__)
   155	/*
   156	 * A variant that does the same, except that the descriptor is not
   157	 * passed as the first argument to the function; it is only called
   158	 * with precisely the macro's varargs.
   159	 */
   160	#define _dynamic_func_call_no_desc_cl(cl, fmt, func, ...)	\
   161		__dynamic_func_call_no_desc_cl(cl, __UNIQUE_ID(ddebug), fmt, func, ##__VA_ARGS__)
   162	#define _dynamic_func_call_no_desc(fmt, func, ...)		\
   163		_dynamic_func_call_no_desc_cl(0, fmt, func, ##__VA_ARGS__)
   164	
   165	#define dynamic_pr_debug_cl(cl, fmt, ...)			\
   166		_dynamic_func_call_cl(cl, fmt, __dynamic_pr_debug,	\
   167				      pr_fmt(fmt), ##__VA_ARGS__)
   168	
   169	#define dynamic_dev_dbg_cl(cl, dev, fmt, ...)			\
 > 170		_dynamic_func_call_cl(cl, fmt, __dynamic_dev_dbg,	\
   171				   dev, fmt, ##__VA_ARGS__)
   172	
   173	#define dynamic_netdev_dbg_cl(cl, dev, fmt, ...)		\
   174		_dynamic_func_call_cl(cl, fmt, __dynamic_netdev_dbg,	\
   175				   dev, fmt, ##__VA_ARGS__)
   176	
   177	#define dynamic_ibdev_dbg_cl(cl, dev, fmt, ...)			\
   178		_dynamic_func_call_cl(cl, fmt, __dynamic_ibdev_dbg,	\
   179				      dev, fmt, ##__VA_ARGS__)
   180	
   181	#define dynamic_pr_debug(...)					\
   182		dynamic_pr_debug_cl(0, ##__VA_ARGS__)
   183	#define dynamic_dev_dbg(...)					\
 > 184		dynamic_dev_dbg_cl(0, ##__VA_ARGS__)
   185	#define dynamic_netdev_dbg(...)					\
   186		dynamic_netdev_dbg_cl(0, ##__VA_ARGS__)
   187	#define dynamic_ibdev_dbg(...)					\
   188		dynamic_ibdev_dbg_cl(0, ##__VA_ARGS__)
   189	

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org

[-- Attachment #2: .config.gz --]
[-- Type: application/gzip, Size: 64045 bytes --]

  parent reply	other threads:[~2020-06-13 20:26 UTC|newest]

Thread overview: 62+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-06-13 15:57 [PATCH v2 00/24] dynamic_debug cleanups, query features, WIP print-classes Jim Cromie
2020-06-13 15:57 ` [PATCH v2 01/24] dyndbg-docs: eschew file /full/path query in docs Jim Cromie
2020-06-14  6:04   ` Greg KH
2020-06-14 14:24     ` jim.cromie
2020-06-13 15:57 ` [PATCH v2 02/24] dyndbg-docs: initialization is done early, not arch Jim Cromie
2020-06-13 15:57 ` [PATCH v2 03/24] dyndbg: drop obsolete comment on ddebug_proc_open Jim Cromie
2020-06-13 15:57 ` [PATCH v2 04/24] dyndbg: refine debug verbosity; 1 is basic, 2 more chatty Jim Cromie
2020-06-13 15:57 ` [PATCH v2 05/24] dyndbg: rename __verbose section to __dyndbg Jim Cromie
2020-06-13 15:57 ` [PATCH v2 06/24] dyndbg: fix overcounting of ram used by dyndbg Jim Cromie
2020-06-13 15:57 ` [PATCH v2 07/24] dyndbg: fix a BUG_ON in ddebug_describe_flags Jim Cromie
2020-06-15 13:20   ` Petr Mladek
2020-06-15 21:53     ` jim.cromie
2020-06-13 15:57 ` [PATCH v2 08/24] dyndbg: make ddebug_tables list LIFO for add/remove_module Jim Cromie
2020-06-13 15:57 ` [PATCH v2 09/24] dyndbg: add maybe(str,"") macro to reduce code Jim Cromie
2020-06-13 16:14   ` Joe Perches
2020-06-15 20:50     ` jim.cromie
2020-06-15 13:28   ` Petr Mladek
2020-06-15 20:52     ` jim.cromie
2020-06-13 15:57 ` [PATCH v2 10/24] dyndbg: refactor parse_linerange out of ddebug_parse_query Jim Cromie
2020-06-15 13:37   ` Petr Mladek
2020-06-15 22:37     ` jim.cromie
2020-06-13 15:57 ` [PATCH v2 11/24] dyndbg: accept 'file foo.c:func1' and 'file foo.c:10-100' Jim Cromie
2020-06-15 14:46   ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 12/24] dyndbg: refactor ddebug_read_flags out of ddebug_parse_flags Jim Cromie
2020-06-13 15:57 ` [PATCH v2 13/24] dyndbg: combine flags & mask into a struct, use that Jim Cromie
2020-06-15 15:14   ` Petr Mladek
2020-06-16  5:47     ` jim.cromie
2020-06-16 11:34       ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 14/24] dyndbg: add filter parameter to ddebug_parse_flags Jim Cromie
2020-06-15 15:17   ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 15/24] dyndbg: extend ddebug_parse_flags to accept optional leading filter-flags Jim Cromie
2020-06-15 15:37   ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 16/24] dyndbg: prefer declarative init in caller, to memset in callee Jim Cromie
2020-06-13 15:57 ` [PATCH v2 17/24] dyndbg: add user-flag, negating-flags, and filtering on flags Jim Cromie
2020-06-16 11:41   ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 18/24] dyndbg: allow negating flag-chars in modflags Jim Cromie
2020-06-16 11:47   ` Petr Mladek
2020-06-13 15:57 ` [PATCH v2 19/24] dyndbg: accept query terms like module:foo and file=bar Jim Cromie
2020-06-16 11:57   ` Petr Mladek
2020-06-16 20:08     ` jim.cromie
2020-06-17 12:11       ` Petr Mladek
2020-06-17 13:32         ` jim.cromie
2020-06-17 14:01           ` Greg KH
2020-06-13 15:57 ` [PATCH v2 20/24] dyndbg: WIP towards debug-print-class based callsite controls Jim Cromie
2020-06-13 19:22   ` Joe Perches
2020-06-16 13:45   ` Petr Mladek
2020-06-16 21:05     ` Joe Perches
2020-06-17  9:31       ` Daniel Thompson
2020-06-17  9:52         ` Petr Mladek
2020-06-17 13:23           ` jim.cromie
2020-06-18 12:20             ` Petr Mladek
2020-06-16 21:13     ` jim.cromie
2020-06-16 21:25       ` jim.cromie
2020-06-13 15:57 ` [PATCH v2 21/24] dyndbg: adapt header macros to pass print-class Jim Cromie
2020-06-13 17:11   ` kernel test robot
2020-06-13 20:25   ` kernel test robot [this message]
2020-06-13 15:57 ` [PATCH v2 22/24] dyndbg: add print-class as trailing number to control output Jim Cromie
2020-06-13 15:57 ` [PATCH v2 23/24] kset-example: add pr_debug()s for easy visibility of its operation Jim Cromie
2020-06-14  6:05   ` Greg KH
2020-06-15 22:18     ` jim.cromie
2020-06-16  6:37       ` Greg KH
2020-06-13 15:57 ` [PATCH v2 24/24] kset-example: use pr_debug_n to create example print-classes Jim Cromie

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=202006140418.lbod7Dc7%lkp@intel.com \
    --to=lkp@intel.com \
    --cc=akpm@linuxfoundation.org \
    --cc=gregkh@linuxfoundation.org \
    --cc=jbaron@akamai.com \
    --cc=jim.cromie@gmail.com \
    --cc=kbuild-all@lists.01.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@rasmusvillemoes.dk \
    --cc=pmladek@suse.com \
    --cc=rostedt@goodmis.org \
    --cc=sergey.senozhatsky@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox