[0.14.1] Crash when consuming user-created event data

This subforum contains all the issues which we already resolved.
mknejp
Fast Inserter
Fast Inserter
Posts: 154
Joined: Wed Apr 27, 2016 8:29 pm
Contact:

[0.14.1] Crash when consuming user-created event data

Post by mknejp »

This crash happens when one mod is trying to iterate over a table of entities provided as data by another mod via game.raise_event. I have a save game and mod environment that reliable make this crash happen. Simply load the game, hop into the car and start driving. It should crash almost immediately.

The crash happens in the function on_charging_stopped at electric-vehicles_0.0.1/src/main.lua:45. Trying to iterate this event data causes the crash. The function above, on_charging_started, has the same problem but the save is not in a place where it gets called. The code that fires this event is in electric-vehicles-lib_0.0.1/src/main.lua:440

savegame: https://www.dropbox.com/s/53s7bqh5hfand ... e.zip?dl=1
mods: https://www.dropbox.com/s/1hi7m9ermh06m ... s.zip?dl=1
log:

Code: Select all

   0.003 2016-08-29 00:33:31; Factorio 0.14.1 (build 24302, win64, steam)
   0.003 Operating system: Windows 8.1 
   0.003 Program arguments: "Steam\steamapps\common\Factorio\bin\x64\Factorio.exe" 
   0.003 Read data path: Steam/steamapps/common/Factorio/data
   0.003 Write data path: AppData/Roaming/Factorio
   0.003 Binaries path: Steam/steamapps/common/Factorio/bin
   0.026 Graphics options: [FullScreen: false] [VSync: false] [UIScale: 100%] [MultiSampling: OFF] [Graphics quality: normal] [Video memory usage: high] [Light scale: 100%] [Screen: 255] [DXT: false]
   0.028 Available display adapters: 1
   0.028  [0]: \\.\DISPLAY1 - NVIDIA GeForce GTX 980 {0x05, [0,0], 1680x1050, 32bit, 59Hz}
   0.028 Create display on adapter 0. Size 1280x720 at position [190, 147].
   0.098 Initialised Direct3D:[0] NVIDIA GeForce GTX 980; driver: nvd3dumx.dll 10.18.13.6839
   0.099     Video memory size (dedicated video/dedicated system/shared system/available): 3960/0/12283/4092 MB
   0.135 Device reset internal.
   0.138 Desktop composition is active.
   0.269 Loading mod core 0.0.0 (data.lua)
   0.276 Loading mod base 0.14.1 (data.lua)
   0.477 Loading mod creative-mode 0.1.4 (data.lua)
   0.608 Loading mod electric-vehicles-lib 0.0.1 (data.lua)
   0.742 Loading mod electric-vehicles 0.0.1 (data.lua)
   0.864 Loading mod creative-mode 0.1.4 (data-final-fixes.lua)
   1.018 Loading mod tree_collision 0.4.0 (data-final-fixes.lua)
   1.162 Checksum for core: 303426634
   1.162 Checksum for mod base: 3069294402
   1.162 Checksum for mod creative-mode: 1326072643
   1.162 Checksum for mod electric-vehicles-lib: 2647612978
   1.162 Checksum for mod tree_collision: 3231141521
   1.162 Checksum for mod electric-vehicles: 829037777
   1.822 Info PlayerData.cpp:45: Local player-data.json available, timestamp 1472423580
   1.822 Info PlayerData.cpp:52: Cloud player-data.json unavailable
   2.072 Initial atlas bitmap size is 16384
   2.075 Created atlas bitmap 16384x5659
   2.739 Created atlas bitmap 4096x1040
   2.767 Created atlas bitmap 4096x3648
  18.947 Sprites loaded
  18.947 Convert atlas 4096x1040 to: trilinear-filtering 
  18.990 Convert atlas 4096x3648 to: mipmap 
  19.710 Loading sounds...
  22.914 Custom inputs active: 0
  22.984 Factorio initialised
  22.986 Device reset internal.
  30.305 Loading map AppData\Roaming\Factorio\saves\crash.zip
  30.459 Info Scenario.cpp:148: Map version 0.14.1-1
  30.642 Checksum for script AppData/Roaming/Factorio/temp/currently-playing/control.lua: 900459546
  30.741 Checksum for script __creative-mode__/control.lua: 2880616640
  30.744 Checksum for script __electric-vehicles-lib__/control.lua: 1119857088
  30.746 Checksum for script __electric-vehicles__/control.lua: 2512723529
  33.188 Error CrashHandler.cpp:135: Exception Code: c0000005, Address: 00007FF74F5A733E
ModuleBase: 00007FF74F100000, ImageSize: 01144000, RelativeAddress: 004a733e
  33.188 Error CrashHandler.cpp:145: Exception Context:
rax=0000000000000000, rbx=0000000000000035, rcx=000000d52d6ede30,
rdx=000000d52fdeec00, rsi=0000000000000035, rdi=000000d52fdeec00,
rip=00007ff74f5a733e, rsp=000000d52fdeeb30, rbp=000000d52fdeec09,
 r8=0000000000000000,  r9=000000d52d6ede30, r10=000000d572277d88,
r11=000000d52ac532d0, r12=0000000000000000, r13=000000d5205d82c0,
r14=000000d5714413f0, r15=0000000000000035
Factorio crashed. Generating symbolized stacktrace, please wait ...
c:\cygwin64\tmp\factorio-hi3c8r\libraries\stackwalker\stackwalker.cpp (906): StackWalker::ShowCallstack
c:\cygwin64\tmp\factorio-hi3c8r\src\util\logger.cpp (332): Logger::writeStacktrace
c:\cygwin64\tmp\factorio-hi3c8r\src\util\logger.cpp (386): Logger::logStacktrace
c:\cygwin64\tmp\factorio-hi3c8r\src\util\crashhandler.cpp (105): CrashHandler::writeStackTrace
c:\cygwin64\tmp\factorio-hi3c8r\src\util\crashhandler.cpp (155): CrashHandler::SehHandler
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE80761F42)
00007FFE80761F42 (KERNELBASE): (filename not available): UnhandledExceptionFilter
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE8328F133)
00007FFE8328F133 (ntdll): (filename not available): memset
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE83271D86)
00007FFE83271D86 (ntdll): (filename not available): _C_specific_handler
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE832833FD)
00007FFE832833FD (ntdll): (filename not available): _chkstk
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE83244847)
00007FFE83244847 (ntdll): (filename not available): RtlRaiseException
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE8328258A)
00007FFE8328258A (ntdll): (filename not available): KiUserExceptionDispatcher
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luaeventdispatcher.cpp (248): LuaEventDispatcher::eventToEventName
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luagamescript.cpp (617): LuaGameScript::runEventHandler
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luaeventdispatcher.cpp (230): LuaEventDispatcher::raiseEvent
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luagamescript.cpp (802): LuaGameScript::luaRaiseEvent
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luabinder.hpp (299): LuaBinder<LuaGameScript>::callWrapper
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\ldo.c (320): luaD_precall
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\lvm.c (735): luaV_execute
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\ldo.c (394): luaD_call
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\ldo.c (131): luaD_rawrunprotected
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\ldo.c (590): luaD_pcall
c:\cygwin64\tmp\factorio-hi3c8r\libraries\lua\lapi.c (946): lua_pcallk
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luagamescript.cpp (2403): LuaGameScript::signallingPCall
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luagamescript.cpp (614): LuaGameScript::runEventHandler
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luaeventdispatcher.cpp (282): LuaEventDispatcher::run<GameAction>
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luaeventdispatcher.cpp (82): LuaEventDispatcher::dispatch
c:\cygwin64\tmp\factorio-hi3c8r\src\script\luacontext.cpp (136): LuaContext::update
c:\cygwin64\tmp\factorio-hi3c8r\src\scenario\scenario.cpp (833): Scenario::update
c:\cygwin64\tmp\factorio-hi3c8r\src\mainloop.cpp (711): MainLoop::gameUpdateStep
c:\cygwin64\tmp\factorio-hi3c8r\src\mainloop.cpp (581): MainLoop::gameUpdateLoop
c:\cygwin64\tmp\factorio-hi3c8r\src\util\workerthread.cpp (33): WorkerThread::loop
c:\program files (x86)\microsoft visual studio 14.0\vc\include\thr\xthread (247): std::_LaunchPad<std::unique_ptr<std::tuple<void (__cdecl WorkerThread::*)(void) __ptr64,WorkerThread * __ptr64>,std::default_delete<std::tuple<void (__cdecl WorkerThread::*)(void) __ptr64,WorkerThread * __ptr64> > > >::_Run
c:\program files (x86)\microsoft visual studio 14.0\vc\include\thr\xthread (210): std::_Pad::_Call_func
d:\th\minkernel\crts\ucrt\src\appcrt\startup\thread.cpp (115): thread_start<unsigned int (__cdecl*)(void * __ptr64)>
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE80ED13D2)
00007FFE80ED13D2 (KERNEL32): (filename not available): BaseThreadInitThunk
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 00007FFE832054E4)
00007FFE832054E4 (ntdll): (filename not available): RtlUserThreadStart
  34.761 Error CrashHandler.cpp:106: Map tick at moment of crash: 1504
  34.761 Error Util.cpp:77: Unexpected error occurred. If you're running the latest version of the game you can help us solve the problem by posting the contents of the log file on the Factorio forums.
Please also include the save file(s), any mods you may be using, and any steps you know of to reproduce the crash.

Rseding91
Factorio Staff
Factorio Staff
Posts: 15244
Joined: Wed Jun 11, 2014 5:23 am
Contact:

Re: [0.14.1] Crash when consuming user-created event data

Post by Rseding91 »

Fixed for the next version of 0.13 and 0.14.

It's crashing trying to throw a script error - now it won't crash but the script error is still there for you/someone to fix :)
If you want to get ahold of me I'm almost always on Discord.
mknejp
Fast Inserter
Fast Inserter
Posts: 154
Joined: Wed Apr 27, 2016 8:29 pm
Contact:

Re: [0.14.1] Crash when consuming user-created event data

Post by mknejp »

Can you give me a head start on the script error? I'm asking because it was also crashing when I made the loops empty while trying to find the cause for the crash so I'm a bit confused.
Post Reply

Return to “Resolved Problems and Bugs”