/*  vm.c -- virtual machine management  */

#include "rts.h"

static Mutex cre_mutex;



/*
 *  Initialize virtual machine mutex.
 */
void
mpd_init_vm ()
{
    INIT_LOCK (cre_mutex, "cre_mutex");
}



/*
 *  Specify location of physical machine.
 */
void
mpd_locate (locn, n, host, exe)
char *locn;
int n;
String *host, *exe;
{
    struct locn_st lr;
    Pach ph;
    int size;
    static String nullstring = { STRING_OVH, 0 };

    mpd_check_stk (CUR_STACK);
    if (!exe)
	exe = &nullstring;

    mpd_init_net ((Ptr) NULL);		/* start up the network, if not up */
    size = (lr.text + host->length + 1 + exe->length + 1) - (char *) &lr;
    if (size > sizeof (lr))
	mpd_loc_abort (locn, "strings too long in locate call");
    lr.num = n;
    memcpy (lr.text, DATA (host), host->length);
    lr.text [host->length] = '\0';
    memcpy (lr.text + host->length + 1, DATA (exe), exe->length);
    lr.text [host->length + 1 + exe->length] = '\0';
    ph = mpd_remote (MPDX_VM, REQ_LOCVM, (Pach) &lr, size);
    mpd_free ((Ptr) ph);			/* free reply packet */
}



/*
 *  Create new virtual machine.  Return its number.
 */
Vcap
mpd_crevm (locn, physm)
char *locn;
int physm;
{
    struct num_st vr;
    Pach ph;
    Vcap v;

    mpd_check_stk (CUR_STACK);
    TRACE ("CREATEV", locn, 0);
    mpd_init_net ((Ptr) NULL);			/* start network, if not up */
    vr.num = physm;				/* set physical machine */
    ph = mpd_remote (MPDX_VM, REQ_CREVM, (Pach) &vr, sizeof (vr));
						/* call mpdx to create the vm */
    v = ((struct num_st *) ph) -> num;		/* save virtual machine no. */
    mpd_free ((Ptr) ph);				/* free reply packet */

    DEBUG (D_MPDX_ACT, "mpd_crevm (%ld) returning %ld", physm, v, 0);
    return v;
}



/*
 *  Create new virtual machine by name.  Return its number.
 */
Vcap
mpd_crevm_name (locn, host)
char *locn;
String *host;
{
    static int num_crevm_name = 0;	/* count of creates by name */
    int n;

    LOCK (cre_mutex, "mpd_crevm_name");
    num_crevm_name++;
    n = - (mpd_my_vm * 1000 + num_crevm_name);
    UNLOCK (cre_mutex, "mpd_crevm_name");
    mpd_locate (locn, n, host, (String *) 0);
    return mpd_crevm (locn, n);
}



/*
 *  Destroy virtual machine.
 */
void
mpd_destvm (locn, vm)
char *locn;
int vm;
{
    struct num_st vr;
    Pach ph;

    CUR_PROC->locn = locn;		/* add locn to proc structure */

    TRACE ("DESTROYV", locn, 0);
    mpd_check_stk (CUR_STACK);
    if (vm == NOOP_VM)
	return;
    if (vm == NULL_VM)
	mpd_loc_abort (locn, "attempting to destroy null vm");

    mpd_init_net ((Ptr) NULL);		/* start network if not up */
    vr.num = vm;			/* set virtual machine number */
    vr.ph.priority = CUR_PROC->priority;
    ph = mpd_remote (MPDX_VM, REQ_DESTVM, (Pach) &vr, sizeof (vr));
					/* ask mpdx to destroy the vm */
    mpd_free ((Ptr) ph);			/* free reply packet */
}


syntax highlighted by Code2HTML, v. 0.9.1