Task #4832
closed[translator][model] VLIW architectures support
100%
Description
The key issue of VLIW architectures is composition of complex instructions (so-called words) from simple ones (so-called syllables). This can be done by enabling multiple operation parameters of the operation type:
op S1(x: arithmetic_instruction) ...
op S2(x: control_instruction) ...
op W2(x: S1, y: S2)
syntax = format("{%s, %s}", x.syntax, y.syntax)
image = format("1101111010101101%b%b", x.image, y.image)
action = { x.action; y.action; }
op W = W2 | ...
op instruction(x: W)
syntax = x.syntax
image = x.image
action = { x.action; }
Translation scheme seems to be simple:
public class W2 {
private S1 x;
private S2 y;
...
public void action() {
x.action();
y.action();
}
}
public class instruction {
private W x;
...
public void action() {
x.action();
}
}
Instantiation of complex instructions in test templates is done as follows:
W2_begin
S1 r(1), r(2), r(3)
S2 r(4), r(5), r(6)
W2_end
...
In general case it might look as it is shown below:
Word_begin
SubWord_begin
Syllable_1 ...
...
SubWord_end
Syllable_N ...
Word_end
...
If there is no ambiguity in determining how to compose words from syllables, begin/end brackets may be omitted:
Syllable_1 ...
...
Syllable_N ...
...
Updated by Alexander Kamkin almost 11 years ago
Better syntax:
Word {
SubWord {
Syllable_1 ...
...
}
Syllable_N ...
}
...
Updated by Alexander Kamkin almost 11 years ago
So, there should be possibility of "manual" instantiation of instructions in test templates:
instruction {
ADD r(1), r(2), r(3)
}
It does not make sense if all non-terminal instructions have one parameter per each. In this case, one can use the default form:
ADD r(1), r(2), r(3) // The default builder Instruction_ADD is invoked
Metainformation should be extended.
Updated by Andrei Tatarnikov over 10 years ago
- % Done changed from 0 to 40
Сделана поддержка на уровне транслятора.
Updated by Andrei Tatarnikov over 10 years ago
Синтаксис будет такой:
Сложный вызов (VLIW):
longword(
(add r(1), r(2), r(3)),
(sub r(1), r(2), r(3)),
r(4),
0xFF
)
Простой вызов (RISK):
add r(1), r(2), r(3)
Примерные сигнатуры runtime-методов, реализующих ISA:
def longword(a, b, c, d)
puts "longword(#{a}, #{b}, #{c}, #{d})"
end
def r(i)
"r#{i}"
end
def add(a, b, c)
"add(#{a}, #{b}, #{c})"
end
def sub(a, b, c)
"sub(#{a}, #{b}, #{c})"
end
Updated by Andrei Tatarnikov over 10 years ago
- % Done changed from 80 to 90
Сейчас все существующие примеры работают. Остались мелкие доделки, тестирование, удаление кода старой реализации (все классы, работающие с сущностью Instruction).
Updated by Andrei Tatarnikov about 10 years ago
- Status changed from Open to Closed
- % Done changed from 90 to 100
- Published in build set to 141018
Сделано. Кусок примера для иллюстрации:
# Possible syntax styles to address the VLIW ISA:
# Style 1:
vliw(
(addi r(4), r(0), 5 do situation('overflow') end),
(addi r(5), r(0), 10 do situation('normal') end)
)
# Style 2:
vliw(
addi(r(4), r(0), 5) do situation('overflow') end,
addi(r(5), r(0), 10) do situation('normal') end
)