github.com/moarvm/moarvm | IRC logs at colabti.org/irclogger/irclogger_logs/moarvm
Set by AlexDaniel on 12 June 2018.
MasterDuke huh. an extra 390m instructions compiling rakudo when moarvm was built with -flto 01:52
according to callgrind
nwc10 SEGV in libuv during nqp's make install - I can't reproduce this - paste.scsys.co.uk/584367 07:38
er, wait, that was rakduo make install 07:50
I'm very confused. but it was really a SEGV and I really can't reproduce it 07:51
I fear that the problem is that the coffee machine at work isn't working well
brrt \o 08:32
timotimo o/ 08:33
brrt: how do you suggest i put this into the jit: pass an object body + an offset as an argument to a C function?
brrt you want two arguments? 08:35
timotimo pretty much
brrt you want the body + offset as a pointer, or the offset as an integer 08:36
timotimo one way i've considered was to have a "just take TMP5's contents" and another node that calculates a p6o's object body offset 08:37
(including the real_data pointer)
the body + offset as a pointer
gimme a sec
github.com/MoarVM/MoarVM/blob/mast...que.c#L490 - basically this 08:38
the last argument is what normally has the OBJECT_BODY, but in this particular function it already got the OBJECT_BODY as the void *data pointer
(but also it had to do the p6opaque_real_data thing itself)
wait, i think what i'm actually after is github.com/MoarVM/MoarVM/blob/mast...ue.c#L1357 08:40
hum, is that different to just using getattr_o and then atkey_o?
timotimo now which one did i actually want :| 08:47
if it's actually just getattr (well, p6oget_o really) plus the original thing, that'd go into spesh instead 08:48
so the only difficult part is with the unboxing ops that have to go pick out a pointer from inside, but only use it for the void *data argument, so that has to be in the jit
anyway, please excuse me, i kind of woke up quite recently 08:49
brrt oh, you want a dynamic offset 09:16
I se
*see
I kind of don't want the old style function invocation to be overloaded further
but
meh
timotimo it's not actually dynamic, it's known at jit time 09:18
would the "this argument shall just take TMP5's value" thing be okay?
brrt timotimo: that seems very, very brittle 11:29
timotimo oh 11:31
should i use stack-relative values instead?
brrt maybe, but, if it's a constant at JIT time... can't you just laod that constant? 11:59
oh, I think I get the problem now 12:00
you want to inline that calculation in the JIT
timotimo yes
because there's a double offset, more or less
first i have to get the real_data pointer and check if it's to be followed 12:01
then i have to add the jit-time-constant offset onto that
brrt just for my curiosity... why do we *need* the real-data pointer? 12:06
(I kind of think jnthn knwos the answer to that) 12:07
timotimo it's for mixins 12:08
adding attributes is hard if something else has its header right after your data pointer :)
er, your body i mean 12:09
so when an object grows due to mixins, we copy the data away and hide it behind one layer of indirection
brrt oh, right, got it 12:19
hmm, and I guess we can't patch up all possible references 12:20
timotimo we should be able to do better when doing a nursery copy or nursery to gen2 12:24
i don't think we've done this yet
brrt Do you mean, maybe act as if the object is concurrently moved to a new location by the GC? 12:50
that's possible... but expensive, too :-D 12:51
timotimo oh, no, i mean whenever the object moves naturally we grow it at the target site and put the "real data" back in place 12:56
brrt well, we should at least do that, I think.. 13:02
timotimo there's also a possibility for spesh here; if we can tell with relative certainty that an object is going to be mixed in very soon after creation, we can already allocate it with the "future" size and have a mixin op that doesn't do the "copy away and use real_data pointer" thing 13:13
also, i think we're currently paying one pointer of memory in every p6opaque object ever?
not sure if we can perhaps put a flag in the header; gotta make sure it won't interfere with inlined objects; P6opaque don't get embedded inside p6opaque, right? and p6opaque doesn't get embedded in anything else? 13:14
brrt I don't think p6opaque's get embedded 13:21
but..... I'd argue that having a forwarding pointer always in p6opaque, is in hindsight premature optimization maybe
timotimo oh, you mean always having the pointer there makes things faster because we don't have to go look somewhere else for a flag? 13:22
brrt no... I mean that we try to fit all objects into a fixed format by default, and then have to fit an overflow pointer for when that won't work 13:32
contrast this with v8 hidden classes; all objects start of as extensible maps, and when v8 speculates that the object structure is really fixed, that's when a fixed format is applied 13:33
in hindsight, I mean, augmenting a class or object is an obvious deoptimization opportunity
hence, the optimized code should not have to consider that case 13:34
I know that when this was designed that way, a runtime optimizer wasn't part of moar yet
timotimo but objects coming in can already have been augmented 13:35
brrt the point is that if you default to an open map structure (as in python, perl5, etc) then that doesn't cost you 13:45
or at least, not extra
currently, even our best optimized code still has to deal with this
timotimo do note that augmenting also changes the st 13:46
brrt yes
timotimo but augmenting is very rare in perl6 compared to js and python 13:48
we're more or less equivalent to python with __slots__ arrays i guess? 13:49
brrt i think python with the __slots__ array prohibits augmentation, is the thing 14:02
timotimo anyway, just because we're "still" in optimized code doesn't mean we won't encounter an object that has a valid forwarding pointer in it 14:06
though we do use variants of ops that don't look at the forwarding pointer in code that only just allocated some object 14:07
lizmat and another Perl 6 Weekly hits the Net: p6weekly.wordpress.com/2019/05/06/...s-to-riga/ 15:24
samcv kawaii, just got some. so should finish up the rest of the things for release in a bit 16:56
kawaii samcv: great, thanks! 16:58
samcv kawaii, moarvm should be released in about 30 min 18:41
brrt \o 19:00
samcv hey brrt 19:01
timotimo o/ 19:03
brrt hey samcv, timotimo 19:05
can we start publicly celebarting that TPF got $ GSoC students this year?
samcv yes! 19:06
brrt \o/
samcv 4!
timotimo great!
brrt Not so bad, hey
samcv last year was zero >_>
timotimo 2 of them are p6, right?
brrt Yes, I think samcv and I are both mentors
tadzik \o/ 19:08
awesome :)
so it's official now?
brrt I think so... official publication date was may 6th, 18:00 UTC, and that hour has passed
samcv So this, is not temporary anymore? github.com/MoarVM/MoarVM/commit/0e94d75a 19:13
or is it still "temporary" as far as mentionable in changelog
timotimo we don't have the proper fix for that yet 19:15
samcv ok. i'll leave the changelog entry as it being temporary
brrt what's the bug that it fixes?
timotimo immediate crashes on bsd
as soon as the jit returns anywhere
brrt (or, what did OpenBSD break that we need to work around) 19:16
oh, I see
lol
timotimo it's protecting against malicious code
you know, the code that the jit spits out
brrt :-D
but, I can help there... 19:17
what if, on OpenBSD, we use a setjmp/longjmp pair
samcv kawaii, is this 2019.05 or 2019.04
kawaii samcv: 2019.05 :)
samcv ook :)
brrt it'd be annoying, but it could probably be made to work 19:18
thing is, with the current method, we can update the return address anywhere in the call stack, and it'll work, and cleanup, too
setjmp/longjmp will screw with that
timotimo we can't properly implement return protection support in the jit?
i don't know how it's implemented
Woodi I read lastly, that W^X disabling helps python and others on OpenBSD 19:21
slides from here: lteo.net/blog/2019/04/27/carolinac...h-openbsd/ 19:24
OB have W^X disabled on /usr/local 19:26
Kaiepi i have W^X disabled where i have perl6 installed but the trace traps still happened 19:37
timotimo can the trace trap be caught by moar and the PC checked for a sensible location inside of jit code? 19:38
like, is it a signal like sigsegv that a handler can sensibly be written for?
samcv timotimo, want to look at the changelog and see if there's any issues 19:40
then i'll do the release
timotimo ok, link please?
samcv oh i guess it didn't print it
timotimo yeah, new geths need github hooks to be changed a bit
Kaiepi i'll test it out timotimo
samcv i pushed but there was no channel message 19:41
timotimo, github.com/MoarVM/MoarVM/blob/mast.../ChangeLog
timotimo we can get rid of the very first one, that was an earlier commit being wrong that got fixed later
i wonder if we shouldn't have some kind of convention for commits like that 19:42
many changes were inspired by fuzzing, but only one (or so?) changes actually have "fuzzing:" in front; should we put fuzzing in all of them, or none? 19:43
and i think the "max inline size per HLL" line should be shortened? there's a few very long lines and i'm not terribly fond of those, but that's a question of style/preference that we may want to just have a decision for 19:44
i think the commit about sp_getvt_o and sp_getvc_o could perhaps fit into the spesh section better 19:46
deallocatedsplit ← typo 19:48
Also call optimize_bb for unspecialized inlines seems duplicated 19:49
Lliberalize typo's an l too many (unless this is spanish? :D)
nine As a packager I say less is more. Most of my time packaging rakudo goes into summarizing changelogs so they fit into the line limit of the Open Build Service 19:50
timotimo i'd probably change the toolchain/macOS one to read "check for mixed toolchain", that's probably easier to understand without following the link
i hope that didn't come across as too negative %) 19:52
the changelog is good, and your work is very much appreciated samcv
samcv <timotimo> i think the commit about sp_getvt_o and sp_getvc_o could perhaps fit into the spesh section better 19:53
so what change do i need to take?
timotimo for that comment, or for all the comments?
samcv just that one for now
timotimo ah. i'd say just cut&paste it from Core: to Spesh: 19:54
samcv ah cool 19:55
timotimo, "being deallocated, split" so typo because it's not in separate words? 19:59
timotimo yeah
but i'd possibly change the whole line to something shorter
"count deallocated objects categorized by life time"? 20:00
samcv and "Improve check for used toolchain on macOS" to "check for mixed toolchain on MacOS" 20:05
timotimo, change which whole line? 20:06
timotimo yeah
brrt "deallocate objects by life choices"
timotimo and yes
pffft :D
samcv also what
hahaha
needs to be more specific
XD
brrt timotimo: how it works, is that when the interpreter would effect a control flow change (throwing an exception, for instance, or a nonlocal return), this is effected in the JIT by updating the return address to the correct code position 20:08
so this quite directly violates a check that tries to ensure that you don't
or, that malicious code can't 20:09
samcv brrt, ok so what do i change to what :)
you mean this + [95094ae2] Count objects being deallocated, split this statistic into "deleted while in nursery and not seen before", "deleted while in nursery, but seen in a previous GC run", and "deleted while in the gen 2". 20:10
ah oops i forgot to combine the two commits
looks like a bug in my changelog updater
gonna have to fix the behavior when i combine commits.
err. or maybe not. not sure.it looks like it but maybe that was the whole title 20:11
brrt samcv: idk, I was kidding :-)
samcv yeah looks like the later
well just tell me what to change it to so i can release :-))
timotimo i don't know what it's like now 20:12
do you have a suggestion for putting "fuzzing" on many, or just the one commit message?
samcv can put it on as many or as few as you think is fine 20:13
Kaiepi <timotimo> like, is it a signal like sigsegv that a handler can sensibly be written for?
you can catch SIGTRAP, yes
samcv i maybe removed it from some since it wasn't needed to understand the message (at least from my opinion at the time)
timotimo well, catch, sure. how do you properly react? if you think the thing was legit, just return, otherwise just kill your own process with the same signal again? 20:14
or exit(1) or whatever
Kaiepi i'm a bit uncomfortable with the idea of trying to determine whether or not what the kernel's doing is justified 20:16
samcv brrt, though seriously what do i change: + [95094ae2] Count objects being deallocated, split this statistic into "deleted while in nursery and not seen before", "deleted while in nursery, but seen in a previous GC run", and "deleted while in the gen 2".
into
then i can release :-) 20:17
timotimo count deallocated objects categorized by life time
any comment on the other things i pointed out?
brrt sleep 20:28
samcv kawaii, ok moarvm is released 20:49
kawaii samcv: amazing, thanks! :)
not sure there is time for me to bump nqp and rakudo tonight, but tomorrow could work 20:50
samcv no problem :)
thanks for doing the rakudo side
timotimo samcv: you kept "lliberalize" :D 20:53