Compare commits

..

10 Commits

2 changed files with 44 additions and 31 deletions

View File

@@ -224,13 +224,22 @@ bool send(Vault& v, int pid, const void* sbuffer, size_t ssize, void* rbuffer, s
} }
DBG_VERBOSE << "" << endl; DBG_VERBOSE << "" << endl;
} }
uint8_t num_pages = (rsize/4096)+1;
// Kopiere Antwort // Kopiere Antwort size kann mehr sein
if (!copy_from_phys(v, msg.ptr, rbuffer, rsize)) { for(uint8_t i=0;i<num_pages;i++){
return false; uintptr_t paddr = isMapped(msg.ptr, target_thread->paging_tree->l4); //always page aligned
} if(rsize-i*4096>4096){ // ganze pages
if (!copy_from_phys(v,paddr,(void*)((uintptr_t) rbuffer+ (4096*i)),4096)) {
return true; return false;
}
} else { //teil von pages
if (!copy_from_phys(v,paddr,(void*)((uintptr_t)rbuffer+ 4096*i), rsize-i*4096)) {
return false;
}
}
}
return true;
} }
int receive(Vault& v, void* buffer, size_t size) { int receive(Vault& v, void* buffer, size_t size) {
@@ -247,13 +256,16 @@ int receive(Vault& v, void* buffer, size_t size) {
if (ipc == nullptr) return -1; if (ipc == nullptr) return -1;
size_t copy_len = (size < ipc->size) ? size:ipc->size; size_t copy_len = (size < ipc->size) ? size:ipc->size;
// Buffer holen size_t total_len = (Page::offset(ipc->ptr)+copy_len);
uint8_t num_pages = (total_len/4096)+1;
for(uint32_t i=0; i<(copy_len/4096)+1; i++){ for(uint32_t i=0; i<num_pages; i++){
uintptr_t offset = i==0?Page::offset(ipc->ptr):0; //apply offset only on first page
uintptr_t paddr = isMapped((ipc->ptr)+(i*4096), v.thread_list[ipc->pid]->paging_tree->l4); uintptr_t paddr = isMapped((ipc->ptr)+(i*4096), v.thread_list[ipc->pid]->paging_tree->l4);
if (!copy_from_phys(v, paddr, buffer, copy_len)) { if(total_len - (i*4096) > 4096)
return -3; copy_from_phys(v, paddr+offset,(void*)((uintptr_t)buffer+i*4096), 4096-offset);
} else
copy_from_phys(v, paddr, (void*)((uintptr_t)buffer+i*4096), total_len - (i*4096)); //last page
} }
return ipc->pid; return ipc->pid;
@@ -273,14 +285,13 @@ bool reply(Vault& v, const void* buffer, size_t size) {
Thread* other_thread = v.thread_list[ipc->pid]; Thread* other_thread = v.thread_list[ipc->pid];
if (other_thread == nullptr) return false; if (other_thread == nullptr) return false;
uintptr_t phys_ptr = isMapped((uintptr_t)buffer, current_thread->paging_tree->l4 ); ipc->ptr = (uintptr_t)buffer;
ipc->ptr = phys_ptr + ((uintptr_t)buffer & 0xFFF);
ipc->size = size; ipc->size = size;
ipc->pid = current_thread->id; ipc->pid = current_thread->id;
ipc->is_answer = true; ipc->is_answer = true;
// Sender aufwecken // Sender aufwecken
other_thread->ipc_sem.v(v); other_thread->ipc_sem.v(v);
return true; return true;
} }

View File

@@ -6,25 +6,27 @@ char sbuf[8194], rbuf[8194]; // (2 * 4KiB) + 2
void main() { void main() {
fork(); fork();
fork(); fork();
int other = fork();
int ppid = sys_getpid(); int ppid = sys_getpid();
write(1, "app", 3, 0, ppid); int other = fork();
//if (ppid == other) { // child //write(1, "app", 3, 0, ppid);
// sbuf[0] = 3; if (ppid == other) { // child
// sbuf[8192] = sys_getpid(); sbuf[0] = 3;
// sbuf[8193] = 1; sbuf[8192] = sys_getpid();
// send(other, sbuf, 8193, rbuf, 8193); sbuf[8193] = 1;
send(other, sbuf, 8193, rbuf, 8193);
// char msg[] = "REPLY: AA\n"; char msg[] = "REPLY: AA\n";
// msg[7] += rbuf[0] + sbuf[8193]; msg[7] += rbuf[0] + sbuf[8193];
// msg[8] += 4 + ppid; msg[8] += 4 + ppid;
// write(0, msg, 10); write(0, msg, 10);
//} else { // parent } else { // parent
// receive(rbuf, 8193); // int X = recv(rbuf, 8193);
// rbuf[0] = rbuf[0] + rbuf[8192]; receive(rbuf, 8193);
// rbuf[8193] = 7; rbuf[0] = rbuf[0] + rbuf[8192];
// reply(rbuf, 8193); rbuf[8193] = 7;
//} // reply(X,rbuf, 8193);
reply(rbuf,8193);
}
sys_exit(); sys_exit();
} }