All of lore.kernel.org
 help / color / mirror / Atom feed
From: kernel test robot <lkp@intel.com>
To: kbuild@lists.01.org
Subject: drivers/cxl/core/port.c:748 cxl_decoder_add_locked() warn: passing zero to 'PTR_ERR'
Date: Sat, 26 Mar 2022 08:58:19 +0800	[thread overview]
Message-ID: <202203260845.FOVvvBb8-lkp@intel.com> (raw)

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

CC: kbuild-all(a)lists.01.org
BCC: lkp(a)intel.com
CC: linux-kernel(a)vger.kernel.org
TO: Dan Williams <dan.j.williams@intel.com>
CC: Ben Widawsky <ben.widawsky@intel.com>
CC: Jonathan Cameron <Jonathan.Cameron@huawei.com>

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   aa5b537b0ecc16992577b013f11112d54c7ce869
commit: d17d0540a0dbf109210f7b57a37571e2978da0fa cxl/core/hdm: Add CXL standard decoder enumeration to the core
date:   6 weeks ago
:::::: branch date: 8 hours ago
:::::: commit date: 6 weeks ago
config: powerpc64-randconfig-m031-20220325 (https://download.01.org/0day-ci/archive/20220326/202203260845.FOVvvBb8-lkp(a)intel.com/config)
compiler: powerpc64-linux-gcc (GCC) 11.2.0

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

New smatch warnings:
drivers/cxl/core/port.c:748 cxl_decoder_add_locked() warn: passing zero to 'PTR_ERR'

Old smatch warnings:
drivers/cxl/core/port.c:796 cxl_decoder_add() warn: passing zero to 'PTR_ERR'

vim +/PTR_ERR +748 drivers/cxl/core/port.c

d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  718  
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  719  /**
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  720   * cxl_decoder_add_locked - Add a decoder with targets
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  721   * @cxld: The cxl decoder allocated by cxl_decoder_alloc()
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  722   * @target_map: A list of downstream ports that this decoder can direct memory
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  723   *              traffic to. These numbers should correspond with the port number
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  724   *              in the PCIe Link Capabilities structure.
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  725   *
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  726   * Certain types of decoders may not have any targets. The main example of this
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  727   * is an endpoint device. A more awkward example is a hostbridge whose root
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  728   * ports get hot added (technically possible, though unlikely).
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  729   *
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  730   * This is the locked variant of cxl_decoder_add().
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  731   *
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  732   * Context: Process context. Expects the device lock of the port that owns the
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  733   *	    @cxld to be held.
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  734   *
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  735   * Return: Negative error code if the decoder wasn't properly configured; else
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  736   *	   returns 0.
d54c1bbe2d34e3 drivers/cxl/core/port.c Ben Widawsky 2022-01-31  737   */
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  738  int cxl_decoder_add_locked(struct cxl_decoder *cxld, int *target_map)
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  739  {
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  740  	struct cxl_port *port;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  741  	struct device *dev;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  742  	int rc;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  743  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  744  	if (WARN_ON_ONCE(!cxld))
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  745  		return -EINVAL;
a5c25802168993 drivers/cxl/core/bus.c  Dan Williams 2021-09-08  746  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  747  	if (WARN_ON_ONCE(IS_ERR(cxld)))
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21 @748  		return PTR_ERR(cxld);
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  749  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  750  	if (cxld->interleave_ways < 1)
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  751  		return -EINVAL;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  752  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  753  	port = to_cxl_port(cxld->dev.parent);
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  754  	rc = decoder_populate_targets(cxld, port, target_map);
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  755  	if (rc)
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  756  		return rc;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  757  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  758  	dev = &cxld->dev;
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  759  	rc = dev_set_name(dev, "decoder%d.%d", port->id, cxld->id);
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  760  	if (rc)
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  761  		return rc;
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  762  
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  763  	/*
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  764  	 * Platform decoder resources should show up with a reasonable name. All
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  765  	 * other resources are just sub ranges within the main decoder resource.
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  766  	 */
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  767  	if (is_root_decoder(dev))
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  768  		cxld->platform_res.name = dev_name(dev);
608135db1b7901 drivers/cxl/core/port.c Ben Widawsky 2022-01-23  769  
48667f676189ec drivers/cxl/core/bus.c  Dan Williams 2021-09-21  770  	return device_add(dev);
40ba17afdfabb0 drivers/cxl/core.c      Dan Williams 2021-06-09  771  }
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  772  EXPORT_SYMBOL_NS_GPL(cxl_decoder_add_locked, CXL);
d17d0540a0dbf1 drivers/cxl/core/port.c Dan Williams 2022-02-01  773  

:::::: The code at line 748 was first introduced by commit
:::::: 48667f676189eccfe9b7ac3a31772d55d6da40e5 cxl/core: Split decoder setup into alloc + add

:::::: TO: Dan Williams <dan.j.williams@intel.com>
:::::: CC: Dan Williams <dan.j.williams@intel.com>

-- 
0-DAY CI Kernel Test Service
https://01.org/lkp

             reply	other threads:[~2022-03-26  0:58 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-03-26  0:58 kernel test robot [this message]
  -- strict thread matches above, loose matches on Subject: below --
2022-06-12 20:36 drivers/cxl/core/port.c:748 cxl_decoder_add_locked() warn: passing zero to 'PTR_ERR' kernel test robot
2022-09-07 12:18 kernel test robot
2022-09-08  8:43 kernel test robot

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=202203260845.FOVvvBb8-lkp@intel.com \
    --to=lkp@intel.com \
    --cc=kbuild@lists.01.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.