aboutsummaryrefslogtreecommitdiff
path: root/src/userspace
diff options
context:
space:
mode:
authorMarvin Borner2019-12-21 12:25:14 +0100
committerMarvin Borner2019-12-21 12:25:14 +0100
commit38610cd06dc0b5a3a4ee46f5fe7c341191aa2bc1 (patch)
tree759378766ee6b22d72a0f2fded1b0dd530376a6e /src/userspace
parent07530dd08e0b29573712b54543a7fc42672bb34b (diff)
Some userspace improvements
GAS is bad, NASM is awesome.
Diffstat (limited to 'src/userspace')
-rw-r--r--src/userspace/main.c4
-rw-r--r--src/userspace/mlibc/stdio/readline.c4
-rw-r--r--src/userspace/mlibc/stdio/vprintf.c6
-rw-r--r--src/userspace/mlibc/stdlib.h6
-rw-r--r--src/userspace/mlibc/string/strlen.c32
5 files changed, 41 insertions, 11 deletions
diff --git a/src/userspace/main.c b/src/userspace/main.c
index 63ce8f4..982a5ff 100644
--- a/src/userspace/main.c
+++ b/src/userspace/main.c
@@ -11,10 +11,10 @@ int32_t starts_with(const char *a, const char *b)
void user_main()
{
- char hello[] = "> Successfully switched to usermode!\n";
- syscall_write(hello);
+ printf("> Successfully switched to usermode!");
// init_framebuffer();
+ writec((char) strlen("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"));
while (1) {
char *input = readline();
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