Hi!

The test PASSes for C, but FAILs for C++:
.../libgomp.c-c++-common/omp_target_memset-3.c: In function 'void 
test_it(void*, int, size_t)':
.../libgomp.c-c++-common/omp_target_memset-3.c:31:7: warning: pointer of type 
'void *' used in arithmetic [-Wpointer-arith]
.../libgomp.c-c++-common/omp_target_memset-3.c:33:13: error: invalid conversion 
from 'void*' to 'int8_t*' {aka 'signed char*'} [-fpermissive]
.../libgomp.c-c++-common/omp_target_memset-3.c:10:19: note: initializing 
argument 1 of 'void init_val(int8_t*, int, size_t)'
.../libgomp.c-c++-common/omp_target_memset-3.c:37:14: error: invalid conversion 
from 'void*' to 'int8_t*' {aka 'signed char*'} [-fpermissive]
.../libgomp.c-c++-common/omp_target_memset-3.c:17:20: note: initializing 
argument 1 of 'void check_val(int8_t*, int, size_t)'
.../libgomp.c-c++-common/omp_target_memset-3.c:38:18: warning: pointer of type 
'void *' used in arithmetic [-Wpointer-arith]
.../libgomp.c-c++-common/omp_target_memset-3.c:38:18: error: invalid conversion 
from 'void*' to 'int8_t*' {aka 'signed char*'} [-fpermissive]
.../libgomp.c-c++-common/omp_target_memset-3.c:17:20: note: initializing 
argument 1 of 'void check_val(int8_t*, int, size_t)'
.../libgomp.c-c++-common/omp_target_memset-3.c: In function 'int main()':
.../libgomp.c-c++-common/omp_target_memset-3.c:46:7: warning: pointer of type 
'void *' used in arithmetic [-Wpointer-arith]

The following two-liner fixes that, tested on x86_64-linux and i686-linux.
Committed to trunk as obvious.

2025-06-03  Jakub Jelinek  <ja...@redhat.com>

        PR libgomp/120444
        * testsuite/libgomp.c-c++-common/omp_target_memset-3.c (test_it):
        Change ptr argument type from void * to int8_t *.
        (main): Change ptr variable type from void * to int8_t * and cast
        omp_target_alloc result to the latter type.

--- libgomp/testsuite/libgomp.c-c++-common/omp_target_memset-3.c.jj     
2025-06-02 21:58:22.144775795 +0200
+++ libgomp/testsuite/libgomp.c-c++-common/omp_target_memset-3.c        
2025-06-03 07:45:37.967822215 +0200
@@ -24,7 +24,7 @@ check_val (int8_t *ptr, int val, size_t
 }
 
 static void
-test_it (void *ptr, int lshift, size_t count)
+test_it (int8_t *ptr, int lshift, size_t count)
 {
   if (N < count + lshift) __builtin_abort ();
   if (lshift >= 4) __builtin_abort ();
@@ -42,7 +42,7 @@ test_it (void *ptr, int lshift, size_t c
 int main()
 {
   size_t size;
-  void *ptr = omp_target_alloc (N + 3, omp_get_default_device());
+  int8_t *ptr = (int8_t *) omp_target_alloc (N + 3, omp_get_default_device());
   ptr += (4 - (uintptr_t) ptr % 4) % 4;
   if ((uintptr_t) ptr % 4 != 0) __builtin_abort ();
 

        Jakub

Reply via email to