Julian Brown 5d5be7bfb5 OpenACC 2.6 deep copy: attach/detach API routines
libgomp/
	* libgomp.h (struct splay_tree_aux): Add attach_count field.
	(gomp_attach_pointer, gomp_detach_pointer): Add prototypes.
	* libgomp.map (OACC_2.6): New section. Add acc_attach,
	acc_attach_async, acc_detach, acc_detach_async, acc_detach_finalize,
	acc_detach_finalize_async.
	* oacc-mem.c (acc_attach_async, acc_attach, goacc_detach_internal,
	acc_detach, acc_detach_async, acc_detach_finalize,
	acc_detach_finalize_async): New functions.
	* openacc.h (acc_attach, acc_attach_async, acc_detach,
	(acc_detach_async, acc_detach_finalize, acc_detach_finalize_async): Add
	prototypes.
	* target.c (gomp_attach_pointer, gomp_detach_pointer): New functions.
	(gomp_remove_var_internal): Free attachment counts if present.
	* testsuite/libgomp.oacc-c-c++-common/deep-copy-3.c: New test.
	* testsuite/libgomp.oacc-c-c++-common/deep-copy-5.c: New test.

Co-Authored-By: Thomas Schwinge <thomas@codesourcery.com>

From-SVN: r279624
2019-12-20 01:20:27 +00:00

82 lines
1.3 KiB
C

#include <assert.h>
#include <stdlib.h>
#include <openacc.h>
struct node
{
struct node *next;
int val;
};
int
sum_nodes (struct node *head)
{
int i = 0, sum = 0;
#pragma acc parallel reduction(+:sum) present(head[:1])
{
for (; head != NULL; head = head->next)
sum += head->val;
}
return sum;
}
void
insert (struct node *head, int val)
{
struct node *n = (struct node *) malloc (sizeof (struct node));
if (head->next)
acc_detach ((void **) &head->next);
n->val = val;
n->next = head->next;
head->next = n;
acc_copyin (n, sizeof (struct node));
acc_attach((void **) &head->next);
if (n->next)
acc_attach ((void **) &n->next);
}
void
destroy (struct node *head)
{
while (head->next != NULL)
{
acc_detach ((void **) &head->next);
struct node * n = head->next;
head->next = n->next;
if (n->next)
acc_detach ((void **) &n->next);
acc_delete (n, sizeof (struct node));
if (head->next)
acc_attach((void **) &head->next);
free (n);
}
}
int
main ()
{
struct node list = { .next = NULL, .val = 0 };
int i;
acc_copyin (&list, sizeof (struct node));
for (i = 0; i < 10; i++)
insert (&list, 2);
assert (sum_nodes (&list) == 10 * 2);
destroy (&list);
acc_delete (&list, sizeof (struct node));
return 0;
}