From dfaaa1e83be9223de7de093e025b874875bad7b3 Mon Sep 17 00:00:00 2001 From: Douglas Thain Date: Fri, 15 Dec 2023 15:07:38 -0500 Subject: [PATCH 1/5] Update build workflow and Makefile with separate phone steps to clarify any build failures. --- .github/workflows/makefile.yml | 18 ++++++++++++++---- Makefile | 30 ++++++++++++++++++++---------- 2 files changed, 34 insertions(+), 14 deletions(-) diff --git a/.github/workflows/makefile.yml b/.github/workflows/makefile.yml index 147b30d6..1764468e 100644 --- a/.github/workflows/makefile.yml +++ b/.github/workflows/makefile.yml @@ -14,9 +14,19 @@ jobs: steps: - uses: actions/checkout@v3 - - name: Install + - name: Setup run: sudo apt-get install -y genisoimage - - name: Build - run: make - + - name: Build Kernel + run: make build-kernel + + - name: Build Standard Library + run: make build-library + + - name: Build Userspace + run: make build-userspace + + - name: Build CDROM Image + run: make build-cdrom-image + + diff --git a/Makefile b/Makefile index 3fb1eee7..3c204e05 100644 --- a/Makefile +++ b/Makefile @@ -7,16 +7,20 @@ USER_PROGRAMS=$(USER_SOURCES:c=exe) KERNEL_SOURCES=$(wildcard kernel/*.[chS]) WORDS=/usr/share/dict/words -all: basekernel.iso +.PHONY: build-kernel build-library build-userspace build-iso -run: basekernel.iso disk.img - qemu-system-i386 -cdrom basekernel.iso -hda disk.img +all: build-iso -debug: basekernel.iso disk.img - qemu-system-i386 -cdrom basekernel.iso -hda disk.img -s -S & +build-kernel: kernel/basekernel.img -disk.img: - qemu-img create disk.img 10M +build-library: library/baselib.a + +build-userspace: $(USER_PROGRAMS) + +build-cdrom-image: basekernel.iso + +kernel/basekernel.img: $(KERNEL_SOURCES) $(LIBRARY_HEADERS) + cd kernel && make library/baselib.a: $(LIBRARY_SOURCES) $(LIBRARY_HEADERS) cd library && make @@ -24,9 +28,6 @@ library/baselib.a: $(LIBRARY_SOURCES) $(LIBRARY_HEADERS) $(USER_PROGRAMS): $(USER_SOURCES) library/baselib.a $(LIBRARY_HEADERS) cd user && make -kernel/basekernel.img: $(KERNEL_SOURCES) $(LIBRARY_HEADERS) - cd kernel && make - image: kernel/basekernel.img $(USER_PROGRAMS) rm -rf image mkdir image image/boot image/bin image/data @@ -37,6 +38,15 @@ image: kernel/basekernel.img $(USER_PROGRAMS) basekernel.iso: image ${ISOGEN} -input-charset utf-8 -iso-level 2 -J -R -o $@ -b boot/basekernel.img image +disk.img: + qemu-img create disk.img 10M + +run: basekernel.iso disk.img + qemu-system-i386 -cdrom basekernel.iso -hda disk.img + +debug: basekernel.iso disk.img + qemu-system-i386 -cdrom basekernel.iso -hda disk.img -s -S & + clean: rm -rf basekernel.iso image cd kernel && make clean From 54a2df3e31e88f1e83c28de441ca09ec0a576515 Mon Sep 17 00:00:00 2001 From: Douglas Thain Date: Fri, 15 Dec 2023 15:08:03 -0500 Subject: [PATCH 2/5] Remove debugging output. --- kernel/page.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/page.c b/kernel/page.c index 2577c2c1..1d80a6fd 100644 --- a/kernel/page.c +++ b/kernel/page.c @@ -82,7 +82,7 @@ void *page_alloc(bool zeroit) if(zeroit) memset(pageaddr, 0, PAGE_SIZE); pages_free--; - printf("page: alloc %d\n",pages_free); + //printf("page: alloc %d\n",pages_free); return pageaddr; } } @@ -103,5 +103,5 @@ void page_free(void *pageaddr) uint32_t cellmask = (1 << celloffset); freemap[cellnumber] |= cellmask; pages_free++; - printf("page: free %d\n",pages_free); + //printf("page: free %d\n",pages_free); } From a02e02a3958dbac74ceb512f31b8cd9f6d85b902 Mon Sep 17 00:00:00 2001 From: Douglas Thain Date: Fri, 15 Dec 2023 15:10:04 -0500 Subject: [PATCH 3/5] Remove disk image. --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 3c204e05..6a1cca9f 100644 --- a/Makefile +++ b/Makefile @@ -48,7 +48,7 @@ debug: basekernel.iso disk.img qemu-system-i386 -cdrom basekernel.iso -hda disk.img -s -S & clean: - rm -rf basekernel.iso image + rm -rf basekernel.iso image disk.img cd kernel && make clean cd library && make clean cd user && make clean From a66d70e09a7936194f7edb50d7f11432274101d6 Mon Sep 17 00:00:00 2001 From: Douglas Thain Date: Fri, 15 Dec 2023 15:12:30 -0500 Subject: [PATCH 4/5] Fix Makefile --- Makefile | 4 ++-- user/sysstat.c | 13 ++++++++++++- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/Makefile b/Makefile index 6a1cca9f..6a667997 100644 --- a/Makefile +++ b/Makefile @@ -7,9 +7,9 @@ USER_PROGRAMS=$(USER_SOURCES:c=exe) KERNEL_SOURCES=$(wildcard kernel/*.[chS]) WORDS=/usr/share/dict/words -.PHONY: build-kernel build-library build-userspace build-iso +.PHONY: build-kernel build-library build-userspace build-cdrom-image -all: build-iso +all: build-cdrom-image build-kernel: kernel/basekernel.img diff --git a/user/sysstat.c b/user/sysstat.c index cf6abfe7..385da0d9 100644 --- a/user/sysstat.c +++ b/user/sysstat.c @@ -6,13 +6,24 @@ See the file LICENSE for details. #include "library/syscalls.h" #include "library/string.h" +#include "library/stdio.h" + +struct system_stats s = {0}; int main(int argc, char *argv[]) { - struct system_stats s = {0}; + printf("a"); + flush(); + + printf("b"); + flush(); + if (syscall_system_stats(&s)) { return 1; } + printf("c"); + flush(); + printf("System uptime: %u:%u:%u\n", s.time / (3600), (s.time % 3600) / 60, s.time % 60); printf("Disk 0: %d blocks read, %d blocks written\n", s.blocks_read[0], s.blocks_written[0]); From 77cea714dcaf69ced9b428b386d2f7ca83c9d4b7 Mon Sep 17 00:00:00 2001 From: Douglas Thain Date: Fri, 15 Dec 2023 15:24:51 -0500 Subject: [PATCH 5/5] Switch fixed mount to automount. --- kernel/kshell.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/kernel/kshell.c b/kernel/kshell.c index dce1cdb0..371bd1f9 100644 --- a/kernel/kshell.c +++ b/kernel/kshell.c @@ -387,7 +387,7 @@ int kshell_launch() const char *argv[100]; int argc; - kshell_mount("atapi",2,"cdromfs"); + kshell_automount(); while(1) { printf("kshell> ");