70 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Copyright (c) 2023 Barcelona Supercomputing Center (BSC)
 | 
						|
 * SPDX-License-Identifier: GPL-3.0-or-later */
 | 
						|
 | 
						|
#include <stdlib.h>
 | 
						|
#include "compat.h"
 | 
						|
#include "instr.h"
 | 
						|
#include "instr_tampi.h"
 | 
						|
 | 
						|
int
 | 
						|
main(void)
 | 
						|
{
 | 
						|
	/* Test that simulates the polling task of TAMPI */
 | 
						|
 | 
						|
	const int rank = atoi(getenv("OVNI_RANK"));
 | 
						|
	const int nranks = atoi(getenv("OVNI_NRANKS"));
 | 
						|
 | 
						|
	instr_start(rank, nranks);
 | 
						|
 | 
						|
	const int transfer_step = 5;
 | 
						|
	const int complete_step = 3;
 | 
						|
 | 
						|
	int nreqs_to_transfer = 100;
 | 
						|
	int nreqs_to_test = 0;
 | 
						|
	int t, c;
 | 
						|
 | 
						|
	/* Simulate the loop of the polling task */
 | 
						|
	while (nreqs_to_transfer || nreqs_to_test) {
 | 
						|
		instr_tampi_library_polling_enter();
 | 
						|
 | 
						|
		t = 0;
 | 
						|
		instr_tampi_transfer_queues_enter();
 | 
						|
		while (nreqs_to_transfer && t < transfer_step) {
 | 
						|
			/* Transfer a request/ticket to the global array */
 | 
						|
			--nreqs_to_transfer;
 | 
						|
			++nreqs_to_test;
 | 
						|
			++t;
 | 
						|
		}
 | 
						|
		instr_tampi_transfer_queues_exit();
 | 
						|
 | 
						|
		/* Check the global array of requests/tickets */
 | 
						|
		if (nreqs_to_test) {
 | 
						|
			instr_tampi_check_global_array_enter();
 | 
						|
 | 
						|
			/* Testsome requests */
 | 
						|
			instr_tampi_testsome_requests_enter();
 | 
						|
			sleep_us(10);
 | 
						|
			instr_tampi_testsome_requests_exit();
 | 
						|
 | 
						|
			c = 0;
 | 
						|
			while (nreqs_to_test && c < complete_step) {
 | 
						|
				/* Process a completed request */
 | 
						|
				instr_tampi_completed_request_enter();
 | 
						|
				sleep_us(1);
 | 
						|
				instr_tampi_completed_request_exit();
 | 
						|
				--nreqs_to_test;
 | 
						|
				++c;
 | 
						|
			}
 | 
						|
			instr_tampi_check_global_array_exit();
 | 
						|
		}
 | 
						|
 | 
						|
		instr_tampi_library_polling_exit();
 | 
						|
 | 
						|
		sleep_us(100);
 | 
						|
	}
 | 
						|
 | 
						|
	instr_end();
 | 
						|
 | 
						|
	return 0;
 | 
						|
}
 |