Marek Olsak | 5df00d6 | 2014-12-07 12:18:57 +0000 | [diff] [blame] | 1 | //===-- CIInstructions.td - CI Instruction Defintions ---------------------===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // Instruction definitions for CI and newer. |
| 10 | //===----------------------------------------------------------------------===// |
Matt Arsenault | 6adf07a | 2015-08-22 00:16:34 +0000 | [diff] [blame] | 11 | // Remaining instructions: |
Matt Arsenault | 6adf07a | 2015-08-22 00:16:34 +0000 | [diff] [blame] | 12 | // S_CBRANCH_CDBGUSER |
| 13 | // S_CBRANCH_CDBGSYS |
| 14 | // S_CBRANCH_CDBGSYS_OR_USER |
| 15 | // S_CBRANCH_CDBGSYS_AND_USER |
Marek Olsak | 5df00d6 | 2014-12-07 12:18:57 +0000 | [diff] [blame] | 16 | |
Marek Olsak | 5df00d6 | 2014-12-07 12:18:57 +0000 | [diff] [blame] | 17 | //===----------------------------------------------------------------------===// |
| 18 | // VOP1 Instructions |
| 19 | //===----------------------------------------------------------------------===// |
| 20 | |
| 21 | let SubtargetPredicate = isCIVI in { |
| 22 | |
Matt Arsenault | e8df879 | 2015-08-22 00:50:41 +0000 | [diff] [blame] | 23 | let SchedRW = [WriteDoubleAdd] in { |
Marek Olsak | 5df00d6 | 2014-12-07 12:18:57 +0000 | [diff] [blame] | 24 | defm V_TRUNC_F64 : VOP1Inst <vop1<0x17>, "v_trunc_f64", |
| 25 | VOP_F64_F64, ftrunc |
| 26 | >; |
| 27 | defm V_CEIL_F64 : VOP1Inst <vop1<0x18>, "v_ceil_f64", |
| 28 | VOP_F64_F64, fceil |
| 29 | >; |
| 30 | defm V_FLOOR_F64 : VOP1Inst <vop1<0x1A>, "v_floor_f64", |
| 31 | VOP_F64_F64, ffloor |
| 32 | >; |
| 33 | defm V_RNDNE_F64 : VOP1Inst <vop1<0x19>, "v_rndne_f64", |
| 34 | VOP_F64_F64, frint |
| 35 | >; |
Matt Arsenault | e8df879 | 2015-08-22 00:50:41 +0000 | [diff] [blame] | 36 | } // End SchedRW = [WriteDoubleAdd] |
| 37 | |
| 38 | let SchedRW = [WriteQuarterRate32] in { |
Marek Olsak | 5df00d6 | 2014-12-07 12:18:57 +0000 | [diff] [blame] | 39 | defm V_LOG_LEGACY_F32 : VOP1Inst <vop1<0x45, 0x4c>, "v_log_legacy_f32", |
| 40 | VOP_F32_F32 |
| 41 | >; |
| 42 | defm V_EXP_LEGACY_F32 : VOP1Inst <vop1<0x46, 0x4b>, "v_exp_legacy_f32", |
| 43 | VOP_F32_F32 |
| 44 | >; |
Matt Arsenault | e8df879 | 2015-08-22 00:50:41 +0000 | [diff] [blame] | 45 | } // End SchedRW = [WriteQuarterRate32] |
Tom Stellard | 731c927 | 2015-06-11 14:51:49 +0000 | [diff] [blame] | 46 | |
Tom Stellard | 12a1910 | 2015-06-12 20:47:06 +0000 | [diff] [blame] | 47 | } // End SubtargetPredicate = isCIVI |