support private mapped file
This commit is contained in:
60
kernel/include/memobj.h
Normal file
60
kernel/include/memobj.h
Normal file
@@ -0,0 +1,60 @@
|
||||
#ifndef HEADER_MEMOBJ_H
|
||||
#define HEADER_MEMOBJ_H
|
||||
|
||||
#include <ihk/types.h>
|
||||
#include <ihk/atomic.h>
|
||||
#include <ihk/lock.h>
|
||||
#include <list.h>
|
||||
|
||||
struct memobj {
|
||||
struct memobj_ops * ops;
|
||||
ihk_spinlock_t lock;
|
||||
};
|
||||
|
||||
typedef void memobj_release_func_t(struct memobj *obj);
|
||||
typedef void memobj_ref_func_t(struct memobj *obj);
|
||||
typedef int memobj_get_page_func_t(struct memobj *obj, off_t off, int p2align, uintptr_t *physp);
|
||||
typedef uintptr_t memobj_copy_page_func_t(struct memobj *obj, uintptr_t orgphys, int p2align);
|
||||
|
||||
struct memobj_ops {
|
||||
memobj_release_func_t * release;
|
||||
memobj_ref_func_t * ref;
|
||||
memobj_get_page_func_t * get_page;
|
||||
memobj_copy_page_func_t * copy_page;
|
||||
};
|
||||
|
||||
static inline void memobj_release(struct memobj *obj)
|
||||
{
|
||||
(*obj->ops->release)(obj);
|
||||
}
|
||||
|
||||
static inline void memobj_ref(struct memobj *obj)
|
||||
{
|
||||
(*obj->ops->ref)(obj);
|
||||
}
|
||||
|
||||
static inline int memobj_get_page(struct memobj *obj, off_t off,
|
||||
int p2align, uintptr_t *physp)
|
||||
{
|
||||
return (*obj->ops->get_page)(obj, off, p2align, physp);
|
||||
}
|
||||
|
||||
static inline uintptr_t memobj_copy_page(struct memobj *obj,
|
||||
uintptr_t orgphys, int p2align)
|
||||
{
|
||||
return (*obj->ops->copy_page)(obj, orgphys, p2align);
|
||||
}
|
||||
|
||||
static inline void memobj_lock(struct memobj *obj)
|
||||
{
|
||||
ihk_mc_spinlock_lock_noirq(&obj->lock);
|
||||
}
|
||||
|
||||
static inline void memobj_unlock(struct memobj *obj)
|
||||
{
|
||||
ihk_mc_spinlock_unlock_noirq(&obj->lock);
|
||||
}
|
||||
|
||||
int fileobj_create(int fd, struct memobj **objp, int *maxprotp);
|
||||
|
||||
#endif /* HEADER_MEMOBJ_H */
|
||||
@@ -2,16 +2,28 @@
|
||||
#define __HEADER_PAGE_H
|
||||
|
||||
struct page {
|
||||
struct list_head list;
|
||||
uint64_t flags;
|
||||
int64_t count;
|
||||
struct list_head list;
|
||||
uint8_t mode;
|
||||
uint8_t padding[3];
|
||||
int32_t count;
|
||||
off_t offset;
|
||||
};
|
||||
|
||||
/* flags */
|
||||
#define PAGE_IN_LIST 0x0001UL
|
||||
/* mode */
|
||||
enum page_mode {
|
||||
PM_NONE = 0x00,
|
||||
PM_PENDING_FREE = 0x01,
|
||||
PM_WILL_PAGEIO = 0x02,
|
||||
PM_PAGEIO = 0x03,
|
||||
PM_DONE_PAGEIO = 0x04,
|
||||
PM_PAGEIO_EOF = 0x05,
|
||||
PM_PAGEIO_ERROR = 0x06,
|
||||
PM_MAPPED = 0x07,
|
||||
};
|
||||
|
||||
struct page *phys_to_page(uintptr_t phys);
|
||||
uintptr_t page_to_phys(struct page *page);
|
||||
int page_unmap(struct page *page);
|
||||
|
||||
void *allocate_pages(int npages, enum ihk_mc_ap_flag flag);
|
||||
void free_pages(void *va, int npages);
|
||||
|
||||
27
kernel/include/pager.h
Normal file
27
kernel/include/pager.h
Normal file
@@ -0,0 +1,27 @@
|
||||
#ifndef HEADER_PAGER_H
|
||||
#define HEADER_PAGER_H
|
||||
|
||||
#include <ihk/types.h>
|
||||
|
||||
enum pager_op {
|
||||
PAGER_REQ_CREATE = 0x0001,
|
||||
PAGER_REQ_RELEASE = 0x0002,
|
||||
PAGER_REQ_READ = 0x0003,
|
||||
};
|
||||
|
||||
/*
|
||||
* int pager_req_create(int fd, int flags, int prot, uintptr_t result_rpa);
|
||||
*/
|
||||
struct pager_create_result {
|
||||
uintptr_t handle;
|
||||
int maxprot;
|
||||
int8_t padding[4];
|
||||
};
|
||||
|
||||
/*
|
||||
* int pager_req_release(uintptr_t handle);
|
||||
*/
|
||||
/*
|
||||
* int pager_req_read(uintptr_t handle, off_t off, size_t size, uintptr_t buf_rpa);
|
||||
*/
|
||||
#endif /* HEADER_PAGER_H */
|
||||
@@ -7,6 +7,7 @@
|
||||
#include <ihk/atomic.h>
|
||||
#include <list.h>
|
||||
#include <signal.h>
|
||||
#include <memobj.h>
|
||||
|
||||
#define VR_NONE 0x0
|
||||
#define VR_STACK 0x1
|
||||
@@ -14,13 +15,21 @@
|
||||
#define VR_IO_NOCACHE 0x100
|
||||
#define VR_REMOTE 0x200
|
||||
#define VR_DEMAND_PAGING 0x1000
|
||||
#define VR_PRIVATE 0x2000
|
||||
#define VR_PROT_NONE 0x00000000
|
||||
#define VR_PROT_READ 0x00010000
|
||||
#define VR_PROT_WRITE 0x00020000
|
||||
#define VR_PROT_EXEC 0x00040000
|
||||
#define VR_PROT_MASK 0x00070000
|
||||
#define VR_MAXPROT_NONE 0x00000000
|
||||
#define VR_MAXPROT_READ 0x00100000
|
||||
#define VR_MAXPROT_WRITE 0x00200000
|
||||
#define VR_MAXPROT_EXEC 0x00400000
|
||||
#define VR_MAXPROT_MASK 0x00700000
|
||||
|
||||
#define PROT_TO_VR_FLAG(prot) (((unsigned long)(prot) << 16) & VR_PROT_MASK)
|
||||
#define VRFLAG_PROT_TO_MAXPROT(vrflag) (((vrflag) & VR_PROT_MASK) << 4)
|
||||
#define VRFLAG_MAXPROT_TO_PROT(vrflag) (((vrflag) & VR_MAXPROT_MASK) >> 4)
|
||||
|
||||
#define PS_RUNNING 0x1
|
||||
#define PS_INTERRUPTIBLE 0x2
|
||||
@@ -42,6 +51,8 @@ struct vm_range {
|
||||
struct list_head list;
|
||||
unsigned long start, end;
|
||||
unsigned long flag;
|
||||
struct memobj *memobj;
|
||||
off_t objoff;
|
||||
};
|
||||
|
||||
struct vm_regions {
|
||||
@@ -61,6 +72,8 @@ struct sig_handler {
|
||||
struct k_sigaction action[_NSIG];
|
||||
};
|
||||
|
||||
typedef void pgio_func_t(void *arg);
|
||||
|
||||
struct process {
|
||||
int pid;
|
||||
int status;
|
||||
@@ -92,6 +105,8 @@ struct process {
|
||||
// TODO: backup FR and MMX regs
|
||||
unsigned long sigrc; // return code of rt_sigreturn (x86_64: rax reg.)
|
||||
struct rlimit rlimit_stack;
|
||||
pgio_func_t *pgio_fp;
|
||||
void *pgio_arg;
|
||||
};
|
||||
|
||||
struct process_vm {
|
||||
@@ -118,11 +133,13 @@ struct process *clone_process(struct process *org,
|
||||
void destroy_process(struct process *proc);
|
||||
void hold_process(struct process *proc);
|
||||
void free_process(struct process *proc);
|
||||
void flush_process_memory(struct process *proc);
|
||||
void free_process_memory(struct process *proc);
|
||||
|
||||
int add_process_memory_range(struct process *process,
|
||||
unsigned long start, unsigned long end,
|
||||
unsigned long phys, unsigned long flag);
|
||||
unsigned long phys, unsigned long flag,
|
||||
struct memobj *memobj, off_t objoff);
|
||||
int remove_process_memory_range(
|
||||
struct process *process, unsigned long start, unsigned long end);
|
||||
int split_process_memory_range(struct process *process,
|
||||
|
||||
@@ -194,6 +194,7 @@ struct syscall_params {
|
||||
|
||||
extern int do_syscall(struct syscall_request *req, ihk_mc_user_context_t *ctx);
|
||||
extern int obtain_clone_cpuid();
|
||||
extern long syscall_generic_forwarding(int n, ihk_mc_user_context_t *ctx);
|
||||
|
||||
#define DECLARATOR(number,name) __NR_##name = number,
|
||||
#define SYSCALL_HANDLED(number,name) DECLARATOR(number,name)
|
||||
|
||||
Reference in New Issue
Block a user