• Home
Name Date Size #Lines LOC

..--

FP/03-May-2024-618506

Thumb/03-May-2024-1,2671,041

Thumb2/03-May-2024-1,7881,454

armv5te/03-May-2024-260104

armv5te-vfp/03-May-2024-240101

armv7-a/03-May-2024-236102

armv7-a-neon/03-May-2024-684412

ArchFactory.cppD03-May-20244.4 KiB12463

ArchUtility.cppD03-May-202414.3 KiB428378

ArmLIR.hD03-May-202435.2 KiB796540

ArmRallocUtil.cppD03-May-20243.7 KiB11663

Assemble.cppD03-May-2024123.7 KiB2,9442,260

CalloutHelper.hD03-May-20245.4 KiB12543

Codegen.hD03-May-20242.2 KiB6625

CodegenCommon.cppD03-May-202412.7 KiB448297

CodegenDriver.cppD03-May-2024173.6 KiB4,7403,357

GlobalOptimizations.cppD03-May-20242.1 KiB6628

LocalOptimizations.cppD03-May-202418.2 KiB467243

README.txtD03-May-20241.4 KiB4934

README.txt

1The codegen file for the ARM-based JIT is composed by files broken by
2functionality hierarchies. The goal is to separate architectural dependent
3and independent components to facilitate maintenance and future extension.
4
5For example, the codegen file for armv7-a is assembled by the following
6components:
7
8--
9
10/* Architectural independent building blocks */
11#include "../CodegenCommon.cpp"
12
13/* Thumb2-specific factory utilities */
14#include "../Thumb2/Factory.cpp"
15/* Factory utilities dependent on arch-specific features */
16#include "../CodegenFactory.cpp"
17
18/* Thumb2-specific codegen routines */
19#include "../Thumb2/Gen.cpp"
20/* Thumb2+VFP codegen routines */
21#include "../FP/Thumb2VFP.cpp"
22
23/* Thumb2-specific register allocation */
24#include "../Thumb2/Ralloc.cpp"
25
26/* MIR2LIR dispatcher and architectural independent codegen routines */
27#include "../CodegenDriver.cpp"
28
29/* Architecture manifest */
30#include "ArchVariant.cpp"
31
32--
33
34For the Thumb/Thumb2 directories, each contain the followin three files:
35
36- Factory.c (low-level routines for instruction selections)
37- Gen.c     (invoke the ISA-specific instruction selection routines)
38- Ralloc.c  (arch-dependent register pools)
39
40The FP directory contains FP-specific codegen routines depending on
41Thumb/Thumb2/VFP/PortableFP:
42
43- Thumb2VFP.c
44- ThumbVFP.c
45- ThumbPortableFP.c
46
47In this way the dependency between generic and specific code tied to
48particular architectures can be explicitly represented.
49