aboutsummaryrefslogtreecommitdiff
path: root/src/mlibc/stdlib
diff options
context:
space:
mode:
authorMarvin Borner2019-11-23 00:36:28 +0100
committerMarvin Borner2019-11-23 00:36:28 +0100
commit45d9495e77dba212551ae9bc8e09b51e9ed6d324 (patch)
tree1e8ead9a55b41fa009c28823ca7a9ac0b1b5b2fe /src/mlibc/stdlib
parent4b178c0feb4c415be36be0e4c0def8c447ed42af (diff)
Tried implementing memory based paging...
Also did many other fixes/improvements. While I think I did most things correct, the ACPI doesn't work anymore (triple fault) and the resolution detection fails with 0x2... :c
Diffstat (limited to 'src/mlibc/stdlib')
-rw-r--r--src/mlibc/stdlib/itoa.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/mlibc/stdlib/itoa.c b/src/mlibc/stdlib/itoa.c
index e9c40c1..8c557ab 100644
--- a/src/mlibc/stdlib/itoa.c
+++ b/src/mlibc/stdlib/itoa.c
@@ -2,11 +2,14 @@
#include <stdint.h>
#include <mlibc/string.h>
#include <mlibc/stdlib.h>
+#include <kernel/paging/paging.h>
static const char __ITOA_TABLE[] = "0123456789";
char *itoa(int n) {
- // Special cases
+ if (paging_enabled == 0)
+ return "0"; // kmalloc isn't available
+
if (!n) {
char *ret = kmalloc(2);
ret[0] = '0';
@@ -16,13 +19,11 @@ char *itoa(int n) {
uint8_t negative = (uint8_t) (n < 0);
if (negative) n *= -1;
- // First get the number of digits.
int sz;
for (sz = 0; n % pow(10, sz) != n; sz++) {}
char *ret = kmalloc(sz + 1);
- // Iterate all digits again.
for (int i = 0; i < sz; i++) {
int digit = (n % pow(10, i + 1)) / pow(10, i);
ret[i] = __ITOA_TABLE[digit];