blob: 52f8338abf329f32fce9975ffba7217d20b6f910 [file] [log] [blame]
typedef BYTE unsigned char;typedef int item_n;typedef int perm_set;struct
PENT{caddr_t v_addr;};typedef struct PENT prec;typedef struct PENT*
prec_t;prec_t mem_hash;BYTE*mem_base;struct PTE{BYTE*p_page;perm_set
p_perms;};typedef struct PTE pte;struct PTP{union{struct*PTP
p_tablep;struct*PTE p_entry;}u;int valid;};typedef struct PTP
(u.p_tablep);int pfree=0;int pcount=0;void mmu_walk_find(va)caddr_t va;{
BYTE*page_addr;if(mmu_base[Level1(va)]->valid==0x0){l1_base=
mmu_base[Level1(va)]->(u.p_tablep)=p_alloc();mmu_base[Level1(va)]->valid=
0x3;for(idx=0;idx<LEVEL1_ENTRIES;idx++)l1_base[idx]->valid=0x0;goto
build_level2;}else l1_base=mmu_base[Level1(va)]->(u.p_tablep);if
(l1_base[Level2(va)]->valid==0x0){build_level2:l2_base=
l1_base[Level2(va)]->(u.p_tablep)=p_alloc();l1_base[Level2(va)]->valid=
0x3;for(idx=0;idx<LEVEL2_ENTRIES;idx++)l2_base[idx]->valid=0x0;goto
build_page;}else l2_base=mmu_base[Level2(va)]->(u.p_tablep);
page_addr=l2_base[Level2(va)]->valid;}void*a_translate(va_op,v_addr)int
va_op;caddr_t v_addr;{register prec_t bucket;register caddr_t p_addr;
bucket=mem_hash+((((v_addr)>>ITEMBITS))&hash_mask);do{if
(bucket->v_addr==((v_addr)>>ITEMBITS){if(!(bucket->perm_set&va_op))
goto prot_fault;return mem_base+v_addr;}}while((bucket++)->v_addr!=
((caddr_t)0));page_miss:p_addr=(--bucket)->p_addr;page_type:switch
(p_addr){case BUCKET_FULL:enlarge_hash_table(mem_hash);case((caddr_t)0):
p_addr=fill_item_entry(va_op,v_addr);goto page_type;case((caddr_t)1):
default:((void)(((0))?0:(__eprintf("Failed assertion`%s'at line%d
of`%s'.\n","FALSE",327,"b.c"),0)));}}void flush_hash(hasht,
hash_size)prec_t hasht;int hash_size;{register prec_t bucket;register int
idx;bucket=hasht;for(idx=(hash_size*3)-1;idx>=0;idx--){
bucket->v_addr=((caddr_t)0);bucket->p_addr=((caddr_t)0);
bucket->perm_set=VA_EMPTY;}}void init_mem(){mem_base=(BYTE*)calloc(1024
,(1<<13));((void)((mem_base!=(BYTE*)0)?0:(__eprintf("Failed
assertion`%s'at line%d of`%s'.\n","mem_base!=(BYTE*)0",366,"b.c"),
0)));hash_num=INIT_NUM_ENTRIES*3;mem_hash=(prec_t)calloc(hash_num,
sizeof(prec));((void)((mem_hash!=(prec_t)0)?0:(__eprintf("Failed
assertion`%s'at line%d of`%s'.\n","mem_hash!=(prec_t)0",370,"b.c"),
0)));flush_hash(mem_hash,32);build_ptables(mem_base,1024*(1<<13));}
struct tm{int tm_sec;int tm_min;int tm_hour;int tm_mday;int tm_mon;int
tm_year;int tm_wday;int tm_yday;int tm_isdst;char*tm_zone;long tm_gmtoff;};