Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

merge release code into development #3219

Open
wants to merge 179 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
179 commits
Select commit Hold shift + click to select a range
bc102bb
Bulk promote till commit '36a6baf8291cc39d485ff21d789a172e3b50f25e' i…
mangupta Jan 6, 2021
9cc6d28
Merge branch 'amd-staging' into amd-master-next
mangupta Feb 22, 2021
30617b3
Merge branch 'amd-staging' into amd-master-next
mangupta Mar 17, 2021
4e6a863
Merge branch 'amd-staging' into amd-master-next
mangupta Apr 6, 2021
6a337d2
Merge branch 'amd-staging' into amd-master-next
mangupta Apr 20, 2021
22745dd
Merge branch 'amd-staging' into amd-master-next
mangupta Apr 23, 2021
4a4bab9
Merge branch 'amd-staging' into amd-master-next
mangupta May 7, 2021
ea6c24f
Merge branch 'amd-staging' into amd-master-next
mangupta May 19, 2021
e6240ff
Merge branch 'amd-staging' into amd-master-next
mangupta May 25, 2021
b96194b
Merge branch 'amd-staging' into amd-master-next
mangupta May 31, 2021
ecacf90
Merge branch 'amd-staging' into amd-master-next
mangupta Jun 25, 2021
3a821ff
Revert "Merge branch 'amd-staging' into amd-master-next"
mangupta Jun 30, 2021
574d398
Merge branch 'amd-master-next' into amd-staging
mangupta Jul 6, 2021
10e1fa2
Merge branch 'amd-staging' into amd-master-next
mangupta Jul 6, 2021
b23c028
Merge branch 'amd-staging' into amd-master-next
mangupta Jul 20, 2021
0890f0d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 13, 2021
76fe4d2
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 20, 2021
f5dcd69
Merge branch 'amd-staging' into amd-master-next
mangupta Aug 24, 2021
ff00b75
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 29, 2021
ea27a01
Merge branch 'amd-staging' into amd-master-next
mangupta Sep 1, 2021
757b01e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 6, 2021
dd31ff8
Merge branch 'amd-staging' into amd-master-next
mangupta Sep 7, 2021
c7892da
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 14, 2021
dddca20
Promote till commit '757b01e5348100d9955fec57469210bf6a74983d'
mangupta Sep 15, 2021
70374f2
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 20, 2021
474fd7f
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 3, 2021
f6e6814
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 6, 2021
d92cc65
Promote till commit 'f6e68140764540bd77390cb6780bef60a4f2695a'
mangupta Nov 20, 2021
d22c527
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 26, 2021
f50aeef
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 3, 2021
e8391f6
Promote till commit 'd22c527d2af2b5a9060e3570a741c46c865332e8'
mangupta Dec 8, 2021
609a0cd
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 9, 2021
2690a65
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 15, 2021
dbd7198
Promote till commit '609a0cd177d376262e3553c1c7556cb99323dd33'
mangupta Dec 16, 2021
a118997
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 21, 2021
3239bb1
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 12, 2022
1c49ca3
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 24, 2022
d8b7287
Promote till commit '3239bb1609a4e0614e19f61bbd7157c4b2f647b0'
mangupta Jan 27, 2022
f64659a
SWDEV-1 - Bump patch version to 20270
mangupta Jan 27, 2022
a4c96fc
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Feb 6, 2022
86cf152
Promote till commit 'a4c96fcf37c1a50ed700d2aad9a8e76cc5a425e2'
mangupta Feb 11, 2022
b5229a0
SWDEV-1 - Bump patch version to 20420
mangupta Feb 11, 2022
ac02c17
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Feb 11, 2022
5cb7fe5
SWDEV-299127 - Merge 'develop' into 'amd-staging'
keerthana4708 Feb 20, 2022
9612809
Promote till commit '5cb7fe5df736c0291bbbcef0e639c085d7ce5e80'
mangupta Feb 22, 2022
773ec02
SWDEV-1 - Bump patch version to 20530
mangupta Feb 22, 2022
55442f7
SWDEV-299127 - Merge 'develop' into 'amd-staging'
keerthana4708 Feb 25, 2022
c7d9453
SWDEV-1 - Bump patch version to 20560
mangupta Feb 25, 2022
b0dad5b
SWDEV-299127 - Merge 'develop' into 'amd-staging'
keerthana4708 Feb 28, 2022
77fd73c
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 1, 2022
8699a20
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 7, 2022
f5c415e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 11, 2022
242c1f8
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 13, 2022
0a9f2c8
SWDEV-1 - Bump patch version to 20590
mangupta Mar 14, 2022
cf3658f
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 17, 2022
4f2d428
Promote till commit '242c1f892fbbe1a3fb7d93e34dd589fff0186432'
mangupta Mar 25, 2022
bda991b
SWDEV-1 - Bump patch version to 20730
mangupta Mar 25, 2022
2e8f00e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 27, 2022
e828e71
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Mar 29, 2022
b9c2d9b
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Apr 4, 2022
3e5668c
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Apr 11, 2022
fc427e0
SWDEV-299127 - Merge branch 'develop' into 'amd-staging'
mangupta Apr 14, 2022
c2d7a80
SWDEV-299127 - Merge branch 'develop' into 'amd-staging'
mangupta Apr 21, 2022
f9764ef
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Apr 26, 2022
5d2fcef
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Apr 28, 2022
f617429
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 5, 2022
1af79bb
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 9, 2022
abf7a9b
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 10, 2022
730b235
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 11, 2022
01afd5d
Promote till commit 'abf7a9b1b3b2016edf58a926c6c90d574d2a1e29'
mangupta May 19, 2022
33df4f4
SWDEV-1 - Bump patch version to 21310
mangupta May 19, 2022
a737db5
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 20, 2022
840d1f8
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 24, 2022
483dd25
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 25, 2022
2974883
Promote till commit '730b235940c38f5c76a9b229974ba7ba47c1a2d4'
mangupta May 26, 2022
7a160e3
SWDEV-1 - Bump patch version to 21400
mangupta May 26, 2022
bac095e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 29, 2022
d593752
SWDEV-299127 - Merge 'develop' into 'amd-staging'
May 31, 2022
1dfaa6d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 10, 2022
80caf65
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 20, 2022
9cfe037
Promote till commit 'd5937524408f41c39e745c3daa7f5f3081a76556'
mangupta Jun 21, 2022
df0d560
SWDEV-1 - Bump patch version to 21530
mangupta Jun 21, 2022
5fc4a13
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 23, 2022
73b187e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 25, 2022
093d0d4
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 28, 2022
3483144
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jun 30, 2022
2f1bb47
Promote till commit '73b187ef79bf2550da85d7b9109c561a1098ed15'
mangupta Jul 5, 2022
81311e3
SWDEV-1 - Bump patch version to 21780
mangupta Jul 5, 2022
7cfde00
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Jul 14, 2022
932a5bd
Promote till commit '3483144a6807da85b5c984c4269d67e38d2dd759'
mangupta Jul 15, 2022
8a680f4
SWDEV-1 - Bump patch version to 21850
mangupta Jul 15, 2022
acd91e9
Promote till commit '7cfde0047f7b6f1e97e4fe6ca0ba861383c9358a'
mangupta Jul 22, 2022
fdc46ed
SWDEV-1 - Bump patch version to 22000
mangupta Jul 22, 2022
3aa38b0
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jul 24, 2022
2d920e7
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jul 26, 2022
6b598ac
Promote till commit '3aa38b08b402b636e8c33aa33d81398a10c2f333'
mangupta Jul 29, 2022
59bcca2
SWDEV-1 - Bump patch version to 22060
mangupta Jul 29, 2022
66c8669
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Aug 3, 2022
314bb5d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 5, 2022
a06436c
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Aug 5, 2022
26019fc
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 10, 2022
f990c93
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 19, 2022
e1f9942
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 22, 2022
14e9fcc
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 25, 2022
ada9cea
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Aug 31, 2022
f85140d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 6, 2022
1c5d61e
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 7, 2022
3b1d417
Promote till commit 'e1f994220bbeaa1ff3c24cd5639648d3308c93b4'
mangupta Sep 8, 2022
53d16b5
SWDEV-1 - Bump patch version to 22360
mangupta Sep 8, 2022
a33182a
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 12, 2022
adb1424
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 13, 2022
3caa8bf
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Sep 16, 2022
956088d
Promote till commit '1c5d61e9026fd6d057951473a2b085cdffb31ba6'
mangupta Sep 20, 2022
ddfea75
SWDEV-1 - Bump patch version to 22520
mangupta Sep 20, 2022
bef3f4c
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Sep 21, 2022
2c90308
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Sep 21, 2022
ce6378e
Promote till commit '2c903087e869b90634ba0e66e856c3d6743aaf81'
mangupta Oct 3, 2022
bb84175
SWDEV-1 - Bump patch version to 22740
mangupta Oct 3, 2022
c3ad9de
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 6, 2022
651503b
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 8, 2022
2765aae
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 10, 2022
b26c932
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 10, 2022
f10d7d8
Promote till commit 'c3ad9dec98d0a9603d326e4b25633a8ca0a679fa'
mangupta Oct 14, 2022
18c68c1
SWDEV-1 - Bump patch version to 22800
mangupta Oct 14, 2022
80a1489
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 18, 2022
57ba04d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 20, 2022
ce9fb39
Promote till commit 'b26c932366de0be377544f04081d11b558421355'
mangupta Oct 21, 2022
e3f6abe
SWDEV-1 - Bump patch version to 22870
mangupta Oct 21, 2022
4b216a5
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Oct 30, 2022
f7abb6f
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 1, 2022
8c04036
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 3, 2022
3ad3ed7
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 4, 2022
83fb425
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 4, 2022
d44e4d0
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 9, 2022
48d545d
Promote till commit '57ba04d1594c3eefb1fa2900daec61529b46ae9e'
mangupta Nov 9, 2022
66c3ba6
SWDEV-1 - Bump patch version to 22990
mangupta Nov 9, 2022
5660cae
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 15, 2022
f40abcc
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 17, 2022
6bc3306
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 21, 2022
67dc15a
Promote till commit 'd44e4d00ba4068cd2e2055d48b94644cb9b56628'
mangupta Nov 21, 2022
9fe0f94
SWDEV-1 - Bump patch version to 23180
mangupta Nov 21, 2022
201502a
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Nov 23, 2022
c0d78ae
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 24, 2022
1728d69
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 25, 2022
ca40a56
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 29, 2022
cf417e5
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Nov 30, 2022
7aec03b
Promote till commit 'f40abcc7cf68df8f805f487b5c586039338f574c'
mangupta Dec 1, 2022
1c310c0
SWDEV-1 - Bump patch version to 23210
mangupta Dec 1, 2022
118d79a
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 6, 2022
7d8c0df
Promote till commit 'cf417e5dac7bb35aae5626a77cafe8492b926680'
mangupta Dec 13, 2022
b96b497
SWDEV-1 - Bump patch version to 23380
mangupta Dec 13, 2022
b799bb4
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 20, 2022
d92296b
SWDEV-299127 - Merge 'develop' into 'amd-staging'
mangupta Dec 20, 2022
b92ad31
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 21, 2022
95fec75
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Dec 23, 2022
9ee364f
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 3, 2023
8aa6cfe
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 5, 2023
cad6238
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 6, 2023
690fdb9
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 8, 2023
f3e9def
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 10, 2023
1c1b12d
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 10, 2023
125bf5f
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 16, 2023
e2e2bdf
SWDEV-299127 - Merge 'develop' into 'amd-staging'
Jan 18, 2023
27e43bf
Promote till commit 'e2e2bdff1d599979e5f4becbe462dfb05eefafbb'
mangupta Jan 27, 2023
d9459e6
SWDEV-1 - Bump patch version to 30200
mangupta Jan 27, 2023
8b48dbd
SWDEV-1 - Bump patch version to 30201
mangupta Feb 3, 2023
916d618
SWDEV-377267 - Update hip_build document for ROCm 5.5
jujiang-del Jan 11, 2023
471ddbf
SWDEV-379789 - Correct virtual function support information
jujiang-del Jan 27, 2023
abfaf1d
SWDEV-376665 - Correct information for hipStreamDestroy API
jujiang-del Jan 9, 2023
2525892
SWDEV-368819 - Add information on HIP APIs
jujiang-del Dec 15, 2022
b928ee0
SWDEV-336460 - Update description for scratch allocation API
jujiang-del Feb 8, 2023
38d2451
SWDEV-306306 - Update information for hipMemGetInfo API
jujiang-del Jan 20, 2023
67ce049
SWDEV-356879 - find_dependency instead of hsa path search
arvindcheru Jan 5, 2023
c96d5a0
SWDEV-355608 - deprecate/cleanup hipcc link flags (#3128)
scchan Jan 24, 2023
1dabde9
SWDEV-355543 - add descriptions in hip API parameters (#3163)
rocm-ci Feb 14, 2023
e63f21b
SWDEV-385406 - [hipcc] Pass HIP_PATH to clang
scchan Feb 24, 2023
b3ffe6a
SWDEV-354557 - correct typo in HIP direct dispatch document
jujiang-del Feb 8, 2023
f3d8fc8
SWDEV-397344 - Bump patch version to 30202
mangupta Apr 27, 2023
9837883
SWDEV-398296/SWDEV-393199 - Added new include file for opengl interop…
iassiour Apr 25, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion VERSION
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@
#HIP_VERSION_MINOR
5
#HIP_VERSION_PATCH
0
30202
71 changes: 34 additions & 37 deletions bin/hipcc.pl
Original file line number Diff line number Diff line change
Expand Up @@ -52,15 +52,21 @@

# retrieve --rocm-path hipcc option from command line.
# We need to respect this over the env var ROCM_PATH for this compilation.
sub get_rocm_path_option {
sub get_path_options {
my $rocm_path="";
my $hip_path="";
my @CLArgs = @ARGV;
foreach $arg (@CLArgs) {
if (index($arg,"--rocm-path=") != -1) {
($rocm_path) = $arg=~ /=\s*(.*)\s*$/;
next;
}
if (index($arg,"--hip-path=") != -1) {
($hip_path) = $arg=~ /=\s*(.*)\s*$/;
next;
}
}
return $rocm_path;
return ($rocm_path, $hip_path);
}

$verbose = $ENV{'HIPCC_VERBOSE'} // 0;
Expand Down Expand Up @@ -99,13 +105,16 @@ sub delete_temp_dirs {
}

my $base_dir;
my $rocmPath;
BEGIN {
$base_dir = dirname(Cwd::realpath(__FILE__) );
$rocmPath = get_rocm_path_option();
if ($rocmPath ne '') {
my ($rocm_path, $hip_path) = get_path_options();
if ($rocm_path ne '') {
# --rocm-path takes precedence over ENV{ROCM_PATH}
$ENV{ROCM_PATH}=$rocm_path;
}
if ($hip_path ne '') {
# --rocm-path takes precedence over ENV{ROCM_PATH}
$ENV{ROCM_PATH}=$rocmPath;
$ENV{HIP_PATH}=$hip_path;
}
}
use lib "$base_dir/";
Expand Down Expand Up @@ -199,10 +208,6 @@ BEGIN
print ("HIP_CLANG_RT_LIB=$HIP_CLANG_RT_LIB\n");
}

$HIPLDFLAGS .= " -L\"$HIP_LIB_PATH\"";
if ($isWindows) {
$HIPLDFLAGS .= " -lamdhip64";
}
if ($HIP_CLANG_HCC_COMPAT_MODE) {
## Allow __fp16 as function parameter and return type.
$HIPCXXFLAGS .= " -Xclang -fallow-half-arguments-and-returns -D__HIP_HCC_COMPAT_MODE__=1";
Expand Down Expand Up @@ -245,8 +250,6 @@ BEGIN
my $printLDFlags = 0; # print HIPLDFLAGS
my $runCmd = 1;
my $buildDeps = 0;
my $linkType = 1;
my $setLinkType = 0;
my $hsacoVersion = 0;
my $funcSupp = 0; # enable function support
my $rdc = 0; # whether -fgpu-rdc is on
Expand Down Expand Up @@ -361,16 +364,11 @@ BEGIN
$compileOnly = 1;
$buildDeps = 1;
}
if(($trimarg eq '-use-staticlib') and ($setLinkType eq 0))
{
$linkType = 0;
$setLinkType = 1;
$swallowArg = 1;
if($trimarg eq '-use-staticlib') {
print "Warning: The -use-staticlib option has been deprecated and is no longer needed.\n"
}
if(($trimarg eq '-use-sharedlib') and ($setLinkType eq 0))
{
$linkType = 1;
$setLinkType = 1;
if($trimarg eq '-use-sharedlib') {
print "Warning: The -use-sharedlib option has been deprecated and is no longer needed.\n"
}
if($arg =~ m/^-O/)
{
Expand Down Expand Up @@ -558,12 +556,6 @@ BEGIN
$HIPCXXFLAGS .= " --cuda-host-only";
}

# Add --hip-link only if it is compile only and -fgpu-rdc is on.
if ($rdc and !$compileOnly and $HIP_PLATFORM eq 'amd') {
$HIPLDFLAGS .= " --hip-link";
$HIPLDFLAGS .= $HIPLDARCHFLAGS;
}

# hipcc currrently requires separate compilation of source files, ie it is not possible to pass
# CPP files combined with .O files
# Reason is that NVCC uses the file extension to determine whether to compile in CUDA mode or
Expand All @@ -583,23 +575,28 @@ BEGIN
}
}

# If the HIP_PATH env var is defined, pass that path to Clang
if ($ENV{'HIP_PATH'}) {
my $hip_path_flag = " --hip-path=\"$HIP_PATH\"";
$HIPCXXFLAGS .= $hip_path_flag;
$HIPLDFLAGS .= $hip_path_flag;
}

if ($hasHIP) {
if ($DEVICE_LIB_PATH ne "$ROCM_PATH/amdgcn/bitcode") {
$HIPCXXFLAGS .= " --hip-device-lib-path=\"$DEVICE_LIB_PATH\"";
}
}
if (not $isWindows) {
$HIPLDFLAGS .= " -lgcc_s -lgcc -lpthread -lm -lrt";
}

if (not $isWindows and not $compileOnly) {
if ($linkType eq 0) {
$toolArgs = " -L$HIP_LIB_PATH -lamdhip64 -L$ROCM_PATH/lib -lhsa-runtime64 -ldl -lnuma " . ${toolArgs};
} else {
$toolArgs = ${toolArgs} . " -Wl,-rpath=$HIP_LIB_PATH:$ROCM_PATH/lib -lamdhip64 ";
}
if (!$compileOnly) {
$HIPLDFLAGS .= " --hip-link";
if ($rdc) {
$HIPLDFLAGS .= $HIPLDARCHFLAGS;
}
if (not $isWindows) {
$HIPLDFLAGS .= " --rtlib=compiler-rt -unwindlib=libgcc";

$toolArgs .= " -L$HIP_CLANG_RT_LIB -lclang_rt.builtins-x86_64 "
}
}
}

Expand Down
2 changes: 1 addition & 1 deletion bin/hipvars.pm
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ use File::Basename;

$HIP_BASE_VERSION_MAJOR = "5";
$HIP_BASE_VERSION_MINOR = "5";
$HIP_BASE_VERSION_PATCH = "0";
$HIP_BASE_VERSION_PATCH = "30202";

#---
# Function to parse config file
Expand Down
52 changes: 28 additions & 24 deletions docs/markdown/hip_build.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,15 +38,15 @@ Install Nvidia driver and pre-build packages (see HIP Installation Guide at http

## Branch of repository

Before get HIP source code, set the expected branch of repository at the variable HIP_BRANCH.
Before get HIP source code, set the expected branch of repository at the variable ROCM_BRANCH.
For example, for ROCm5.0 release branch, set
```
export HIP_BRANCH=rocm-5.0.x
export ROCM_BRANCH=rocm-5.0.x
```

ROCm5.1 release branch, set
ROCm5.4 release branch, set
```
export HIP_BRANCH=rocm-5.1.x
export ROCM_BRANCH=rocm-5.4.x
```
Similiar format for future branches.

Expand All @@ -59,9 +59,10 @@ ROCM_PATH is path where ROCM is installed. BY default ROCM_PATH is at /opt/rocm.
## Get HIP source code

```
git clone -b $HIP_BRANCH https://github.com/ROCm-Developer-Tools/hipamd.git
git clone -b $HIP_BRANCH https://github.com/ROCm-Developer-Tools/hip.git
git clone -b $HIP_BRANCH https://github.com/ROCm-Developer-Tools/ROCclr.git
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/hipamd.git
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/hip.git
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/ROCclr.git
git clone -b "$ROCM_BRANCH" https://github.com/RadeonOpenCompute/ROCm-OpenCL-Runtime.git
```

## Set the environment variables
Expand Down Expand Up @@ -136,51 +137,54 @@ Please note, the integrated HIP directed tests, will be deprecated in future rel

### Build HIP catch tests

After build and install HIP commands, catch tests can be built via the following instructions,
HIP catch tests, with new architectured Catch2, are official seperated from HIP project, exist in HIP tests repository, can be built via the following instructions.

#### Get HIP tests source code

```
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/hip-tests.git
```
#### Build HIP tests from source

```
cd "$HIP_DIR"
export HIP_TESTS_DIR="$(readlink -f hip-tests)"
cd "$HIP_TESTS_DIR"
mkdir -p build; cd build
export HIP_PATH=$HIPAMD_DIR/build/install
cmake ../tests/catch/ -DHIP_PLATFORM=amd
export HIP_PATH=$HIPAMD_DIR/build/install (or any path where HIP is installed, for example, /opt/rocm)
cmake ../catch/ -DHIP_PLATFORM=amd
make -j$(nproc) build_tests
ctest # run tests
```
HIP catch tests are built under the folder $HIP_TESTS_DIR/build.

HIP catch tests are built under the folder $HIP_DIR/build.

To run a single catch test, the following is an example,
To run any single catch test, the following is an example,

```
cd $HIP_DIR/build/unit/texture
cd $HIP_TESTS_DIR/build/catch_tests/unit/texture
./TextureTest
```

### Build HIP Catch2 standalone test
#### Build HIP Catch2 standalone test

HIP Catch2 supports build a standalone test, for example,

```
export PATH=$HIP_DIR/bin:$PATH
export HIP_PATH=$HIPAMD_DIR/build/install

hipcc $HIP_DIR/tests/catch/unit/memory/hipPointerGetAttributes.cc -I ./tests/catch/include ./tests/catch/hipTestMain/standalone_main.cc -I ./tests/catch/external/Catch2 -g -o hipPointerGetAttributes
cd "$HIP_TESTS_DIR"
hipcc $HIP_TESTS_DIR/catch/unit/memory/hipPointerGetAttributes.cc -I ./catch/include ./catch/hipTestMain/standalone_main.cc -I ./catch/external/Catch2 -o hipPointerGetAttributes
./hipPointerGetAttributes
...

All tests passed
```

HIP catch tests, especially new architectured Catch2, will be official HIP tests in the repository and can be built alone as with the instructions shown above.

# Build HIP on NVIDIA platform


## Get HIP source code

```
git clone -b $HIP_BRANCH https://github.com/ROCm-Developer-Tools/hip.git
git clone -b $HIP_BRANCH https://github.com/ROCm-Developer-Tools/hipamd.git
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/hip.git
git clone -b "$ROCM_BRANCH" https://github.com/ROCm-Developer-Tools/hipamd.git
```

## Set the environment variables
Expand Down
3 changes: 2 additions & 1 deletion docs/markdown/hip_kernel_language.md
Original file line number Diff line number Diff line change
Expand Up @@ -862,8 +862,9 @@ Output Constraints are specified by an `"="` prefix as shown above ("=v"). This
## C++ Support
The following C++ features are not supported:
- Run-time-type information (RTTI)
- Virtual functions
- Try/catch
- Virtual functions
Virtual functions are not supported if objects containing virtual function tables are passed between GPU's of different offload arch's, e.g. between gfx906 and gfx1030. Otherwise virtual functions are supported.

## Kernel Compilation
hipcc now supports compiling C++/HIP kernels to binary code objects.
Expand Down
4 changes: 2 additions & 2 deletions docs/markdown/hip_programming_guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -108,9 +108,9 @@ A stronger system-level fence can be specified when the event is created with hi
- HIP/ROCm also supports the ability to cache host memory in the GPU using the "Non-Coherent" host memory allocations. This can provide performance benefit, but care must be taken to use the correct synchronization.

## Direct Dispatch
HIP runtime has Direct Dispatch enabled by default in ROCM 4.4. With this feature we move away from our conventional producer-consumer model where the runtime creates a worker thread(consumer) for each HIP Stream, where as the host thread(producer) enqueues commands to a command queue(per stream).
HIP runtime has Direct Dispatch enabled by default in ROCM 4.4. With this feature we move away from our conventional producer-consumer model where the runtime creates a worker thread(consumer) for each HIP Stream, and the host thread(producer) enqueues commands to a command queue(per stream).

For Direct Dispatch, the runtime would directly queue a packet to the AQL queue (user mode queue to GPU) in case of Dispatch and some of the synchronization. This has shown to the total latency of the HIP Dispatch API and latency to launch first wave on the GPU.
For Direct Dispatch, HIP runtime would directly enqueue a packet to the AQL queue (user mode queue on GPU) on the Dispatch API call from the application. That has shown to reduce the latency to launch the first wave on the idle GPU and total time of tiny dispatches synchronized with the host.

In addition, eliminating the threads in runtime has reduced the variance in the dispatch numbers as the thread scheduling delays and atomics/locks synchronization latencies are reduced.

Expand Down
21 changes: 2 additions & 19 deletions hip-lang-config.cmake.in
Original file line number Diff line number Diff line change
Expand Up @@ -72,32 +72,15 @@ get_filename_component(_DIR "${CMAKE_CURRENT_LIST_FILE}" REALPATH)
get_filename_component(_IMPORT_PREFIX "${_DIR}/../../../../" ABSOLUTE)


#If HIP isnot installed under ROCm, need this to find HSA assuming HSA is under ROCm
if( DEFINED ENV{ROCM_PATH} )
set(ROCM_PATH "$ENV{ROCM_PATH}")
endif()

#if HSA is not under ROCm then provide CMAKE_PREFIX_PATH=<HSA_PATH>
find_path(HSA_HEADER hsa/hsa.h
PATHS
"${_IMPORT_PREFIX}/include"
"${ROCM_PATH}/include"
)

if (NOT HSA_HEADER)
message (FATAL_ERROR "HSA header not found! ROCM_PATH environment not set")
endif()


set_target_properties(hip-lang::device PROPERTIES
INTERFACE_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include>"
INTERFACE_SYSTEM_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include>"
)

set_target_properties(hip-lang::amdhip64 PROPERTIES
INTERFACE_COMPILE_DEFINITIONS "$<$<COMPILE_LANGUAGE:HIP>:__HIP_ROCclr__=1>"
INTERFACE_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include;${HSA_HEADER}>"
INTERFACE_SYSTEM_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include;${HSA_HEADER}>"
INTERFACE_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include>"
INTERFACE_SYSTEM_INCLUDE_DIRECTORIES "$<$<COMPILE_LANGUAGE:HIP>:${_IMPORT_PREFIX}/include>"
)
set_target_properties(hip-lang::device PROPERTIES
INTERFACE_COMPILE_DEFINITIONS "$<$<COMPILE_LANGUAGE:HIP>:__HIP_ROCclr__=1>"
Expand Down
30 changes: 30 additions & 0 deletions include/hip/hip_gl_interop.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
/*
Copyright (c) 2023 Advanced Micro Devices, Inc. All rights reserved.

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*/
#ifndef HIP_GL_INTEROP_H
#define HIP_GL_INTEROP_H

#include <hip/hip_common.h>

#if !(defined(__HIP_PLATFORM_HCC__) || defined(__HIP_PLATFORM_AMD__)) && (defined(__HIP_PLATFORM_NVCC__) || defined(__HIP_PLATFORM_NVIDIA__))
#include "hip/nvidia_detail/nvidia_hip_gl_interop.h"
#endif
#endif
Loading