reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35
   36
   37
   38
   39
   40
   41
   42
   43
   44
   45
   46
   47
   48
   49
   50
   51
   52
   53
   54
   55
   56
   57
   58
   59
   60
   61
   62
   63
   64
   65
   66
   67
# RUN: not llvm-mc -triple mips-unknown-linux-gnu -mcpu=mips32r2 \
# RUN:             -mattr=+micromips %s 2>&1 \
# RUN:   | FileCheck --check-prefixes=ALL,MMR2 %s
# RUN: not llvm-mc -triple mips-unknown-linux-gnu -mcpu=mips32r6 \
# RUN:             -mattr=+micromips %s 2>&1 \
# RUN:   | FileCheck --check-prefixes=ALL,MMR6 %s
# RUN: not llvm-mc -triple mips-unknown-linux-gnu -mcpu=mips32r6 %s 2>&1 \
# RUN:   | FileCheck --check-prefixes=ALL,MIPS32R6 %s

# This tests the mnemonic spell checker.

# First check what happens when an instruction is omitted:

$2, $1, $25

# ALL:      error: unexpected token at start of statement
# ALL-NEXT: $2, $1, $25
# ALL-NEXT:  ^

# We don't want to see a suggestion here; the edit distance is too large to
# give sensible suggestions:

aaaaaaaaaaaaaaa $2, $1, $25

# ALL:      error: unknown instruction
# ALL-NEXT: aaaaaaaaaaaaaaa $2, $1, $25
# ALL-NEXT: ^

# Check that we get one suggestion: 'addiuspi' is 1 edit away, i.e. an deletion.

addiuspi -16

# MMR2:     error: unknown instruction, did you mean: addiusp?
# MMR6:     error: unknown instruction, did you mean: addiusp?
# MIPS32R6: error: unknown instruction{{$}}
# ALL:      addiuspi -16
# ALL-NEXT: ^

# Check edit distance 1 and 2, just insertions:

addru $9, $6, 17767

# MMR2:      error: unknown instruction, did you mean: add, addiu, addu, maddu?
# MMR6:      error: unknown instruction, did you mean: add, addiu, addu?
# MIPS32R6:  error: unknown instruction, did you mean: add, addiu, addu?
# ALL:       addru $9, $6, 17767
# ALL-NEXT:  ^

# Check an instruction that is 2 edits away, and also has a lot of candidates:

culE.d  $fcc7, $f24, $f18

# MMR2:     error: unknown instruction, did you mean: c.le.d, c.ule.d?
# MMR6:     error: unknown instruction{{$}}
# MIPS32R6: error: unknown instruction{{$}}
# ALL:      culE.d  $fcc7, $f24, $f18
# ALL-NEXT: ^

# Check that candidates list includes only instructions valid for target CPU.

swk $3, $4

# MMR2: error: unknown instruction, did you mean: sw, swl, swm, swp, swr, usw?
# MMR6: error: unknown instruction, did you mean: sw, swm, swp, usw?
# MIPS32R6: error: unknown instruction, did you mean: sw, usw?
# ALL:      swk $3, $4
# ALL-NEXT: ^