Yashwant Singh
b7836d8562
[CodeGen]Allow targets to use target specific COPY instructions for live range splitting
...
Replacing D143754. Right now the LiveRangeSplitting during register allocation uses
TargetOpcode::COPY instruction for splitting. For AMDGPU target that creates a
problem as we have both vector and scalar copies. Vector copies perform a copy over
a vector register but only on the lanes(threads) that are active. This is mostly sufficient
however we do run into cases when we have to copy the entire vector register and
not just active lane data. One major place where we need that is live range splitting.
Allowing targets to use their own copy instructions(if defined) will provide a lot of
flexibility and ease to lower these pseudo instructions to correct MIR.
- Introduce getTargetCopyOpcode() virtual function and use if to generate copy in Live range
splitting.
- Replace necessary MI.isCopy() checks with TII.isCopyInstr() in register allocator pipeline.
Reviewed By: arsenm, cdevadas, kparzysz
Differential Revision: https://reviews.llvm.org/D150388
2023-07-07 22:29:50 +05:30
..
2023-02-09 18:45:20 +03:00
2023-01-05 13:21:20 +01:00
2022-12-19 12:56:12 +01:00
2023-02-09 18:45:20 +03:00
2023-01-12 12:40:04 +01:00
2023-01-05 13:21:20 +01:00
2023-01-14 19:12:18 +03:00
2022-12-19 12:56:12 +01:00
2023-06-14 22:27:15 +00:00
2022-05-30 19:19:23 +01:00
2022-05-30 19:19:23 +01:00
2023-01-05 13:21:20 +01:00
2023-06-28 22:45:04 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-02-06 20:36:11 -08:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-02-09 18:45:20 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-09-21 12:50:12 +00:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-07-19 10:59:07 +01:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2021-05-24 19:43:40 +02:00
2022-12-19 12:56:12 +01:00
2022-11-15 14:36:01 -08:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-06-21 10:30:43 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2022-04-06 09:18:08 +01:00
2022-12-19 12:56:12 +01:00
2022-05-30 19:19:23 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-05-11 23:40:38 +01:00
2023-01-05 13:21:20 +01:00
2023-06-14 22:27:15 +00:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-10-29 15:40:26 -07:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-03-23 14:06:50 -07:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2022-12-19 12:56:12 +01:00
2020-11-13 14:31:13 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-05-30 19:19:23 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2020-11-13 14:31:13 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-05-30 19:19:23 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-11-02 11:38:25 +00:00
2022-05-06 09:26:30 -07:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-03-01 15:33:45 +01:00
2020-09-30 10:35:25 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-02-09 18:45:20 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-06-06 17:07:18 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-05-17 17:03:15 +02:00
2022-12-19 12:56:12 +01:00
2022-11-23 09:04:42 +00:00
2023-01-13 10:34:27 +01:00
2021-03-01 10:08:10 -08:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-07-07 22:29:50 +05:30
2022-12-19 12:56:12 +01:00
2021-03-01 10:08:10 -08:00
2022-12-19 12:56:12 +01:00
2022-05-30 19:19:23 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-01-05 13:21:20 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-06-30 16:54:13 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2021-05-24 19:43:40 +02:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-06-14 22:27:15 +00:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2020-11-13 14:31:13 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-03-03 13:53:36 -08:00
2022-03-03 13:53:36 -08:00
2022-03-03 13:53:36 -08:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-03-12 21:59:18 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2021-06-17 09:38:28 +02:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-06-17 09:38:28 +02:00
2022-12-19 12:56:12 +01:00
2022-05-12 23:25:09 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-06-07 10:00:25 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-06-02 00:49:11 +00:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-06-08 10:59:46 -07:00
2022-12-19 12:56:12 +01:00
2021-09-27 11:30:45 -04:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-05-24 19:43:40 +02:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-01-05 13:21:20 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-05-14 09:50:01 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2021-12-31 15:59:44 +03:00
2022-01-20 20:10:04 +03:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2022-12-19 12:56:12 +01:00
2023-06-18 13:32:40 -07:00
2022-01-21 17:00:03 -08:00
2022-12-19 12:56:12 +01:00