am.h 2.4 KB
Newer Older
Y
Yanyan Jiang 已提交
1
/*
Y
Yanyan Jiang 已提交
2
 * The Nexus Abstract Machine Architecture (AM)
Y
Yanyan Jiang 已提交
3
 * A portable abstraction of a bare-metal computer
Y
Yanyan Jiang 已提交
4
 */
Y
Yanyan Jiang 已提交
5

Y
Yanyan Jiang 已提交
6 7 8
#ifndef __AM_H__
#define __AM_H__

9 10 11 12
#define __XSTR(x) #x
#define __STR(x) __XSTR(x)
#define ARCH_H_PATH __STR(arch/__ARCH__.h)

13
#include <stdint.h>
Y
Yanyan Jiang 已提交
14
#include <stddef.h>
15
#include ARCH_H_PATH // "arch/x86-qemu.h"
16

Y
Yanyan Jiang 已提交
17 18 19 20
#ifdef __cplusplus
extern "C" {
#endif

J
jyy 已提交
21
// ===================== Constants and Structs =======================
Y
Yanyan Jiang 已提交
22

J
jyy 已提交
23 24
enum {
  _EVENT_NULL = 0,
Y
Yanyan Jiang 已提交
25
  _EVENT_ERROR,
J
jyy 已提交
26 27 28 29 30 31 32
  _EVENT_IRQ_TIMER,
  _EVENT_IRQ_IODEV,
  _EVENT_PAGEFAULT,
  _EVENT_YIELD,
  _EVENT_SYSCALL,
};

33 34 35 36 37 38
enum {
  _PROT_NONE  = 1, // no access
  _PROT_READ  = 2, // can read
  _PROT_WRITE = 4, // can write
  _PROT_EXEC  = 8, // can execute
};
J
jyy 已提交
39

Y
Yanyan Jiang 已提交
40
// Memory area for [@start, @end)
Y
Yanyan Jiang 已提交
41 42 43 44
typedef struct _Area {
  void *start, *end;
} _Area; 

J
jyy 已提交
45
// An event of type @event, caused by @cause of pointer @ref
Y
Yanyan Jiang 已提交
46 47 48
typedef struct _Event {
  int event;
  uintptr_t cause, ref;
Y
Yanyan Jiang 已提交
49
  const char *msg;
Y
Yanyan Jiang 已提交
50
} _Event;
51 52

// Arch-dependent processor context
Y
Yanyan Jiang 已提交
53
typedef struct _Context _Context;
Y
Yanyan Jiang 已提交
54

J
jyy 已提交
55 56
// A protected address space with user memory @area
// and arch-dependent @ptr
57
typedef struct _AddressSpace {
Y
Yanyan Jiang 已提交
58 59
  size_t pgsize;
  _Area area;
Y
Yanyan Jiang 已提交
60
  void *ptr;
61
} _AddressSpace;
Y
Yanyan Jiang 已提交
62

Y
Yanyan Jiang 已提交
63
// ====================== Turing Machine (TRM) =======================
J
jyy 已提交
64 65 66

extern _Area _heap;
void _putc(char ch);
Y
Yanyan Jiang 已提交
67
void _halt(int code) __attribute__((__noreturn__));
J
jyy 已提交
68 69 70 71

// ======================= I/O Extension (IOE) =======================

int _ioe_init();
72 73
size_t _io_read(uint32_t dev, uintptr_t reg, void *buf, size_t size);
size_t _io_write(uint32_t dev, uintptr_t reg, void *buf, size_t size);
J
jyy 已提交
74

Z
Zihao Yu 已提交
75
// ====================== Context Extension (CTE) ====================
J
jyy 已提交
76

Z
Zihao Yu 已提交
77
int _cte_init(_Context *(*handler)(_Event ev, _Context *ctx));
J
jyy 已提交
78 79 80
void _yield();
int _intr_read();
void _intr_write(int enable);
Y
Yanyan Jiang 已提交
81
_Context *_kcontext(_Area kstack, void (*entry)(void *), void *arg);
J
jyy 已提交
82

Z
Zihao Yu 已提交
83
// ================= Virtual Memory Extension (VME) ==================
J
jyy 已提交
84

Z
Zihao Yu 已提交
85
int _vme_init(void *(*pgalloc)(size_t size), void (*pgfree)(void *));
86 87 88 89
int _protect(_AddressSpace *as);
void _unprotect(_AddressSpace *as);
int _map(_AddressSpace *as, void *va, void *pa, int prot);
_Context *_ucontext(_AddressSpace *as, _Area ustack, _Area kstack,
Y
Yanyan Jiang 已提交
90
                                 void *entry, void *args);
Y
Yanyan Jiang 已提交
91

J
jyy 已提交
92
// ================= Multi-Processor Extension (MPE) =================
Y
Yanyan Jiang 已提交
93

J
jyy 已提交
94
int _mpe_init(void (*entry)());
Y
Yanyan Jiang 已提交
95
int _ncpu();
Y
Yanyan Jiang 已提交
96
int _cpu();
Y
Yanyan Jiang 已提交
97
intptr_t _atomic_xchg(volatile intptr_t *addr, intptr_t newval);
Y
Yanyan Jiang 已提交
98 99 100 101 102

#ifdef __cplusplus
}
#endif

103
#endif