| # RUN: not llvm-mc -triple amdgcn < %s 2>&1 | FileCheck %s |
| |
| # This tests the mnemonic spell checker. |
| |
| # First check what happens when an instruction is omitted: |
| |
| v2, v4, v6 |
| |
| # CHECK: unknown token in expression |
| # CHECK-NEXT: v2, v4, v6 |
| # CHECK-NEXT: ^ |
| |
| # CHECK: error: not a valid operand. |
| # CHECK-NEXT: v2, v4, v6 |
| # CHECK-NEXT: ^ |
| |
| # We don't want to see a suggestion here; the edit distance is too large to |
| # give sensible suggestions: |
| |
| aaaaaaaaaaaaaaa v1, v2, v3 |
| |
| # CHECK: error: invalid instruction |
| # CHECK-NEXT: aaaaaaaaaaaaaaa v1, v2, v3 |
| # CHECK-NEXT: ^ |
| |
| # Check that we get one suggestion: 'dsc_write_src2_b64' is 1 edit away, i.e. an deletion. |
| |
| dsc_write_src2_b64 v1, v2, v3 |
| |
| # CHECK: error: invalid instruction, did you mean: ds_write_src2_b64? |
| # CHECK-NEXT: dsc_write_src2_b64 v1, v2, v3 |
| # CHECK-NEXT: ^ |
| |
| # Check edit distance 1 and 2, just insertions: |
| |
| s_mov_b v1, v2 |
| |
| # CHECK: error: invalid instruction, did you mean: s_mov_b32, s_mov_b64? |
| # CHECK-NEXT: s_mov_b v1, v2 |
| # CHECK-NEXT: ^ |
| |
| # Check an instruction that is 2 edits away, and also has a lot of candidates: |
| |
| s_load_dwordx v1, v2, v3 |
| |
| # CHECK: error: invalid instruction, did you mean: s_load_dword, s_load_dwordx16, s_load_dwordx2, s_load_dwordx4, s_load_dwordx8? |
| # CHECK-NEXT: s_load_dwordx v1, v2, v3 |
| # CHECK-NEXT: ^ |