Compare commits
	
		
			50 Commits
		
	
	
		
			1.1.3-alph
			...
			1145b900e4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 1145b900e4 | |||
| 436cd86d8c | |||
| 540444dfbf | |||
| 2d7c51ed15 | |||
| c842d9774f | |||
| 5963504f6b | |||
| e64a59714a | |||
| dd5d908e43 | |||
| 28846af43c | |||
| b1e3953960 | |||
| 7e00e23801 | |||
| bd12bbe862 | |||
| 48c203f028 | |||
| d859e40e4a | |||
| 8c3649f691 | |||
| b47194ed99 | |||
| 6bca42f2a5 | |||
| f1211f3cca | |||
| 0913daebc6 | |||
| d1a4b4d42f | |||
| 2906b8724b | |||
| 5e6e6c394a | |||
| 315050f095 | |||
| f795ba24f8 | |||
| 738307d070 | |||
| 04cff2e2c3 | |||
| 0b5981242b | |||
| f0dc598f44 | |||
| d4236f455e | |||
| 96fcf19c14 | |||
| 8c51bd8690 | |||
| 43464bb550 | |||
| 6a1b87e250 | |||
| 9473e26b50 | |||
| f19444201d | |||
| f907b7e072 | |||
| 80d0183391 | |||
| 5f3de290f3 | |||
| 07106b9aed | |||
| 25df276101 | |||
| dbc5105b9b | |||
| a61289a318 | |||
| 189526cab8 | |||
| 595dd4fbac | |||
| ba6d8037d2 | |||
| 208bda92c8 | |||
| 4c5038b001 | |||
| 98481ea1ce | |||
| 346dc4e4c9 | |||
| b2eee58df4 | 
							
								
								
									
										65
									
								
								.drone.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								.drone.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | kind: pipeline | ||||||
|  | type: docker | ||||||
|  | name: build | ||||||
|  |  | ||||||
|  | steps: | ||||||
|  |   - name: build-image | ||||||
|  |     image: plugins/docker | ||||||
|  |     settings: | ||||||
|  |       repo: t3hn3rd/asuro-build | ||||||
|  |       tags: latest | ||||||
|  |       dockerfile: Dockerfile | ||||||
|  |       registry: docker.io | ||||||
|  |       username: | ||||||
|  |         from_secret: docker_username | ||||||
|  |       password: | ||||||
|  |         from_secret: docker_password | ||||||
|  |  | ||||||
|  |   - name: compile | ||||||
|  |     image: t3hn3rd/asuro-build:latest | ||||||
|  |     depends_on: | ||||||
|  |       - build-image | ||||||
|  |     commands: | ||||||
|  |       - git fetch --tags | ||||||
|  |       - find . -type f -print0 | xargs -0 dos2unix | ||||||
|  |       - chmod +x /drone/src/*.sh | ||||||
|  |       - /drone/src/compile.sh | ||||||
|  |        | ||||||
|  |   - name: upload-iso-artifact | ||||||
|  |     image: alpine/git | ||||||
|  |     depends_on: | ||||||
|  |       - compile | ||||||
|  |     when: | ||||||
|  |       branch: | ||||||
|  |         - master | ||||||
|  |     environment: | ||||||
|  |       GITEA_TOKEN: | ||||||
|  |         from_secret: gitea_token | ||||||
|  |     commands: | ||||||
|  |       - apk add --no-cache curl | ||||||
|  |       - chmod +w Asuro.iso | ||||||
|  |       - cp Asuro.iso "Asuro-$(git rev-parse --short HEAD).iso" | ||||||
|  |       - echo "Uploading Asuro-$(git rev-parse --short HEAD).iso to Gitea Packages..." | ||||||
|  |       - | | ||||||
|  |          curl -X PUT "https://gitea.spexeah.com/api/packages/Spexeah/generic/asuro-iso/$(git rev-parse --short HEAD)/Asuro.iso" \ | ||||||
|  |          -H "Authorization: token $GITEA_TOKEN" --upload-file "Asuro-$(git rev-parse --short HEAD).iso" | ||||||
|  |       - echo "Updating latest ISO reference..." | ||||||
|  |       - | | ||||||
|  |         curl -X DELETE https://gitea.spexeah.com/api/packages/Spexeah/generic/asuro-iso/latest/Asuro.iso \ | ||||||
|  |         -H "Authorization: token $GITEA_TOKEN" || echo "No previous latest version found." | ||||||
|  |       - | | ||||||
|  |         curl -X PUT https://gitea.spexeah.com/api/packages/Spexeah/generic/asuro-iso/latest/Asuro.iso \ | ||||||
|  |         -H "Authorization: token $GITEA_TOKEN" --upload-file "Asuro-$(git rev-parse --short HEAD).iso" | ||||||
|  |  | ||||||
|  |   - name: msg status | ||||||
|  |     image: appleboy/drone-discord | ||||||
|  |     depends_on: | ||||||
|  |       - compile | ||||||
|  |     when: | ||||||
|  |       status: [success, failure, changed] | ||||||
|  |     settings: | ||||||
|  |       webhook_id: | ||||||
|  |         from_secret: discord_webhook_id | ||||||
|  |       webhook_token: | ||||||
|  |         from_secret: discord_webhook_secret | ||||||
|  |       message: "**Asuro Build**\n\n{{#success build.status}}✅ Build successful!\n\n{{else}}❌ Build failed!\n\n{{/success}}Repository: `{{repo.namespace}}/{{repo.name}}`\nBranch: `{{commit.branch}}`\nCommit: `{{commit.sha}}`\nAuthor: `{{commit.author}} <{{commit.email}}>`\n\nGitea Diff: [Link](<{{commit.link}}>)\nDrone Build: [Link](<{{build.link}}>)\n\nMessage: {{commit.message}}" | ||||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,5 +10,4 @@ | |||||||
| /*.sh~ | /*.sh~ | ||||||
| /*.img | /*.img | ||||||
| src/include/asuro.pas | src/include/asuro.pas | ||||||
| .vscode/launch.json | localenv.json | ||||||
| .vscode |  | ||||||
|   | |||||||
| @@ -1,73 +0,0 @@ | |||||||
| stages: |  | ||||||
|   - Compile Versions |  | ||||||
|   - Compile Sources |  | ||||||
|   - Link |  | ||||||
|   - Generate Documentation |  | ||||||
|   - Deploy |  | ||||||
|  |  | ||||||
| cache: |  | ||||||
|   - key: ${CI_COMMIT_REF_SLUG} |  | ||||||
|     paths: |  | ||||||
|       - lib/*.o |  | ||||||
|       - bin/kernel.bin |  | ||||||
|       - doc |  | ||||||
|  |  | ||||||
| before_script: |  | ||||||
|   - chmod +x *.sh |  | ||||||
|  |  | ||||||
| versions: |  | ||||||
|   stage: Compile Versions |  | ||||||
|   script: |  | ||||||
|     - ./compile_vergen.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - release/*.svg |  | ||||||
|       - src/include/asuro.pas |  | ||||||
|  |  | ||||||
| compile_sources: |  | ||||||
|   stage: Compile Sources |  | ||||||
|   script: |  | ||||||
|     - rm -f lib/*.so |  | ||||||
|     - ./compile_sources.sh |  | ||||||
|   needs: |  | ||||||
|     - versions |  | ||||||
|  |  | ||||||
| link: |  | ||||||
|   stage: Link |  | ||||||
|   script: |  | ||||||
|     - ./compile_stub.sh |  | ||||||
|     - ./compile_link.sh |  | ||||||
|   needs: |  | ||||||
|     - versions |  | ||||||
|     - compile_sources |  | ||||||
|  |  | ||||||
| isogen: |  | ||||||
|   stage: Deploy |  | ||||||
|   script: |  | ||||||
|     - ./compile_isogen.sh |  | ||||||
|     - ./compile_sumgen.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - ./Asuro.iso |  | ||||||
|       - ./release/checksum.svg |  | ||||||
|   needs: |  | ||||||
|     - link |  | ||||||
|  |  | ||||||
| docgen: |  | ||||||
|   stage: Generate Documentation |  | ||||||
|   only: |  | ||||||
|     - master |  | ||||||
|     - develop |  | ||||||
|   script: |  | ||||||
|     - ./compile_sourcelist.sh |  | ||||||
|     - ./compile_docs.sh |  | ||||||
|     # Remove comments when we want to use gitlab pages. |  | ||||||
|     #- cp doc public |  | ||||||
|   allow_failure: true |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - doc |  | ||||||
|       #- public/* |  | ||||||
|       #- ./sources.list |  | ||||||
|   needs: |  | ||||||
|     - versions |  | ||||||
							
								
								
									
										13
									
								
								.mailmap
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								.mailmap
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | # Map all Aaron identities to a single preferred identity | ||||||
|  | Aaron Hance <ah@aaronhance.me> aaron <aaron@6dbc8c32-bb84-406f-8558-d1cf31a0ab0c> | ||||||
|  | Aaron Hance <ah@aaronhance.me> aaronhance <ah@aaronhance.me> | ||||||
|  | Aaron Hance <ah@aaronhance.me> aaron hance <ah@aaronhance.me> | ||||||
|  | Aaron Hance <ah@aaronhance.me> Aaron <ah@aaronhance.me> | ||||||
|  |  | ||||||
|  | # Map all Kieron identities to a single preferred identity | ||||||
|  | Kieron Morris <kjm@kieronmorris.me> kieron <kieron@6dbc8c32-bb84-406f-8558-d1cf31a0ab0c> | ||||||
|  | Kieron Morris <kjm@kieronmorris.me> Kieron <kjm@kieronmorris.me> | ||||||
|  | Kieron Morris <kjm@kieronmorris.me> t3hn3rd <kjm@kieronmorris.me> | ||||||
|  |  | ||||||
|  | # Map goose's multiple identities | ||||||
|  | goose <goose@6dbc8c32-bb84-406f-8558-d1cf31a0ab0c> goose <angus@actm.uk> | ||||||
							
								
								
									
										13
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							| @@ -3,18 +3,11 @@ | |||||||
|         { |         { | ||||||
|             "name":"Run", |             "name":"Run", | ||||||
|             "request": "launch", |             "request": "launch", | ||||||
|             "type": "coreclr", |             "type": "PowerShell", | ||||||
|             "preLaunchTask": "Build", |             "preLaunchTask": "Build", | ||||||
|             "program": "VBoxSDL", |             "script": "${workspaceFolder}/virtualbox-wrapper.ps1", | ||||||
|             "args": [ |             "args": ["-Command", "up"], | ||||||
|                 "--comment",  |  | ||||||
|                 "Asuro",  |  | ||||||
|                 "--startvm",  |  | ||||||
|                 "7d395c96-891c-4139-b77d-9b6b144b0b93" |  | ||||||
|             ], |  | ||||||
|             "cwd": "${workspaceFolder}", |             "cwd": "${workspaceFolder}", | ||||||
|             "console": "internalConsole", |  | ||||||
|             "internalConsoleOptions": "neverOpen" |  | ||||||
|         } |         } | ||||||
|     ] |     ] | ||||||
| } | } | ||||||
							
								
								
									
										26
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							| @@ -9,14 +9,18 @@ | |||||||
|             "command": "docker-compose", |             "command": "docker-compose", | ||||||
|             "args": [ |             "args": [ | ||||||
|                 "run", |                 "run", | ||||||
|                 "builder" |                 "builder", | ||||||
|             ], |             ], | ||||||
|             "type": "shell", |             "type": "shell", | ||||||
|             "problemMatcher": [], |             "problemMatcher": [], | ||||||
|             "group": { |             "group": { | ||||||
|                 "kind": "build", |                 "kind": "build", | ||||||
|                 "isDefault": true |                 "isDefault": true | ||||||
|             } |             }, | ||||||
|  |             "dependsOn": [ | ||||||
|  |                 "Close VirtualBox", | ||||||
|  |                 "Clean" | ||||||
|  |             ] | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Build (Builder)", |             "label": "Build (Builder)", | ||||||
| @@ -26,6 +30,24 @@ | |||||||
|                 "builder" |                 "builder" | ||||||
|             ], |             ], | ||||||
|             "type": "shell" |             "type": "shell" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "label": "Clean", | ||||||
|  |             "command": "docker-compose", | ||||||
|  |             "args": [ | ||||||
|  |                 "down", | ||||||
|  |                 "--remove-orphans" | ||||||
|  |             ], | ||||||
|  |             "type": "shell" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "label": "Close VirtualBox", | ||||||
|  |             "command": "./virtualbox-wrapper.ps1", | ||||||
|  |             "args": [ | ||||||
|  |                 "-Command",  | ||||||
|  |                 "down" | ||||||
|  |             ], | ||||||
|  |             "type": "shell" | ||||||
|         } |         } | ||||||
|     ] |     ] | ||||||
| } | } | ||||||
| @@ -16,7 +16,7 @@ RUN curl -sL https://sourceforge.net/projects/freepascal/files/Linux/$FPC_VERSIO | |||||||
|  |  | ||||||
| COPY compile.sh /compile.sh | COPY compile.sh /compile.sh | ||||||
| ADD https://raw.githubusercontent.com/fsaintjacques/semver-tool/master/src/semver /usr/bin/semver | ADD https://raw.githubusercontent.com/fsaintjacques/semver-tool/master/src/semver /usr/bin/semver | ||||||
| RUN mkdir /code && chmod +x /usr/bin/semver | RUN chmod +x /usr/bin/semver | ||||||
| WORKDIR /code | WORKDIR /code | ||||||
| RUN find . -type f -print0 | xargs -0 dos2unix | RUN find . -type f -print0 | xargs -0 dos2unix | ||||||
| ENTRYPOINT ["/bin/bash", "-c"] | ENTRYPOINT ["/bin/bash", "-c"] | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								compile.sh
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								compile.sh
									
									
									
									
									
								
							| @@ -20,26 +20,30 @@ runOrFail() { | |||||||
| 	fi | 	fi | ||||||
| } | } | ||||||
|  |  | ||||||
| runOrFail $(pwd)/compile_stub.sh "Failed to compile stub!" | declare -a run_steps=( | ||||||
|  | 	"compile_stub.sh" "Failed to compile stub!" | ||||||
|  | 	"compile_vergen.sh" "Versions failed to compile" | ||||||
|  | 	"compile_sources.sh" "Failed to compile FPC Sources!" | ||||||
|  | 	"compile_link.sh" "Failed linking!" | ||||||
|  | 	"compile_isogen.sh" "Failed to create ISO!" | ||||||
|  | ) | ||||||
|  |  | ||||||
| #Generate .pas with versioning headers. | for ((i=0; i<${#run_steps[@]}; i+=2)) | ||||||
| runOrFail $(pwd)/compile_vergen.sh "Versions failed to compile" | do | ||||||
|  | 	if [ "$ERRCOUNT" -eq "0" ] | ||||||
| #Compile all .pas sources | 	then | ||||||
| runOrFail $(pwd)/compile_sources.sh "Failed to compile FPC Sources!" | 			script=$(pwd)/"${run_steps[$i]}" | ||||||
|  | 			message="${run_steps[$i+1]}" | ||||||
| #Link into a binary. | 			runOrFail "$script" "$message" | ||||||
| runOrFail $(pwd)/compile_link.sh "Failed linking!" | 	fi | ||||||
|  | done | ||||||
| #Generate an ISO with GRUB as the Bootloader. |  | ||||||
| runOrFail ./compile_isogen.sh "Failed to create ISO!" |  | ||||||
|  |  | ||||||
| #Call generate final artifacts based on failure or success of the above. | #Call generate final artifacts based on failure or success of the above. | ||||||
| if [ "$ERRCOUNT" -ne "0" ] | if [ "$ERRCOUNT" -ne "0" ] | ||||||
| then | then | ||||||
| 	./compile_finish.sh "failed" | 	. ./compile_finish.sh "failed" | ||||||
| else | else | ||||||
| 	./compile_finish.sh "success" | 	. ./compile_finish.sh "success" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| cd .. | cd .. | ||||||
| @@ -4,4 +4,4 @@ echo "=======================" | |||||||
| echo " " | echo " " | ||||||
| echo "Compiling FPC Sources..." | echo "Compiling FPC Sources..." | ||||||
| echo " " | echo " " | ||||||
| fpc -Aelf -gw -n -va -O3 -Op3 -Si -Sc -Sg -Xd -CX -XXs -CfSSE -CfSSE2 -Rintel -Pi386 -Tlinux -FElib/ -Fusrc/* -Fusrc/driver/* -Fusrc/driver/net/* src/kernel.pas | fpc -Aelf -gw -g -gl -n -vlewn -O3 -Op3 -Si -Sc -Sg -Xd -CX -XXs -CfSSE -CfSSE2 -Rintel -Pi386 -Tlinux -FElib/ -Fusrc/* -Fusrc/driver/* -Fusrc/driver/net/* src/kernel.pas | ||||||
| @@ -1,4 +1,3 @@ | |||||||
| version: "3.9" |  | ||||||
| services: | services: | ||||||
|   builder: |   builder: | ||||||
|     build: . |     build: . | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ ENTRY(loader) | |||||||
| SECTIONS | SECTIONS | ||||||
| { | { | ||||||
|   . = 0xC0100000; |   . = 0xC0100000; | ||||||
|  |   kernel_start = .; | ||||||
|   .text : AT(ADDR(.text) - 0xC0000000) |   .text : AT(ADDR(.text) - 0xC0000000) | ||||||
|   { |   { | ||||||
|     text = .; _text = .; __text = .; |     text = .; _text = .; __text = .; | ||||||
| @@ -33,4 +33,5 @@ SECTIONS | |||||||
|     . = ALIGN(4096); |     . = ALIGN(4096); | ||||||
|   } |   } | ||||||
|   end = .; _end = .; __end = .; |   end = .; _end = .; __end = .; | ||||||
|  |   kernel_end = .; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										45
									
								
								readme.md
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								readme.md
									
									
									
									
									
								
							| @@ -13,8 +13,8 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f | |||||||
|     I don't think this needs an explaination. |     I don't think this needs an explaination. | ||||||
| * [VSCode (Optional, but highly recommended)](https://code.visualstudio.com/) | * [VSCode (Optional, but highly recommended)](https://code.visualstudio.com/) | ||||||
|     Visual Studio code is our IDE of choice, and we have a number of recommended plugins. |     Visual Studio code is our IDE of choice, and we have a number of recommended plugins. | ||||||
|     * [C# Plugin by Microsoft](https://marketplace.visualstudio.com/items?itemName=ms-dotnettools.csharp) |     * [PowerShell Plugin by Microsoft](https://marketplace.visualstudio.com/items?itemName=ms-vscode.powershell) | ||||||
|         This plugin gives you the ability to use the 'coreclr' task type, allowing the automatic launching of virtualbox with the resulting image generated during compilation of Asuro. |         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](https://www.virtualbox.org/) | * [VirtualBox](https://www.virtualbox.org/) | ||||||
|     Virtualbox is our Virtualisation environment of choice, don't ask why, it just is. |     Virtualbox is our Virtualisation environment of choice, don't ask why, it just is. | ||||||
|  |  | ||||||
| @@ -27,15 +27,15 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f | |||||||
| 3. Install Docker for Windows. | 3. Install Docker for Windows. | ||||||
| 4. Install Git for Windows. | 4. Install Git for Windows. | ||||||
| 5. Install VSCode & the listed plugins. | 5. Install VSCode & the listed plugins. | ||||||
| 6. Install VirtualBox. | 6. Install VirtualBox (v7+). | ||||||
| 7. Clone this repository. | 7. Clone this repository. | ||||||
| 8. Run the following command in the root of the repo to build the docker image: | 8. Run the following command in the root of the repo to build the docker image: | ||||||
|     ```powershell |     ```powershell | ||||||
|     docker-compose build builder |     docker compose build builder | ||||||
|     ``` |     ``` | ||||||
| 9. Run the following command to compile Asuro: | 9. Run the following command to compile Asuro: | ||||||
|     ```powershell |     ```powershell | ||||||
|     docker-compose run builder |     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. | 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: | 11. Add the virtualbox installation directory to your `%PATH%` environment variable, usually: | ||||||
| @@ -50,32 +50,29 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f | |||||||
|     ```xml |     ```xml | ||||||
|     <Machine uuid="{7d395c96-891c-4139-b77d-9b6b144b0b93}" name="Asuro" OSType="Linux" snapshotFolder="Snapshots" lastStateChange="2021-06-20T20:33:07Z"> |     <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` and replace the uuid found in `.vscode\launch.json` under `args`, so that it looks something like this: |     Copy the uuid, in our case `7d395c96-891c-4139-b77d-9b6b144b0b93` & create a `localenv.json` file in the project root with the following content: | ||||||
|     ```json |     ```json | ||||||
|     { |     { | ||||||
|         "configurations": [ |         "VirtualBox":{ | ||||||
|             { |             "MachineName":"<YOUR_UUID_OR_MACHINE_NAME>" | ||||||
|                 "name":"Run", |  | ||||||
|                 "request": "launch", |  | ||||||
|                 "type": "coreclr", |  | ||||||
|                 "preLaunchTask": "Build", |  | ||||||
|                 "program": "VBoxSDL", |  | ||||||
|                 "args": [ |  | ||||||
|                     "--comment",  |  | ||||||
|                     "Asuro",  |  | ||||||
|                     "--startvm",  |  | ||||||
|                     "<YOUR UUID HERE>" |  | ||||||
|                 ], |  | ||||||
|                 "cwd": "${workspaceFolder}", |  | ||||||
|                 "console": "internalConsole", |  | ||||||
|                 "internalConsoleOptions": "neverOpen" |  | ||||||
|         } |         } | ||||||
|         ] |  | ||||||
|     } |     } | ||||||
|     ``` |     ``` | ||||||
|     This will allow VSCode to automatically launch VirtualBox once Asuro has been compiled. |     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: | ||||||
|  |     ```json | ||||||
|  |     { | ||||||
|  |         "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. | 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! | 14. Congratulations! You can now play with Asuro! | ||||||
|  |  | ||||||
| ### Gotchas | ### 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`. | - 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`. | ||||||
| @@ -491,22 +491,26 @@ begin | |||||||
|          |          | ||||||
|         { Create a new header to the use in our DHCP REQUEST packet } |         { Create a new header to the use in our DHCP REQUEST packet } | ||||||
|         SendHeader:= createHeader(); |         SendHeader:= createHeader(); | ||||||
|         CopyIPv4(puint8(@Header^.Your_IP[0]), puint8(@SendHeader^.Client_IP[0])); |         CopyIPv4(@getIPv4Config^.Address[0], puint8(@SendHeader^.Client_IP[0])); | ||||||
|         CopyIPv4(puint8(@Header^.Server_IP[0]), puint8(@SendHeader^.Server_IP[0])); |         CopyIPv4(puint8(@Header^.Server_IP[0]), puint8(@SendHeader^.Server_IP[0])); | ||||||
|         processHeader(SendHeader); |         processHeader(SendHeader); | ||||||
|  |  | ||||||
|         { Setup Options } |         { Setup Options } | ||||||
|         SendOptions:= newOptions(); |         SendOptions:= newOptions(); | ||||||
|  |  | ||||||
|         { Create a message type option and assign it the value REQUEST } |         { Create a message type option and assign it the value REQUEST } | ||||||
|         SendMsgType:= ord(TDHCPMessageType.REQUEST); |         SendMsgType:= ord(TDHCPMessageType.REQUEST); | ||||||
|         NewOption(SendOptions, TDHCPOpCode.DHCP_MESSAGE_TYPE, void(@SendMsgType), 1, false); |         NewOption(SendOptions, TDHCPOpCode.DHCP_MESSAGE_TYPE, void(@SendMsgType), 1, false); | ||||||
|  |  | ||||||
|         { Create a Requested IP option and assign it the value from the OFFER packet header } |         { Create a Requested IP option and assign it the value from the OFFER packet header } | ||||||
|         NewOption(SendOptions, TDHCPOpCode.REQUESTED_IP_ADDRESS, void(@SendHeader^.Client_IP[0]), 4, false); |         NewOption(SendOptions, TDHCPOpCode.REQUESTED_IP_ADDRESS, void(@Header^.Your_IP[0]), 4, false); | ||||||
|  |  | ||||||
|         { Create a Server Identifier Option and assign it the value from the OFFER packet options } |         { Create a Server Identifier Option and assign it the value from the OFFER packet options } | ||||||
|         Option:= getOptionByOpcode(Options, TDHCPOpCode.SERVER_IDENTIFIER); |         Option:= getOptionByOpcode(Options, TDHCPOpCode.SERVER_IDENTIFIER); | ||||||
|         if Option <> nil then begin |         if Option <> nil then begin | ||||||
|             NewOption(SendOptions, TDHCPOpCode.SERVER_IDENTIFIER, void(@Option^.Value[0]), 4, false); |             NewOption(SendOptions, TDHCPOpCode.SERVER_IDENTIFIER, void(@Option^.Value[0]), 4, false); | ||||||
|         end; |         end; | ||||||
|  |  | ||||||
|         { Create a Parameter Request List, Request the following: Netmask, Gateway, DNS Name & DNS Server } |         { Create a Parameter Request List, Request the following: Netmask, Gateway, DNS Name & DNS Server } | ||||||
|         RequestParams[0]:= Ord(TDHCPOpCode.SUBNET_MASK); |         RequestParams[0]:= Ord(TDHCPOpCode.SUBNET_MASK); | ||||||
|         RequestParams[1]:= Ord(TDHCPOpCode.ROUTER); |         RequestParams[1]:= Ord(TDHCPOpCode.ROUTER); | ||||||
| @@ -522,9 +526,13 @@ begin | |||||||
|         MAC:= getMAC(); |         MAC:= getMAC(); | ||||||
|         packetCtx:= PPacketContext(Kalloc(sizeof(TPacketContext))); |         packetCtx:= PPacketContext(Kalloc(sizeof(TPacketContext))); | ||||||
|         packetCtx^.TTL:= 128; |         packetCtx^.TTL:= 128; | ||||||
|         copyMAC(@BROADCAST_MAC[0], @packetCtx^.MAC.Destination[0]); |  | ||||||
|  |         { Copy over MAC - src: broadcast - dst: DHCP Server } | ||||||
|         copyMAC(MAC, @packetCtx^.MAC.Source[0]); |         copyMAC(MAC, @packetCtx^.MAC.Source[0]); | ||||||
|         copyIPv4(@NULL_IP[0], @packetCtx^.IP.Source[0]); |         copyMAC(@BROADCAST_MAC[0], @packetCtx^.MAC.Destination[0]); | ||||||
|  |          | ||||||
|  |         { Copy over IP - src: NULL - dst: Broadcast } | ||||||
|  |         CopyIPv4(@getIPv4Config^.Address[0], @packetCtx^.IP.Source[0]); | ||||||
|         copyIPv4(@BROADCAST_IP[0], @packetCtx^.IP.Destination[0]); |         copyIPv4(@BROADCAST_IP[0], @packetCtx^.IP.Destination[0]); | ||||||
|  |  | ||||||
|         { Setup UDPContext (UDP) & copy in the correct details } |         { Setup UDPContext (UDP) & copy in the correct details } | ||||||
| @@ -570,7 +578,7 @@ begin | |||||||
|  |  | ||||||
|     { Check the frame is for us and then process } |     { Check the frame is for us and then process } | ||||||
|     MAC:= getMAC; |     MAC:= getMAC; | ||||||
|     if MACEqual(@context^.PacketContext^.MAC.Destination[0], MAC) then begin |     if MACEqual(@context^.PacketContext^.MAC.Destination[0], MAC) or MACEqual(@context^.PacketContext^.MAC.Destination[0], BROADCAST_MAC) then begin | ||||||
|         Outputln('DHCP','Frame is addressed to us.'); |         Outputln('DHCP','Frame is addressed to us.'); | ||||||
|         { Check the message type is client specific } |         { Check the message type is client specific } | ||||||
|         If Header^.Message_Type = $02 then begin |         If Header^.Message_Type = $02 then begin | ||||||
| @@ -655,7 +663,7 @@ begin | |||||||
|         copyMAC(@BROADCAST_MAC[0], @packetCtx^.MAC.Destination[0]); |         copyMAC(@BROADCAST_MAC[0], @packetCtx^.MAC.Destination[0]); | ||||||
|         MAC:= getMAC; |         MAC:= getMAC; | ||||||
|         copyMAC(MAC, @packetCtx^.MAC.Source[0]); |         copyMAC(MAC, @packetCtx^.MAC.Source[0]); | ||||||
|         copyIPv4(@NULL_IP[0], @packetCtx^.IP.Source[0]); |         CopyIPv4(@getIPv4Config^.Address[0], @packetCtx^.IP.Source[0]); | ||||||
|         copyIPv4(@BROADCAST_IP[0], @packetCtx^.IP.Destination[0]); |         copyIPv4(@BROADCAST_IP[0], @packetCtx^.IP.Destination[0]); | ||||||
|  |  | ||||||
|         { Setup UDPContext (UDP) } |         { Setup UDPContext (UDP) } | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -16,6 +16,7 @@ | |||||||
| 	Include->Strings - String Manipulation. | 	Include->Strings - String Manipulation. | ||||||
| 	 | 	 | ||||||
| 	@author(Kieron Morris <kjm@kieronmorris.me>) | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  |     @author(Aaron Hance <ah@aaronhance.me>) | ||||||
| } | } | ||||||
| unit strings; | unit strings; | ||||||
|  |  | ||||||
| @@ -33,6 +34,10 @@ function stringCopy(str : pchar) : pchar; | |||||||
| function stringNew(size : uint32) : pchar; | function stringNew(size : uint32) : pchar; | ||||||
| function stringSize(str : pchar) : uint32; | function stringSize(str : pchar) : uint32; | ||||||
| function stringConcat(str1, str2 : pchar) : pchar; | function stringConcat(str1, str2 : pchar) : pchar; | ||||||
|  | function stringTrim(str : pchar; length : uint32) : pchar; | ||||||
|  | function stringSub(str : pchar; start, size : uint32) : pchar; | ||||||
|  | function stringReplace(str, find, replace : pchar) : pchar; | ||||||
|  | function stringIndexOf(str, find : pchar) : sint32; | ||||||
| function stringContains(str : pchar; sub : pchar) : boolean; | function stringContains(str : pchar; sub : pchar) : boolean; | ||||||
| function stringToInt(str : pchar) : uint32; | function stringToInt(str : pchar) : uint32; | ||||||
| function hexStringToInt(str : pchar) : uint32; | function hexStringToInt(str : pchar) : uint32; | ||||||
| @@ -151,6 +156,94 @@ begin | |||||||
|     stringConcat:= result; |     stringConcat:= result; | ||||||
| end; | end; | ||||||
|  |  | ||||||
|  | // Trim the string to the specified length. | ||||||
|  | function stringTrim(str : pchar; length : uInt32) : pchar; | ||||||
|  | var | ||||||
|  |     result : pchar; | ||||||
|  | begin | ||||||
|  |     result:= stringNew(length); | ||||||
|  |     memcpy(uint32(str), uint32(result), length); | ||||||
|  |     stringTrim:= result; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | // Return a substring of the string. | ||||||
|  | function stringSub(str : pchar; start, size : uint32) : pchar; | ||||||
|  | var | ||||||
|  |     result : pchar; | ||||||
|  | begin | ||||||
|  |     result:= stringNew(size); | ||||||
|  |     memcpy(uint32(str)+start, uint32(result), size); | ||||||
|  |     stringSub:= result; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | // Replace first instance of a string with another. | ||||||
|  | function stringReplace(str, find, replace : pchar) : pchar; | ||||||
|  | var | ||||||
|  |     result : pchar; | ||||||
|  |     i, j, k : uint32; | ||||||
|  |     found : boolean; | ||||||
|  | begin | ||||||
|  |  | ||||||
|  |     // Find the first instance of the find string. | ||||||
|  |     i:= 0; | ||||||
|  |     found:= false; | ||||||
|  |     while (i < stringSize(str)) and (not found) do begin | ||||||
|  |         if stringEquals(str+i, find) then begin | ||||||
|  |             found:= true; | ||||||
|  |         end else begin | ||||||
|  |             inc(i); | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  |  | ||||||
|  |     // If we found the find string, replace it. | ||||||
|  |     if found then begin | ||||||
|  |         result:= stringNew(stringSize(str) - stringSize(find) + stringSize(replace)); | ||||||
|  |         j:= 0; | ||||||
|  |         k:= 0; | ||||||
|  |         while i < stringSize(str) do begin | ||||||
|  |             if stringEquals(str+i, find) then begin | ||||||
|  |                 memcpy(uint32(replace), uint32(result+j), stringSize(replace)); | ||||||
|  |                 j:= j + stringSize(replace); | ||||||
|  |                 inc(i, stringSize(find)); | ||||||
|  |             end else begin | ||||||
|  |                 result[j]:= str[i]; | ||||||
|  |                 inc(j); | ||||||
|  |                 inc(i); | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |         stringReplace:= result; | ||||||
|  |     end else begin | ||||||
|  |         stringReplace:= stringCopy(str); | ||||||
|  |     end; | ||||||
|  |  | ||||||
|  |     // Return the result. | ||||||
|  |     stringReplace:= result; | ||||||
|  |  | ||||||
|  | end; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Find the index of the first instance of a string. | ||||||
|  | function stringIndexOf(str, find : pchar) : sint32; | ||||||
|  | var  | ||||||
|  |     i : uint32; | ||||||
|  |     found : boolean; | ||||||
|  | begin | ||||||
|  |     i:= 0; | ||||||
|  |     found:= false; | ||||||
|  |     while (i < stringSize(str)) and (not found) do begin | ||||||
|  |         if stringEquals(str+i, find) then begin | ||||||
|  |             found:= true; | ||||||
|  |         end else begin | ||||||
|  |             inc(i); | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  |     if found then begin | ||||||
|  |         stringIndexOf:= i; | ||||||
|  |     end else begin | ||||||
|  |         stringIndexOf:= -1; | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
| function stringContains(str : pchar; sub : pchar) : boolean; | function stringContains(str : pchar; sub : pchar) : boolean; | ||||||
| var | var | ||||||
|     strEnd, subEnd, i, j, count : uint32; |     strEnd, subEnd, i, j, count : uint32; | ||||||
|   | |||||||
| @@ -143,6 +143,22 @@ type | |||||||
|  |  | ||||||
|     PText = ^Text; |     PText = ^Text; | ||||||
|  |  | ||||||
|  | var | ||||||
|  |   AK_START : uint32; external name 'kernel_start'; | ||||||
|  |   AK_END   : uint32; external name 'kernel_end'; | ||||||
|  |   ASURO_KERNEL_START : uint32; | ||||||
|  |   ASURO_KERNEL_END   : uint32; | ||||||
|  |   ASURO_KERNEL_SIZE  : uint32; | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  |  | ||||||
| implementation | implementation | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  | begin | ||||||
|  |     ASURO_KERNEL_START := uint32(@AK_START); | ||||||
|  |     ASURO_KERNEL_END := uint32(@AK_END); | ||||||
|  |     ASURO_KERNEL_SIZE:= ASURO_KERNEL_END - ASURO_KERNEL_START; | ||||||
|  | end; | ||||||
|  |  | ||||||
| end. | end. | ||||||
|   | |||||||
| @@ -125,6 +125,9 @@ var | |||||||
|    HM              : PHashMap; |    HM              : PHashMap; | ||||||
|     |     | ||||||
| begin | begin | ||||||
|  |      { Init the base system unit } | ||||||
|  |      System.init(); | ||||||
|  |  | ||||||
|      { Serial Init } |      { Serial Init } | ||||||
|      serial.init(); |      serial.init(); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								virtualbox-wrapper.ps1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								virtualbox-wrapper.ps1
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | |||||||
|  | <#  | ||||||
|  | You need a local git-ignored localenv.json file with the following content: | ||||||
|  | { | ||||||
|  |   "virtualbox": { | ||||||
|  |     "MachineName": "your-machine-name or guid" | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | #> | ||||||
|  |  | ||||||
|  | param ( | ||||||
|  |   [Parameter(Mandatory=$true)] | ||||||
|  |   [ValidateSet('up', 'down')] | ||||||
|  |   [String]$Command | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | $Config = Get-Content .\localenv.json | ConvertFrom-Json | ||||||
|  | $MachineName = $Config.virtualbox.MachineName | ||||||
|  | $LogLocation = $Config.virtualbox.LogLocation | ||||||
|  | $LogOutputEnabled = $LogLocation -ne $null | ||||||
|  |  | ||||||
|  | if ($Command -eq 'up') { | ||||||
|  |  | ||||||
|  |   if($LogOutputEnabled) { | ||||||
|  |     Clear-Content $LogLocation | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   $MonitorJob = Start-Job -ArgumentList $MachineName -ScriptBlock { | ||||||
|  |     param($MachineName) | ||||||
|  |     Write-Output "Starting $MachineName" | ||||||
|  |     VBoxManage.exe startvm $MachineName | ||||||
|  |     $running=$true | ||||||
|  |     while($running) { | ||||||
|  |       $status=(VBoxManage.exe list runningvms) | ||||||
|  |       if($status) { | ||||||
|  |         $running=$status.contains($MachineName) | ||||||
|  |       } else { | ||||||
|  |         $running=$false | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |    | ||||||
|  |   if($LogOutputEnabled) { | ||||||
|  |     $LogJob = Start-Job -ArgumentList $LogLocation -ScriptBlock { | ||||||
|  |       param($LogLocation) | ||||||
|  |       Get-Content -Path $LogLocation -Wait | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   while($MonitorJob.State -eq 'Running') { | ||||||
|  |     if($LogOutputEnabled) { | ||||||
|  |       Receive-Job $LogJob | ||||||
|  |     } | ||||||
|  |     Receive-Job $MonitorJob | ||||||
|  |   } | ||||||
|  |   Get-Job | Stop-Job | Remove-Job -Force | ||||||
|  | } elseif ($Command -eq 'down') { | ||||||
|  |   Write-Output "Stopping $MachineName" | ||||||
|  |   VBoxManage.exe controlvm $MachineName poweroff | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user