From: Dan Carpenter <dan.carpenter@oracle.com>
To: kbuild@lists.01.org, Chris Wilson <chris@chris-wilson.co.uk>
Cc: "Thomas Hellström" <thomas.hellstrom@linux.intel.com>,
kbuild-all@lists.01.org, lkp@intel.com,
intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org,
"Matthew Auld" <matthew.auld@intel.com>
Subject: [drm-intel:drm-intel-gt-next 8/14] drivers/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
Date: Fri, 2 Jul 2021 11:44:43 +0300 [thread overview]
Message-ID: <202107020708.XXwacDfG-lkp@intel.com> (raw)
tree: git://anongit.freedesktop.org/drm-intel drm-intel-gt-next
head: 5cd57f676bb946a00275408f0dd0d75dbc466d25
commit: cf586021642d8017cde111b7dd1ba86224e9da51 [8/14] drm/i915/gt: Pipelined page migration
config: x86_64-randconfig-m001-20210630 (attached as .config)
compiler: gcc-9 (Debian 9.3.0-22) 9.3.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/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
drivers/gpu/drm/i915/gt/selftest_migrate.c:113 copy() error: uninitialized symbol 'vaddr'.
Old smatch warnings:
drivers/gpu/drm/i915/gem/i915_gem_object.h:182 __i915_gem_object_lock() error: we previously assumed 'ww' could be null (see line 171)
vim +/rq +102 drivers/gpu/drm/i915/gt/selftest_migrate.c
cf586021642d80 Chris Wilson 2021-06-17 32 static int copy(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 33 int (*fn)(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 34 struct i915_gem_ww_ctx *ww,
cf586021642d80 Chris Wilson 2021-06-17 35 struct drm_i915_gem_object *src,
cf586021642d80 Chris Wilson 2021-06-17 36 struct drm_i915_gem_object *dst,
cf586021642d80 Chris Wilson 2021-06-17 37 struct i915_request **out),
cf586021642d80 Chris Wilson 2021-06-17 38 u32 sz, struct rnd_state *prng)
cf586021642d80 Chris Wilson 2021-06-17 39 {
cf586021642d80 Chris Wilson 2021-06-17 40 struct drm_i915_private *i915 = migrate->context->engine->i915;
cf586021642d80 Chris Wilson 2021-06-17 41 struct drm_i915_gem_object *src, *dst;
cf586021642d80 Chris Wilson 2021-06-17 42 struct i915_request *rq;
cf586021642d80 Chris Wilson 2021-06-17 43 struct i915_gem_ww_ctx ww;
cf586021642d80 Chris Wilson 2021-06-17 44 u32 *vaddr;
cf586021642d80 Chris Wilson 2021-06-17 45 int err = 0;
One way to silence these warnings would be to initialize err = -EINVAL.
Then Smatch would know that we goto err_out for an empty list.
cf586021642d80 Chris Wilson 2021-06-17 46 int i;
cf586021642d80 Chris Wilson 2021-06-17 47
cf586021642d80 Chris Wilson 2021-06-17 48 src = create_lmem_or_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 49 if (IS_ERR(src))
cf586021642d80 Chris Wilson 2021-06-17 50 return 0;
cf586021642d80 Chris Wilson 2021-06-17 51
cf586021642d80 Chris Wilson 2021-06-17 52 dst = i915_gem_object_create_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 53 if (IS_ERR(dst))
cf586021642d80 Chris Wilson 2021-06-17 54 goto err_free_src;
cf586021642d80 Chris Wilson 2021-06-17 55
cf586021642d80 Chris Wilson 2021-06-17 56 for_i915_gem_ww(&ww, err, true) {
cf586021642d80 Chris Wilson 2021-06-17 57 err = i915_gem_object_lock(src, &ww);
cf586021642d80 Chris Wilson 2021-06-17 58 if (err)
cf586021642d80 Chris Wilson 2021-06-17 59 continue;
cf586021642d80 Chris Wilson 2021-06-17 60
cf586021642d80 Chris Wilson 2021-06-17 61 err = i915_gem_object_lock(dst, &ww);
cf586021642d80 Chris Wilson 2021-06-17 62 if (err)
cf586021642d80 Chris Wilson 2021-06-17 63 continue;
cf586021642d80 Chris Wilson 2021-06-17 64
cf586021642d80 Chris Wilson 2021-06-17 65 vaddr = i915_gem_object_pin_map(src, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 66 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 67 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 68 continue;
cf586021642d80 Chris Wilson 2021-06-17 69 }
cf586021642d80 Chris Wilson 2021-06-17 70
cf586021642d80 Chris Wilson 2021-06-17 71 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 72 vaddr[i] = i;
cf586021642d80 Chris Wilson 2021-06-17 73 i915_gem_object_flush_map(src);
cf586021642d80 Chris Wilson 2021-06-17 74
cf586021642d80 Chris Wilson 2021-06-17 75 vaddr = i915_gem_object_pin_map(dst, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 76 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 77 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 78 goto unpin_src;
cf586021642d80 Chris Wilson 2021-06-17 79 }
cf586021642d80 Chris Wilson 2021-06-17 80
cf586021642d80 Chris Wilson 2021-06-17 81 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 82 vaddr[i] = ~i;
cf586021642d80 Chris Wilson 2021-06-17 83 i915_gem_object_flush_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 84
cf586021642d80 Chris Wilson 2021-06-17 85 err = fn(migrate, &ww, src, dst, &rq);
cf586021642d80 Chris Wilson 2021-06-17 86 if (!err)
cf586021642d80 Chris Wilson 2021-06-17 87 continue;
Does fn() initialize "rq" on the success path? Anyway Smatch would
complain anyway because it thinks the list could be empty or that we
might hit and early continue for everything.
cf586021642d80 Chris Wilson 2021-06-17 88
cf586021642d80 Chris Wilson 2021-06-17 89 if (err != -EDEADLK && err != -EINTR && err != -ERESTARTSYS)
cf586021642d80 Chris Wilson 2021-06-17 90 pr_err("%ps failed, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 91 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 92 i915_request_wait(rq, 0, HZ);
cf586021642d80 Chris Wilson 2021-06-17 93 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 94 }
cf586021642d80 Chris Wilson 2021-06-17 95 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 96 unpin_src:
cf586021642d80 Chris Wilson 2021-06-17 97 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 98 }
cf586021642d80 Chris Wilson 2021-06-17 99 if (err)
cf586021642d80 Chris Wilson 2021-06-17 100 goto err_out;
cf586021642d80 Chris Wilson 2021-06-17 101
cf586021642d80 Chris Wilson 2021-06-17 @102 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 103 if (i915_request_wait(rq, 0, HZ) < 0) {
cf586021642d80 Chris Wilson 2021-06-17 104 pr_err("%ps timed out, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 105 err = -ETIME;
cf586021642d80 Chris Wilson 2021-06-17 106 }
cf586021642d80 Chris Wilson 2021-06-17 107 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 108 }
cf586021642d80 Chris Wilson 2021-06-17 109
cf586021642d80 Chris Wilson 2021-06-17 110 for (i = 0; !err && i < sz / PAGE_SIZE; i++) {
cf586021642d80 Chris Wilson 2021-06-17 111 int x = i * 1024 + i915_prandom_u32_max_state(1024, prng);
cf586021642d80 Chris Wilson 2021-06-17 112
cf586021642d80 Chris Wilson 2021-06-17 @113 if (vaddr[x] != x) {
cf586021642d80 Chris Wilson 2021-06-17 114 pr_err("%ps failed, size: %u, offset: %zu\n",
cf586021642d80 Chris Wilson 2021-06-17 115 fn, sz, x * sizeof(u32));
cf586021642d80 Chris Wilson 2021-06-17 116 igt_hexdump(vaddr + i * 1024, 4096);
cf586021642d80 Chris Wilson 2021-06-17 117 err = -EINVAL;
cf586021642d80 Chris Wilson 2021-06-17 118 }
cf586021642d80 Chris Wilson 2021-06-17 119 }
cf586021642d80 Chris Wilson 2021-06-17 120
cf586021642d80 Chris Wilson 2021-06-17 121 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 122 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 123
cf586021642d80 Chris Wilson 2021-06-17 124 err_out:
cf586021642d80 Chris Wilson 2021-06-17 125 i915_gem_object_put(dst);
cf586021642d80 Chris Wilson 2021-06-17 126 err_free_src:
cf586021642d80 Chris Wilson 2021-06-17 127 i915_gem_object_put(src);
cf586021642d80 Chris Wilson 2021-06-17 128
cf586021642d80 Chris Wilson 2021-06-17 129 return err;
cf586021642d80 Chris Wilson 2021-06-17 130 }
---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org
WARNING: multiple messages have this Message-ID (diff)
From: Dan Carpenter <dan.carpenter@oracle.com>
To: kbuild@lists.01.org, Chris Wilson <chris@chris-wilson.co.uk>
Cc: "Thomas Hellström" <thomas.hellstrom@linux.intel.com>,
kbuild-all@lists.01.org, intel-gfx@lists.freedesktop.org,
dri-devel@lists.freedesktop.org,
"Matthew Auld" <matthew.auld@intel.com>
Subject: [Intel-gfx] [drm-intel:drm-intel-gt-next 8/14] drivers/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
Date: Fri, 2 Jul 2021 11:44:43 +0300 [thread overview]
Message-ID: <202107020708.XXwacDfG-lkp@intel.com> (raw)
tree: git://anongit.freedesktop.org/drm-intel drm-intel-gt-next
head: 5cd57f676bb946a00275408f0dd0d75dbc466d25
commit: cf586021642d8017cde111b7dd1ba86224e9da51 [8/14] drm/i915/gt: Pipelined page migration
config: x86_64-randconfig-m001-20210630 (attached as .config)
compiler: gcc-9 (Debian 9.3.0-22) 9.3.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/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
drivers/gpu/drm/i915/gt/selftest_migrate.c:113 copy() error: uninitialized symbol 'vaddr'.
Old smatch warnings:
drivers/gpu/drm/i915/gem/i915_gem_object.h:182 __i915_gem_object_lock() error: we previously assumed 'ww' could be null (see line 171)
vim +/rq +102 drivers/gpu/drm/i915/gt/selftest_migrate.c
cf586021642d80 Chris Wilson 2021-06-17 32 static int copy(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 33 int (*fn)(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 34 struct i915_gem_ww_ctx *ww,
cf586021642d80 Chris Wilson 2021-06-17 35 struct drm_i915_gem_object *src,
cf586021642d80 Chris Wilson 2021-06-17 36 struct drm_i915_gem_object *dst,
cf586021642d80 Chris Wilson 2021-06-17 37 struct i915_request **out),
cf586021642d80 Chris Wilson 2021-06-17 38 u32 sz, struct rnd_state *prng)
cf586021642d80 Chris Wilson 2021-06-17 39 {
cf586021642d80 Chris Wilson 2021-06-17 40 struct drm_i915_private *i915 = migrate->context->engine->i915;
cf586021642d80 Chris Wilson 2021-06-17 41 struct drm_i915_gem_object *src, *dst;
cf586021642d80 Chris Wilson 2021-06-17 42 struct i915_request *rq;
cf586021642d80 Chris Wilson 2021-06-17 43 struct i915_gem_ww_ctx ww;
cf586021642d80 Chris Wilson 2021-06-17 44 u32 *vaddr;
cf586021642d80 Chris Wilson 2021-06-17 45 int err = 0;
One way to silence these warnings would be to initialize err = -EINVAL.
Then Smatch would know that we goto err_out for an empty list.
cf586021642d80 Chris Wilson 2021-06-17 46 int i;
cf586021642d80 Chris Wilson 2021-06-17 47
cf586021642d80 Chris Wilson 2021-06-17 48 src = create_lmem_or_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 49 if (IS_ERR(src))
cf586021642d80 Chris Wilson 2021-06-17 50 return 0;
cf586021642d80 Chris Wilson 2021-06-17 51
cf586021642d80 Chris Wilson 2021-06-17 52 dst = i915_gem_object_create_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 53 if (IS_ERR(dst))
cf586021642d80 Chris Wilson 2021-06-17 54 goto err_free_src;
cf586021642d80 Chris Wilson 2021-06-17 55
cf586021642d80 Chris Wilson 2021-06-17 56 for_i915_gem_ww(&ww, err, true) {
cf586021642d80 Chris Wilson 2021-06-17 57 err = i915_gem_object_lock(src, &ww);
cf586021642d80 Chris Wilson 2021-06-17 58 if (err)
cf586021642d80 Chris Wilson 2021-06-17 59 continue;
cf586021642d80 Chris Wilson 2021-06-17 60
cf586021642d80 Chris Wilson 2021-06-17 61 err = i915_gem_object_lock(dst, &ww);
cf586021642d80 Chris Wilson 2021-06-17 62 if (err)
cf586021642d80 Chris Wilson 2021-06-17 63 continue;
cf586021642d80 Chris Wilson 2021-06-17 64
cf586021642d80 Chris Wilson 2021-06-17 65 vaddr = i915_gem_object_pin_map(src, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 66 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 67 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 68 continue;
cf586021642d80 Chris Wilson 2021-06-17 69 }
cf586021642d80 Chris Wilson 2021-06-17 70
cf586021642d80 Chris Wilson 2021-06-17 71 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 72 vaddr[i] = i;
cf586021642d80 Chris Wilson 2021-06-17 73 i915_gem_object_flush_map(src);
cf586021642d80 Chris Wilson 2021-06-17 74
cf586021642d80 Chris Wilson 2021-06-17 75 vaddr = i915_gem_object_pin_map(dst, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 76 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 77 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 78 goto unpin_src;
cf586021642d80 Chris Wilson 2021-06-17 79 }
cf586021642d80 Chris Wilson 2021-06-17 80
cf586021642d80 Chris Wilson 2021-06-17 81 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 82 vaddr[i] = ~i;
cf586021642d80 Chris Wilson 2021-06-17 83 i915_gem_object_flush_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 84
cf586021642d80 Chris Wilson 2021-06-17 85 err = fn(migrate, &ww, src, dst, &rq);
cf586021642d80 Chris Wilson 2021-06-17 86 if (!err)
cf586021642d80 Chris Wilson 2021-06-17 87 continue;
Does fn() initialize "rq" on the success path? Anyway Smatch would
complain anyway because it thinks the list could be empty or that we
might hit and early continue for everything.
cf586021642d80 Chris Wilson 2021-06-17 88
cf586021642d80 Chris Wilson 2021-06-17 89 if (err != -EDEADLK && err != -EINTR && err != -ERESTARTSYS)
cf586021642d80 Chris Wilson 2021-06-17 90 pr_err("%ps failed, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 91 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 92 i915_request_wait(rq, 0, HZ);
cf586021642d80 Chris Wilson 2021-06-17 93 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 94 }
cf586021642d80 Chris Wilson 2021-06-17 95 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 96 unpin_src:
cf586021642d80 Chris Wilson 2021-06-17 97 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 98 }
cf586021642d80 Chris Wilson 2021-06-17 99 if (err)
cf586021642d80 Chris Wilson 2021-06-17 100 goto err_out;
cf586021642d80 Chris Wilson 2021-06-17 101
cf586021642d80 Chris Wilson 2021-06-17 @102 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 103 if (i915_request_wait(rq, 0, HZ) < 0) {
cf586021642d80 Chris Wilson 2021-06-17 104 pr_err("%ps timed out, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 105 err = -ETIME;
cf586021642d80 Chris Wilson 2021-06-17 106 }
cf586021642d80 Chris Wilson 2021-06-17 107 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 108 }
cf586021642d80 Chris Wilson 2021-06-17 109
cf586021642d80 Chris Wilson 2021-06-17 110 for (i = 0; !err && i < sz / PAGE_SIZE; i++) {
cf586021642d80 Chris Wilson 2021-06-17 111 int x = i * 1024 + i915_prandom_u32_max_state(1024, prng);
cf586021642d80 Chris Wilson 2021-06-17 112
cf586021642d80 Chris Wilson 2021-06-17 @113 if (vaddr[x] != x) {
cf586021642d80 Chris Wilson 2021-06-17 114 pr_err("%ps failed, size: %u, offset: %zu\n",
cf586021642d80 Chris Wilson 2021-06-17 115 fn, sz, x * sizeof(u32));
cf586021642d80 Chris Wilson 2021-06-17 116 igt_hexdump(vaddr + i * 1024, 4096);
cf586021642d80 Chris Wilson 2021-06-17 117 err = -EINVAL;
cf586021642d80 Chris Wilson 2021-06-17 118 }
cf586021642d80 Chris Wilson 2021-06-17 119 }
cf586021642d80 Chris Wilson 2021-06-17 120
cf586021642d80 Chris Wilson 2021-06-17 121 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 122 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 123
cf586021642d80 Chris Wilson 2021-06-17 124 err_out:
cf586021642d80 Chris Wilson 2021-06-17 125 i915_gem_object_put(dst);
cf586021642d80 Chris Wilson 2021-06-17 126 err_free_src:
cf586021642d80 Chris Wilson 2021-06-17 127 i915_gem_object_put(src);
cf586021642d80 Chris Wilson 2021-06-17 128
cf586021642d80 Chris Wilson 2021-06-17 129 return err;
cf586021642d80 Chris Wilson 2021-06-17 130 }
---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
WARNING: multiple messages have this Message-ID (diff)
From: kernel test robot <lkp@intel.com>
To: kbuild@lists.01.org
Subject: [drm-intel:drm-intel-gt-next 8/14] drivers/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
Date: Fri, 02 Jul 2021 07:14:16 +0800 [thread overview]
Message-ID: <202107020708.XXwacDfG-lkp@intel.com> (raw)
[-- Attachment #1: Type: text/plain, Size: 8176 bytes --]
CC: kbuild-all(a)lists.01.org
CC: intel-gfx(a)lists.freedesktop.org
CC: dri-devel(a)lists.freedesktop.org
TO: Chris Wilson <chris@chris-wilson.co.uk>
CC: Matthew Auld <matthew.auld@intel.com>
CC: "Thomas Hellström" <thomas.hellstrom@linux.intel.com>
tree: git://anongit.freedesktop.org/drm-intel drm-intel-gt-next
head: 5cd57f676bb946a00275408f0dd0d75dbc466d25
commit: cf586021642d8017cde111b7dd1ba86224e9da51 [8/14] drm/i915/gt: Pipelined page migration
:::::: branch date: 2 weeks ago
:::::: commit date: 2 weeks ago
config: x86_64-randconfig-m001-20210630 (attached as .config)
compiler: gcc-9 (Debian 9.3.0-22) 9.3.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/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
drivers/gpu/drm/i915/gt/selftest_migrate.c:113 copy() error: uninitialized symbol 'vaddr'.
Old smatch warnings:
drivers/gpu/drm/i915/gem/i915_gem_object.h:182 __i915_gem_object_lock() error: we previously assumed 'ww' could be null (see line 171)
vim +/rq +102 drivers/gpu/drm/i915/gt/selftest_migrate.c
cf586021642d80 Chris Wilson 2021-06-17 31
cf586021642d80 Chris Wilson 2021-06-17 32 static int copy(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 33 int (*fn)(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 34 struct i915_gem_ww_ctx *ww,
cf586021642d80 Chris Wilson 2021-06-17 35 struct drm_i915_gem_object *src,
cf586021642d80 Chris Wilson 2021-06-17 36 struct drm_i915_gem_object *dst,
cf586021642d80 Chris Wilson 2021-06-17 37 struct i915_request **out),
cf586021642d80 Chris Wilson 2021-06-17 38 u32 sz, struct rnd_state *prng)
cf586021642d80 Chris Wilson 2021-06-17 39 {
cf586021642d80 Chris Wilson 2021-06-17 40 struct drm_i915_private *i915 = migrate->context->engine->i915;
cf586021642d80 Chris Wilson 2021-06-17 41 struct drm_i915_gem_object *src, *dst;
cf586021642d80 Chris Wilson 2021-06-17 42 struct i915_request *rq;
cf586021642d80 Chris Wilson 2021-06-17 43 struct i915_gem_ww_ctx ww;
cf586021642d80 Chris Wilson 2021-06-17 44 u32 *vaddr;
cf586021642d80 Chris Wilson 2021-06-17 45 int err = 0;
cf586021642d80 Chris Wilson 2021-06-17 46 int i;
cf586021642d80 Chris Wilson 2021-06-17 47
cf586021642d80 Chris Wilson 2021-06-17 48 src = create_lmem_or_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 49 if (IS_ERR(src))
cf586021642d80 Chris Wilson 2021-06-17 50 return 0;
cf586021642d80 Chris Wilson 2021-06-17 51
cf586021642d80 Chris Wilson 2021-06-17 52 dst = i915_gem_object_create_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 53 if (IS_ERR(dst))
cf586021642d80 Chris Wilson 2021-06-17 54 goto err_free_src;
cf586021642d80 Chris Wilson 2021-06-17 55
cf586021642d80 Chris Wilson 2021-06-17 56 for_i915_gem_ww(&ww, err, true) {
cf586021642d80 Chris Wilson 2021-06-17 57 err = i915_gem_object_lock(src, &ww);
cf586021642d80 Chris Wilson 2021-06-17 58 if (err)
cf586021642d80 Chris Wilson 2021-06-17 59 continue;
cf586021642d80 Chris Wilson 2021-06-17 60
cf586021642d80 Chris Wilson 2021-06-17 61 err = i915_gem_object_lock(dst, &ww);
cf586021642d80 Chris Wilson 2021-06-17 62 if (err)
cf586021642d80 Chris Wilson 2021-06-17 63 continue;
cf586021642d80 Chris Wilson 2021-06-17 64
cf586021642d80 Chris Wilson 2021-06-17 65 vaddr = i915_gem_object_pin_map(src, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 66 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 67 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 68 continue;
cf586021642d80 Chris Wilson 2021-06-17 69 }
cf586021642d80 Chris Wilson 2021-06-17 70
cf586021642d80 Chris Wilson 2021-06-17 71 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 72 vaddr[i] = i;
cf586021642d80 Chris Wilson 2021-06-17 73 i915_gem_object_flush_map(src);
cf586021642d80 Chris Wilson 2021-06-17 74
cf586021642d80 Chris Wilson 2021-06-17 75 vaddr = i915_gem_object_pin_map(dst, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 76 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 77 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 78 goto unpin_src;
cf586021642d80 Chris Wilson 2021-06-17 79 }
cf586021642d80 Chris Wilson 2021-06-17 80
cf586021642d80 Chris Wilson 2021-06-17 81 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 82 vaddr[i] = ~i;
cf586021642d80 Chris Wilson 2021-06-17 83 i915_gem_object_flush_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 84
cf586021642d80 Chris Wilson 2021-06-17 85 err = fn(migrate, &ww, src, dst, &rq);
cf586021642d80 Chris Wilson 2021-06-17 86 if (!err)
cf586021642d80 Chris Wilson 2021-06-17 87 continue;
cf586021642d80 Chris Wilson 2021-06-17 88
cf586021642d80 Chris Wilson 2021-06-17 89 if (err != -EDEADLK && err != -EINTR && err != -ERESTARTSYS)
cf586021642d80 Chris Wilson 2021-06-17 90 pr_err("%ps failed, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 91 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 92 i915_request_wait(rq, 0, HZ);
cf586021642d80 Chris Wilson 2021-06-17 93 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 94 }
cf586021642d80 Chris Wilson 2021-06-17 95 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 96 unpin_src:
cf586021642d80 Chris Wilson 2021-06-17 97 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 98 }
cf586021642d80 Chris Wilson 2021-06-17 99 if (err)
cf586021642d80 Chris Wilson 2021-06-17 100 goto err_out;
cf586021642d80 Chris Wilson 2021-06-17 101
cf586021642d80 Chris Wilson 2021-06-17 @102 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 103 if (i915_request_wait(rq, 0, HZ) < 0) {
cf586021642d80 Chris Wilson 2021-06-17 104 pr_err("%ps timed out, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 105 err = -ETIME;
cf586021642d80 Chris Wilson 2021-06-17 106 }
cf586021642d80 Chris Wilson 2021-06-17 107 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 108 }
cf586021642d80 Chris Wilson 2021-06-17 109
cf586021642d80 Chris Wilson 2021-06-17 110 for (i = 0; !err && i < sz / PAGE_SIZE; i++) {
cf586021642d80 Chris Wilson 2021-06-17 111 int x = i * 1024 + i915_prandom_u32_max_state(1024, prng);
cf586021642d80 Chris Wilson 2021-06-17 112
cf586021642d80 Chris Wilson 2021-06-17 @113 if (vaddr[x] != x) {
cf586021642d80 Chris Wilson 2021-06-17 114 pr_err("%ps failed, size: %u, offset: %zu\n",
cf586021642d80 Chris Wilson 2021-06-17 115 fn, sz, x * sizeof(u32));
cf586021642d80 Chris Wilson 2021-06-17 116 igt_hexdump(vaddr + i * 1024, 4096);
cf586021642d80 Chris Wilson 2021-06-17 117 err = -EINVAL;
cf586021642d80 Chris Wilson 2021-06-17 118 }
cf586021642d80 Chris Wilson 2021-06-17 119 }
cf586021642d80 Chris Wilson 2021-06-17 120
cf586021642d80 Chris Wilson 2021-06-17 121 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 122 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 123
cf586021642d80 Chris Wilson 2021-06-17 124 err_out:
cf586021642d80 Chris Wilson 2021-06-17 125 i915_gem_object_put(dst);
cf586021642d80 Chris Wilson 2021-06-17 126 err_free_src:
cf586021642d80 Chris Wilson 2021-06-17 127 i915_gem_object_put(src);
cf586021642d80 Chris Wilson 2021-06-17 128
cf586021642d80 Chris Wilson 2021-06-17 129 return err;
cf586021642d80 Chris Wilson 2021-06-17 130 }
cf586021642d80 Chris Wilson 2021-06-17 131
---
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: 48632 bytes --]
WARNING: multiple messages have this Message-ID (diff)
From: Dan Carpenter <dan.carpenter@oracle.com>
To: kbuild-all@lists.01.org
Subject: [drm-intel:drm-intel-gt-next 8/14] drivers/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
Date: Fri, 02 Jul 2021 11:44:43 +0300 [thread overview]
Message-ID: <202107020708.XXwacDfG-lkp@intel.com> (raw)
[-- Attachment #1: Type: text/plain, Size: 8087 bytes --]
tree: git://anongit.freedesktop.org/drm-intel drm-intel-gt-next
head: 5cd57f676bb946a00275408f0dd0d75dbc466d25
commit: cf586021642d8017cde111b7dd1ba86224e9da51 [8/14] drm/i915/gt: Pipelined page migration
config: x86_64-randconfig-m001-20210630 (attached as .config)
compiler: gcc-9 (Debian 9.3.0-22) 9.3.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/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq'.
drivers/gpu/drm/i915/gt/selftest_migrate.c:113 copy() error: uninitialized symbol 'vaddr'.
Old smatch warnings:
drivers/gpu/drm/i915/gem/i915_gem_object.h:182 __i915_gem_object_lock() error: we previously assumed 'ww' could be null (see line 171)
vim +/rq +102 drivers/gpu/drm/i915/gt/selftest_migrate.c
cf586021642d80 Chris Wilson 2021-06-17 32 static int copy(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 33 int (*fn)(struct intel_migrate *migrate,
cf586021642d80 Chris Wilson 2021-06-17 34 struct i915_gem_ww_ctx *ww,
cf586021642d80 Chris Wilson 2021-06-17 35 struct drm_i915_gem_object *src,
cf586021642d80 Chris Wilson 2021-06-17 36 struct drm_i915_gem_object *dst,
cf586021642d80 Chris Wilson 2021-06-17 37 struct i915_request **out),
cf586021642d80 Chris Wilson 2021-06-17 38 u32 sz, struct rnd_state *prng)
cf586021642d80 Chris Wilson 2021-06-17 39 {
cf586021642d80 Chris Wilson 2021-06-17 40 struct drm_i915_private *i915 = migrate->context->engine->i915;
cf586021642d80 Chris Wilson 2021-06-17 41 struct drm_i915_gem_object *src, *dst;
cf586021642d80 Chris Wilson 2021-06-17 42 struct i915_request *rq;
cf586021642d80 Chris Wilson 2021-06-17 43 struct i915_gem_ww_ctx ww;
cf586021642d80 Chris Wilson 2021-06-17 44 u32 *vaddr;
cf586021642d80 Chris Wilson 2021-06-17 45 int err = 0;
One way to silence these warnings would be to initialize err = -EINVAL.
Then Smatch would know that we goto err_out for an empty list.
cf586021642d80 Chris Wilson 2021-06-17 46 int i;
cf586021642d80 Chris Wilson 2021-06-17 47
cf586021642d80 Chris Wilson 2021-06-17 48 src = create_lmem_or_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 49 if (IS_ERR(src))
cf586021642d80 Chris Wilson 2021-06-17 50 return 0;
cf586021642d80 Chris Wilson 2021-06-17 51
cf586021642d80 Chris Wilson 2021-06-17 52 dst = i915_gem_object_create_internal(i915, sz);
cf586021642d80 Chris Wilson 2021-06-17 53 if (IS_ERR(dst))
cf586021642d80 Chris Wilson 2021-06-17 54 goto err_free_src;
cf586021642d80 Chris Wilson 2021-06-17 55
cf586021642d80 Chris Wilson 2021-06-17 56 for_i915_gem_ww(&ww, err, true) {
cf586021642d80 Chris Wilson 2021-06-17 57 err = i915_gem_object_lock(src, &ww);
cf586021642d80 Chris Wilson 2021-06-17 58 if (err)
cf586021642d80 Chris Wilson 2021-06-17 59 continue;
cf586021642d80 Chris Wilson 2021-06-17 60
cf586021642d80 Chris Wilson 2021-06-17 61 err = i915_gem_object_lock(dst, &ww);
cf586021642d80 Chris Wilson 2021-06-17 62 if (err)
cf586021642d80 Chris Wilson 2021-06-17 63 continue;
cf586021642d80 Chris Wilson 2021-06-17 64
cf586021642d80 Chris Wilson 2021-06-17 65 vaddr = i915_gem_object_pin_map(src, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 66 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 67 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 68 continue;
cf586021642d80 Chris Wilson 2021-06-17 69 }
cf586021642d80 Chris Wilson 2021-06-17 70
cf586021642d80 Chris Wilson 2021-06-17 71 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 72 vaddr[i] = i;
cf586021642d80 Chris Wilson 2021-06-17 73 i915_gem_object_flush_map(src);
cf586021642d80 Chris Wilson 2021-06-17 74
cf586021642d80 Chris Wilson 2021-06-17 75 vaddr = i915_gem_object_pin_map(dst, I915_MAP_WC);
cf586021642d80 Chris Wilson 2021-06-17 76 if (IS_ERR(vaddr)) {
cf586021642d80 Chris Wilson 2021-06-17 77 err = PTR_ERR(vaddr);
cf586021642d80 Chris Wilson 2021-06-17 78 goto unpin_src;
cf586021642d80 Chris Wilson 2021-06-17 79 }
cf586021642d80 Chris Wilson 2021-06-17 80
cf586021642d80 Chris Wilson 2021-06-17 81 for (i = 0; i < sz / sizeof(u32); i++)
cf586021642d80 Chris Wilson 2021-06-17 82 vaddr[i] = ~i;
cf586021642d80 Chris Wilson 2021-06-17 83 i915_gem_object_flush_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 84
cf586021642d80 Chris Wilson 2021-06-17 85 err = fn(migrate, &ww, src, dst, &rq);
cf586021642d80 Chris Wilson 2021-06-17 86 if (!err)
cf586021642d80 Chris Wilson 2021-06-17 87 continue;
Does fn() initialize "rq" on the success path? Anyway Smatch would
complain anyway because it thinks the list could be empty or that we
might hit and early continue for everything.
cf586021642d80 Chris Wilson 2021-06-17 88
cf586021642d80 Chris Wilson 2021-06-17 89 if (err != -EDEADLK && err != -EINTR && err != -ERESTARTSYS)
cf586021642d80 Chris Wilson 2021-06-17 90 pr_err("%ps failed, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 91 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 92 i915_request_wait(rq, 0, HZ);
cf586021642d80 Chris Wilson 2021-06-17 93 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 94 }
cf586021642d80 Chris Wilson 2021-06-17 95 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 96 unpin_src:
cf586021642d80 Chris Wilson 2021-06-17 97 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 98 }
cf586021642d80 Chris Wilson 2021-06-17 99 if (err)
cf586021642d80 Chris Wilson 2021-06-17 100 goto err_out;
cf586021642d80 Chris Wilson 2021-06-17 101
cf586021642d80 Chris Wilson 2021-06-17 @102 if (rq) {
cf586021642d80 Chris Wilson 2021-06-17 103 if (i915_request_wait(rq, 0, HZ) < 0) {
cf586021642d80 Chris Wilson 2021-06-17 104 pr_err("%ps timed out, size: %u\n", fn, sz);
cf586021642d80 Chris Wilson 2021-06-17 105 err = -ETIME;
cf586021642d80 Chris Wilson 2021-06-17 106 }
cf586021642d80 Chris Wilson 2021-06-17 107 i915_request_put(rq);
cf586021642d80 Chris Wilson 2021-06-17 108 }
cf586021642d80 Chris Wilson 2021-06-17 109
cf586021642d80 Chris Wilson 2021-06-17 110 for (i = 0; !err && i < sz / PAGE_SIZE; i++) {
cf586021642d80 Chris Wilson 2021-06-17 111 int x = i * 1024 + i915_prandom_u32_max_state(1024, prng);
cf586021642d80 Chris Wilson 2021-06-17 112
cf586021642d80 Chris Wilson 2021-06-17 @113 if (vaddr[x] != x) {
cf586021642d80 Chris Wilson 2021-06-17 114 pr_err("%ps failed, size: %u, offset: %zu\n",
cf586021642d80 Chris Wilson 2021-06-17 115 fn, sz, x * sizeof(u32));
cf586021642d80 Chris Wilson 2021-06-17 116 igt_hexdump(vaddr + i * 1024, 4096);
cf586021642d80 Chris Wilson 2021-06-17 117 err = -EINVAL;
cf586021642d80 Chris Wilson 2021-06-17 118 }
cf586021642d80 Chris Wilson 2021-06-17 119 }
cf586021642d80 Chris Wilson 2021-06-17 120
cf586021642d80 Chris Wilson 2021-06-17 121 i915_gem_object_unpin_map(dst);
cf586021642d80 Chris Wilson 2021-06-17 122 i915_gem_object_unpin_map(src);
cf586021642d80 Chris Wilson 2021-06-17 123
cf586021642d80 Chris Wilson 2021-06-17 124 err_out:
cf586021642d80 Chris Wilson 2021-06-17 125 i915_gem_object_put(dst);
cf586021642d80 Chris Wilson 2021-06-17 126 err_free_src:
cf586021642d80 Chris Wilson 2021-06-17 127 i915_gem_object_put(src);
cf586021642d80 Chris Wilson 2021-06-17 128
cf586021642d80 Chris Wilson 2021-06-17 129 return err;
cf586021642d80 Chris Wilson 2021-06-17 130 }
---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org
next reply other threads:[~2021-07-02 8:45 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-01 23:14 kernel test robot [this message]
2021-07-02 8:44 ` [drm-intel:drm-intel-gt-next 8/14] drivers/gpu/drm/i915/gt/selftest_migrate.c:102 copy() error: uninitialized symbol 'rq' Dan Carpenter
2021-07-02 8:44 ` [Intel-gfx] " Dan Carpenter
2021-07-02 8:44 ` Dan Carpenter
2021-07-02 10:32 ` [Intel-gfx] " Matthew Auld
2021-07-02 10:32 ` Matthew Auld
2021-07-02 10:32 ` Matthew Auld
2021-07-02 11:07 ` Dan Carpenter
2021-07-02 11:07 ` Dan Carpenter
2021-07-02 11:07 ` Dan Carpenter
2021-07-02 11:07 ` Dan Carpenter
2021-07-02 11:13 ` Dan Carpenter
2021-07-02 11:13 ` Dan Carpenter
2021-07-02 11:13 ` Dan Carpenter
2021-07-02 11:13 ` Dan Carpenter
2021-07-02 11:57 ` Matthew Auld
2021-07-02 11:57 ` Matthew Auld
2021-07-02 11:57 ` Matthew Auld
2021-07-02 11:34 ` Matthew Auld
2021-07-02 11:34 ` Matthew Auld
2021-07-02 11:34 ` Matthew Auld
2021-07-02 12:19 ` Dan Carpenter
2021-07-02 12:19 ` Dan Carpenter
2021-07-02 12:19 ` Dan Carpenter
2021-07-02 12:19 ` Dan Carpenter
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=202107020708.XXwacDfG-lkp@intel.com \
--to=dan.carpenter@oracle.com \
--cc=chris@chris-wilson.co.uk \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=kbuild-all@lists.01.org \
--cc=kbuild@lists.01.org \
--cc=lkp@intel.com \
--cc=matthew.auld@intel.com \
--cc=thomas.hellstrom@linux.intel.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 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.