github.com/moarvm/moarvm | IRC logs at colabti.org/irclogger/irclogger_logs/moarvm
Set by AlexDaniel on 12 June 2018.
nwc10 good *, #moarvm 09:45
nine nwc10, timotimo: since you seem to be here. Any idea how this patch could cost us ~20 % performance in stage parse? gist.github.com/niner/4e9b4be7f22c...2aca046faa 11:57
In short it's just moving the cur_op += 6; before a function call for some ops. This necessitates adding some local variables for holding the GET_* data. Which I assume the compiler will optimize away immediately. 11:58
timotimo i wonder if this sometimes jumps us out of the range where a lexical is defined? 12:00
nine ?
timotimo frame walker and co rely on cur_op to find stuff, right? 12:01
nine That would be a good explanation if it weren't for the fact that MVM_frame_find_lexical_by_name doesn't use the frame walker (and is marked :noinline) 12:04
If it's the C compiler not being able to optimize this as well for some reason, other ops using the same structure might be affected too 12:09
nwc10 nothing obvious from looking at the code. I assume that the thing to do next is to exploit your nice new fast machine, and brute force try changing each op in turn, to see which one (or ones) causes the 20% 12:16
and then look at the C code that changes 12:17
MasterDuke nine: same thing with a different compiler (e.g., clang vs gcc)? 12:29
nine MasterDuke: good question 12:30
jnthn nine: You've probably broken spesh logging by changing getlex_no, meaning the optimizer has a lot less data to go on about lexical types, so can't do a bunch of optimizations. 12:39
nine: It logs against the bytecode position
nine Aaah...that must be it!
jnthn getstaticlex also, though that will likely have much more impact on Raku code 12:42
Rather than setting compilation
nine Incidentally, I just managed to get the first spec test clean version without those giant wrapper frames! 12:43
jnthn ah, nice :)
nine But boy, this was a lot more involved than expected.
jnthn I'm not entirely surprised :)
MasterDuke nine: and that'll primarily help parsing (once the spesh logging is fixed)? 12:44
nine But I think that even if it will be obsoleted by RakuAST, some parts will survive. At least a lot of lessons about places where we need to access symbols that aren't fully compiled yet
The spesh log thing is not really an issue. Everything works fine without that change.
jnthn You've added hooks for us to do some kind of fallback on failed lexical lookups? 12:45
nine I added fallback-versions of the getlex_n*, bindlex_n*, getlexouter, getlexperinvtype_o and sp_getlex_n ops, so normal code will not be affected 12:46
And _fallback versions of MVM_frame_find_lexical_by_name and MVM_frame_find_lexical_by_name_outer and MVM_frame_getdynlex 12:47
jnthn OK
Those will be useful :)
nine Initially I thought I could get by without new ops at all, since the fallback code will only run when we normally would throw an exception already. But the call to the HLL resolver necessitates the ops to be marked invokish and maycausedeopt, so we'd lose some optimizations in normal code 12:48
jnthn I guess the main remaining missing piece I'll want in RakuAST will be a way to have contexts possible to refer to even before we really compile them. 12:49
Well, and to create
So I can interpret role bodies and the closure taking in the common case
MasterDuke while everybody's here, does gist.github.com/MasterDuke17/50f78...5fb0c5d387 look suspicious? or is that barking up the wrong tree? (this is on the make speshcandidate a repr branch) 12:50
nine Oh, btw. I stash the HLL resolver as an attribute of the MVMCompUnit. That makes accessing it quite cheap and its available to the running code independently of the call stack 12:52
jnthn MasterDuke: Hmmm
189 MVM_ASSIGN_REF(tc, &(spesh->common.header),
What is the full statement? 12:53
I think the problem may be that when candidates weren't GC-able, the referencing GC object was the frame spesh object as a whole, but now it should probably be the candidate 12:54
Geth MoarVM/getlex_fallback: 12 commits pushed by (Stefan Seifert)++
review: github.com/MoarVM/MoarVM/compare/d...b931cc68ca
nine jnthn: I pushed the 3 branches in case you're curious about which places need adaptions to running without the wrapper frames 12:56
jnthn nine: I'm a little surprised MVM_frame_get_lexical_resolver goes looking down the dynamic scope 13:02
(Well, that it needs to go scope hunting at all)
nine That's needed purely for looking up dynamics. I don't think it ever goes up for normal lexicals. Code started out in a somewhat desparate attempt and came in quite handy for dynamics 13:03
I'll probably split it into two versions to make that more clear 13:04
jnthn OK; I worry about false positives and weird issues to debug
"Why did it find that resolver", etc.
jnthn MasterDuke: github.com/MoarVM/MoarVM/blob/8d7a...del.c#L185 and line 189 likely want &(tc->cur_frame->spesh_cand->common.header) instead of &(spesh->common.header) 13:10
MasterDuke jnthn: stage parse hasn't immediately died... 13:47
oh! rakudo built (and with GC_DEBUG = 1) 13:48
now will run a spectest with it set back to 0 13:49
jnthn yay :) 13:53
Guess my dropping by here today was at least somewhat useful :)
MasterDuke of course this was just in preparation to enable us to undo optimizations if there are too many deopts 13:55
and a spectest just passed! jnthn++
jnthn yay 13:56
MasterDuke++ 13:57
MasterDuke likely gonna be afk for a while, but any high-level suggestions for what undoing should look like? 14:00
MasterDuke hm, if i'm reading the code correctly, we (currently) only count the number of times a deopt happened when profiling, and even then it's just a global count, not per-(de)opt 20:33
MasterDuke looks like just marking the candidate as discarded isn't enough to stop it being used (and then deopted) in the future 21:35
MasterDuke calling MVM_spesh_arg_guard_discard after doesn't help either 23:23
but i guess that isn't completely unexpected, since that could have been done before MVMSpeshCandidate was made GC-able 23:29