From c32d5edd560c238f2708e47313a0a7f94303ee3b Mon Sep 17 00:00:00 2001 From: vanten-s Date: Wed, 18 Dec 2024 08:55:12 +0100 Subject: [PATCH] Added post --- content/posts/os/2024-08-11.md | 52 ++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 content/posts/os/2024-08-11.md diff --git a/content/posts/os/2024-08-11.md b/content/posts/os/2024-08-11.md new file mode 100644 index 0000000..271264d --- /dev/null +++ b/content/posts/os/2024-08-11.md @@ -0,0 +1,52 @@ ++++ +title = 'Os Devlog: Lisp Compiler' +date = 2024-09-08T12:00:00+02:00 +categories = ["os"] +tags = ["lowlevel", "lisp", "compiler"] +summary = "LISP :3" +draft = true ++++ + +## Introduction +In my previous article I wrote about my [os](https://forgejo.vanten-s.com/vanten-s/os). +In this article I will explore the [compiler I have made for the system](https://forgejo.vanten-s.com/vanten-s/lisp-8bit). + +## Goals for the compiler +Goals are important for getting stuff done. With this compiler I want to: +- Implement a simple LISP language +- Compile to a format that my OS supports +- Functions +- Variables +- Loops +- If statements +- First-class functions + +## AST + +For the program +```lisp +(+ 1 (+ + a b )) +``` +The AST looks like this: +```text + / \ + + / \ + 1 / \ + / \ NIL + + / \ + a / \ + b NIL +``` + +## Compilation +My lisp-implementation is heavily stack-based, and only uses registers when using instructions that need them. + +For example, a + function could compiler to this: +```asm +pop eax +pop ebx +add eax, ebx +push eax +``` +