# Workshop on Essential Abstractions in GCC

# More Details of Machine Descriptions

GCC Resource Center (www.cse.iitb.ac.in/grc)

Department of Computer Science and Engineering, Indian Institute of Technology, Bombay



2 July 2012

2 July 2012 MD Details: Outline 1/38

Outline

- Some details of MD constructs
  - ▶ On names of patterns in .md files
  - ▶ On the role of define\_expand
  - ▶ On the role of predicates and constraints
  - ► Mode and code iterators
  - Defining attributes
  - ▶ Other constructs
- Improving machine descriptions and instruction selection
  - ▶ New constructs to factor out redundancy
  - ► Cost based tree tiling for instruction selection

Votes

2 July 2012 MD Details: Outline 1/38

Outline

# More Features

# Notes

2 July 2012 MD Details: More Features 2/38

# Pattern Names in .md File



2 July 2012

MD Details: More Features

Pattern Names in .md File

Notes

2/38

Role of define\_expand

# Role of define\_expand



2 July 2012

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bomba

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bomb

2 July 2012

MD Details: More Features

2 July 2012

4/38

MD Details: More Features

Using define\_expand for Generating RTL statements

4/38

Using define\_expand for Generating RTL statements







5/38

### **Use of Predicates**

Predicates are using for matching operands

- For constructing an insn during expansion
   name> must be a standard pattern name
- For recognizing an instruction (in subsequent RTL passes including pattern matching)

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bombay



2 July 2012

MD Details: More Features

6/38

# **Understanding Constraints**

- Reloading operands in the most suitable register class
- Fine tuning within the set of operands allowed by the predicate
- If omitted, operands will depend only on the predicates

# **Use of Predicates**

# Notes

2 July 2012

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

GCC Resource Center, IIT

6/38

2 July 2012

MD Details: More Features

**Understanding Constraints** 





### **Role of Constraints**

Consider the following two instruction patterns:

- ▶ During expansion, the destination and left operands must match the same predicate
- During recognition, the destination and left operands must be identical

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay



2 July 2012

MD Details: More Features

8/38

### Role of Constraints

• Consider an insn for recognition

```
(insn n prev next
    (set (reg:SI 3)
          (plus:SI (reg:SI 6) (reg:SI 109)))
          ...)}
```

- Predicates of the first pattern do not match (because they require identical operands during recognition)
- Constraints do not match for operand 1 of the second pattern
- Reload pass generates additional insn to that the first pattern can be used



**Role of Constraints** 

Notes

2 July 2012

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

2 July 2012

MD Details: More Features

8/38

### Role of Constraints



## Part 2

# Factoring Out Common Information

2 July 2012

MD Details: Factoring Out Common Information

2 July 2012

# **Handling Mode Differences**

# **Handling Mode Differences**

```
(define_insn "subsi3"
    [(set (match_operand:SI 0 "register_operand" "=d")
           (minus:SI (match_operand:SI 1 "register_operand" "d")
                       (match_operand:SI 2 "register_operand" "d")))]
    " "
    "subu\t %0,%1,%2"
    [(set_attr "type" "arith")
    (set_attr "mode" "SI")])
(define_insn "subdi3"
    [(set (match_operand:DI 0 "register_operand" "=d")
           (minus:DI (match_operand:DI 1 "register_operand" "d")
                       (match_operand:DI 2 "register_operand" "d")))]
    "dsubu\t %0,%1,%2"
    [(set_attr "type" "arith")
    (set_attr "mode" "DI")])
```



9/38



# Mode Iterators: Abstracting Out Mode Differences

**Essential Abstractions in GCC** 

GCC Resource Center, III Bombay



2 July 2012

MD Details: Factoring Out Common Information

### 11/38

# **Handling Code Differences**



# Notes

2 July 2012

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

11/38

2 July 2012

MD Details: Factoring Out Common Information

**Handling Code Differences** 

# **Code Iterators: Abstracting Out Code Differences**

**Essential Abstractions in GCC** 

CC Resource Center, IIT Bombay

Part 3

Miscellaneous Features

Note

2 July 2012

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bombay



# **Defining Attributes**

- Classifications are need based
- Useful to GCC phases e.g. pipelining

Property: Pipelining

Need: To classify target instructions

Construct: define\_attr

```
;; Instruction type.
(define_attr "type"

"other,multi, alu,alu1,negnot, ... str,cld, ..."

(const_string "other")
```

Attribute name, all possible values, one of the possible values, default.

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bomba



13/38

2 July 2012

Fields:

MD Details: Miscellaneous Features

14/38

# **Specifying Instruction Attributes**

- Optional field of a define\_insn
- For an i386, we choose to mark string instructions with the attribute value str

```
(define_insn "*strmovdi_rex_1"
  [(set (mem:DI (match_operand:DI 2 ...)]
  "TARGET_64BIT && (TARGET_SINGLE_ ...)"
  "movsq"
  [ (set_attr "type" "str")
  ...
  (set_attr "memory" "both")])
```

### NOTE

An instruction may have more than one attribute!



**Defining Attributes** 

Notes

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

GCC Resource Center, IIT

2 July 2012

MD Details: Miscellaneous Features

14/38

# **Specifying Instruction Attributes**

# **Using Attributes**

Pipeline specification requires the CPU type to be "pentium" and the instruction type to be "str"

T Bombay

**Essential Abstractions in GCC** 

2 July 2012

16/38

Some Other RTL Constructs

MD Details: Miscellaneous Features

- define\_split: Split complex insn into simpler ones e.g. for better use of delay slots
- define\_insn\_and\_split: A combination of define\_insn and define\_split
   Used when the split pattern matches and insn exactly.
- define\_peephole2: Peephole optimization over insns that substitutes insns. Run after register allocation, and before scheduling.
- define\_constants: Use literal constants in rest of the MD.

Using Attributes

Notes

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay `

GCC Resource Center, IIT

16/38

Some Other RTL Constructs

MD Details: Miscellaneous Features

Notes

2 July 2012





# Part 4

# Machine Descriptions in specRTL

Notes

2 July 2012

MD Details: Machine Descriptions in specRTL

17/38

MD Details: Machine Descriptions in specRTL

17/38

# The Need for Improving Machine Descriptions

# The Need for Improving Machine Descriptions

## The Problems:

- The specification mechanism for Machine descriptions is quite adhoc
  - ▶ Only syntax borrowed from LISP, neither semantics not spirit!
  - ► Non-composable rules
  - ▶ Mode and code iterator mechanisms are insufficient
- Adhoc design decisions
  - ► Honouring operand constraints delayed to global register allocation During GIMPLE to RTL translation, a lot of C code is required
  - ► Choice of insertion of NOPs



2 July 2012





# **Handing Constraints**

- define\_insns patterns have operand predicates and constraints
- While generating an RTL insn from GIMPLE, only the predicates are checked. The constraints are completely ignored
- An insn which is generated in the expander is modified in the reload pass to satisfy the constraints
- It may be possible to generate this final form of RTL during expansion by honouring constraints
  - ▶ Honouring contraints earlier than the current place
    - ⇒ May get rid of some C code in define\_expand



Essential Abstractions in GCC

2 July 2012

**Essential Abstractions in GCC** 

MD Details: Machine Descriptions in specRTL

**Design Flaws in Machine Descriptions** 

19/38

2 July 2012

MD Details: Machine Descriptions in specRTL

19/38

# **Design Flaws in Machine Descriptions**

Multiple patterns with same structure

- Repetition of almost similar RTL expressions across multiple define\_insn an define\_expand patterns
  - ▶ Some Modes, Predicates, Constraints, Boolean Condition, or RTL Expression may differ everything else may be identical
  - ▶ One RTL expression may appears as a sub-expression of some other RTL expression
- Repetition of C code along with RTL expressions in these patterns.

# **Handing Constraints**

2 July 2012

GCC Resource Center, IIT

# Redundancy in MIPS Machine Descriptions: Example 1

[(set (match\_operand:  $\underline{m}$  0 "register\_operand" " $\underline{c}\underline{\theta}$ ") (plus:  $\underline{m}$  (match\_operand:  $\underline{m}$  1 "register\_operand" " $\underline{c}\underline{1}$ ") (match\_operand:  $\underline{m}$  2 "p" " $\underline{c}\underline{2}$ ")))]



### Details

| Pattern name                       | <u>m</u> | <u>p</u>         | <u>c0</u> | <u>c1</u> | <u>c2</u> |
|------------------------------------|----------|------------------|-----------|-----------|-----------|
| define_insn<br>add <mode>3</mode>  | ANYF     | register_operand | =f        | f         | f         |
| define_expand add <mode>3</mode>   | GPR      | arith_operand    |           |           |           |
| define_insn<br>*add <mode>3</mode> | GPR      | arith_operand    | =d,d      | d,d       | d,Q       |

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bomba



2 July 2012

MD Details: Machine Descriptions in specRTL

21/38

# Redundancy in MIPS Machine Descriptions: Example 2

[(set (match\_operand:  $\underline{m}$  0 "register\_operand" " $\underline{c}\underline{\theta}$ ") (mult:  $\underline{m}$  (match\_operand:  $\underline{m}$  1 "register\_operand" " $\underline{c}\underline{1}$ ") (match\_operand:  $\underline{m}$  2 "register\_operand" " $\underline{c}\underline{2}$ ")))]



### Details

| Pattern name                                 | <u>m</u> | <u>c0</u> | <u>c1</u> | <u>c2</u> |
|----------------------------------------------|----------|-----------|-----------|-----------|
| define_insn *mul <mode>3</mode>              | SCALARF  | =f        | f         | f         |
| define_insn *mul <mode>3_r4300</mode>        | SCALARF  | =f        | f         | f         |
| define_insn mulv2sf3                         | V2SF     | =f        | f         | f         |
| define_expand mul <mode>3</mode>             | GPR      |           |           |           |
| define_insn mul <mode>3_mul3_loongson</mode> | GPR      | =d        | d         | d         |
| define_insn mul <mode>3_mul3</mode>          | GPR      | d,1       | d,d       | d,d       |

# Redundancy in MIPS Machine Descriptions: Example 1

Notes

2 July 2012

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

-

2 July 2012

MD Details: Machine Descriptions in specRTL

21/38

# Redundancy in MIPS Machine Descriptions: Example 2



# Redundancy in MIPS Machine Descriptions: Example 3

MD Details: Machine Descriptions in specRTL

[(set (match\_operand:  $\underline{m}$  0 "register\_operand" " $\underline{c}\underline{0}$ ") (plus:  $\underline{m}$  (mult:  $\underline{m}$  (match\_operand:  $\underline{m}$  1 "register\_operand" " $\underline{c}\underline{1}$ ") (match\_operand:  $\underline{m}$  2 "register\_operand" " $\underline{c}\underline{2}$ ")))] (match\_operand:  $\underline{m}$  3 "register\_operand" " $\underline{c}\underline{3}$ ")))]



| Pattern name         | <u>m</u> | <u>c0</u>     | <u>c1</u> | <u>c2</u> | <u>c3</u> |
|----------------------|----------|---------------|-----------|-----------|-----------|
| *mul_acc_si          | SI       | =1*?*?,d?     | d,d       | d,d       | 0,d       |
| *mul_acc_si_r3900    | SI       | =1*?*?,d*?,d? | d,d,d     | d,d,d     | 0,1,d     |
| *macc                | SI       | =1,d          | d,d       | d,d       | 0,1       |
| *madd4 <mode></mode> | ANYF     | =f            | f         | f         | f         |
| *madd3 <mode></mode> | ANYF     | =f            | f         | f         | 0         |

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bomba



2 July 2012

MD Details: Machine Descriptions in specRTL

23/38

### **Insufficient Iterator Mechanism**

- Iterators cannot be used across define\_insn, define\_expand, define\_peephole2 and other patterns
- Defining iterator attribute for each varying parameter becomes tedious
- For same set of modes and rtx codes, change in other fields of pattern makes use of iterators impossible
- Mode and code attributes cannot be defined for operator or operand number, name of the pattern etc.
- Patterns with different RTL template share attribute value vector for which iterators can not be used

# Redundancy in MIPS Machine Descriptions: Example 3

Notes

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay



2 July 2012

MD Details: Machine Descriptions in specRTL

23/38

**Insufficient Iterator Mechanism** 





# Many Similar Patterns Cannot be Combined

```
(define_expand "iordi3"
   [(set (match_operand:DI 0 "nonimmediate_operand" "")
      (ior:DI (match_operand:DI 1 "nonimmediate_operand" "")
           (match_operand:DI 2 "x86_64_general_operand" "")))
   (clobber (reg:CC FLAGS_REG))]
   "TARGET_64BIT"
   "ix86_expand_binary_operator (IOR, DImode, operands); DONE;")
(define_insn "*iordi_1_rex64"
   [(set (match_operand:DI 0 "nonimmediate_operand" "=rm,r")
      (ior:DI (match_operand:DI 1 "nonimmediate_operand" "%0,0")
           (match_operand:DI 2 "x86_64_general_operand" "re,rme")))
   (clobber (reg:CC FLAGS_REG))]
   "TARGET_64BIT
   && ix86_binary_operator_ok (IOR, DImode, operands)"
   "or{q}\t{%2, %0|%0, %2}"
   [(set_attr "type" "alu")
   (set_attr "mode" "DI")])
```



2 July 2012

MD Details: Machine Descriptions in specRTL

25/38

# **Measuring Redundancy in RTL Templates**

| MD File | Total number of patterns | Number of primitive trees | Number of times<br>primitive trees<br>are used to create<br>composite trees |
|---------|--------------------------|---------------------------|-----------------------------------------------------------------------------|
| i386.md | 1303                     | 349                       | 4308                                                                        |
| arm.md  | 534                      | 232                       | 1369                                                                        |
| mips.md | 337                      | 147                       | 921                                                                         |

# Many Similar Patterns Cannot be Combined

Notes

2 July 2012

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bombay

2 July 2012

MD Details: Machine Descriptions in specRTL

25/38

# **Measuring Redundancy in RTL Templates**





# specRTL: Key Observations

• Davidson Fraser insight

Register transfers are target specific but their form is target independent

- GCC's approach
  - ▶ Use Target independent RTL for machine specification
  - ► Generate expander and recognizer by reading machine descriptions

Main problems with GCC's Approach

Although the shapes of RTL statements are target independent, they have to be provided in RTL templates

• Our key idea:

Separate shapes of RTL statements from the target specific details  ${\sf SE}$ 

**Essential Abstractions in GCC** 

GCC Resource Center, III Bomb



2 July 2012

MD Details: Machine Descriptions in specRTL

27/38

# Specification Goals of specRTL

Support all of the following

- Separation of shapes from target specific details
- Creation of new shapes by composing shapes
- Associtiating concrete details with shapes
- Overriding concrete details

tes

2 July 2012

**Essential Abstractions in GCC** 

2 July 2012

GCC Resource Center, IIT Bombay `

GCC Resource Center, IIT

27/38

IVID

MD Details: Machine Descriptions in specRTL

Specification Goals of specRTL





# **Software Engineering Goals of specRTL**

- Allow non-disruptive migration for existing machine descriptions
  - ► Incremental changes
  - ► No need to change GCC source until we are sure of the new specification

GCC must remain usable after each small change made in the machine descriptions



29/38

**Essential Abstractions in GCC** 

2 July 2012

GCC Resource Center, III Bombay

# MD Details: Machine Descriptions in specRTL Meeting the Specification Goals: Key Idea

- Separation of shapes from target specific details:
  - $\blacktriangleright \ \, \mathsf{Shape} \equiv \mathsf{tree} \,\, \mathsf{structure} \,\, \mathsf{of} \,\, \mathsf{RTL} \,\, \mathsf{templates}$
  - Details ≡ attributes of tree nodes (eg. modes, predicates, constraints etc.)
- Abstract patterns and Concrete patterns
  - ► Abstract patterns are shapes with "holes" in them that represent missing information
  - ► Concrete patterns are shapes in which all holes are plugged in using target specific information
- Abstract patterns capture shapes which can be concretized by providing details

Notes

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bombay

2 July 2012

MD Details: Machine Descriptions in specRTL

29/38

Meeting the Specification Goals: Key Idea



# Meeting the Specification Goals: Operations

# Meeting the Specification Goals: Operations

• Creating new shapes by composing shapes: extends

• Associtiating concrete details with shapes: instantiates

• Overriding concrete details: overrides

Base

pattern



**Essential Abstractions in GCC** 

Operation

extends

**Essential Abstractions in GCC** 

2 July 2012

MD Details: Machine Descriptions in specRTL

31/38

# **Properties of Operations**

Nodes Derived Can change pattern influenced Abstract Abstract Leaf nodes Structure

instantiates Abstract Concrete All nodes Attributes Abstract Internal nodes Attributes Abstract overrides Concrete All nodes Attributes Concrete

2 July 2012

2 July 2012

MD Details: Machine Descriptions in specRTL

31/38

**Properties of Operations** 





root.1

**Creating Abstract Patterns** 

# MD Details: Machine Descriptions in specRTL **Creating Abstract Patterns**

abstract set\_plus extends set root

root.2

root.2.2

root.2.1 root abstract set\_macc extends set\_plus root.2 root.1 root.2.2 = mult; root.2.2.1 root.2.2.2



**Essential Abstractions in GCC** 

2 July 2012

root.2 = plus;

MD Details: Machine Descriptions in specRTL

33/38

# **Creating Concrete Patterns**

```
abstract set_plus extends set
                                                root
                                                    root.2
  root.2 = plus;
                                     root.2.1
                                                     root.2.2
concrete add<mode>3.insn instantiates set_plus
{ set_plus(register_operand:ANYF:"=f",
           register_operand:ANYF:"f",
           register_operand:ANYF:"f");
  root.2.mode = ANYF;
concrete add<mode>3.expand instantiates set_plus
{ set_plus(register_operand:GPR:"",
           register_operand:GPR:"",
           arith_operand:GPR:"");
  root.2.mode = GPR;
```

**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bom

33/38

MD Details: Machine Descriptions in specRTL

## **Creating Concrete Patterns**

2 July 2012





# **Generating Conventional Machine Descriptions**

```
abstract set_plus extends set
                                                  root
                                                  +) root.2
                                     root.1
   root.2 = plus;
                                       root.2.
                                                      root.2.2
concrete add<mode>3.insn instantiates set plus
 set_plus(register_operand:ANYF:"=f", register_operand:ANYF:"f",
           register_operand:ANYF:"f");
  root.2.mode = ANYF;
{: /* Conventional Machine Description Fragments */ :`
                      Resulting MD Specification
(define_insn "add<mode>3"
[(set (match_operand:ANYF 0 "register_operand" "=f")
      (plus:ANYF (match_operand:ANYF 1 "register_operand" "f")
                 (match_operand:ANYF 2 "register_operand" "f")))]
/* Conventional Machine Description Fragments */
```

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay



34/38

2 July 2012

MD Details: Machine Descriptions in specRTL

35/38

# **Overriding Details**



**Generating Conventional Machine Descriptions** 

# Votes

Essential Abstractions in GCC

GCC Resource Center, IIT Bombay

y

2 July 2012

MD Details: Machine Descriptions in specRTL

35/38

# **Overriding Details**



# **Some More Examples**

Omitting conventional MD fragments



**Essential Abstractions in GCC** 

GCC Resource Center, IIT Bombay `

2 July 2012

MD Details: Conclusions

37/38

# **Current Status and Plans for Future Work**

- specRTL compiler is ready
- Many of the i386 instructions and all spim instructions have been rewritten
- We invite more people to try out specRTL in writing other descriptions

Part 5

Conclusions

2 July 2012 MD Details: Conclusions 37/38

**Current Status and Plans for Future Work** 



**Conclusions** 

# **Conclusions**

- Separating shapes from concrete details is very helpful
- It may be possible to identify a large number of common shapes
- Machine descriptions may become much smaller Only the concrete details need to be specified
- Non-disruptive and incremental migration to new machine descriptions
- GCC source need not change until these machine descriptions have been found useful



