Re: [PATCH rdma-next 3/4] RDMA/umem: Add missing initialization of owning_mm

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jan 22, 2019 at 09:16:10AM +0200, Leon Romanovsky wrote:
> From: Artemy Kovalyov <artemyko@xxxxxxxxxxxx>
> 
> When allocating a umem leaf for implicit ODP MR during page fault the
> field owning_mm was not set.
> 
> Initialize and take a reference on this field to avoid kernel panic when
> trying to access this field.
> 
>  BUG: unable to handle kernel NULL pointer dereference at 0000000000000058
>  PGD 800000022dfed067 P4D 800000022dfed067 PUD 22dfcf067 PMD 0
>  Oops: 0000 [#1] SMP PTI
>  CPU: 0 PID: 634 Comm: kworker/u33:0 Not tainted 4.20.0-rc6+ #89
>  Hardware name: Red Hat KVM, BIOS 0.5.1 01/01/2011
>  Workqueue: mlx5_ib_page_fault mlx5_ib_eqe_pf_action [mlx5_ib]
>  RIP: 0010:ib_umem_odp_map_dma_pages+0xf3/0x710 [ib_core]
>  Code: 45 c0 48 21 f3 48 89 75 b0 31 f6 4a 8d 04 33 48 89 45 a8 49 8b 44 24 60 48 8b 78 10 e8 66 16 a8 c5 49 8b 54 24 08 48 89 45 98 <8b> 42 58 85 c0 0f 84 8e 05 00 00 8d 48 01 48 8d 72 58 f0 0f b1 4a
>  RSP: 0000:ffffb610813a7c20 EFLAGS: 00010202
>  RAX: ffff95ace6e8ac80 RBX: 0000000000000000 RCX: 000000000000000c
>  RDX: 0000000000000000 RSI: 0000000000000850 RDI: ffff95aceaadae80
>  RBP: ffffb610813a7ce0 R08: 0000000000000000 R09: 0000000000080c77
>  R10: ffff95acfffdbd00 R11: 0000000000000000 R12: ffff95aceaa20a00
>  R13: 0000000000001000 R14: 0000000000001000 R15: 000000000000000c
>  FS:  0000000000000000(0000) GS:ffff95acf7800000(0000) knlGS:0000000000000000
>  CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>  CR2: 0000000000000058 CR3: 000000022c834001 CR4: 00000000001606f0
>  Call Trace:
>   pagefault_single_data_segment+0x1df/0xc60 [mlx5_ib]
>   mlx5_ib_eqe_pf_action+0x7bc/0xa70 [mlx5_ib]
>   ? __switch_to+0xe1/0x470
>   process_one_work+0x174/0x390
>   worker_thread+0x4f/0x3e0
>   kthread+0x102/0x140
>   ? drain_workqueue+0x130/0x130
>   ? kthread_stop+0x110/0x110
>   ret_from_fork+0x1f/0x30
> 
> Fixes: f27a0d50a4bc ("RDMA/umem: Use umem->owning_mm inside ODP")
> Signed-off-by: Artemy Kovalyov <artemyko@xxxxxxxxxxxx>
> Signed-off-by: Moni Shoua <monis@xxxxxxxxxxxx>
> Signed-off-by: Leon Romanovsky <leonro@xxxxxxxxxxxx>
> ---
>  drivers/infiniband/core/umem_odp.c | 3 +++
>  1 file changed, 3 insertions(+)

Applied to for-rc

Thanks,
Jason



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux