X-Git-Url: http://git.buserror.net/cgi-bin/gitweb.cgi?p=polintos%2Fscott%2Fpriv.git;a=blobdiff_plain;f=kernel%2Finclude%2Fkern%2Forb.h;h=52d611d86139496b1eb2d7530eb1eb5821523b6b;hp=dc832c385c1566d0e8122c389408eea6e1d1522b;hb=0ffa4628c337dbad2ba2aa6b9f539e9b50bf4983;hpb=b4bfc871337ca32ce83407916a87db2524729ca9 diff --git a/kernel/include/kern/orb.h b/kernel/include/kern/orb.h index dc832c3..52d611d 100644 --- a/kernel/include/kern/orb.h +++ b/kernel/include/kern/orb.h @@ -2,10 +2,14 @@ #define _KERN_ORB_H #include +#include #include #include #include +#include +#include + #include namespace Mem { @@ -50,15 +54,9 @@ namespace ORB { CallFrame frames[0]; }; - - struct ObjectHdr; - struct Object; - - typedef Util::RBTree IDRMap; struct ObjectHdr { - IDRMap::Node rbtree_node; - u32 id; + ID id; union { struct { @@ -77,15 +75,31 @@ namespace ORB { struct ObjectPtr : public ObjectHdr { Object *object; }; + + union ObjTableEntry { + ObjectHdr hdr; + Object obj; + ObjectPtr ptr; + }; + + typedef Util::RadixTree IDTable; + typedef Util::RadixTree IDRMap; + typedef Util::BitmapTree IDAlloc; class IDSpace { // Reverse mapping of object pointers to local IDs - IDRMap id_rmap; + IDTable table; + IDRMap rmap; + IDAlloc alloc; public: Object *lookup(u32 id); - u32 rlookup(Object *obj); + ObjectHdr *get_local_hdr(Object *obj); + Object *newobj(Mem::ProcAddrSpace *aspace, uintptr_t entry); }; + + void invoke_method(System::RunTime::ParamInfoBlock *pib, uintptr_t &stack); + uintptr_t return_from_method(uintptr_t &exptr, size_t &exlen); } #endif