1
1
openmpi/orte/test/system/opal_hotel.c
2015-07-24 07:34:59 -07:00

107 строки
2.9 KiB
C

/* -*- C -*-
*
* $HEADER$
*
*/
#include <stdio.h>
#include <unistd.h>
#include "opal/mca/event/event.h"
#include "opal/class/opal_hotel.h"
#include "opal/runtime/opal.h"
#include "opal/runtime/opal_progress.h"
#define NUM_OCC 200
#define NUM_RMS 128
#define NUM_CYCLES 10
static int num_evicted = 0;
typedef struct {
int id;
int room;
} occupant_t;
occupant_t occupants[NUM_OCC];
occupant_t *checked_out[NUM_OCC];
static void evict_cbfunc(opal_hotel_t *hotel,
int room_num,
void *occupant_arg)
{
int *occupant = (int*) occupant_arg;
fprintf(stderr, "Room %d / occupant %d evicted!\n", *occupant, room_num);
++num_evicted;
}
int main(int argc, char* argv[])
{
int rc;
opal_hotel_t hotel;
int i, j, rm;
int num_occupied;
if (0 > (rc = opal_init(&argc, &argv))) {
fprintf(stderr, "orte_hotel: couldn't init opal - error code %d\n", rc);
return rc;
}
OBJ_CONSTRUCT(&hotel, opal_hotel_t);
opal_hotel_init(&hotel, NUM_RMS, opal_sync_event_base,
3000000, OPAL_EV_SYS_HI_PRI, evict_cbfunc);
/* prep the occupants */
for (i=0; i < NUM_OCC; i++) {
occupants[i].id = i;
occupants[i].room = -1;
}
/* arbitrarily checkin/checkout some things */
for (i=0; i < NUM_RMS; i++) {
if (OPAL_SUCCESS != opal_hotel_checkin(&hotel,
(void*)(&occupants[i]), &rm)) {
fprintf(stderr, "Hotel is fully occupied\n");
continue;
}
occupants[i].room = rm;
fprintf(stderr, "Occupant %d checked into room %d\n",
occupants[i].id, rm);
}
num_occupied = NUM_RMS;
fprintf(stderr, "---------------------------------------\n");
/* cycle thru adding and removing some */
for (i=0; i < NUM_CYCLES; i++) {
for (j=0; j < 30; j++) {
fprintf(stderr, "Checking occupant %d out of room %d\n",
occupants[i + j].id, occupants[i + j].room);
opal_hotel_checkout(&hotel, occupants[i + j].room);
--num_occupied;
}
for (j=0; j < 30; j++) {
if (OPAL_SUCCESS !=
opal_hotel_checkin(&hotel, (void*) &(occupants[i + j]), &rm)) {
fprintf(stderr, "Hotel is fully occupied\n");
continue;
}
occupants[i + j].room = rm;
fprintf(stderr, "Occupant %d checked into room %d\n",
occupants[i + j].id, rm);
++num_occupied;
}
fprintf(stderr, "---------------------------------------\n");
}
/* sit here and see if we get an eviction notice */
fprintf(stderr, "Waiting for %d evictions...\n", num_occupied);
while (num_evicted < num_occupied) {
opal_progress();
}
fprintf(stderr, "All occupants evicted!\n");
OBJ_DESTRUCT(&hotel);
opal_finalize();
return 0;
}