1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-22 07:52:12 +01:00

89 lines
2.2 KiB
C

/*
# This file is Copyright 2007, 2009, 2010 Dean Hall.
#
# This file is part of the PyMite VM.
# The PyMite VM is free software: you can redistribute it and/or modify
# it under the terms of the GNU GENERAL PUBLIC LICENSE Version 2.
#
# The PyMite VM is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# A copy of the GNU GENERAL PUBLIC LICENSE Version 2
# is seen in the file COPYING in this directory.
*/
#ifndef __THREAD_H__
#define __THREAD_H__
/**
* \file
* \brief VM Thread
*
* Encapsulating a frame pointer, a root code object and thread state.
*/
#include "interp.h"
/** Frequency in Hz to switch threads */
#define THREAD_RESCHEDULE_FREQUENCY 10
/**
* Interpreter return values
*
* Used to control interpreter loop
* and indicate return value.
* Negative values indicate erroneous results.
* Positive values indicate "continue interpreting",
* but first do something special like reschedule threads
* or (TBD) sweep the heap.
*/
typedef enum PmInterpCtrl_e
{
/* other erroneous exits go here with negative values */
INTERP_CTRL_ERR = -1, /**< Generic error causes exit */
INTERP_CTRL_EXIT = 0, /**< Normal execution exit */
INTERP_CTRL_CONT = 1, /**< Continue interpreting */
INTERP_CTRL_RESCHED = 2 /**< Reschedule threads */
/* all positive values indicate "continue interpreting" */
} PmInterpCtrl_t, *pPmInterpCtrl_t;
/**
* Thread obj
*
*/
typedef struct PmThread_s
{
/** object descriptor */
PmObjDesc_t od;
/** current frame pointer */
pPmFrame_t pframe;
/**
* Interpreter loop control value
*
* A positive value means continue interpreting.
* A zero value means normal interpreter exit.
* A negative value signals an error exit.
*/
PmInterpCtrl_t interpctrl;
} PmThread_t,
*pPmThread_t;
/**
* Constructs a thread for a root frame.
*
* @param pframe Frame object as a basis for this thread.
* @param r_pobj Return by reference; Ptr to the newly created thread object.
* @return Return status
*/
PmReturn_t thread_new(pPmObj_t pframe, pPmObj_t *r_pobj);
#endif /* __THREAD_H__ */