Project

General

Profile

Язык описания шаблонов тестовых программ » History » Version 14

Alexander Kamkin, 09/25/2011 01:39 PM

1 4 Alexander Kamkin
h1. Язык M4TEST описания шаблонов тестовых программ
2 1 Alexander Kamkin
3 11 Alexander Kamkin
Язык *M4TEST* (Macro language for TEST programs) предназначен для компактного и переиспользуемого описания тестов для микропроцессоров и других программируемых устройств. Язык представляет собой смесь языка ассемблера целевого микропроцессора (*TL*, Target Language) и управляющего языка высокого уровня (*ML*, Meta Language). При этом ML можно рассматривать как макропроцессор, поскольку в результате выполнения его конструкций генерируется текст на TL. Кроме того, никто не запрещает использовать стандартные препроцессоры (например, препроцессор языка программирования С или макропроцессор m4).
4 1 Alexander Kamkin
5 12 Alexander Kamkin
h2. Интуитивное описание языка на примерах
6
7 14 Alexander Kamkin
h3. Пример 1
8
9 13 Alexander Kamkin
<pre>
10 14 Alexander Kamkin
repeat(100) {
11
    ld Reg1, 0x0(Base1)     @ choice{L1Hit:50}                       // Загрузка в регистр Reg1 содержимого памяти по адресу, содержащемуся в регистре Base1
12
    ld Reg2, 0x0(Base2)     @ choice{L1Hit:50} && [Base1] != [Base2] //
13
    dadd Result, Reg1, Reg2 @ !IntegerOverflow                       //
14
}
15 13 Alexander Kamkin
</pre>
16 12 Alexander Kamkin
17 13 Alexander Kamkin
h2. Формализованное описание языка
18 12 Alexander Kamkin
19 2 Alexander Kamkin
Шаблон - это последовательность операторов.
20
21 1 Alexander Kamkin
<pre>
22
Template ::= Statement*
23
</pre>
24
25 2 Alexander Kamkin
Операторы делятся на два класса: реальные операторы (операторы, которые порождают код) и мета операторы (операторы, которые используются для управления генерацией кода).
26
27 1 Alexander Kamkin
<pre>
28 2 Alexander Kamkin
Statement ::= RealStatement | MetaStatement
29 1 Alexander Kamkin
</pre> 
30
31
<pre>
32 2 Alexander Kamkin
InstructionStatement ::= (Instruction | InstructionClass) (@ Situation)?
33 1 Alexander Kamkin
</pre>
34
35 2 Alexander Kamkin
Формат инструкции зависит от ассемблера. Обычно он имеет следующий вид: 
36
37 1 Alexander Kamkin
<pre>
38
ConcreteInstruction ::= Identifier (Parameter (, Parameter)+)?
39
</pre>
40
41
<pre>
42
InstructionClass ::= Identifier (Parameter (, Parameter)+)?
43 2 Alexander Kamkin
</pre>
44
45
<pre>
46
MetaStatement ::= MetaVariableDeclaration |
47
                  MetaVariableAssignment  |
48
                  MetaIfStatement         |
49
                  MetaForStatement        |
50
                  MetaWhileStatement      |
51
                  ...
52
                  
53 1 Alexander Kamkin
</pre>