summaryrefslogtreecommitdiff
path: root/src/main.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.c')
-rw-r--r--src/main.c30
1 files changed, 19 insertions, 11 deletions
diff --git a/src/main.c b/src/main.c
index 8e59664..e4d3b4e 100644
--- a/src/main.c
+++ b/src/main.c
@@ -1,38 +1,46 @@
#define NB_COLS 80
#define NB_ROWS 25
+#define VIDEO_BUFFER 0xB8000
+
/* XXX doest not always handle memory overlaps */
-static void my_memmove(void *dest, const void *src, size_t n)
+static void my_memmove(void *_dest, const void *_src, int n)
{
- for (size_t i = 0; i < n; ++i) {
+ char *dest = _dest;
+ const char *src = _src;
+
+ for (int i = 0; i < n; ++i) {
dest[i] = src[i];
}
}
-static void my_memset(void *dest, int c, size_t n)
+static void my_memset(void *_dest, int c, int n)
{
- for (size_t i = 0; i < n; ++i) {
+ char *dest = _dest;
+
+ for (int i = 0; i < n; ++i) {
dest[i] = c;
}
}
int printk(const char *str)
{
- static char *offset = (char *) 0xb8000;
- static char *addr = offset;
+ static const long int offset = VIDEO_BUFFER;
+ static char *addr = (char *) VIDEO_BUFFER;
int count = 0;
for (int i = 0; str[i]; ++i) {
- if ((long)addr >= 0xb8000 + NB_COLS * NB_ROWS) {
+ /* TODO add the serial port handling */
+
+ if ((long)addr >= offset + NB_COLS * NB_ROWS) {
/* shift up */
addr -= NB_COLS;
- my_memmove(offset, offset + NB_COLS, NB_COLS * (NB_ROWS - 1));
- my_memset(offset + NB_COLS * (NB_ROWS - 1), ' ', NB_ROWS);
+ my_memmove((void *)offset, (void *)offset + NB_COLS, NB_COLS * (NB_ROWS - 1));
+ my_memset((void *)offset + NB_COLS * (NB_ROWS - 1), ' ', NB_ROWS);
}
- *addr++ = str[i]
+ *addr++ = str[i];
++count;
-
}
return count;