Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 1 | /* SPDX-License-Identifier: MIT */ |
| 2 | /* |
| 3 | * Define Arm target-specific constraint sets. |
| 4 | * Copyright (c) 2021 Linaro |
| 5 | */ |
| 6 | |
| 7 | /* |
| 8 | * C_On_Im(...) defines a constraint set with <n> outputs and <m> inputs. |
| 9 | * Each operand should be a sequence of constraint letters as defined by |
| 10 | * tcg-target-con-str.h; the constraint combination is inclusive or. |
| 11 | */ |
| 12 | C_O0_I1(r) |
| 13 | C_O0_I2(r, r) |
| 14 | C_O0_I2(r, rIN) |
Richard Henderson | 7212812 | 2023-04-24 12:31:46 +0100 | [diff] [blame] | 15 | C_O0_I2(q, q) |
Richard Henderson | 000cf47 | 2021-05-03 16:47:52 -0700 | [diff] [blame] | 16 | C_O0_I2(w, r) |
Richard Henderson | 7212812 | 2023-04-24 12:31:46 +0100 | [diff] [blame] | 17 | C_O0_I3(q, q, q) |
| 18 | C_O0_I3(Q, p, q) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 19 | C_O0_I4(r, r, rI, rI) |
Richard Henderson | 7212812 | 2023-04-24 12:31:46 +0100 | [diff] [blame] | 20 | C_O0_I4(Q, p, q, q) |
| 21 | C_O1_I1(r, q) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 22 | C_O1_I1(r, r) |
Richard Henderson | 000cf47 | 2021-05-03 16:47:52 -0700 | [diff] [blame] | 23 | C_O1_I1(w, r) |
Richard Henderson | 7df44cf | 2020-09-05 11:58:47 -0700 | [diff] [blame] | 24 | C_O1_I1(w, w) |
Richard Henderson | 000cf47 | 2021-05-03 16:47:52 -0700 | [diff] [blame] | 25 | C_O1_I1(w, wr) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 26 | C_O1_I2(r, 0, rZ) |
Richard Henderson | 7212812 | 2023-04-24 12:31:46 +0100 | [diff] [blame] | 27 | C_O1_I2(r, q, q) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 28 | C_O1_I2(r, r, r) |
| 29 | C_O1_I2(r, r, rI) |
| 30 | C_O1_I2(r, r, rIK) |
| 31 | C_O1_I2(r, r, rIN) |
| 32 | C_O1_I2(r, r, ri) |
| 33 | C_O1_I2(r, rZ, rZ) |
Richard Henderson | 5047ae6 | 2020-09-05 13:26:48 -0700 | [diff] [blame] | 34 | C_O1_I2(w, 0, w) |
Richard Henderson | 000cf47 | 2021-05-03 16:47:52 -0700 | [diff] [blame] | 35 | C_O1_I2(w, w, w) |
Richard Henderson | d74b86e | 2020-09-05 15:54:33 -0700 | [diff] [blame] | 36 | C_O1_I2(w, w, wO) |
| 37 | C_O1_I2(w, w, wV) |
| 38 | C_O1_I2(w, w, wZ) |
Richard Henderson | f2b46c7 | 2020-09-05 12:54:37 -0700 | [diff] [blame] | 39 | C_O1_I3(w, w, w, w) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 40 | C_O1_I4(r, r, r, rI, rI) |
| 41 | C_O1_I4(r, r, rIN, rIK, 0) |
Richard Henderson | 7212812 | 2023-04-24 12:31:46 +0100 | [diff] [blame] | 42 | C_O2_I1(e, p, q) |
| 43 | C_O2_I2(e, p, q, q) |
Richard Henderson | 7166eeb | 2020-10-17 09:19:33 -0700 | [diff] [blame] | 44 | C_O2_I2(r, r, r, r) |
| 45 | C_O2_I4(r, r, r, r, rIN, rIK) |
| 46 | C_O2_I4(r, r, rI, rI, rIN, rIK) |