git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Timer re-worked!
[lunaix-os.git]
/
lunaix-os
/
kernel
/
mm
/
kalloc.c
diff --git
a/lunaix-os/kernel/mm/kalloc.c
b/lunaix-os/kernel/mm/kalloc.c
index 675a51f4033fe0191a5fba16c46e0f558e22f40e..e9f05648c6caf00ade4abb92f3fcbe56fac5ad36 100644
(file)
--- a/
lunaix-os/kernel/mm/kalloc.c
+++ b/
lunaix-os/kernel/mm/kalloc.c
@@
-14,16
+14,16
@@
#include <lunaix/mm/kalloc.h>
#include <lunaix/mm/dmm.h>
#include <lunaix/mm/kalloc.h>
#include <lunaix/mm/dmm.h>
-#include <lunaix/co
nstants
.h>
+#include <lunaix/co
mmon
.h>
#include <lunaix/spike.h>
#include <lunaix/spike.h>
-#include <libc/string.h>
+#include <
k
libc/string.h>
#include <stdint.h>
extern uint8_t __kernel_heap_start;
#include <stdint.h>
extern uint8_t __kernel_heap_start;
-heap_context_t __kalloc_kheap;
+
static
heap_context_t __kalloc_kheap;
void*
lx_malloc_internal(heap_context_t* heap, size_t size);
void*
lx_malloc_internal(heap_context_t* heap, size_t size);
@@
-82,13
+82,20
@@
lxmalloc(size_t size) {
}
void*
}
void*
-lxcalloc(size_t size) {
- void* ptr = lxmalloc(size);
+lxcalloc(size_t n, size_t elem) {
+ size_t pd = n * elem;
+
+ // overflow detection
+ if (pd < elem || pd < n) {
+ return NULL;
+ }
+
+ void* ptr = lxmalloc(pd);
if (!ptr) {
return NULL;
}
if (!ptr) {
return NULL;
}
- return memset(ptr, 0,
size
);
+ return memset(ptr, 0,
pd
);
}
void
}
void