On Wed, Nov 29, 2017 at 09:09:49AM +0000, Dmitry Monakhov wrote: > Once infiniband was compiled as core component it's subsystems must be > enabled before device initialization. Otherwise this result NULL pointer > dereference during mlx4_core init, calltrace: > ->device_add > if (dev->class) { > deref dev->class->p =>NULLPTR > > #Config > CONFIG_NET_DEVLINK=y > CONFIG_MAY_USE_DEVLINK=y > CONFIG_MLX4_EN=y > > Signed-off-by: Dmitry Monakhov <dmonakhov@xxxxxxxxxx> > --- > drivers/infiniband/core/cm.c | 2 +- > drivers/infiniband/core/device.c | 2 +- > drivers/infiniband/ulp/srp/ib_srp.c | 2 +- > 3 files changed, 3 insertions(+), 3 deletions(-) First please follow submission rules (patch versioning and changelog) and second, I have hard time to believe that those changes in CM and SRP are really needed. Can you please provide actual kernel panic *without* any changes to init sequences? Thanks > > diff --git a/drivers/infiniband/core/cm.c b/drivers/infiniband/core/cm.c > index 4c4b465..1012fd8 100644 > --- a/drivers/infiniband/core/cm.c > +++ b/drivers/infiniband/core/cm.c > @@ -4370,6 +4370,6 @@ static void __exit ib_cm_cleanup(void) > idr_destroy(&cm.local_id_table); > } > > -module_init(ib_cm_init); > +subsys_initcall(ib_cm_init); > module_exit(ib_cm_cleanup); > > diff --git a/drivers/infiniband/core/device.c b/drivers/infiniband/core/device.c > index 84fc32a..5e1be49 100644 > --- a/drivers/infiniband/core/device.c > +++ b/drivers/infiniband/core/device.c > @@ -1253,5 +1253,5 @@ static void __exit ib_core_cleanup(void) > > MODULE_ALIAS_RDMA_NETLINK(RDMA_NL_LS, 4); > > -module_init(ib_core_init); > +subsys_initcall(ib_core_init); > module_exit(ib_core_cleanup); > diff --git a/drivers/infiniband/ulp/srp/ib_srp.c b/drivers/infiniband/ulp/srp/ib_srp.c > index fa5ccdb..0c21a71 100644 > --- a/drivers/infiniband/ulp/srp/ib_srp.c > +++ b/drivers/infiniband/ulp/srp/ib_srp.c > @@ -3785,5 +3785,5 @@ static void __exit srp_cleanup_module(void) > destroy_workqueue(srp_remove_wq); > } > > -module_init(srp_init_module); > +subsys_initcall(srp_init_module); > module_exit(srp_cleanup_module); > -- > 1.8.3.1 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-rdma" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html
Attachment:
signature.asc
Description: PGP signature