aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--apps/wm.c5
-rw-r--r--kernel/features/proc.c7
-rw-r--r--kernel/features/syscall.c2
-rw-r--r--kernel/inc/proc.h2
-rw-r--r--libgui/gui.c55
-rw-r--r--libgui/vesa.c10
6 files changed, 45 insertions, 36 deletions
diff --git a/apps/wm.c b/apps/wm.c
index c4ed193..c6a1a31 100644
--- a/apps/wm.c
+++ b/apps/wm.c
@@ -82,11 +82,12 @@ int main(int argc, char **argv)
struct window *win = iterator->data;
gui_win_on_win(exchange, win, win->x, win->y);
} while ((iterator = iterator->next) != NULL);
- gui_win_on_win(direct, exchange, 0, 0);
+ memcpy(direct->fb, exchange->fb,
+ exchange->pitch * exchange->height);
}
break;
default:
- printf("Unknown WM request %d from pid %d", msg->type, msg->src);
+ printf("Unknown WM request %d from pid %d\n", msg->type, msg->src);
}
};
diff --git a/kernel/features/proc.c b/kernel/features/proc.c
index 5b4da1f..021a3d6 100644
--- a/kernel/features/proc.c
+++ b/kernel/features/proc.c
@@ -114,9 +114,8 @@ struct proc *proc_from_pid(u32 pid)
{
struct node *iterator = proc_list->head;
do {
- if (((struct proc *)iterator->data)->pid == pid) {
+ if (((struct proc *)iterator->data)->pid == pid)
return iterator->data;
- }
} while ((iterator = iterator->next) != NULL);
return NULL;
}
@@ -139,10 +138,10 @@ void proc_exit(struct proc *proc, int status)
hlt();
}
-// TODO: More instant yield
-void proc_yield()
+void proc_yield(struct regs *r)
{
quantum = 0;
+ scheduler(r);
}
struct proc *proc_make()
diff --git a/kernel/features/syscall.c b/kernel/features/syscall.c
index fb6adf1..fbbb68b 100644
--- a/kernel/features/syscall.c
+++ b/kernel/features/syscall.c
@@ -71,7 +71,7 @@ void syscall_handler(struct regs *r)
}
case SYS_YIELD: {
/* printf("yield\n"); */
- proc_yield();
+ proc_yield(r);
break;
}
case SYS_TIME: {
diff --git a/kernel/inc/proc.h b/kernel/inc/proc.h
index 36d8e85..0c0ec9e 100644
--- a/kernel/inc/proc.h
+++ b/kernel/inc/proc.h
@@ -43,7 +43,7 @@ void proc_send(struct proc *src, struct proc *dest, enum message_type type, void
struct proc_message *proc_receive(struct proc *proc);
struct proc *proc_from_pid(u32 pid);
void proc_exit(struct proc *proc, int status);
-void proc_yield();
+void proc_yield(struct regs *r);
struct proc *proc_make();
#endif
diff --git a/libgui/gui.c b/libgui/gui.c
index 118bd95..0759df6 100644
--- a/libgui/gui.c
+++ b/libgui/gui.c
@@ -4,6 +4,7 @@
#include <assert.h>
#include <bmp.h>
#include <gui.h>
+#include <mem.h>
#include <psf.h>
#include <str.h>
#include <sys.h>
@@ -13,9 +14,9 @@ struct font *font;
void gui_write_char(struct vbe *vbe, int x, int y, const u32 c[3], char ch)
{
- int bpl = vbe->bpp >> 3;
+ int bypp = vbe->bpp >> 3;
- int pos = x * bpl + y * vbe->pitch;
+ int pos = x * bypp + y * vbe->pitch;
char *draw = (char *)&vbe->fb[pos];
u32 stride = font->char_size / font->height;
@@ -24,9 +25,9 @@ void gui_write_char(struct vbe *vbe, int x, int y, const u32 c[3], char ch)
u8 bits = font->chars[ch * font->char_size + cy * stride + cx / 8];
u8 bit = bits >> (7 - cx % 8) & 1;
if (bit) {
- draw[bpl * cx] = c[2];
- draw[bpl * cx + 1] = c[1];
- draw[bpl * cx + 2] = c[0];
+ draw[bypp * cx] = c[2];
+ draw[bypp * cx + 1] = c[1];
+ draw[bypp * cx + 2] = c[0];
}
}
draw += vbe->pitch;
@@ -49,12 +50,12 @@ void gui_load_image(struct window *win, char *path, int x, int y)
// TODO: Support padding with odd widths
u8 *srcfb = bmp->data;
u8 *destfb = win->fb;
- int bpl = bmp->bpp >> 3;
+ int bypp = bmp->bpp >> 3;
for (u32 cy = 0; cy < bmp->height; cy++) {
for (u32 cx = 0; cx < bmp->width; cx++) {
- destfb[bpl * cx + 0] = srcfb[bpl * cx + 0];
- destfb[bpl * cx + 1] = srcfb[bpl * cx + 1];
- destfb[bpl * cx + 2] = srcfb[bpl * cx + 2];
+ destfb[bypp * cx + 0] = srcfb[bypp * cx + 0];
+ destfb[bypp * cx + 1] = srcfb[bypp * cx + 1];
+ destfb[bypp * cx + 2] = srcfb[bypp * cx + 2];
}
srcfb += bmp->pitch;
destfb += win->pitch;
@@ -66,16 +67,24 @@ void gui_load_wallpaper(struct window *win, char *path)
gui_load_image(win, path, 0, 0);
}
+// TODO: Optimize!
void gui_win_on_win(struct window *dest, struct window *src, int x, int y)
{
+ // Optimization?
+ /* if (src->width == dest->width && src->height == dest->height && src->x == 0 && */
+ /* dest->y == 0) { */
+ /* memcpy(dest->fb, src->fb, dest->pitch * dest->height); */
+ /* return; */
+ /* } */
+
+ int bypp = dest->bpp >> 3;
u8 *srcfb = src->fb;
- u8 *destfb = &dest->fb[x * (dest->bpp >> 3) + y * dest->pitch];
- int bpl = dest->bpp >> 3;
+ u8 *destfb = &dest->fb[x * bypp + y * dest->pitch];
for (u32 cy = 0; cy < src->height - 1; cy++) {
for (u32 cx = 0; cx < src->width - 1; cx++) {
- destfb[bpl * cx + 0] = srcfb[bpl * cx + 0];
- destfb[bpl * cx + 1] = srcfb[bpl * cx + 1];
- destfb[bpl * cx + 2] = srcfb[bpl * cx + 2];
+ destfb[bypp * cx + 0] = srcfb[bypp * cx + 0];
+ destfb[bypp * cx + 1] = srcfb[bypp * cx + 1];
+ destfb[bypp * cx + 2] = srcfb[bypp * cx + 2];
}
srcfb += src->pitch;
destfb += dest->pitch;
@@ -84,15 +93,15 @@ void gui_win_on_win(struct window *dest, struct window *src, int x, int y)
void gui_draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 color[3])
{
- int bpl = win->bpp >> 3;
+ int bypp = win->bpp >> 3;
- int pos1 = x1 * bpl + y1 * win->pitch;
+ int pos1 = x1 * bypp + y1 * win->pitch;
u8 *draw = &win->fb[pos1];
for (int i = 0; i < y2 - y1; i++) {
for (int j = 0; j < x2 - x1; j++) {
- draw[bpl * j + 0] = color[2];
- draw[bpl * j + 1] = color[1];
- draw[bpl * j + 2] = color[0];
+ draw[bypp * j] = color[2];
+ draw[bypp * j + 1] = color[1];
+ draw[bypp * j + 2] = color[0];
}
draw += win->pitch;
}
@@ -108,16 +117,16 @@ void gui_border(struct window *win, const u32 color[3], u32 width)
if (width <= 0)
return;
- int bpl = win->bpp >> 3;
+ int bypp = win->bpp >> 3;
u8 *draw = win->fb;
for (u32 i = 0; i < win->height; i++) {
for (u32 j = 0; j < win->width; j++) {
if (j <= width - 1 || i <= width - 1 ||
j - win->width + width + 1 <= width ||
i - win->height + width + 1 <= width) {
- draw[bpl * j + 0] = color[2];
- draw[bpl * j + 1] = color[1];
- draw[bpl * j + 2] = color[0];
+ draw[bypp * j + 0] = color[2];
+ draw[bypp * j + 1] = color[1];
+ draw[bypp * j + 2] = color[0];
}
}
draw += win->pitch;
diff --git a/libgui/vesa.c b/libgui/vesa.c
index df2c692..c005711 100644
--- a/libgui/vesa.c
+++ b/libgui/vesa.c
@@ -5,15 +5,15 @@
void vesa_draw_rectangle(struct vbe *vbe, int x1, int y1, int x2, int y2, const u32 color[3])
{
- int bpl = vbe->bpp >> 3;
+ int bypp = vbe->bpp >> 3;
- int pos1 = x1 * bpl + y1 * vbe->pitch;
+ int pos1 = x1 * bypp + y1 * vbe->pitch;
u8 *draw = &vbe->fb[pos1];
for (int i = 0; i <= y2 - y1; i++) {
for (int j = 0; j <= x2 - x1; j++) {
- draw[bpl * j] = color[2];
- draw[bpl * j + 1] = color[1];
- draw[bpl * j + 2] = color[0];
+ draw[bypp * j] = color[2];
+ draw[bypp * j + 1] = color[1];
+ draw[bypp * j + 2] = color[0];
}
draw += vbe->pitch;
}