github.com/moarvm/moarvm | IRC logs at colabti.org/irclogger/irclogger_logs/moarvm
Set by AlexDaniel on 12 June 2018.
MasterDuke timotimo: fyi blog.mozilla.org/nnethercote/2019/...tter-dhat/ 01:35
brrt \o 07:54
patrickb o/
jnthn o/ 09:14
timotimo o/ 09:24
afl found out that P6opaque just writes to whatever reprid slot is in the serialized blob at that position, no matter how high (but truncated to a 16 bit unsigned integer) 09:59
in its deserialize_repr_data function
huh. it doesn't write the reprid/slot if the reprid is 0, which would be MVMString 10:01
that can't be right?
Geth MoarVM: 275098a2db | (Timo Paulssen)++ | src/6model/reprs/P6opaque.c
fuzzing: don't accept out-of-range repr ids

also: accept 0 as repr id (it's MVMString)
10:15
timotimo ==7491== Warning: set address range perms: large range [0x7a6d040, 0x17b574a8) (undefined) 10:16
what the? :D
timotimo i wonder if moar should actually immediately panic when it encounters a wrong value there 10:22
lizmat seems like a good thing to do to me 10:23
timotimo another piece of that function throws an exception when serialization goes wrong
which ... is kind of odd, but okay
also, the code should probably check against out-of-range slots, too
jnthn: is spesh robust against "log_parameter" just not doing anything in some instances? because afl found a way to smuggle a low-level null in there and it makes log_parameter's first line, which tries to get the container spec via STABLE(obj), segfault 10:47
jnthn timotimo: The problem is it got the low-level null in there in the first place, I'd say 10:48
We shouldn't solve problems by sprinking null checks everywhere, but rather figure out how we manage to end up with real NULLs in object registers 10:49
timotimo aye 10:53
i'll have a closerl ook
Geth MoarVM: 0e94d75a7b | (Ben Davies)++ | build/setup.pm
Temporarily use -fno-ret-protector when building on OpenBSD

  See #1091
11:11
MoarVM: e73e82fa36 | (Jonathan Worthington)++ (committed using GitHub Web editor) | build/setup.pm
Merge pull request #1092 from Kaiepi/retguard

Temporarily use -fno-ret-protector when building on OpenBSD
MoarVM: 09e1575355 | (Ben Davies)++ (committed using GitHub Web editor) | src/core/alloc.h
Remove unnecessary (void *) cast in MVM_free_zero
11:12
MoarVM: d111dd9014 | (Jonathan Worthington)++ (committed using GitHub Web editor) | src/core/alloc.h
Merge pull request #1088 from Kaiepi/patch-1

Remove unnecessary (void *) cast in MVM_free_null
MoarVM/master: 6 commits pushed by (Vadim Belman)++, (Jonathan Worthington)++ 11:13
patrickb jnthn++ # Great you're working on getting the PR backlog smaller! 11:14
Geth MoarVM: cc06ad280e | (Patrick Böker)++ | Configure.pl
Never build a relocatable moar on OpenBSD

  See github.com/rakudo/rakudo/issues/2818
OpenBSDs implementation of $ORIGIN in rpath is unreliable. Also it misses a mechanism to determine the executable path in general. So even at runtime one has a hard time implementing something like this in a robust manner.
11:16
MoarVM: 12e7590cf9 | (Jonathan Worthington)++ (committed using GitHub Web editor) | Configure.pl
Merge pull request #1089 from patzim/openbsd-no-relocatable

Never build a relocatable moar on OpenBSD
timotimo i don't really get it ... 11:43
the frame just sets up a callsite with one positional arg and a few nameds, passes a single object argument, and invokes what the frame got called with (after a decont)
the frame is <main>, the object it passes is what it gets from MVM_clargs 11:44
travis-ci MoarVM build passed. Jonathan Worthington 'Merge pull request #1089 from patzim/openbsd-no-relocatable 11:45
travis-ci.org/MoarVM/MoarVM/builds/521669706 github.com/MoarVM/MoarVM/compare/0...e7590cf9c1
timotimo perhaps i'm looking at the wrong frame here? 11:48
timotimo oh, wait, the callsite has a flag_count of 6, arg_count of 11, and num_pos of 1, but there's only a single argument being passed 11:54
so the reason why we get this problem is that the callsite used in the bytecode has a different amount of arguments than the bytecode 11:56
so the validator needs to be a bit more agressive when it comes to argument and invoke sequences 12:01
timotimo so it turns out the necessary code to make sure all flags actually have values passed is already in the validator, it just doesn't get called in the necessary place 12:58
spec tests don't seem unhappy yet (though i haven't run them all yet) 13:03
timotimo i should perhaps have recompiled moar with C optimization before running a spec test, i now realize 13:19
timotimo that's a full pass! 13:20
Geth MoarVM: 654417932b | (Timo Paulssen)++ | src/core/validation.c
fuzzing: activate 2nd argument count check for invocations

until now the bytecode validator only made sure the number of positionals in the callsite matched the number of arg commands that corresponded to positionals, but there could be nameds that didn't have a corresponding arg command that would then leave a low-level null in object registers, which spesh would stumble over
13:27
MoarVM: 8fef199947 | (Timo Paulssen)++ | src/6model/reprs/P6opaque.c
fuzzing: reject out-of-bounds unbox slot numbers
timotimo oh my, the cur_arg variable in the validator's "validate the argument passing ops" just counts from 0 to n and makes an index comparison there 13:37
so it doesn't catch when an argument op has an out-of-bounds arg index
japhb timotimo: BTW, huge fan of this fuzzing work. Thank you! 15:05
timotimo japhb: sadly the effects will barely be felt IRL :P 15:15
japhb timotimo: IRL I work for a company that is literally constantly under attack from major governments. Fuzzing seems incredibly useful to me. Also, as jnthn points out, some of the situations the fuzzer is pointing out aren't just cases of a missing null check (where a null would be rare but reasonable), but indications of something more serious wrong in that a null shouldn't even be possible at that point. 15:17
So it's catching real implementation issues, not just forgetfulness. 15:18
timotimo right, though the current fuzzing work mostly requires you to actually manipulate bytecode or the serialized blob :)
some things like nqp::elems(nqp::array) null-pointering can be reached
but not something like "the argument passing ops aren't proper" 15:19
japhb Also the company I work for deals with enough data for bit errors to be an effectively constant problem. We do a lot of ECC. ;-)
ugexe we are missing the most important part of fuzzing: the $some-amount of buzz it generates when someone eventually posts it on hackernews 15:22
timotimo hah 15:26
we don't have something for "the bytecode was correct when the validator saw it, but then it got corrupted in memory by a bit-flip" 15:27
ugexe: would be very nice to at some point fuzz actual perl6 code, but our run time speed isn't there yet 15:28
and of course the first run through the test corpus i'm using won't be terribly interesting from the standpoint of tickling deep bugs 15:30
since it's currently only doing one derivation step from what i put in (which is the stage2 of nqp) 15:31
it should also do some "mixing" near the end of the first run; cut portions out, move big chunks around, cross-over with other versions perhaps?
but since it's usually doing about 75 executions per second and i'm only utilizing a single of hack's 4 cores ... 15:32
ugexe is your local environment not sufficient? 15:33
timotimo it tends to be ram-starved because i use a web browser 15:34
tadzik ouch :D 15:35
timotimo 16 gig just ain't cutting it these days
tadzik huh
8 is usually sufficient for me
but I'm a person who closes tabs
timotimo i close tabs also, but i still have too many of 'em 15:37
tadzik :(
ugexe browse on hack via VNC and develop locally 15:38
japhb I sleep tabs, on machines where I have the proper extensions installed. That way I can get them back without too much trouble, thus keeping me from tab hoarding *too* strongly.
timotimo is gurgel chrome capable of that? 15:39
japhb timotimo: I use Tabs Outliner (free version) for Chrome. Some other people on my team use an extension that auto-sleeps any tab you haven't looked at in a while. Advantage of Tabs Outliner is that the tabs/windows you sleep actually disappear (becoming grayed out in the outline), it tracks what tabs launch other tabs, you can drag and drop tab hierarchies around easily, and you can sleep large swaths of 15:42
the tab outline all at once.
Advantage of their extension: You don't have to think about it at all, it's like having automatic memory and CPU reduction for Chrome. 15:43
Which, let's face it, is not terribly light on either.
timotimo ah, i also have tabs outliner
i barely open it
it's got about a hundred "crashed windows" that i never got around to cleaning up 15:44
japhb Heh
Would be nice if Chrome didn't produce quite so many of those ....
timotimo i don't recall a time it crashed on me because of chrome 15:45
usually it's one thread exhausting ram or something, then the core dump exhausts my hard drive, then chrome hangs and gets killed ... or dies? dunno.
ugexe hmmmm, what the hell sites are you vising that do all that... 15:47
timotimo oh, the sites don't do that 15:48
rakudo does
when i let it write extraordinarily big profiles or heap snapshots into /tmp, which is in my ram, for example
dogbert17 japhb: wrt R#2848 running your example with MVM_SPESH_INLINE_DISABLE=1 seems to resolve the problem 16:00
synopsebot R#2848 [open]: github.com/rakudo/rakudo/issues/2848 Writing to many synchronously run child processes grinds to a halt
japhb dogbert17: Oooh, that is very interesting. 16:15
dogbert17: Yup, confirmed even with 4 threads max. In fact, running with RAKUDO_SCHEDULER_DEBUG=1 RAKUDO_MAX_THREADS=4 MVM_SPESH_INLINE_DISABLE=1 shows no new threads at all. 16:18
brrt \o 20:09
samcv jnthn, how do you feel about having a thing to check for malloc_trim in configure.pm? 22:43
or whichever file it was :). since there seems to be no better way to detect this, but it would be nice to be able to ensure perl 6 lowers its memory usage. or at least what shows up 22:44
jnthn samcv: Yeah, a probe for its availability is fine. I think the only outstanding questions are how often to call it, and what the value to it should be. I think it's pretty much agreed we want it. 22:57
Also, maybe the best way to determine those two will be to get it in and prof real programs
samcv yeah 22:58
jnthn, sounds good. will look into that 22:59
jnthn samcv++
samcv maybe we want to make sure not to call it more than X number of ms or something 23:00
jnthn Putting it after GC is probably reasonable, though question is if it's every run, every N runs, or every full (non-nursery) collection 23:01
japhb jnthn: While every full collection seems like a good default, I worry about further extending the difference in pause time between nursery and full collections. Animation code I've written that shows frame-by-frame delay shows a clear signal of pauses every ~N frames long enough to be perceived as visible stutter; my best guess (until we have telemetry of some sort for when GC pauses happen and what type) 23:13
is that these are the full GC cycles. 23:14
Oddly, for animations it's often OK to have lower but steadier frame rate.
(As a side note, a pause of just 16-17 milliseconds represents a full dropped frame at 60 fps, so it doesn't take a very long pause to make a very big stutter.) 23:16
jnthn japhb: Hmm, does such code normally have a lot of objects that would live long enough to get promoted? 23:18
Perhaps, given Perl 6 being allocation heavy, the answer is "yes, until EA is doing a better job" :) 23:19
I ask because full collects are not just "every N nursery collects", but based on the rate of object promotion
A program that never promotes anything will potentially never do a full collect
That's also an interesting point were we to pick doing it every gen2: what of programs that manage to fragment unmanaged memory while never causing enough gen2 promotion to trigger the malloc_trim? 23:21
japhb jnthn: Yeah, that latter bit is true. :-) But actually, I wonder if there isn't some amount of "There's enough in Gen 2 after a while that full collections are just slow even if the fraction of new objects is low." (I get your point about a certain number of object promotions being necessary to trigger full GC, and I'm not sure what exactly is getting promoted each time.)
(latter bit == promotions common until EA does better)
Oh yeah, fragmented unmanaged memory is an interesting question. 23:22
jnthn The EA work is looking quite promising, it's just tricky :)
japhb I BET!
jnthn: Are you holding back merging EA until it is "more correct", "more effective", or "after the release cycle"? 23:24
jnthn japhb: I'm working on it in phases, merging each phase "when it's ready". The initial one was "do some EA in very simple cases"; that's already in master. 23:29
japhb jnthn: Yeah, that one I'd seen. I guess I meant the branch you've been working on a while. 23:30
jnthn The current phase is: analyzing transitive references, P6bigint handling, and making it handle partial escapes, which together should be effective in a lot more cases.
Transitive references: the analysis is correct, but deopt needs adaptation. 23:31
P6bigint handling: just got some first cases of that working. Will probably handle a few more, though doing them all isn't a pre-req for merge. BUT it does need further work to make sure it won't ever leak the unmanaged mp_int buffers. That's quite important to get right. :)
japhb oh yeah, definitely. 23:32
jnthn Partial escapes: actually the algorithm we're using was based on one found in a paper on partial escape analysis, so a lot is set up for this already. It'll also make things vastly more useful.
japhb nodnod 23:33
jnthn Example of the latter: array indexing. We inline the fast-path common case. But the Int index can escape to the slow path (out of bounds erorr reporting, etc.)
Partial escape handling lets us defer the allocation to the point we know it's escapging 23:34
*escaping
But also, if we have a bunch of integer calculations and store the final result, we also want to materialize the final result at that point too; at the moment we can't do that, so end up with the whole chain of operations being considered escaping. 23:35
Once I get those 3 in decent shape, I'll merge. I hope to make it in time for the 2019.5 release, but won't be rushing.
The phase after that will be about handling EA in code involving loops and OSR. 23:36
Once that is done, we have a fairly complete overall structure, so it'll be a case of smaller situation-specific additions. 23:37
For example, extending it to cover things other than P6opaque, such as hashes indexed entirely with constant keys 23:38
The hash case is very common in object construction; in principle, the slurpy hash and the indexing of it could in some cases entirely go away. 23:39
japhb Oh nice, that would probably have quite a big effect. 23:53
jnthn Hope so. :) 23:58
sleep o/