[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <202301161653.hbqd7e0q-lkp@intel.com>
Date: Mon, 16 Jan 2023 16:43:17 +0800
From: kernel test robot <lkp@...el.com>
To: Pierluigi Passaro <pierluigi.passaro@...il.com>, andrew@...n.ch,
hkallweit1@...il.com, linux@...linux.org.uk, davem@...emloft.net,
edumazet@...gle.com, kuba@...nel.org, pabeni@...hat.com,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org
Cc: oe-kbuild-all@...ts.linux.dev, eran.m@...iscite.com,
nate.d@...iscite.com, francesco.f@...iscite.com,
pierluigi.p@...iscite.com
Subject: Re: [PATCH] net: mdio: force deassert MDIO reset signal
Hi Pierluigi,
Thank you for the patch! Yet something to improve:
[auto build test ERROR on net-next/master]
[also build test ERROR on net/master linus/master v6.2-rc4 next-20230116]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch#_base_tree_information]
url: https://github.com/intel-lab-lkp/linux/commits/Pierluigi-Passaro/net-mdio-force-deassert-MDIO-reset-signal/20230116-001044
patch link: https://lore.kernel.org/r/20230115161006.16431-1-pierluigi.p%40variscite.com
patch subject: [PATCH] net: mdio: force deassert MDIO reset signal
config: nios2-defconfig
compiler: nios2-linux-gcc (GCC) 12.1.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
# https://github.com/intel-lab-lkp/linux/commit/3f08f04af6947d4fce17b11443001c4e386ca66e
git remote add linux-review https://github.com/intel-lab-lkp/linux
git fetch --no-tags linux-review Pierluigi-Passaro/net-mdio-force-deassert-MDIO-reset-signal/20230116-001044
git checkout 3f08f04af6947d4fce17b11443001c4e386ca66e
# save the config file
mkdir build_dir && cp config build_dir/.config
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.1.0 make.cross W=1 O=build_dir ARCH=nios2 olddefconfig
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-12.1.0 make.cross W=1 O=build_dir ARCH=nios2 SHELL=/bin/bash
If you fix the issue, kindly add following tag where applicable
| Reported-by: kernel test robot <lkp@...el.com>
All errors (new ones prefixed by >>):
nios2-linux-ld: drivers/net/mdio/fwnode_mdio.o: in function `fwnode_mdiobus_register_phy':
>> drivers/net/mdio/fwnode_mdio.c:164: undefined reference to `gpiochip_free_own_desc'
drivers/net/mdio/fwnode_mdio.c:164:(.text+0x230): relocation truncated to fit: R_NIOS2_CALL26 against `gpiochip_free_own_desc'
vim +164 drivers/net/mdio/fwnode_mdio.c
113
114 int fwnode_mdiobus_register_phy(struct mii_bus *bus,
115 struct fwnode_handle *child, u32 addr)
116 {
117 struct mii_timestamper *mii_ts = NULL;
118 struct pse_control *psec = NULL;
119 struct phy_device *phy;
120 bool is_c45 = false;
121 u32 phy_id;
122 int rc;
123 int reset_deassert_delay = 0;
124 struct gpio_desc *reset_gpio;
125
126 psec = fwnode_find_pse_control(child);
127 if (IS_ERR(psec))
128 return PTR_ERR(psec);
129
130 mii_ts = fwnode_find_mii_timestamper(child);
131 if (IS_ERR(mii_ts)) {
132 rc = PTR_ERR(mii_ts);
133 goto clean_pse;
134 }
135
136 rc = fwnode_property_match_string(child, "compatible",
137 "ethernet-phy-ieee802.3-c45");
138 if (rc >= 0)
139 is_c45 = true;
140
141 reset_gpio = fwnode_gpiod_get_index(child, "reset", 0, GPIOD_OUT_LOW, "PHY reset");
142 if (reset_gpio == ERR_PTR(-EPROBE_DEFER)) {
143 dev_dbg(&bus->dev, "reset signal for PHY@%u not ready\n", addr);
144 return -EPROBE_DEFER;
145 } else if (IS_ERR(reset_gpio)) {
146 if (reset_gpio == ERR_PTR(-ENOENT))
147 dev_dbg(&bus->dev, "reset signal for PHY@%u not defined\n", addr);
148 else
149 dev_dbg(&bus->dev, "failed to request reset for PHY@%u, error %ld\n", addr, PTR_ERR(reset_gpio));
150 reset_gpio = NULL;
151 } else {
152 dev_dbg(&bus->dev, "deassert reset signal for PHY@%u\n", addr);
153 fwnode_property_read_u32(child, "reset-deassert-us",
154 &reset_deassert_delay);
155 if (reset_deassert_delay)
156 fsleep(reset_deassert_delay);
157 }
158
159 if (is_c45 || fwnode_get_phy_id(child, &phy_id))
160 phy = get_phy_device(bus, addr, is_c45);
161 else
162 phy = phy_device_create(bus, addr, phy_id, 0, NULL);
163
> 164 gpiochip_free_own_desc(reset_gpio);
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests
View attachment "config" of type "text/plain" (46609 bytes)
Powered by blists - more mailing lists