[luxis1999-dev-iommu:dev-iommu-5.14-rfcv1 7/20] drivers/iommu/iommufd/iommufd.c:181:7: warning: variable 'ret' is used uninitialized whenever 'if' condition is true

From: kernel test robot
Date: Fri Oct 01 2021 - 00:31:08 EST


tree: https://github.com/luxis1999/dev-iommu dev-iommu-5.14-rfcv1
head: 8d2f14a235e67092365d15107cfc357e86d69629
commit: e2fbb8c54de073a2a173e15b62884c64e6c4a4b6 [7/20] iommu/iommufd: Add iommufd_[un]bind_device()
config: riscv-randconfig-r042-20211001 (attached as .config)
compiler: clang version 14.0.0 (https://github.com/llvm/llvm-project 962e503cc8bc411f7523cc393acae8aae425b1c4)
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
# install riscv cross compiling tool for clang build
# apt-get install binutils-riscv64-linux-gnu
# https://github.com/luxis1999/dev-iommu/commit/e2fbb8c54de073a2a173e15b62884c64e6c4a4b6
git remote add luxis1999-dev-iommu https://github.com/luxis1999/dev-iommu
git fetch --no-tags luxis1999-dev-iommu dev-iommu-5.14-rfcv1
git checkout e2fbb8c54de073a2a173e15b62884c64e6c4a4b6
# save the attached .config to linux build tree
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang make.cross W=1 ARCH=riscv

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

All warnings (new ones prefixed by >>):

>> drivers/iommu/iommufd/iommufd.c:181:7: warning: variable 'ret' is used uninitialized whenever 'if' condition is true [-Wsometimes-uninitialized]
if (idev->dev == dev || idev->dev_cookie == dev_cookie) {
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
drivers/iommu/iommufd/iommufd.c:221:17: note: uninitialized use occurs here
return ERR_PTR(ret);
^~~
drivers/iommu/iommufd/iommufd.c:181:3: note: remove the 'if' if its condition is always false
if (idev->dev == dev || idev->dev_cookie == dev_cookie) {
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>> drivers/iommu/iommufd/iommufd.c:181:7: warning: variable 'ret' is used uninitialized whenever '||' condition is true [-Wsometimes-uninitialized]
if (idev->dev == dev || idev->dev_cookie == dev_cookie) {
^~~~~~~~~~~~~~~~
drivers/iommu/iommufd/iommufd.c:221:17: note: uninitialized use occurs here
return ERR_PTR(ret);
^~~
drivers/iommu/iommufd/iommufd.c:181:7: note: remove the '||' if its condition is always false
if (idev->dev == dev || idev->dev_cookie == dev_cookie) {
^~~~~~~~~~~~~~~~~~~
drivers/iommu/iommufd/iommufd.c:171:9: note: initialize the variable 'ret' to silence this warning
int ret;
^
= 0
2 warnings generated.


vim +181 drivers/iommu/iommufd/iommufd.c

151
152 /**
153 * iommufd_bind_device - Bind a physical device marked by a device
154 * cookie to an iommu fd.
155 * @fd: [in] iommufd file descriptor.
156 * @dev: [in] Pointer to a physical device struct.
157 * @dev_cookie: [in] A cookie to mark the device in /dev/iommu uAPI.
158 *
159 * A successful bind establishes a security context for the device
160 * and returns struct iommufd_device pointer. Otherwise returns
161 * error pointer.
162 *
163 */
164 struct iommufd_device *iommufd_bind_device(int fd, struct device *dev,
165 u64 dev_cookie)
166 {
167 struct iommufd_ctx *ictx;
168 struct iommufd_device *idev;
169 unsigned long index;
170 unsigned int id;
171 int ret;
172
173 ictx = iommufd_ctx_fdget(fd);
174 if (!ictx)
175 return ERR_PTR(-EINVAL);
176
177 mutex_lock(&ictx->lock);
178
179 /* check duplicate registration */
180 xa_for_each(&ictx->device_xa, index, idev) {
> 181 if (idev->dev == dev || idev->dev_cookie == dev_cookie) {
182 idev = ERR_PTR(-EBUSY);
183 goto out_unlock;
184 }
185 }
186
187 idev = kzalloc(sizeof(*idev), GFP_KERNEL);
188 if (!idev) {
189 ret = -ENOMEM;
190 goto out_unlock;
191 }
192
193 /* Establish the security context */
194 ret = iommu_device_init_user_dma(dev, (unsigned long)ictx);
195 if (ret)
196 goto out_free;
197
198 ret = xa_alloc(&ictx->device_xa, &id, idev,
199 XA_LIMIT(IOMMUFD_DEVID_MIN, IOMMUFD_DEVID_MAX),
200 GFP_KERNEL);
201 if (ret) {
202 idev = ERR_PTR(ret);
203 goto out_user_dma;
204 }
205
206 idev->ictx = ictx;
207 idev->dev = dev;
208 idev->dev_cookie = dev_cookie;
209 idev->id = id;
210 mutex_unlock(&ictx->lock);
211
212 return idev;
213 out_user_dma:
214 iommu_device_exit_user_dma(idev->dev);
215 out_free:
216 kfree(idev);
217 out_unlock:
218 mutex_unlock(&ictx->lock);
219 iommufd_ctx_put(ictx);
220
221 return ERR_PTR(ret);
222 }
223 EXPORT_SYMBOL_GPL(iommufd_bind_device);
224

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

Attachment: .config.gz
Description: application/gzip