diff options
Diffstat (limited to 'src/userspace/mlibc')
-rw-r--r-- | src/userspace/mlibc/stdio/readline.c | 4 | ||||
-rw-r--r-- | src/userspace/mlibc/stdio/vprintf.c | 6 | ||||
-rw-r--r-- | src/userspace/mlibc/stdlib.h | 6 | ||||
-rw-r--r-- | src/userspace/mlibc/string/strlen.c | 32 |
4 files changed, 39 insertions, 9 deletions
diff --git a/src/userspace/mlibc/stdio/readline.c b/src/userspace/mlibc/stdio/readline.c index b948884..91b5da0 100644 --- a/src/userspace/mlibc/stdio/readline.c +++ b/src/userspace/mlibc/stdio/readline.c @@ -9,8 +9,8 @@ char *readline() while (buf != '\n') { buf = getch(); writec(buf); - strcpy(ret, buf); + strcpy(ret, &buf); } - strcpy(ret, buf); + strcpy(ret, &buf); return ret; }
\ No newline at end of file diff --git a/src/userspace/mlibc/stdio/vprintf.c b/src/userspace/mlibc/stdio/vprintf.c index 92999b6..1d43c77 100644 --- a/src/userspace/mlibc/stdio/vprintf.c +++ b/src/userspace/mlibc/stdio/vprintf.c @@ -1,8 +1,6 @@ #include <stdarg.h> #include <stdint.h> #include <mlibc/stdio.h> -#include <mlibc/string.h> -#include <mlibc/stdlib.h> #include <mlibc/stdlib.h> void __writes(const char *data) @@ -32,12 +30,12 @@ void vprintf(const char *fmt, va_list args) } else if (buff == 'x') { char *p = htoa((uint32_t) va_arg(args, int)); __writes(p); - // kfree(p); + free(p); readyToFormat = 0; } else if (buff == 'd') { char *p = itoa(va_arg(args, int)); __writes(p); - // kfree(p); + free(p); readyToFormat = 0; } else if (buff == 'c') { writec((char) va_arg(args, int)); diff --git a/src/userspace/mlibc/stdlib.h b/src/userspace/mlibc/stdlib.h index ff8603c..36a3b5f 100644 --- a/src/userspace/mlibc/stdlib.h +++ b/src/userspace/mlibc/stdlib.h @@ -3,6 +3,12 @@ #include <stdint.h> +#ifndef MELVIX_ALLOC_H + +#include <mlibc/stdlib/liballoc.h> + +#endif + #ifndef MELVIX_STRING_H #include <mlibc/string.h> diff --git a/src/userspace/mlibc/string/strlen.c b/src/userspace/mlibc/string/strlen.c index 133ee3d..f6a06a4 100644 --- a/src/userspace/mlibc/string/strlen.c +++ b/src/userspace/mlibc/string/strlen.c @@ -2,7 +2,33 @@ size_t strlen(const char *str) { - size_t len = 0; - while (str[len]) len++; - return len; + const char *char_ptr; + const unsigned long int *longword_ptr; + unsigned long int longword, himagic, lomagic; + + for (char_ptr = str; ((unsigned long int) char_ptr & (sizeof(longword) - 1)) != 0; ++char_ptr) + if (*char_ptr == '\0') + return char_ptr - str; + + longword_ptr = (unsigned long int *) char_ptr; + + himagic = 0x80808080L; + lomagic = 0x01010101L; + + for (;;) { + longword = *longword_ptr++; + + if (((longword - lomagic) & himagic) != 0) { + const char *cp = (const char *) (longword_ptr - 1); + + if (cp[0] == 0) + return cp - str; + if (cp[1] == 0) + return cp - str + 1; + if (cp[2] == 0) + return cp - str + 2; + if (cp[3] == 0) + return cp - str + 3; + } + } }
\ No newline at end of file |