blob: 23f40daf3d237b7123c482f04af3f9a239614820 [file] [log] [blame]
Marek Olsak693e9be2016-12-09 19:49:48 +00001; RUN: llc -march=amdgcn -mcpu=kaveri -verify-machineinstrs < %s | FileCheck -check-prefix=CI -check-prefix=GCN %s
2; RUN: llc -march=amdgcn -mcpu=fiji -verify-machineinstrs < %s | FileCheck -check-prefix=VI-NOXNACK -check-prefix=GCN %s
Marek Olsak0f55fba2016-12-09 19:49:54 +00003
4; RUN: llc -march=amdgcn -mcpu=carrizo -mattr=-xnack -verify-machineinstrs < %s | FileCheck -check-prefix=VI-NOXNACK -check-prefix=GCN %s
5; RUN: llc -march=amdgcn -mcpu=stoney -mattr=-xnack -verify-machineinstrs < %s | FileCheck -check-prefix=VI-NOXNACK -check-prefix=GCN %s
6
Marek Olsak693e9be2016-12-09 19:49:48 +00007; RUN: llc -march=amdgcn -mcpu=carrizo -verify-machineinstrs < %s | FileCheck -check-prefix=VI-XNACK -check-prefix=GCN %s
Matt Arsenault7aad8fd2017-01-24 22:02:15 +00008; RUN: llc -march=amdgcn -mcpu=stoney -verify-machineinstrs < %s | FileCheck -check-prefix=VI-XNACK -check-prefix=GCN %s
Matt Arsenault07f65712016-07-26 16:45:50 +00009
Marek Olsak693e9be2016-12-09 19:49:48 +000010; RUN: llc -march=amdgcn -mtriple=amdgcn--amdhsa -mcpu=kaveri -verify-machineinstrs < %s | FileCheck -check-prefix=HSA-CI -check-prefix=GCN %s
11; RUN: llc -march=amdgcn -mtriple=amdgcn--amdhsa -mcpu=carrizo -mattr=-xnack -verify-machineinstrs < %s | FileCheck -check-prefix=HSA-VI-NOXNACK -check-prefix=GCN %s
12; RUN: llc -march=amdgcn -mtriple=amdgcn--amdhsa -mcpu=carrizo -mattr=+xnack -verify-machineinstrs < %s | FileCheck -check-prefix=HSA-VI-XNACK -check-prefix=GCN %s
Tom Stellardcaaa3aa2015-12-17 17:05:09 +000013
14; GCN-LABEL: {{^}}no_vcc_no_flat:
Marek Olsak693e9be2016-12-09 19:49:48 +000015; HSA-CI: is_xnack_enabled = 0
16; HSA-VI-NOXNACK: is_xnack_enabled = 0
17; HSA-VI-XNACK: is_xnack_enabled = 1
Matt Arsenault07f65712016-07-26 16:45:50 +000018
Marek Olsak693e9be2016-12-09 19:49:48 +000019; CI: ; NumSgprs: 8
20; VI-NOXNACK: ; NumSgprs: 8
21; VI-XNACK: ; NumSgprs: 12
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000022define amdgpu_kernel void @no_vcc_no_flat() {
Tom Stellardcaaa3aa2015-12-17 17:05:09 +000023entry:
24 call void asm sideeffect "", "~{SGPR7}"()
25 ret void
26}
27
28; GCN-LABEL: {{^}}vcc_no_flat:
Marek Olsak693e9be2016-12-09 19:49:48 +000029; HSA-CI: is_xnack_enabled = 0
30; HSA-VI-NOXNACK: is_xnack_enabled = 0
31; HSA-VI-XNACK: is_xnack_enabled = 1
Matt Arsenault07f65712016-07-26 16:45:50 +000032
Marek Olsak693e9be2016-12-09 19:49:48 +000033; CI: ; NumSgprs: 10
34; VI-NOXNACK: ; NumSgprs: 10
35; VI-XNACK: ; NumSgprs: 12
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000036define amdgpu_kernel void @vcc_no_flat() {
Tom Stellardcaaa3aa2015-12-17 17:05:09 +000037entry:
38 call void asm sideeffect "", "~{SGPR7},~{VCC}"()
39 ret void
40}
41
42; GCN-LABEL: {{^}}no_vcc_flat:
Marek Olsak693e9be2016-12-09 19:49:48 +000043; HSA-CI: is_xnack_enabled = 0
44; HSA-VI-NOXNACK: is_xnack_enabled = 0
45; HSA-VI-XNACK: is_xnack_enabled = 1
Matt Arsenault07f65712016-07-26 16:45:50 +000046
Marek Olsak693e9be2016-12-09 19:49:48 +000047; CI: ; NumSgprs: 8
48; VI-NOXNACK: ; NumSgprs: 8
49; VI-XNACK: ; NumSgprs: 12
50; HSA-CI: ; NumSgprs: 8
51; HSA-VI-NOXNACK: ; NumSgprs: 8
52; HSA-VI-XNACK: ; NumSgprs: 12
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000053define amdgpu_kernel void @no_vcc_flat() {
Tom Stellardcaaa3aa2015-12-17 17:05:09 +000054entry:
55 call void asm sideeffect "", "~{SGPR7},~{FLAT_SCR}"()
56 ret void
57}
58
59; GCN-LABEL: {{^}}vcc_flat:
Matt Arsenault07f65712016-07-26 16:45:50 +000060; HSA-NOXNACK: is_xnack_enabled = 0
61; HSA-XNACK: is_xnack_enabled = 1
62
Marek Olsak693e9be2016-12-09 19:49:48 +000063; CI: ; NumSgprs: 10
64; VI-NOXNACK: ; NumSgprs: 10
65; VI-XNACK: ; NumSgprs: 12
66; HSA-CI: ; NumSgprs: 10
67; HSA-VI-NOXNACK: ; NumSgprs: 10
68; HSA-VI-XNACK: ; NumSgprs: 12
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000069define amdgpu_kernel void @vcc_flat() {
Tom Stellardcaaa3aa2015-12-17 17:05:09 +000070entry:
71 call void asm sideeffect "", "~{SGPR7},~{VCC},~{FLAT_SCR}"()
72 ret void
73}