Source: haskell-pandoc
Version: 3.1.3-1
Severity: important
Tags: ftbfs patch
User: debian-loonga...@lists.debian.org
Usertags: loong64

Dear maintainers,

Compiling the haskell-pandoc failed for loong64 in the Debian Package Auto-Building environment.
The error log is as follows,
```
[58 of 58] Linking dist-ghc/build/test-pandoc/test-pandoc
/usr/bin/ld.bfd: /usr/lib/ghc/lib/../lib/loongarch64-linux-ghc-9.4.7/rts-1.0.2/libHSrts-1.0.2_thr.a(NonMovingMark.thr_o): relocation R_LARCH_B26 overflow 0xfffffffff5fec6a4
Dump relocate record:
stack top        relocation name        symbol
at /usr/lib/gcc/loongarch64-linux-gnu/13/../../../loongarch64-linux-gnu/crt1.o(.text+0x0):
...
0x0000000000000000 R_LARCH_NONE    `<nameless>' + 3(0x3)
......
```

The Full log can be found at https://buildd.debian.org/status/logs.php?pkg=haskell-pandoc&ver=3.1.3-1&arch=loong64.

The reason for the above error is that "relocation R_LARCH_B26 overflow ......" occurs during static linking in the test-pandoc stage. Currently we have two suggestions to solve "relocation R_LARCH_B26 overflow ......" during static linking.

1.Add build rules to reduce binary size.
Use "DEB_SETUP_GHC_CONFIGURE_ARGS += --enable-executable-dynamic -O2" when compiling haskell-pandoc for loong64.
The parameters are explained as follows,
"--enable-executable-dynamic" means "Enable Executable dynamic linking".
"-O, --enable-optimization[=n]" means "Build with optimization (n is 0--2, default is 1)".

2.Disable tests in d/rules on loong64.
The error "relocation R_LARCH_B26 overflow ......" occurs during the testing stage.
It is recommended to use "DEB_ENABLE_TESTS = no" in d/rules for loong64.
The haskell-pandoc was built successfully in my local ENV.
About disable tests in d/rules on loong64, please consider the below patch,
```
diff --git a/debian/rules b/debian/rules
index 6fbf01d..385f58e 100755
--- a/debian/rules
+++ b/debian/rules
@@ -1,6 +1,10 @@
 #!/usr/bin/make -f

 DEB_ENABLE_TESTS = yes
+ifneq (,$(filter $(DEB_HOST_ARCH_CPU), loong64))
+DEB_ENABLE_TESTS = no
+endif
+
```

The haskel-pandoc blocks the construction of pandoc.
And pandoc blocks the compilation of 103 packages.

Please help us to choose 1 of the 2 solutions I provided above.
Or help us to solve "relocation R_LARCH_B26 overflow ......".
Looking forward to your reply.

Thanks,
Dandan Zhang

Reply via email to