Jump to content

Problem with Ryzen 3000er series


szz
 Share

Recommended Posts

HI everyone, I tried to install 0ad in archlinux, both from repos and compiling the game from source, and the game won't start, if I type 0ad in a terminal I get:

  Reveal hidden contents

Is there anyway to fix this?

Thanks in advance.

 

P.D: related topic ==> https://forum.manjaro.org/t/0ad-cache-cpp-54-assertion-failed-tlb-validate/78421

Edited by user1
Spoiler to reduce clutter
Link to comment
Share on other sites

HI;  there you go:

gdb 0ad/system/pyrogenesis_dbg >> run >> bt:

#0  0x00007ffff594cd42 in waitpid () from /usr/lib/libpthread.so.0
#1  0x0000555555daa347 in try_gui_display_error (
    text=0x7fff33d10000 L"Assertion failed: \"tlb.Validate()\"\r\nLocation: cache.cpp:54 (AddTLB)\r\n\r\nCall stack:\r\n\r\n(0x555555da8b91) /home/szz/0ad/0ad/binaries/system/pyrogenesis_dbg(+0x854b91) [0x555555da8b91]\n(0x555555d6ca63) /h"..., manual_break=true, allow_suppress=true, no_continue=false) at ../../../source/lib/sysdep/os/unix/unix.cpp:165
#2  0x0000555555daa558 in sys_display_error (
    text=0x7fff33d10000 L"Assertion failed: \"tlb.Validate()\"\r\nLocation: cache.cpp:54 (AddTLB)\r\n\r\nCall stack:\r\n\r\n(0x555555da8b91) /home/szz/0ad/0ad/binaries/system/pyrogenesis_dbg(+0x854b91) [0x555555da8b91]\n(0x555555d6ca63) /h"..., flags=6) at ../../../source/lib/sysdep/os/unix/unix.cpp:215
#3  0x0000555555d6ccb2 in CallDisplayError (
    text=0x7fff33d10000 L"Assertion failed: \"tlb.Validate()\"\r\nLocation: cache.cpp:54 (AddTLB)\r\n\r\nCall stack:\r\n\r\n(0x555555da8b91) /home/szz/0ad/0ad/binaries/system/pyrogenesis_dbg(+0x854b91) [0x555555da8b91]\n(0x555555d6ca63) /h"..., flags=6) at ../../../source/lib/debug.cpp:383
#4  0x0000555555d6d082 in debug_DisplayError (description=0x7fffffffb100 L"Assertion failed: \"tlb.Validate()\"", flags=6, context=0x7fffffffb740, lastFuncToSkip=0x5555571fe070 L"debug_OnAssertionFailure", 
    pathname=0x555555f83158 L"../../../source/lib/sysdep/arch/x86_x64/cache.cpp", line=54, func=0x555555f83f39 <x86_x64::AddTLB(x86_x64::Cache const&)::__func__> "AddTLB", 
    suppress=0x55555621ec28 <x86_x64::AddTLB(x86_x64::Cache const&)::suppress__>) at ../../../source/lib/debug.cpp:474
#5  0x0000555555d6d550 in debug_OnAssertionFailure (expr=0x555555f83268 L"tlb.Validate()", suppress=0x55555621ec28 <x86_x64::AddTLB(x86_x64::Cache const&)::suppress__>, 
    file=0x555555f83158 L"../../../source/lib/sysdep/arch/x86_x64/cache.cpp", line=54, func=0x555555f83f39 <x86_x64::AddTLB(x86_x64::Cache const&)::__func__> "AddTLB") at ../../../source/lib/debug.cpp:563
#6  0x0000555555d9b1a3 in x86_x64::AddTLB (tlb=...) at ../../../source/lib/sysdep/arch/x86_x64/cache.cpp:54
#7  0x0000555555d9b7f2 in x86_x64::AMD::AddTLB2Pair (reg=1442866176, pageSize=4096) at ../../../source/lib/sysdep/arch/x86_x64/cache.cpp:172
#8  0x0000555555d9b9e8 in x86_x64::AMD::DetectCacheAndTLB () at ../../../source/lib/sysdep/arch/x86_x64/cache.cpp:203
#9  0x0000555555d9c1f3 in x86_x64::DetectCacheAndTLB () at ../../../source/lib/sysdep/arch/x86_x64/cache.cpp:623
#10 0x0000555555ded703 in ModuleInit (initState=0x55555621ec80 <x86_x64::Caches(unsigned long)::initState>, init=0x555555d9c144 <x86_x64::DetectCacheAndTLB()>) at ../../../source/lib/module_init.cpp:46
#11 0x0000555555d9c5a4 in x86_x64::Caches (idxCache=2) at ../../../source/lib/sysdep/arch/x86_x64/cache.cpp:652
#12 0x0000555555d9cf85 in topology::MaxLogicalPerCache () at ../../../source/lib/sysdep/arch/x86_x64/topology.cpp:116
#13 0x0000555555d9d764 in topology::DetermineCachesProcessorMask (cachesProcessorMask=0x55555621ef68 <topology::cacheTopology+520>, numCaches=@0x55555621ed60: 0) at ../../../source/lib/sysdep/arch/x86_x64/topology.cpp:392
#14 0x0000555555d9d9ce in topology::InitCacheTopology () at ../../../source/lib/sysdep/arch/x86_x64/topology.cpp:449
#15 0x0000555555ded703 in ModuleInit (initState=0x55555621f168 <topology::cacheInitState>, init=0x555555d9d991 <topology::InitCacheTopology()>) at ../../../source/lib/module_init.cpp:46
#16 0x0000555555d9da3b in topology::NumCaches () at ../../../source/lib/sysdep/arch/x86_x64/topology.cpp:456
#17 0x00005555559e961b in RunHardwareDetection () at ../../../source/ps/GameSetup/HWDetect.cpp:306
#18 0x00005555559d94ca in InitGraphics (args=..., flags=0, installedMods=std::vector of length 0, capacity 0) at ../../../source/ps/GameSetup/GameSetup.cpp:1001
#19 0x00005555556c5f75 in RunGameOrAtlas (argc=1, argv=0x7fffffffdfb8) at ../../../source/main.cpp:631
#20 0x00005555556c67d2 in main (argc=1, argv=0x7fffffffdfb8) at ../../../source/main.cpp:680

If there is anything more I can do please make me know!

Thanks!

 

Szz.

Link to comment
Share on other sites

Hey! there you go:

cpuid -1: (I guess all the processors are identical and there are a few ...)

  Reveal hidden contents

Hope it helps, and ask for anything you may need.

Thanks!

Edited by user1
Spoiler to reduce clutter
  • Thanks 1
Link to comment
Share on other sites

Hello! I looked into this, I am a bit puzzled:

Based on the line numbers of the stack trace, the validation fails for the output of the function 0x80000006/ebx.

L2 TLB/cache information: 4K pages & L2 TLB (0x80000006/ebx):
   instruction # entries     = 0x400 (1024)
   instruction associativity = 8-way (6)
   data # entries            = 0x600 (1536)
   data associativity        = 0x5 (5)

So according to cpuid, your processor answers 0x400 6 600 5 (I added the spaces for clarity).

However the stack trace says that the value of the register is 1442866176, which is 0x56006400. The byte fields are the other way around (not per byte but per field, so it's not a little/big endianness confusion). :scratch_one-s_head:

I looked at the source code of the cpuid tool, and it looks like our code is doing the same. So I don't see why the value you are getting in our engine is bogus. In order to dissipate any doubt that I can have on the output of gdb, would you mind applying this patch (and recompiling) that just outputs the values sent by the call to cpuid. And share the output here :)

cpuid-debug.patchFetching info...

Thank you very much!

  • Like 1
Link to comment
Share on other sites

Hey! applied your patch and recompiled, Here you have your registers:

  Reveal hidden contents

 

Thanks for your attention!

Edited by user1
Spoiler to reduce clutter
  • Like 1
  • Thanks 1
Link to comment
Share on other sites

Well, the strange value is confirmed... I'll do some experiments and probably give you a small minimal program reproducing the inconsistency, but I'm not sure what I will find.

In the meantime, if you want to play, you can safely comment out the

// ENSURE(tlb.Validate());

on line 54 of cache.cpp. It is only a sanity check (something insane is indeed happening! ;)) which doesn't prevent you from playing at all. Unless the root cause of this issue causes other issues down the line, in which case you can report here.

  • Like 1
Link to comment
Share on other sites

Hey; commented out the line 54 and the for loop at line 648, now the game launch properly!! Really appreciated!

If I can do anything more count on me!

P.D: If I experiment anything weird while playing I'll post it here!

Thanks!!

 

  • Like 2
Link to comment
Share on other sites

  • 5 months later...

Hello together. When I started to run 0 A.D. on my new Ryzen PC the game crashes. However, it was possible to continue the starting procedure. Then it crashes again and again. After three crashes it entered the starting page of 0 A.D. Maybe the other two crashes occur because of the first one. The problem now is that the game, because it crashed while starting procedure,  is running in windowed mod. Is there a possibility to avoid the crashes, or a workaround to get fullscreen mod even the game is running? Could you please help me?

I also tested the current svn rP22785. Here the game crashes four times until it enters the starting page.

I had tested both version a few times. It crashes every time the same way.

The three crash logs for the alpha 23b, the four crash logs for the svn, and the system info are attached.

alpha_23b_crashlog_1.txtFetching info... alpha_23b_crashlog_2.txtFetching info... alpha_23b_crashlog_3.txtFetching info... 22785_crashlog_1.txtFetching info... 22785_crashlog_2.txtFetching info... 22785_crashlog_3.txtFetching info... 22785_crashlog_4.txtFetching info... system_info.txtFetching info...

  • Like 1
Link to comment
Share on other sites

  • 3 weeks later...

hello guys,

 

I have an error opening the new installed on a win 10 new cpu, 0 a.d.

 

 

Assertion failed: "cache.Validate()"
Location: cache.cpp:43 (x86_x64::AddCache)

Call stack:

010096AD

0100B403

01001035

010010C4


errno = 0 (No error reported here)
OS error = 203 (The system could not find the environment option that was entered.)

 

 

 

how can i fix it?
 

Edited by Azazel
Link to comment
Share on other sites

  • 3 weeks later...

Hi all !

I just upgrade my hardware with a Ryzen 5 3600, and since that, I could not launch 0ad and I get the error below

  Reveal hidden contents

It seems really similar to this :

 

However, I wasn't able to find the cache.cpp (I imagine it's only if you compile the game. I installed it from repo)

I'm on ArchLinux.

0ad version is 0.0.23.

It seemed like cpuid was helpfull so here it goes :

  Reveal hidden contents

 

On windows, with the same hardware, I also get errors but game started and worked. I can paste the errors if that help ?

If you need anything, let me know :)

Thanks very much !

Edited by user1
Spoiler to reduce clutter
Link to comment
Share on other sites

I did tried to remove cache directory without success.

I did not reinstall my OS.

@Stan`, I tried as you said, with "svn checkout -r 21946", but this time the error came from line 637

binaries/system/pyrogenesis
TIMER| InitVfs: 24.9339 ms
Writing the mainlog at /home/emeric/.config/0ad/logs/mainlog.html
TIMER| CONFIG_Init: 9.39126 ms
Sound: AlcInit success, using OpenAL Soft
TIMER| shutdown ConfigDB: 0.381 us
TIMER| resource modules: 2.24461 ms
TIMER TOTALS (9 clients)
-----------------------------------------------------
  tc_pool_alloc: 0 c (0x)
  tc_png_decode: 0 c (0x)
  tc_dds_transform: 0 c (0x)
  tc_transform: 0 c (0x)
  tc_plain_transform: 0 c (0x)
  tc_ShaderGLSLLink: 0 c (0x)
  tc_ShaderGLSLCompile: 0 c (0x)
  tc_ShaderValidation: 0 c (0x)
  xml_validation: 0 c (0x)
-----------------------------------------------------
TIMER| shutdown misc: 142.225 us
TIMER| InitVfs: 383.985 us
Writing the mainlog at /home/emeric/.config/0ad/logs/mainlog.html
TIMER| CONFIG_Init: 1.37519 ms
Sound: AlcInit success, using OpenAL Soft
cache.cpp(637): Assertion failed: "caches[L1D+idxLevel].Validate() == true"
Assertion failed: "caches[L1D+idxLevel].Validate() == true"
Location: cache.cpp:637 (DetectCacheAndTLB)

Call stack:

(0x564ac7266545) binaries/system/pyrogenesis(+0x5cc545) [0x564ac7266545]
(0x564ac721a371) binaries/system/pyrogenesis(+0x580371) [0x564ac721a371]
(0x564ac721b714) binaries/system/pyrogenesis(+0x581714) [0x564ac721b714]
(0x564ac721bdd7) binaries/system/pyrogenesis(+0x581dd7) [0x564ac721bdd7]
(0x564ac725f142) binaries/system/pyrogenesis(+0x5c5142) [0x564ac725f142]
(0x564ac72941e3) binaries/system/pyrogenesis(+0x5fa1e3) [0x564ac72941e3]
(0x564ac725eb5e) binaries/system/pyrogenesis(+0x5c4b5e) [0x564ac725eb5e]
(0x564ac7260afa) binaries/system/pyrogenesis(+0x5c6afa) [0x564ac7260afa]
(0x564ac72941e3) binaries/system/pyrogenesis(+0x5fa1e3) [0x564ac72941e3]
(0x564ac72606da) binaries/system/pyrogenesis(+0x5c66da) [0x564ac72606da]
(0x564ac6f314cc) binaries/system/pyrogenesis(+0x2974cc) [0x564ac6f314cc]
(0x564ac6f271a8) binaries/system/pyrogenesis(+0x28d1a8) [0x564ac6f271a8]
(0x564ac6d42923) binaries/system/pyrogenesis(+0xa8923) [0x564ac6d42923]
(0x564ac6d2f41a) binaries/system/pyrogenesis(+0x9541a) [0x564ac6d2f41a]
(0x7f4d363b3ee3) /usr/lib/libc.so.6(__libc_start_main+0xf3) [0x7f4d363b3ee3]
(0x564ac6d3cb7e) binaries/system/pyrogenesis(+0xa2b7e) [0x564ac6d3cb7e]

errno = 0 (Error during IO)
OS error = ?

 

Can the error came because I did not do a fresh install and some dep might have been compiled with my previous hardware ? (on Arch, some packages are compiled on AUR repos)

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

×
×
  • Create New...