I have tried the master simutrans-exp branch and experienced a hard lock at the beginning of each month. The CPU is nailed at 98%-101% (not sure why top is reporting 101%). The ticker tape status display keeps on moving. I did see another earlier post regarding this. It was recommended to try the devel branch so I did.
I switched over to the devel branch
$ git checkout remotes/origin/devel
warning: refname 'remotes/origin/devel' is ambiguous.
Switched to branch 'remotes/origin/devel
$ git branch -a
master
* remotes/origin/devel
remotes/origin/8.x
remotes/origin/9.x
remotes/origin/HEAD -> origin/master
remotes/origin/devel
remotes/origin/devel-2
remotes/origin/master
$ git checkout
Not sure about the warning.
After the checkout, I copy config.template to config.default.
Edit the values to:
BACKEND = sdl
COLOUR_DEPTH = 16
OSTYPE = linux
DEBUG = 3
OPTIMISE = 1
SDL_CONFIG = sdl-config
FLAGS = -DUSE_C -DNDEBUG'
The compile completes with just warnings.
Although when I ran from a terminal, simutrans-exp crashes. I have run valgrind on it and here is the output:
valgrind --leak-check=full ./sim
==17086== Memcheck, a memory error detector
==17086== Copyright (C) 2002-2009, and GNU GPL'd, by Julian Seward et al.
==17086== Using Valgrind-3.5.0 and LibVEX; rerun with -h for copyright info
==17086== Command: ./sim
==17086==
Reading low level config data ...
FATAL ERROR: loadsave_t::rdwr_str()
expected "<i32>", got "<boo>"
FATAL ERROR: loadsave_t::rdwr_str()
expected "<i32>", got "<boo>"
==17086==
==17086== HEAP SUMMARY:
==17086== in use at exit: 99,656 bytes in 26 blocks
==17086== total heap usage: 29 allocs, 3 frees, 101,360 bytes allocated
==17086==
==17086== 56 bytes in 1 blocks are possibly lost in loss record 4 of 26
==17086== at 0x4C26AA7: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==17086== by 0x57A6898: std::string::_Rep::_S_create(unsigned long, unsigned long, std::allocator<char> const&) (in /usr/lib/libstdc++.so.6.0.14)
==17086== by 0x57A6ABA: std::string::_M_mutate(unsigned long, unsigned long, unsigned long) (in /usr/lib/libstdc++.so.6.0.14)
==17086== by 0x57A6C8B: std::string::_M_replace_safe(unsigned long, unsigned long, char const*, unsigned long) (in /usr/lib/libstdc++.so.6.0.14)
==17086== by 0x462A24: loadsave_t::rd_open(char const*) (loadsave.cc:157)
==17086== by 0x5A7B88: simu_main(int, char**) (simmain.cc:492)
==17086== by 0x629E10: main (simsys_s.cc:731)
==17086==
==17086== 200 bytes in 1 blocks are possibly lost in loss record 5 of 26
==17086== at 0x4C26509: operator new[](unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==17086== by 0x475B1B: vector_tpl<weighted_vector_tpl<unsigned int> >::vector_tpl(unsigned int) (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x475647: __static_initialization_and_destruction_0(int, int) (baum.cc:72)
==17086== by 0x475694: global constructors keyed to _ZN6baum_t16distribute_treesEP7karte_ti (baum.cc:576)
==17086== by 0x62A3F5: ??? (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x403A3A: ??? (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0xFF: ???
==17086== by 0x62A344: __libc_csu_init (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x5EC4BDF: (below main) (in /lib/libc-2.12.1.so)
==17086==
==17086== 264 bytes in 1 blocks are possibly lost in loss record 9 of 26
==17086== at 0x4C26509: operator new[](unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==17086== by 0x4FACE4: vector_tpl<legend_entry>::vector_tpl(unsigned int) (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x4FABCB: __static_initialization_and_destruction_0(int, int) (map_frame.cc:52)
==17086== by 0x4FABF7: global constructors keyed to _ZN11map_frame_t4sizeE (map_frame.cc:556)
==17086== by 0x62A3F5: ??? (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x403A3A: ??? (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0xFF: ???
==17086== by 0x62A344: __libc_csu_init (in /home/pub/build/custompkgs/simutrans-exp-git/src/simutrans/sim)
==17086== by 0x5EC4BDF: (below main) (in /lib/libc-2.12.1.so)
==17086==
==17086== LEAK SUMMARY:
==17086== definitely lost: 0 bytes in 0 blocks
==17086== indirectly lost: 0 bytes in 0 blocks
==17086== possibly lost: 520 bytes in 3 blocks
==17086== still reachable: 99,136 bytes in 23 blocks
==17086== suppressed: 0 bytes in 0 blocks
==17086== Reachable blocks (those to which a pointer was found) are not shown.
==17086== To see them, rerun with: --leak-check=full --show-reachable=yes
==17086==
==17086== For counts of detected and suppressed errors, rerun with: -v
==17086== ERROR SUMMARY: 3 errors from 3 contexts (suppressed: 6 from 6)
Aborted
I thinking that it is a 64 bit issue since i32 does not appear to be functioning correctly.
I am running ArchLinux x86_64.
The compiler is gcc 4.5.1 without multilib support,
bzip2 1.0.6
libpng 1.4.4
sdl 1.2.14
sdl_mixer 1.2.11
zlib 1.2.5
Hopefully this will help pinpoint the issue, since I really would like to play experimental.
Thanks