Files
clang-p2996/llvm/test/CodeGen/SPARC/tn0012.mir
Daniel Cederman 7faf1a0868 [Sparc] Add errata workaround pass for GR712RC and UT700 (#103843)
This patch adds a pass that provides workarounds for the errata
described in GRLIB-TN-0009, GRLIB-TN-0010, GRLIB-TN-0011, GRLIB-TN-0012,
and GRLIB-TN-0013, that are applicable to the GR712RC and UT700. The
documents are available for download from here:

https://www.gaisler.com/index.php/information/app-tech-notes

The pass will detect certain sensitive instruction sequences and prevent
them from occurring by inserting NOP instruction. Below is an overview
of each of the workarounds. A similar implementation is available in
GCC.

GRLIB-TN-0009:

* Insert NOPs to prevent the sequence (stb/sth/st/stf) -> (single
non-store/load instruction) -> (any store)

* Insert NOPs to prevent the sequence (std/stdf) -> (any store)

GRLIB-TN-0010:

* Insert a NOP between load instruction and atomic instruction (swap and
casa).

* Insert a NOP at branch target if load in delay slot and atomic
instruction at branch target.

* Do not allow functions to begin with atomic instruction.

GRLIB-TN-0011:

* Insert .p2align 4 before atomic instructions (swap and casa).

GRLIB-TN-0012:

* Place a NOP at the branch target of an integer branch if it is a
floating-point operation or a floating-point branch.

GRLIB-TN-0013:

* Prevent (div/sqrt) instructions in the delay slot.

* Insert NOPs to prevent the sequence (div/sqrt) -> (two or three
floating point operations or loads) -> (div/sqrt).

* Do not insert NOPs if any of the floating point operations have a
dependency on the destination register of the first (div/sqrt).

* Do not insert NOPs if one of the floating point operations is a
(div/sqrt).

* Insert NOPs to prevent (div/sqrt) followed by a branch.
2024-08-19 07:59:58 +02:00

66 lines
1.1 KiB
YAML

# RUN: llc %s -mattr=+fix-tn0012 -march=sparc -run-pass=errata-workaround -o - \
# RUN: | FileCheck %s
---
# CHECK: bb.2:
# CHECK: NOP
# CHECK-NEXT: $f0 = FADDS $f0, $f0
name: er-5-1
body: |
bb.0.entry:
successors: %bb.1, %bb.2
BCOND %bb.2, 10, implicit $icc {
NOP
}
bb.1.entry:
successors: %bb.2
NOP
bb.2:
$f0 = FADDS $f0, $f0
---
# CHECK: bb.2:
# CHECK: NOP
# CHECK-NEXT: FBCOND %bb.3, 22, implicit $fcc0 {
name: er-5-2
body: |
bb.0.entry:
successors: %bb.2, %bb.1
BCOND %bb.1, 10, implicit $icc {
NOP
}
bb.2.entry:
successors: %bb.1
NOP
bb.1:
successors: %bb.3
FBCOND %bb.3, 22, implicit $fcc0 {
NOP
}
bb.3:
NOP
---
# CHECK: bb.2:
# CHECK: NOP
# CHECK-NEXT: FCMPS $f0, $f0, implicit-def $fcc0
name: er-5-3
body: |
bb.0.entry:
successors: %bb.1, %bb.2
BCOND %bb.2, 10, implicit $icc {
NOP
}
bb.1.entry:
successors: %bb.2
NOP
bb.2:
FCMPS $f0, $f0, implicit-def $fcc0
...