thanks to medium spellchecker

This commit is contained in:
Torsten 2020-03-23 19:39:02 +02:00
parent de1fd0087f
commit dfd242ab46
2 changed files with 16 additions and 18 deletions

View File

@ -2,7 +2,7 @@
I had put off proper register allocation until now, and somehow the 100 commits I had put off proper register allocation until now, and somehow the 100 commits
it took verfies that i wasn't completely wrong. I think there are quite a it took verfies that i wasn't completely wrong. I think there are quite a
few differences to the normal problem and solution, to warrant an explanation, few differences to the normal problem and solution, to warrant an explanation,
so here it goes: How RubyX does Static Single Assignent and Register Allocation so here it goes: How RubyX does Static Single Assignment and Register Allocation
in a ruby compiler. in a ruby compiler.
%h2 Simple register allocation, the old way %h2 Simple register allocation, the old way
@ -20,11 +20,11 @@
through to r15. through to r15.
%p %p
Early on i made two decisions, the current Message object would live in r0. This was Early on i made two decisions, the current Message object would live in r0. This was
one constant hardcoded throughout. The other descision was to design Slot level one constant hardcoded throughout. The other decision was to design Slot level
instructions such, that each instruction had use of all registers. To use registers instructions such, that each instruction had use of all registers. To use registers
i implemented a simple stack, but that was reset after every Slot level instruction. i implemented a simple stack, but that was reset after every Slot level instruction.
%h2 Motiviation for change %h2 Motivation for change
%p %p
There are two major problems with the simple solution outlined above. The first is There are two major problems with the simple solution outlined above. The first is
that it is sub-optimal now, the second that it is restrictive in the future. that it is sub-optimal now, the second that it is restrictive in the future.
@ -40,7 +40,7 @@
register assumptions being made, but there were implicit, ie could not be checked register assumptions being made, but there were implicit, ie could not be checked
and would only show up if broken. and would only show up if broken.
%p %p
But the real motiviation for this work came from the future, or the lack of But the real motivation for this work came from the future, or the lack of
expandability with this approach. Basically i found from benchmarking that inlining expandability with this approach. Basically i found from benchmarking that inlining
would have to happen quite soon. Even it would would have to happen quite soon. Even it would
%em only %em only
@ -51,9 +51,7 @@
was a thing. was a thing.
%h2 SSA and Register Allocation %h2 SSA and Register Allocation
.container
%p.full_width
=image_tag "register_alloc.png"
%p %p
So then we come to the way that it is coded now. The basic idea (followed by most So then we come to the way that it is coded now. The basic idea (followed by most
compilers) is to assign new names for every new usage of a register. I'll talk compilers) is to assign new names for every new usage of a register. I'll talk
@ -64,18 +62,18 @@
%h3 Static Single Assignment %h3 Static Single Assignment
%p %p
A A
=ext_link "Static Single Assignent form" , "https://en.wikipedia.org/wiki/Static_single_assignment_form" =ext_link "Static Single Assignment form" , "https://en.wikipedia.org/wiki/Static_single_assignment_form"
of the Instructions is one where every register of the Instructions is one where every register
name is assigned only once. Hence the name is assigned only once. Hence the
%em Single %em Single
Assignent. The static part means that this single assignment is only true for a static Assignment. The static part means that this single assignment is only true for a static
analysis, so at run time the code may assign many times. analysis, so at run time the code may assign many times.
But it would be the But it would be the
%em same %em same
code doing several assignemnts. code doing several assignments.
%p %p
SSA is often achieved by first naming registers according to the variables they hold, SSA is often achieved by first naming registers according to the variables they hold,
and to derive subsequent names by increasing an subsript index. This did not sound and to derive subsequent names by increasing an subscript index. This did not sound
very fitting. For one, RubyX does not really have "floating" variables (that later very fitting. For one, RubyX does not really have "floating" variables (that later
may get popped on some stack), rather every variable is an instance variable. may get popped on some stack), rather every variable is an instance variable.
Assigning to a variable does not create a new register value, but needs to be stored Assigning to a variable does not create a new register value, but needs to be stored
@ -120,7 +118,7 @@
ensure that different branches of an ensure that different branches of an
%b if %b if
produce the same registers, or the same produce the same registers, or the same
registers are meaningfully filled after the merge of an registers are meaningfuly filled after the merge of an
%b if. %b if.
My hope is that the ruby variable argument from above gets us out of that, and for some My hope is that the ruby variable argument from above gets us out of that, and for some
risc functions i added some transfers to ensure things work as they should. risc functions i added some transfers to ensure things work as they should.
@ -147,18 +145,18 @@
%b inlining %b inlining
is high up, that's for sure. is high up, that's for sure.
%p %p
But also there is something called escape analysis. This essentially means reclaming But also there is something called escape analysis. This essentially means reclaiming
objects that are created in a method, but never get passed out. A sort of immediate GC, objects that are created in a method, but never get passed out. A sort of immediate GC,
thus not only saving on GC time, but also on allocation. Mostly though it would thus not only saving on GC time, but also on allocation. Mostly though it would
allow to run larger benchmarks, because there is no GC, and integers get created allow to run larger benchmarks, because there is no GC, and integers get created
a lot before a meaningfull number of milliseconds has elapsed. a lot before a meaningful number of milliseconds has elapsed.
%p %p
On the register front, some low hanging fruits are redundant transfer elimination and On the register front, some low hanging fruits are redundant transfer elimination and
double load elimination. Since methods have not grown to exhaust registers, double load elimination. Since methods have not grown to exhaust registers,
unloading register is undone and thus is looming. Which brings with it code cost unloading register is undone and thus is looming. Which brings with it code cost
analysis. So much more fun to be had!! analysis. So much more fun to be had!!
%p %p
I am happy to annoounce that RubyX is part of I am happy to announce that RubyX is part of
=ext_link "Rails Girls Summer of Code" , "https://railsgirlssummerofcode.org/" =ext_link "Rails Girls Summer of Code" , "https://railsgirlssummerofcode.org/"
and some interest is being show. Since i have enjoyed my last RGSoC summer, and some interest is being show. Since i have enjoyed my last RGSoC summer,
i am looking forward to some mentoring, and outside participation. i am looking forward to some mentoring, and outside participation.

View File

@ -91,11 +91,11 @@
%section#start2 %section#start2
%p Start 2014 at Frozen rails %p Start 2014 at Frozen rails
%p.fragment started vm mindset %p.fragment started vm mindset
%p.fragment main descisions %p.fragment main decisions
%p.fragment good progress %p.fragment good progress
%section#descision %section#decision
%h2 Early descisions %h2 Early decisions
%p OO calling %p OO calling
%p memory design: cache size %p memory design: cache size
%p kernel calling %p kernel calling