Compare commits
2 Commits
cb5e408525
...
758017a8e7
Author | SHA1 | Date | |
---|---|---|---|
|
758017a8e7 | ||
|
f8b1b2c5a7 |
@ -148,7 +148,7 @@ uaddr_t loadElfProg(const char *prog, struct process *proc)
|
|||||||
// Hack: Even if already allocated mark the adresse space as managed by a ressource
|
// Hack: Even if already allocated mark the adresse space as managed by a ressource
|
||||||
// So this address space is not used by another ressource.
|
// So this address space is not used by another ressource.
|
||||||
uaddr = elf_phdrs[i].p_vaddr;
|
uaddr = elf_phdrs[i].p_vaddr;
|
||||||
zeroMmap(as, &uaddr, elf_phdrs[i].p_memsz, PAGING_MEM_USER | PAGING_MEM_WRITE | PAGING_MEM_READ, 0);
|
assert(zeroMmap(as, &uaddr, elf_phdrs[i].p_memsz, PAGING_MEM_USER | PAGING_MEM_WRITE | PAGING_MEM_READ, 0) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
processInitHeap(proc, lastUserAddr);
|
processInitHeap(proc, lastUserAddr);
|
||||||
|
@ -425,7 +425,8 @@ int vsnprintf(char *str, size_t size, const char *format, va_list ap)
|
|||||||
case 'x': {
|
case 'x': {
|
||||||
char val[sizeof(long long int) * 2];
|
char val[sizeof(long long int) * 2];
|
||||||
unsigned int valIdx = 0;
|
unsigned int valIdx = 0;
|
||||||
long long int d = va_arg(ap, long long int);
|
unsigned long long int d =
|
||||||
|
va_arg(ap, unsigned long long int);
|
||||||
itoa(d, val, 16);
|
itoa(d, val, 16);
|
||||||
if (str) {
|
if (str) {
|
||||||
while (val[valIdx]) {
|
while (val[valIdx]) {
|
||||||
@ -453,7 +454,7 @@ int vsnprintf(char *str, size_t size, const char *format, va_list ap)
|
|||||||
case 'x': {
|
case 'x': {
|
||||||
char val[sizeof(int) * 2];
|
char val[sizeof(int) * 2];
|
||||||
unsigned int valIdx = 0;
|
unsigned int valIdx = 0;
|
||||||
long int d = va_arg(ap, long int);
|
unsigned long int d = va_arg(ap, unsigned long int);
|
||||||
itoa(d, val, 16);
|
itoa(d, val, 16);
|
||||||
if (str) {
|
if (str) {
|
||||||
while (val[valIdx]) {
|
while (val[valIdx]) {
|
||||||
|
@ -216,7 +216,8 @@ int uAddrSpaceUnmap(struct uAddrSpace *as, uaddr_t uaddr, size_t size)
|
|||||||
reg->res->ops->unmap(reg, uaddr, size);
|
reg->res->ops->unmap(reg, uaddr, size);
|
||||||
break;
|
break;
|
||||||
// Only affect the end
|
// Only affect the end
|
||||||
} else if (uaddr > reg->addr && uaddr + size > reg->addr + reg->size) {
|
} else if (uaddr > reg->addr && uaddr < reg->addr + size &&
|
||||||
|
uaddr + size > reg->addr + reg->size) {
|
||||||
size_t unmapSize = reg->addr + reg->size - uaddr;
|
size_t unmapSize = reg->addr + reg->size - uaddr;
|
||||||
reg->size = uaddr - reg->addr;
|
reg->size = uaddr - reg->addr;
|
||||||
|
|
||||||
@ -306,6 +307,12 @@ int uAddrSpaceHeapCheckNAlloc(struct uAddrSpace *as, vaddr_t addr)
|
|||||||
newReg->size = PAGE_SIZE;
|
newReg->size = PAGE_SIZE;
|
||||||
newReg->right = right;
|
newReg->right = right;
|
||||||
|
|
||||||
|
// keep the AS list sorted
|
||||||
|
struct uAddrVirtualReg *prev = findVirtualRegionBeforeAddr(as, addrAlign);
|
||||||
|
if (prev)
|
||||||
|
list_insert_after_named(as->listVirtualReg, prev, newReg, prevInAddrSpace,
|
||||||
|
nextInAddrSpace);
|
||||||
|
else
|
||||||
list_add_tail_named(as->listVirtualReg, newReg, nextInAddrSpace, prevInAddrSpace);
|
list_add_tail_named(as->listVirtualReg, newReg, nextInAddrSpace, prevInAddrSpace);
|
||||||
|
|
||||||
unrefPhyPage(ppage);
|
unrefPhyPage(ppage);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user