You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
inthostname_size=MAX_HOSTNAME_LEN;
inti, errors=0;
char*hostname= (char*) shmem_malloc (hostname_size*sizeof(char));
char*dest= (char*) shmem_malloc (my_info->num_pes*hostname_size*sizeof(char));
if (hostname==NULL||dest==NULL) {
fprintf(stderr, "shmem_malloc failed to allocate for hostname strings\n");
return-1;
}
hostname_status=gethostname(hostname, hostname_size);
if (hostname_status!=0) {
fprintf(stderr, "gethostname failed (%d)\n", hostname_status);
return-1;
}
The issue is MAX_HOSTNAME_LEN is the maximum total characters of the hostname not including the end of string character '\0'. If the hostname happens to be 64 characters long, gethostname() would return an error and shmem_runtime_util_put_hostname() would state error "gethostname failed (-1)"
The input length parameter needs to be set to MAX_HOSTNAME_LEN+1
The text was updated successfully, but these errors were encountered:
MAX_HOSTNAME_LEN is the maximum total characters of the hostname not
including the end of string character '\0'. If the hostname happens to
be 64 characters long, gethostname() would return an error and
shmem_runtime_util_put_hostname() would state error "gethostname failed (-1)"
Changed length to MAX_HOSTNAME_LEN+1
Issue openshmem-org#48
Signed-off-by: Mark F. Brown <[email protected]>
test/performance/shmem_perf_suite/common.h:check_hostname_validation()
The issue is MAX_HOSTNAME_LEN is the maximum total characters of the hostname not including the end of string character '\0'. If the hostname happens to be 64 characters long, gethostname() would return an error and shmem_runtime_util_put_hostname() would state error "gethostname failed (-1)"
The input length parameter needs to be set to MAX_HOSTNAME_LEN+1
The text was updated successfully, but these errors were encountered: