t3hn3rd 8be364c990
All checks were successful
continuous-integration/drone/push Build is passing
Merge pull request 'feature/ci-cd-drone-migration' (#3) from feature/ci-cd-drone-migration into develop
Reviewed-on: #3
2025-03-10 20:08:38 +00:00
2025-03-09 13:05:39 +00:00
2020-10-29 15:27:40 +00:00
2020-10-29 15:27:40 +00:00
2020-10-29 15:27:40 +00:00
ds
2017-05-20 18:25:38 +00:00
2021-06-22 23:42:43 +01:00
2025-03-09 13:05:39 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2022-02-06 13:32:57 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-07-06 19:18:23 +00:00
2021-06-22 20:55:23 +00:00
2021-06-22 20:54:58 +00:00
2022-02-06 13:29:29 +00:00
2025-03-09 13:05:39 +00:00
2020-10-29 15:35:00 +00:00

Asuro

We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel free to follow the steps below and mess with Asuro for fun or profit.

Setting up your build environment

Prerequisites

  • WSL2 WSL2 is used in conjunction with Docker to predefine a build environment for Asuro.
  • Docker for Windows Docker is used to ensure a predefined environment with the correct versions of; Freepascal, Binutils, NASM, Make, xorriso & grub-mk-rescue installed is used for compilation. An ISO will be generated at the end of the build process.
  • Git (Obviously) I don't think this needs an explaination.
  • VSCode (Optional, but highly recommended) Visual Studio code is our IDE of choice, and we have a number of recommended plugins.
    • PowerShell Plugin by Microsoft This plugin gives you the ability to use the 'PowerShell' task type, allowing the automatic launching of virtualbox with the resulting image generated during compilation of Asuro.
  • VirtualBox Virtualbox is our Virtualisation environment of choice, don't ask why, it just is.

Installation (correct as of 2021/06/20)

  1. Install WSL2 as described in the article linked above & ensure Virtualization is enabled in the BIOS.

  2. Ensure WSL2 is used by default with the following command:

    wsl --set-default-version 2
    
  3. Install Docker for Windows.

  4. Install Git for Windows.

  5. Install VSCode & the listed plugins.

  6. Install VirtualBox (v7+).

  7. Clone this repository.

  8. Run the following command in the root of the repo to build the docker image:

    docker compose build builder
    
  9. Run the following command to compile Asuro:

    docker compose run builder
    
  10. Create a new virtual machine in Virtualbox and mount the Asuro.iso generated in step 9 as a boot image.

  11. Add the virtualbox installation directory to your %PATH% environment variable, usually:

    %PROGRAMFILES%\Oracle\VirtualBox
    
  12. Naviage to your virtualbox machines folder, this is usually the following

    %userprofile%\VirtualBox VMs\<VM Name>
    

    Open the Virtual Machine Definition file (.vbox) in your text editor of choice and find the following line:

    <Machine uuid="{7d395c96-891c-4139-b77d-9b6b144b0b93}" name="Asuro" OSType="Linux" snapshotFolder="Snapshots" lastStateChange="2021-06-20T20:33:07Z">
    

    Copy the uuid, in our case 7d395c96-891c-4139-b77d-9b6b144b0b93 & create a localenv.json file in the project root with the following content:

    {
        "VirtualBox":{
            "MachineName":"<YOUR_UUID_OR_MACHINE_NAME>"
        }
    }
    

    This will allow VSCode to automatically launch VirtualBox once Asuro has been compiled.

    You can also enable the serial adapter "COM1" in mode "Raw File", give it a path, and provide this path in the localenv.json as follows:

    {
        "VirtualBox" : {
            "MachineName": "<YOUR_UUID_OR_MACHINE_NAME>",
            "LogLocation": "Fully\\Qualified\\Path\\To\\Your\\Log\\File"
        }
    }
    

    This will allow you to see the console output from Asuro in your host terminal.

  13. Open your project folder in VSCode, use CTRL+SHIFT+B to build & F5 to build + run in VBox.

  14. Congratulations! You can now play with Asuro!

Notes & Gotchas

  • The above process has been updated to be compatible with VirtualBox 7+, in which VBoxSDL was removed and vboxmanage should be used in its place. A small wrapper powershell script is used to achieve this.
  • It was noted that Windows builds above 20H2 seem to have issues installing WSL2. We may have to wait for a patch from Microsoft to fix this. Our devs are currently using build 20H2.
Description
An x86 Operating System that started development in 2015 as somewhat of an academic project. Written almost entirely in Freepascal, with NASM used only for bootstrapping & minimal low-level routines, Asuro is a purely hobbyist operating system that differs quite majorly in design from any mainstream OS.
https://asuro.xyz
Readme Pixar 52 MiB
Languages
Pascal 98.7%
Shell 0.7%
Assembly 0.3%
PowerShell 0.2%