Files
rust/src/rt/rust_kernel.h
T
2012-02-03 23:48:12 -08:00

68 lines
1.5 KiB
C++

// -*- c++ -*-
#ifndef RUST_KERNEL_H
#define RUST_KERNEL_H
#include "memory_region.h"
#include "rust_log.h"
struct rust_task_thread;
struct rust_scheduler;
/**
* A global object shared by all thread domains. Most of the data structures
* in this class are synchronized since they are accessed from multiple
* threads.
*/
class rust_kernel {
memory_region _region;
rust_log _log;
public:
rust_srv *srv;
private:
rust_scheduler *sched;
// Tracks the number of tasks that are being managed by
// schedulers. When this hits 0 we will tell all schedulers
// to exit.
volatile int live_tasks;
// Protects max_task_id and task_table
lock_and_signal task_lock;
rust_task_id max_task_id;
hash_map<rust_task_id, rust_task *> task_table;
lock_and_signal rval_lock;
int rval;
public:
struct rust_env *env;
rust_kernel(rust_srv *srv, size_t num_threads);
~rust_kernel();
void log(uint32_t level, char const *fmt, ...);
void fatal(char const *fmt, ...);
void *malloc(size_t size, const char *tag);
void *realloc(void *mem, size_t size);
void free(void *mem);
void fail();
int start_schedulers();
rust_scheduler* get_default_scheduler();
#ifdef __WIN32__
void win32_require(LPCTSTR fn, BOOL ok);
#endif
void register_task(rust_task *task);
rust_task *get_task_by_id(rust_task_id id);
void release_task_id(rust_task_id tid);
void set_exit_status(int code);
};
#endif /* RUST_KERNEL_H */