diff mbox series

RDMA/hns: Fix build error again

Message ID 20191007211826.3361202-1-arnd@arndb.de
State Accepted
Commit d5b60e26e86a463ca83bb5ec502dda6ea685159e
Headers show
Series RDMA/hns: Fix build error again | expand

Commit Message

Arnd Bergmann Oct. 7, 2019, 9:18 p.m. UTC
This is not the first attempt to fix building random configurations,
unfortunately the attempt in commit a07fc0bb483e ("RDMA/hns: Fix build
error") caused a new problem when CONFIG_INFINIBAND_HNS_HIP06=m
and CONFIG_INFINIBAND_HNS_HIP08=y:

drivers/infiniband/hw/hns/hns_roce_main.o:(.rodata+0xe60): undefined reference to `__this_module'

Revert commits a07fc0bb483e ("RDMA/hns: Fix build error") and
a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment") to get
back to the previous state, then fix the issues described there
differently, by adding more specific dependencies: INFINIBAND_HNS
can now only be built-in if at least one of HNS or HNS3 are
built-in, and the individual back-ends are only available if
that code is reachable from the main driver.

Fixes: a07fc0bb483e ("RDMA/hns: Fix build error")
Fixes: a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment")
Fixes: dd74282df573 ("RDMA/hns: Initialize the PCI device for hip08 RoCE")
Fixes: 08805fdbeb2d ("RDMA/hns: Split hw v1 driver from hns roce driver")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>

---
 drivers/infiniband/hw/hns/Kconfig  | 17 ++++++++++++++---
 drivers/infiniband/hw/hns/Makefile |  8 ++++++--
 2 files changed, 20 insertions(+), 5 deletions(-)

-- 
2.20.0

Comments

Doug Ledford Oct. 21, 2019, 9:08 p.m. UTC | #1
On Mon, 2019-10-07 at 23:18 +0200, Arnd Bergmann wrote:
> This is not the first attempt to fix building random configurations,

> unfortunately the attempt in commit a07fc0bb483e ("RDMA/hns: Fix build

> error") caused a new problem when CONFIG_INFINIBAND_HNS_HIP06=m

> and CONFIG_INFINIBAND_HNS_HIP08=y:

> 

> drivers/infiniband/hw/hns/hns_roce_main.o:(.rodata+0xe60): undefined

> reference to `__this_module'

> 

> Revert commits a07fc0bb483e ("RDMA/hns: Fix build error") and

> a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment") to get

> back to the previous state, then fix the issues described there

> differently, by adding more specific dependencies: INFINIBAND_HNS

> can now only be built-in if at least one of HNS or HNS3 are

> built-in, and the individual back-ends are only available if

> that code is reachable from the main driver.

> 

> Fixes: a07fc0bb483e ("RDMA/hns: Fix build error")

> Fixes: a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment")

> Fixes: dd74282df573 ("RDMA/hns: Initialize the PCI device for hip08

> RoCE")

> Fixes: 08805fdbeb2d ("RDMA/hns: Split hw v1 driver from hns roce

> driver")

> Signed-off-by: Arnd Bergmann <arnd@arndb.de>


This fix looks reasonable, but since I can't test this at all, and I'm
personally tired of trying and failing to fix this issue, I need to ask
if you've tried all the permutations for this just to confirm it works
in all valid cases?

-- 
Doug Ledford <dledford@redhat.com>
    GPG KeyID: B826A3330E572FDD
    Fingerprint = AE6B 1BDA 122B 23B4 265B  1274 B826 A333 0E57 2FDD
Arnd Bergmann Oct. 21, 2019, 9:51 p.m. UTC | #2
On Mon, Oct 21, 2019 at 11:09 PM Doug Ledford <dledford@redhat.com> wrote:
>

> This fix looks reasonable, but since I can't test this at all, and I'm

> personally tired of trying and failing to fix this issue, I need to ask

> if you've tried all the permutations for this just to confirm it works

> in all valid cases?


I'm fairly sure I would have found them all by now: Since I sent this
patch I built 4680 randconfig kernels, 293 of which had some HNS
driver enabled.

I also like to think that I spent more time to think it through in theory.

      Arnd
Doug Ledford Oct. 22, 2019, 5:50 p.m. UTC | #3
On Mon, 2019-10-21 at 23:51 +0200, Arnd Bergmann wrote:
> On Mon, Oct 21, 2019 at 11:09 PM Doug Ledford <dledford@redhat.com>

> wrote:

> > This fix looks reasonable, but since I can't test this at all, and

> > I'm

> > personally tired of trying and failing to fix this issue, I need to

> > ask

> > if you've tried all the permutations for this just to confirm it

> > works

> > in all valid cases?

> 

> I'm fairly sure I would have found them all by now: Since I sent this

> patch I built 4680 randconfig kernels, 293 of which had some HNS

> driver enabled.

> 

> I also like to think that I spent more time to think it through in

> theory.


I reviewed it pretty closely, and I couldn't find any way in which I
thought it would fail, I'm just being picky because I want this to be
the last fix ;-)

-- 
Doug Ledford <dledford@redhat.com>
    GPG KeyID: B826A3330E572FDD
    Fingerprint = AE6B 1BDA 122B 23B4 265B  1274 B826 A333 0E57 2FDD
Jason Gunthorpe Oct. 29, 2019, 7:17 p.m. UTC | #4
On Mon, Oct 07, 2019 at 11:18:08PM +0200, Arnd Bergmann wrote:
> This is not the first attempt to fix building random configurations,

> unfortunately the attempt in commit a07fc0bb483e ("RDMA/hns: Fix build

> error") caused a new problem when CONFIG_INFINIBAND_HNS_HIP06=m

> and CONFIG_INFINIBAND_HNS_HIP08=y:

> 

> drivers/infiniband/hw/hns/hns_roce_main.o:(.rodata+0xe60): undefined reference to `__this_module'

> 

> Revert commits a07fc0bb483e ("RDMA/hns: Fix build error") and

> a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment") to get

> back to the previous state, then fix the issues described there

> differently, by adding more specific dependencies: INFINIBAND_HNS

> can now only be built-in if at least one of HNS or HNS3 are

> built-in, and the individual back-ends are only available if

> that code is reachable from the main driver.

> 

> Fixes: a07fc0bb483e ("RDMA/hns: Fix build error")

> Fixes: a3e2d4c7e766 ("RDMA/hns: remove obsolete Kconfig comment")

> Fixes: dd74282df573 ("RDMA/hns: Initialize the PCI device for hip08 RoCE")

> Fixes: 08805fdbeb2d ("RDMA/hns: Split hw v1 driver from hns roce driver")

> Signed-off-by: Arnd Bergmann <arnd@arndb.de>

> ---

>  drivers/infiniband/hw/hns/Kconfig  | 17 ++++++++++++++---

>  drivers/infiniband/hw/hns/Makefile |  8 ++++++--

>  2 files changed, 20 insertions(+), 5 deletions(-)


Applied to for-next, let us give it some time in linux-next I guess?

Thanks,
Jason
diff mbox series

Patch

diff --git a/drivers/infiniband/hw/hns/Kconfig b/drivers/infiniband/hw/hns/Kconfig
index d602b698b57e..4921c1e40ccd 100644
--- a/drivers/infiniband/hw/hns/Kconfig
+++ b/drivers/infiniband/hw/hns/Kconfig
@@ -1,23 +1,34 @@ 
 # SPDX-License-Identifier: GPL-2.0-only
 config INFINIBAND_HNS
-	bool "HNS RoCE Driver"
+	tristate "HNS RoCE Driver"
 	depends on NET_VENDOR_HISILICON
 	depends on ARM64 || (COMPILE_TEST && 64BIT)
+	depends on (HNS_DSAF && HNS_ENET) || HNS3
 	---help---
 	  This is a RoCE/RDMA driver for the Hisilicon RoCE engine. The engine
 	  is used in Hisilicon Hip06 and more further ICT SoC based on
 	  platform device.
 
+	  To compile HIP06 or HIP08 driver as module, choose M here.
+
 config INFINIBAND_HNS_HIP06
-	tristate "Hisilicon Hip06 Family RoCE support"
+	bool "Hisilicon Hip06 Family RoCE support"
 	depends on INFINIBAND_HNS && HNS && HNS_DSAF && HNS_ENET
+	depends on INFINIBAND_HNS=m || (HNS_DSAF=y && HNS_ENET=y)
 	---help---
 	  RoCE driver support for Hisilicon RoCE engine in Hisilicon Hip06 and
 	  Hip07 SoC. These RoCE engines are platform devices.
 
+	  To compile this driver, choose Y here: if INFINIBAND_HNS is m, this
+	  module will be called hns-roce-hw-v1
+
 config INFINIBAND_HNS_HIP08
-	tristate "Hisilicon Hip08 Family RoCE support"
+	bool "Hisilicon Hip08 Family RoCE support"
 	depends on INFINIBAND_HNS && PCI && HNS3
+	depends on INFINIBAND_HNS=m || HNS3=y
 	---help---
 	  RoCE driver support for Hisilicon RoCE engine in Hisilicon Hip08 SoC.
 	  The RoCE engine is a PCI device.
+
+	  To compile this driver, choose Y here: if INFINIBAND_HNS is m, this
+	  module will be called hns-roce-hw-v2.
diff --git a/drivers/infiniband/hw/hns/Makefile b/drivers/infiniband/hw/hns/Makefile
index 449a2d81319d..e105945b94a1 100644
--- a/drivers/infiniband/hw/hns/Makefile
+++ b/drivers/infiniband/hw/hns/Makefile
@@ -9,8 +9,12 @@  hns-roce-objs := hns_roce_main.o hns_roce_cmd.o hns_roce_pd.o \
 	hns_roce_ah.o hns_roce_hem.o hns_roce_mr.o hns_roce_qp.o \
 	hns_roce_cq.o hns_roce_alloc.o hns_roce_db.o hns_roce_srq.o hns_roce_restrack.o
 
+ifdef CONFIG_INFINIBAND_HNS_HIP06
 hns-roce-hw-v1-objs := hns_roce_hw_v1.o $(hns-roce-objs)
-obj-$(CONFIG_INFINIBAND_HNS_HIP06) += hns-roce-hw-v1.o
+obj-$(CONFIG_INFINIBAND_HNS) += hns-roce-hw-v1.o
+endif
 
+ifdef CONFIG_INFINIBAND_HNS_HIP08
 hns-roce-hw-v2-objs := hns_roce_hw_v2.o hns_roce_hw_v2_dfx.o $(hns-roce-objs)
-obj-$(CONFIG_INFINIBAND_HNS_HIP08) += hns-roce-hw-v2.o
+obj-$(CONFIG_INFINIBAND_HNS) += hns-roce-hw-v2.o
+endif