annotate python/target/armv7.lidl @ 340:c7cc54c0dfdf devel

Test featurebranch
author Windel Bouwman
date Sun, 23 Feb 2014 16:24:01 +0100
parents 44f336460c2a
children
rev   line source
292
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
1
322
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
2 # This file specifies the encoding of the arm instruction set.
292
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
3
322
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
4 fields {
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
5 word16 16 {
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
6 opcode 15:12
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
7 top2 15:14
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
8 top6 15:10
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
9 data_opcode 9..6
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
10 opB 11:9
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
11 Rm 8:6
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
12 Rn 5:3
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
13 Rt 2:0
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
14 }
292
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
15 }
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
16
322
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
17 patterns {
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
18 add = 0
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
19 sub, mul = 1..2
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
20 [r1, r2, r3, r4, r5] is todo = 1..5
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
21 [STR, STRH, STRB, LDRSB, LDR, LDRH, LDRB, LDRSH] is opcode = 0b0101 & opB = {0 to 7}
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
22
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
23 EQ, NE, CS, CC, MI, PL, VS, VC, HI, LS, GE, LT, GT, LE, AL = 0..14
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
24 [AND, EOR, LSL, LSR, ASR, ADC, SBC, ROR, TST, RSB, CMP, CMN, ORR, MUL, BIC, MVN] is 0..15
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
25
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
26 memop is STR | STRH | STRB | LDRSB | LDR | LDR | LDRH | LDRB | LDRSH
292
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
27 }
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
28
322
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
29
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
30 constructors
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
31 {
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
32 alu rs1, reg_or_imm, rd
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
33 memop Rt, [Rn, Rm] is memop & Rt & Rn & Rm
292
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
34 }
534b94b40aa8 Fixup reorganize
Windel Bouwman
parents:
diff changeset
35
322
44f336460c2a Half of use of burg spec for arm
Windel Bouwman
parents: 292
diff changeset
36