projects
/
GitHub
/
moto-9609
/
android_kernel_motorola_exynos9610.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
d4cea38
)
drm/msm: fix WARN_ON in add_vma() with no iommu
author
Hans Verkuil
<hverkuil@xs4all.nl>
Sun, 30 Jul 2017 12:42:36 +0000
(14:42 +0200)
committer
Rob Clark
<robdclark@gmail.com>
Tue, 1 Aug 2017 22:39:35 +0000
(18:39 -0400)
While I was testing the upcoming adv7533 CEC support with my Dragonboard c410
I encountered this warning several times during boot:
[ 4.408309] WARNING: CPU: 3 PID: 1347 at drivers/gpu/drm/msm/msm_gem.c:312 add_vma+0x78/0x88 [msm]
[ 4.412951] Modules linked in: snd_soc_hdmi_codec adv7511 cec qcom_wcnss_pil msm mdt_loader drm_kms_helper msm_rng rng_core drm
[ 4.421728] CPU: 3 PID: 1347 Comm: kworker/3:3 Not tainted 4.13.0-rc1-dragonboard #111
[ 4.433090] Hardware name: Qualcomm Technologies, Inc. APQ 8016 SBC (DT)
[ 4.441081] Workqueue: events deferred_probe_work_func
[ 4.447929] task:
ffff800031243600
task.stack:
ffff800003394000
[ 4.453023] PC is at add_vma+0x78/0x88 [msm]
[ 4.458823] LR is at _msm_gem_new+0xd4/0x188 [msm]
[ 4.463207] pc : [<
ffff000000ac01f8
>] lr : [<
ffff000000ac06b4
>] pstate:
40000145
[ 4.467811] sp :
ffff8000033978a0
[ 4.475357] x29:
ffff8000033978a0
x28:
ffff8000031dea18
[ 4.478572] x27:
ffff800003933a00
x26:
ffff800003b39800
[ 4.483953] x25:
ffff8000338ff800
x24:
0000000000000001
[ 4.489249] x23:
0000000000000000
x22:
ffff800003b39800
[ 4.494544] x21:
ffff8000338ff800
x20:
0000000000000000
[ 4.499839] x19:
ffff800003932600
x18:
0000000000000001
[ 4.505135] x17:
0000ffff8969e9e0
x16:
ffff7e00000ce7a0
[ 4.510429] x15:
ffffffffffffffff
x14:
ffff8000833977ef
[ 4.515724] x13:
ffff8000033977f3
x12:
0000000000000038
[ 4.521020] x11:
0101010101010101
x10:
ffffff7f7fff7f7f
[ 4.526315] x9 :
0000000000000000
x8 :
ffff800003932800
[ 4.531633] x7 :
0000000000000000
x6 :
000000000000003f
[ 4.531644] x5 :
0000000000000040
x4 :
0000000000000000
[ 4.531650] x3 :
ffff800031243600
x2 :
0000000000000000
[ 4.531655] x1 :
0000000000000000
x0 :
0000000000000000
[ 4.531670] Call trace:
[ 4.531676] Exception stack(0xffff8000033976c0 to 0xffff8000033977f0)
[ 4.531683] 76c0:
ffff800003932600
0001000000000000
ffff8000033978a0
ffff000000ac01f8
[ 4.531688] 76e0:
0000000000000140
0000000000000000
ffff800003932550
ffff800003397780
[ 4.531694] 7700:
ffff800003397730
ffff000008261ce8
0000000000000000
ffff8000031d2f80
[ 4.531699] 7720:
ffff800003397800
ffff0000081d671c
0000000000000140
0000000000000000
[ 4.531705] 7740:
ffff000000ac04c0
0000000000004003
ffff800003397908
00000000014080c0
[ 4.531710] 7760:
0000000000000000
ffff800003b39800
0000000000000000
0000000000000000
[ 4.531716] 7780:
0000000000000000
ffff800031243600
0000000000000000
0000000000000040
[ 4.531721] 77a0:
000000000000003f
0000000000000000
ffff800003932800
0000000000000000
[ 4.531726] 77c0:
ffffff7f7fff7f7f
0101010101010101
0000000000000038
ffff8000033977f3
[ 4.531730] 77e0:
ffff8000833977ef
ffffffffffffffff
[ 4.531881] [<
ffff000000ac01f8
>] add_vma+0x78/0x88 [msm]
[ 4.532011] [<
ffff000000ac06b4
>] _msm_gem_new+0xd4/0x188 [msm]
[ 4.532134] [<
ffff000000ac1900
>] msm_gem_new+0x10/0x18 [msm]
[ 4.532260] [<
ffff000000acb274
>] msm_dsi_host_modeset_init+0x17c/0x268 [msm]
[ 4.532384] [<
ffff000000ac9024
>] msm_dsi_modeset_init+0x34/0x1b8 [msm]
[ 4.532504] [<
ffff000000ab6168
>] modeset_init+0x408/0x488 [msm]
[ 4.532623] [<
ffff000000ab6c4c
>] mdp5_kms_init+0x2b4/0x338 [msm]
[ 4.532745] [<
ffff000000abeff8
>] msm_drm_bind+0x218/0x4e8 [msm]
[ 4.532755] [<
ffff00000855d744
>] try_to_bring_up_master+0x1f4/0x318
[ 4.532762] [<
ffff00000855d900
>] component_add+0x98/0x180
[ 4.532887] [<
ffff000000ac8da0
>] dsi_dev_probe+0x18/0x28 [msm]
[ 4.532895] [<
ffff000008565fe8
>] platform_drv_probe+0x58/0xc0
[ 4.532901] [<
ffff00000856410c
>] driver_probe_device+0x324/0x458
[ 4.532907] [<
ffff00000856440c
>] __device_attach_driver+0xac/0x170
[ 4.532913] [<
ffff000008561ef4
>] bus_for_each_drv+0x4c/0x98
[ 4.532918] [<
ffff000008563c38
>] __device_attach+0xc0/0x160
[ 4.532924] [<
ffff000008564530
>] device_initial_probe+0x10/0x18
[ 4.532929] [<
ffff000008562f84
>] bus_probe_device+0x94/0xa0
[ 4.532934] [<
ffff0000085635d4
>] deferred_probe_work_func+0x8c/0xe8
[ 4.532941] [<
ffff0000080d79bc
>] process_one_work+0x1d4/0x330
[ 4.532946] [<
ffff0000080d7b60
>] worker_thread+0x48/0x468
[ 4.532952] [<
ffff0000080ddae4
>] kthread+0x12c/0x130
[ 4.532958] [<
ffff000008082f10
>] ret_from_fork+0x10/0x40
[ 4.532962] ---[ end trace
b1ac6888ec40b0bb
]---
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Rob Clark <robdclark@gmail.com>
drivers/gpu/drm/msm/msm_gem.c
patch
|
blob
|
blame
|
history
diff --git
a/drivers/gpu/drm/msm/msm_gem.c
b/drivers/gpu/drm/msm/msm_gem.c
index 065d933df2c3b17e2b1bb772d41ebf08be7ee75c..a0c60e738db8d7be5e841311832e82f0b45bd7fa 100644
(file)
--- a/
drivers/gpu/drm/msm/msm_gem.c
+++ b/
drivers/gpu/drm/msm/msm_gem.c
@@
-930,8
+930,12
@@
static struct drm_gem_object *_msm_gem_new(struct drm_device *dev,
if (use_vram) {
struct msm_gem_vma *vma;
struct page **pages;
+ struct msm_gem_object *msm_obj = to_msm_bo(obj);
+
+ mutex_lock(&msm_obj->lock);
vma = add_vma(obj, NULL);
+ mutex_unlock(&msm_obj->lock);
if (IS_ERR(vma)) {
ret = PTR_ERR(vma);
goto fail;