That hacky patch for arith-slow.pure.lisp should really only be necessary for testing threads. As you pointed out, once threading is enabled the tests for arith-slow.pure.lisp fail very early on, unfortunately. That patch was to let tests run a little further to see if only that particular test was not working properly in threaded mode. In non-threaded mode, that patch should not be necessary at all and the tests should run okay but you will have a non-threaded build of sbcl in that case. If the non-threaded build is failing at some part, that might be due to some other feature in later versions of sbcl that got turned on that is finicky on Haiku (perhaps simd or perhaps one of the compression options?). I believe I was able to get that to build and test successfully but with many features disabled (including threads) albeit with a far less featured non-threaded sbcl build.
Great news on getting what looks like the start of threading support in upstream for Haiku. One thing I noticed is that pthread_getattr_np is not implemented but it looks like this might be available in Haiku? Not sure if enabling it would help. I wish I could provide some more suggestions or guidance but this is where I ended up getting stuck as it was unclear if there some other bits in the runtime that might need patching to work with Haiku or if the way threading works in sbcl was triggering some conditions in Haiku itself.
My concern is that after applying threading patch, this error shows up in different places regardless of the options and their combinations I build SBCL: with or without threads, core compressions or simd.
~/Desktop> ls -al /boot/home/haikuports/packages/sbcl-2.2.11-1-x86_64.hpkg
-rw-r--r-- 1 user root 11863865 Dec 22 15:05 /boot/home/haikuports/packages/sbcl-2.2.11-1-x86_64.hpkg
-rw-r--r-- 1 user root 12330348 Dec 24 03:23 /boot/home/haikuports/packages/sbcl-2.3.11-1-x86_64.hpkg
I can test sbcl 2.4.11 if that is going to become the new Haiku port.
Hi @cocobean, thank you for your interest. The available version SBCL 2.4.11 does not contain recent Haiku fixes and particularly fails building.
You can instead grab the most recent version from git master https://github.com/sbcl/sbcl. You can compile SBCL with CLIPS from Depot with the following command:
cd contrib/asdf && sh pull-asdf.sh
SBCL_CONTRIB_BLOCKLIST=" sb-bsd-sockets sb-simple-streams" sh make.sh --xc-host='clisp -norc' --with-sb-core-compression --with-sb-simd-pack --with-sb-thread
I tested by running included tests. The reality is there are several different errors. Many of them seem to be caused by threads + garbage collection. Sometimes the runtime fails after reporting successful test. Sometimes a test seems to succeed one run but fails next time.
I suspect the wrong inclusion of header files for signal and error constants in contrib/sb-posix/constants.lisp. Also, it is interesting to investigate the build log related to Grovel. Grovel is used to generate Common Lisp code from C header files. This log contains a list of expected but not found declaration of constants and functions, most probably because of wrong / incomplete list of header files provided. In my case, this list is:
; Note: Building "sb-posix"
STYLE-WARNING: Couldn't grovel for SIGEMT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for SIGPWR (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOTBLK (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ECHRNG (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EL2NSYNC (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EL3HLT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EL3RST (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELNRNG (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EUNATCH (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOCSI (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EL2HLT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBADE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBADR (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EXFULL (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOANO (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBADRQC (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBADSLT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EDEADLOCK (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBFONT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENONET (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOPKG (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EREMOTE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EADV (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ESRMNT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ECOMM (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EDOTDOT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOTUNIQ (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EBADFD (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EREMCHG (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELIBACC (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELIBBAD (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELIBSCN (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELIBMAX (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ELIBEXEC (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ERESTART (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ESTRPIPE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EUSERS (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ESOCKTNOSUPPORT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ETOOMANYREFS (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EUCLEAN (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOTNAM (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENAVAIL (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EREMOTEIO (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for ENOMEDIUM (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for EMEDIUMTYPE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for S_IFWHT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for MCL_CURRENT (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for MCL_FUTURE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for O_ASYNC (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for O_LARGEFILE (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for F_GETOWN (unknown to the C compiler).
STYLE-WARNING: Couldn't grovel for F_SETOWN (unknown to the C compiler).
STYLE-WARNING: Didn't find definition for "fdatasync"
STYLE-WARNING: Didn't find definition for "setfsuid"
STYLE-WARNING: Didn't find definition for "setresuid"
STYLE-WARNING: Didn't find definition for "setfsgid"
STYLE-WARNING: Didn't find definition for "setresgid"
STYLE-WARNING: Didn't find definition for "mlockall"
STYLE-WARNING: Didn't find definition for "munlockall"
I am not sure if this is critical or not, all them are reported as style warnings, not errors.
EDIT: It seems all these constants / functions are not available in Haiku and optionally needs to be marked #-haiku.
Thanks. I built sbcl 2.4.11. I’ll review the parts you mentioned for further clean up.
ls -al /boot/home/haikuports/packages/sbcl-2.4.11-1-x86_64.hpkg
-rw-r--r-- 1 user root 11810653 Dec 24 04:17 /boot/home/haikuports/packages/sbcl-2.4.11-1-x86_64.hpkg
I am unsure the errors in tests are critical. I can see such errors also without stopping the process. More than that, the tests can run for quite long time without failing and threads seem to work in many cases. The memory corruption seems to be related to garbage collector.
On the other hand, sometimes the process stops in SBCL debugger reporting a long list of missing symbols, maybe all C functions involved in runtime.
Of course, the Haiku port needs clean-up and stabilization, but is in rather good condition.
I am really waiting for SBCL to integrate my patches. The working recipe of the current stage is available at my desktop. I plan to update SBCL recipe one per month after each upstream release. Unfortunately, the for December the tree is frozen for 2.5.0 release, so BSD Sockets patch I sent will be probably integrated in January. After that I plan to prepare ASDF patch and one more patch that enables _np variants of threading functions.
That being said, I am glad if somebody else is also working on this. Of course I will review the recipe.
OK, I see the existing recipe for SBCL 2.2.4 is just bumped to 2.4.11. I did not test the build with this recipe, but overall, I see no reason to merge this one. The release 2.5.0 of SBCL is expected at 29 of December. After that, I will prepare the current recipe.
~/Desktop> ls -al ~/haikuports/packages/sbcl*
-rw-r--r-- 1 user root 11819047 Dec 29 08:31 /boot/home/haikuports/packages/sbcl-2.5.0-1-x86_64.hpkg
Seems I hit a memory corruption during unit tests - this didn’t happen with SBCL 2.4.11.
CORRUPTION WARNING in SBCL pid 8795:
Memory fault at 0x7 (pc=0x20000040, fp=0x49cda87ce8, sp=0x49cda878f8)
The integrity of this image is possibly compromised.
Exiting.
Welcome to LDB, a low-level debugger for the Lisp runtime environment.
ldb>
You can continue from the debugger which will complete the remaining unit tests.
**Finished running tests** .... (109 tests skipped for this combination of platform and features)
I believe the memory corruption is since threads support in SBCL, which is enabled in 2.5.0 and disabled in 2.4.11. You can see it by asking:
*features*
in SBCL shell.
They are of course need to be investigated. After release, the repository is again open for patches, so new ones will hopefully be merged in January. I already sent the (corrected) patch for SB-BSD-SOCKETS and prepared the working patch for ASDF (it is a good idea to keep the same version of ASDF module in SBCL on all OSes, and SBCL refrains from upgrading it from upstream).
Next, I plan to play with _np versions of threading functions, and your help @cocobean would be much appreciated here. There are chances that once SBCL on Haiku has _ng threading support, the memory corruption will be less an issue.
Anyway, the memory corruption happens sporadically (but rather regular) and only on intensive testing. Overall, SBCL can spawn multiple threads without failing. So, today I plan to submit the recipe for 2.5.0.
As for memory corruption, threads and garbage collection: Of course it may be also a regression. The relevant code is in src/runtime/{thread.c, haiku-os.c}. The threads support patched these files.
The garbage collection related stuff in in src/runtime/{gc.h, cheneygc.c, fullcgc.c, gencgc.c, gc-*.c}. Again, the exact variant of active GC can be consulted in *features*. These files were not affected by Haiku patches, but maybe some sensible changes were introduced between SBCL releases. My guess (I never programmed threads or GC or similar) is to start looking in gc-thread-pool.c. Maybe gc-unit-tests.c could help as well.
I see the function int pthread_getattr_np(pthread_t thread, pthread_attr_t *attr) is available in gnu/pthread.h (not in posix/pthread.h). So, adding this function to SBCL runtime is the matter of including one more header.
Compiled fine using CLISP. Can clean out older SBCL recipes.
~/haikuports/dev-lisp/sbcl> ls -al /boot/home/haikuports/packages/sbcl-2.5.0-1-x86_64.hpkg
-rw-r--r-- 1 user root 12633547 Dec 30 05:26 /boot/home/haikuports/packages/sbcl-2.5.0-1-x86_64.hpkg
Needed to re-enable unit testing in recipe:
TEST()
{
cd tests
run-tests.sh
}
NOTE: bug during unit testing of arith-slow.pure.lisp
@cocobean, I would keep the patchset for recipe as small as possible and always try to send the patches to upstream. The patches included with recipe:
Enables sb-bsd-sockets module,
Fixes asdf module.
I already sent them to SBCL and wait for the feedback. This new patch (enable pthread_getattr_np function) probably makes the difference, but I do not know what it fixes or enables. If you approve it, I will send it as well upstream.
In my testing, tests from the following files fail (did not research if all the tests from each file fail or not):
arith-slow.pure.lisp,
info.pure.lisp,
profile.pure.lisp,
symbol.pure.lisp.
The errors are similar to what you pasted above. Additionally, the test :sproof-consing-test from sb-prof.impure.lisp freezes whole OS, after which system needs restarting. Several times the tests crash with popup asking to choose what to do (and I choose Terminare). At the end the report says several dozens of tests are not passed.
I can modify the recipe to re-enable TEST() function, but other than that I would keep it as is for 2.5.0 release. @Begasus, do you think I should modify the recipe?
Nah, PR should be fine once the buildmasters are online, you “can” enable the TEST() case, doesn’t effect the build process as they don’t run the tests (as @jmairboeck already mentioned).
So it’s up to you, you can do this now or at a later stage.
OK, thank you @Begasus. I would leave the recipe 2.5.0 as is. For 2.5.1 (end of January) I can uncomment the TEST() function.
During January, my goal is to upstream all remaining existing patches. Additionally, it is necessary to analyze the failing tests. Maybe some interesting patterns can be found and some more fixes can be prepared.