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=404e9c0dbad8ab78daa30300f8f0930559d08254;hp=dc832c385c1566d0e8122c389408eea6e1d1522b;hb=0601614ebbcc48b961a2f0613281e6e629af29b1;hpb=b4bfc871337ca32ce83407916a87db2524729ca9 diff --git a/kernel/include/kern/orb.h b/kernel/include/kern/orb.h index dc832c3..404e9c0 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 { @@ -53,12 +57,10 @@ namespace ORB { struct ObjectHdr; struct Object; - - typedef Util::RBTree IDRMap; + typedef u32 ID; struct ObjectHdr { - IDRMap::Node rbtree_node; - u32 id; + ID id; union { struct { @@ -77,15 +79,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