Compare commits
	
		
			45 Commits
		
	
	
		
			feature/do
			...
			feature/vi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8be364c990 | |||
| 0e2c6b2936 | |||
| 632c3fa66b | |||
| 875e3e4765 | |||
| e28d68128d | |||
| a9969d58f8 | |||
| d7a54d858d | |||
| 4e991c3e6f | |||
| a3217de71a | |||
| 19b433a19f | |||
| 69d1d22a18 | |||
| 5c15343ed0 | |||
| 3ae349fbc8 | |||
| 78c060c114 | |||
| cd925e96c2 | |||
| 142dd486dd | |||
| beeeabd441 | |||
| b73c66f6d6 | |||
| 189526cab8 | |||
| 595dd4fbac | |||
| ba6d8037d2 | |||
| 208bda92c8 | |||
| a7111d3cac | |||
| d182fd7f46 | |||
| 4c5038b001 | |||
| 98481ea1ce | |||
| b5582b1284 | |||
| 346dc4e4c9 | |||
| b2eee58df4 | |||
| 161cea4920 | |||
| 6b81c4ece0 | |||
| ee17f69115 | |||
| 81c19bff16 | |||
| e7cda58113 | |||
| 44f18554e1 | |||
| 52b42ec975 | |||
| 2815dd9e4d | |||
| d057bfc3ff | |||
| e4621c8aaa | |||
| 170b93dd69 | |||
| 34d6873a6a | |||
| e69d06ea4f | |||
|   | 2939afa729 | ||
| ad8e80913a | |||
| 4d25ceef77 | 
							
								
								
									
										52
									
								
								.drone.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.drone.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | 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" | ||||||
							
								
								
									
										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,99 +0,0 @@ | |||||||
| stages: |  | ||||||
|   - Generate Stub and Versions |  | ||||||
|   - Generate Version Files |  | ||||||
|   - Compile Sources |  | ||||||
|   - Link |  | ||||||
|   - Generate ISO |  | ||||||
|   - Generate Sources List |  | ||||||
|   - Generate Documentation |  | ||||||
|  |  | ||||||
| compile_stub: |  | ||||||
|   stage: Generate Stub and Versions |  | ||||||
|   script:  |  | ||||||
|     - chmod +x ./compile_stub.sh |  | ||||||
|     - ./compile_stub.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - lib/stub.o |  | ||||||
|  |  | ||||||
| vergen: |  | ||||||
|   stage: Generate Stub and Versions |  | ||||||
|   script:  |  | ||||||
|     - chmod +x ./compile_vergen.sh |  | ||||||
|     - ./compile_vergen.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - release/*.svg |  | ||||||
|       - src/include/asuro.pas |  | ||||||
|  |  | ||||||
| compile_sources: |  | ||||||
|   stage: Compile Sources |  | ||||||
|   script: |  | ||||||
|     - chmod +x ./compile_sources.sh |  | ||||||
|     - ./compile_sources.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - lib/*.o |  | ||||||
|   dependencies: |  | ||||||
|     - compile_stub |  | ||||||
|     - vergen |  | ||||||
|   needs: |  | ||||||
|     - vergen |  | ||||||
|     - compile_stub |  | ||||||
|  |  | ||||||
| link: |  | ||||||
|   stage: Link |  | ||||||
|   script: |  | ||||||
|     - chmod +x ./compile_link.sh |  | ||||||
|     - ./compile_link.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - bin/kernel.bin |  | ||||||
|   dependencies: |  | ||||||
|     - compile_sources |  | ||||||
|   needs: |  | ||||||
|     - compile_sources |  | ||||||
|  |  | ||||||
| isogen: |  | ||||||
|   stage: Generate ISO |  | ||||||
|   script: |  | ||||||
|     - chmod +x ./compile_isogen.sh |  | ||||||
|     - ./compile_isogen.sh |  | ||||||
|     - chmod +x ./compile_sumgen.sh |  | ||||||
|     - ./compile_sumgen.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - ./Asuro.iso |  | ||||||
|       - ./release/checksum.svg |  | ||||||
|   dependencies: |  | ||||||
|     - link |  | ||||||
|   needs: |  | ||||||
|     - link |  | ||||||
|  |  | ||||||
| sourcelist: |  | ||||||
|   stage: Generate Sources List |  | ||||||
|   script: |  | ||||||
|     - chmod +x ./compile_sourcelist.sh |  | ||||||
|     - ./compile_sourcelist.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - ./sources.list |  | ||||||
|   dependencies: |  | ||||||
|     - vergen |  | ||||||
|   needs: |  | ||||||
|     - vergen |  | ||||||
|  |  | ||||||
| docgen: |  | ||||||
|   stage: Generate Documentation |  | ||||||
|   script: |  | ||||||
|     - chmod +x ./compile_docs.sh |  | ||||||
|     - ./compile_docs.sh |  | ||||||
|   artifacts: |  | ||||||
|     paths: |  | ||||||
|       - ./doc/* |  | ||||||
|   dependencies: |  | ||||||
|     - vergen |  | ||||||
|     - sourcelist |  | ||||||
|   needs: |  | ||||||
|     - vergen |  | ||||||
|     - sourcelist |  | ||||||
							
								
								
									
										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" | ||||||
|         } |         } | ||||||
|     ] |     ] | ||||||
| } | } | ||||||
							
								
								
									
										22
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -2,18 +2,22 @@ FROM ubuntu:latest | |||||||
|  |  | ||||||
| VOLUME ["/code"] | VOLUME ["/code"] | ||||||
|  |  | ||||||
|  | ENV DEBIAN_FRONTEND=noninteractive | ||||||
| RUN dpkg --add-architecture i386 | RUN dpkg --add-architecture i386 | ||||||
| RUN apt-get update | RUN apt-get update && apt-get install -y \ | ||||||
| RUN apt-get install nasm curl make:i386 binutils:i386 xorriso grub-pc-bin dos2unix -y | 	curl dos2unix wget git make nasm binutils:i386 xorriso grub-pc-bin && \ | ||||||
| RUN apt-get clean | 	apt-get clean my room | ||||||
| RUN curl https://sourceforge.net/projects/freepascal/files/Linux/2.6.4/fpc-2.6.4.i386-linux.tar/download --output fpc.tar -L && \ |  | ||||||
| 	tar -xf fpc.tar |  | ||||||
|  |  | ||||||
| WORKDIR ./fpc-2.6.4.i386-linux | SHELL ["/bin/bash", "-c"] | ||||||
| RUN ./install.sh | ARG FPC_VERSION=2.6.4 | ||||||
|  | RUN curl -sL https://sourceforge.net/projects/freepascal/files/Linux/$FPC_VERSION/fpc-$FPC_VERSION.i386-linux.tar/download | tar -xf - && \ | ||||||
|  | 	pushd fpc-$FPC_VERSION.i386-linux && ./install.sh && popd && \ | ||||||
|  | 	rm -rf fpc-$FPC_VERSION.i386-linux | ||||||
|  |  | ||||||
| COPY compile.sh /compile.sh | COPY compile.sh /compile.sh | ||||||
| RUN mkdir /code | ADD https://raw.githubusercontent.com/fsaintjacques/semver-tool/master/src/semver /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", "/compile.sh"] | ENTRYPOINT ["/bin/bash", "-c"] | ||||||
|  | CMD ["/compile.sh"] | ||||||
							
								
								
									
										71
									
								
								compile.sh
									
									
									
									
									
								
							
							
						
						
									
										71
									
								
								compile.sh
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env bash | ||||||
| ERRCOUNT=0 | ERRCOUNT=0 | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| @@ -7,56 +7,43 @@ echo "Asuro Compilation" | |||||||
| echo " " | echo " " | ||||||
|  |  | ||||||
| #Compile Stub.asm | #Compile Stub.asm | ||||||
| ./compile_stub.sh | rm lib/* | ||||||
| if [ $? -ne 0 ] |  | ||||||
| then |  | ||||||
| 	echo "Failed to compile stub!" |  | ||||||
| 	ERRCOUNT=$((ERRCOUNT+1))	 |  | ||||||
| else |  | ||||||
| 	echo "Success." |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| #Generate .pas with versioning headers. | runOrFail() { | ||||||
| ./compile_vergen.sh | 	local binary=$1 | ||||||
|  | 	local errorText=$2 | ||||||
| #Compile all .pas sources | 	if $binary; then | ||||||
| ./compile_sources.sh |  | ||||||
| if [ $? -ne 0 ] |  | ||||||
| then |  | ||||||
| 	echo " " |  | ||||||
| 	echo "Failed to compile FPC Sources!" |  | ||||||
| 	ERRCOUNT=$((ERRCOUNT+1))	 |  | ||||||
| else |  | ||||||
| 	echo " " |  | ||||||
| 		echo "Success." | 		echo "Success." | ||||||
| fi | 	else | ||||||
|  | 		echo "$errorText" | ||||||
| #Link into a binary. |  | ||||||
| ./compile_link.sh |  | ||||||
| if [ $? -ne 0 ] |  | ||||||
| then |  | ||||||
| 	echo "Failed linking!" |  | ||||||
| 		ERRCOUNT=$((ERRCOUNT+1)) | 		ERRCOUNT=$((ERRCOUNT+1)) | ||||||
| else | 	fi | ||||||
| 	echo "Success." | } | ||||||
| fi |  | ||||||
|  |  | ||||||
| #Generate an ISO with GRUB as the Bootloader. | declare -a run_steps=( | ||||||
| ./compile_isogen.sh | 	"compile_stub.sh" "Failed to compile stub!" | ||||||
| if [ $? -ne 0 ] | 	"compile_vergen.sh" "Versions failed to compile" | ||||||
| then | 	"compile_sources.sh" "Failed to compile FPC Sources!" | ||||||
| 	echo "Failed to create ISO!" | 	"compile_link.sh" "Failed linking!" | ||||||
| 	ERRCOUNT=$((ERRCOUNT+1)) | 	"compile_isogen.sh" "Failed to create ISO!" | ||||||
| else | ) | ||||||
| 	echo "Success." |  | ||||||
| fi | for ((i=0; i<${#run_steps[@]}; i+=2)) | ||||||
|  | do | ||||||
|  | 	if [ "$ERRCOUNT" -eq "0" ] | ||||||
|  | 	then | ||||||
|  | 			script=$(pwd)/"${run_steps[$i]}" | ||||||
|  | 			message="${run_steps[$i+1]}" | ||||||
|  | 			runOrFail "$script" "$message" | ||||||
|  | 	fi | ||||||
|  | done | ||||||
|  |  | ||||||
| #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 .. | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/bash | #!/usr/bin/env bash | ||||||
| echo > checksums.md5 | echo > checksums.md5 | ||||||
| for directory in $(find src/ -maxdepth 10 -type d); do | for directory in $(find src/ -maxdepth 10 -type d); do | ||||||
| 	for filename in $directory/*.pas; do | 	for filename in $directory/*.pas; do | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/bash | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
| @@ -15,4 +15,3 @@ rm -rf ./doc/* | |||||||
| echo "Generating Docs..." | echo "Generating Docs..." | ||||||
| ./pasdoc/bin/pasdoc -N "Asuro" -T "Asuro OS Documentation" -O "html" -E ./doc/ -S sources.list --use-tipue-search | ./pasdoc/bin/pasdoc -N "Asuro" -T "Asuro OS Documentation" -O "html" -E ./doc/ -S sources.list --use-tipue-search | ||||||
| echo "Docgen finished." | echo "Docgen finished." | ||||||
| exit 0 |  | ||||||
| @@ -1,8 +1,8 @@ | |||||||
| #/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
| if [ "$1" == "failed" ] | if [[ "$1" == "failed" ]] | ||||||
| then | then | ||||||
| 	echo "Errors Occurred, please review." | 	echo "Errors Occurred, please review." | ||||||
| 	wget -q https://img.shields.io/badge/build-failed-red.svg -O release/build.svg 2>/dev/null | 	wget -q https://img.shields.io/badge/build-failed-red.svg -O release/build.svg 2>/dev/null | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/bash | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | 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,8 +1,7 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
| echo "Compiling Stub..." | echo "Compiling Stub..." | ||||||
| echo " " | echo " " | ||||||
| rm lib/* |  | ||||||
| nasm -f elf src/stub/stub.asm -o lib/stub.o | nasm -f elf src/stub/stub.asm -o lib/stub.o | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| #/bin/sh | #!/usr/bin/env bash | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| #!/bin/bash | #!/usr/bin/env bash | ||||||
|  | set -e | ||||||
| echo " " | echo " " | ||||||
| echo "=======================" | echo "=======================" | ||||||
| echo " " | echo " " | ||||||
| @@ -8,60 +9,67 @@ chmod +x ./compile_checksum.sh | |||||||
| ./compile_checksum.sh | ./compile_checksum.sh | ||||||
| outfile="src/include/asuro.pas" | outfile="src/include/asuro.pas" | ||||||
| file="version" | file="version" | ||||||
| while IFS=: read -r line;do | { | ||||||
| 	major=$(echo $line | awk '{print $1}') | 	# this script requires semver tool | ||||||
| 	minor=$(echo $line | awk '{print $2}') | 	wget -q https://raw.githubusercontent.com/fsaintjacques/semver-tool/master/src/semver -O bin/semver && chmod +x bin/semver | ||||||
| 	sub=$(echo $line | awk '{print $3}') | 	export PATH="$(pwd)/bin:$PATH" | ||||||
| 	release=$(echo $line | awk '{print $4}') | } | ||||||
| done <"$file" | tagref=$(git describe --tags) | ||||||
|  | revision=$(git rev-parse --short=8 HEAD) | ||||||
|  | major=$(semver get major $tagref) | ||||||
|  | minor=$(semver get minor $tagref) | ||||||
|  | sub=$(semver get patch $tagref) | ||||||
|  | version=$(semver get release $tagref) | ||||||
|  | release=$(semver get prerel $tagref) | ||||||
|  | build=$(semver get build $tagref) | ||||||
| linecount=$(./loc.sh | awk '{print $1}') | linecount=$(./loc.sh | awk '{print $1}') | ||||||
| sourcecount=$(find src -type f | wc -l) | sourcecount=$(find src -type f | wc -l) | ||||||
| drivercount=$(find src/driver -type f | wc -l) | drivercount=$(find src/driver -type f | wc -l) | ||||||
| revision=$(git rev-list --all --count) |  | ||||||
| fpcversion=$(fpc -h | grep -m 1 version | awk '{print $5}') | fpcversion=$(fpc -h | grep -m 1 version | awk '{print $5}') | ||||||
| makeversion=$(make -v | grep GNU | awk '{print $3}' | grep -v GNU) | makeversion=$(make -v | grep GNU | awk '{print $3}' | grep -v GNU) | ||||||
| nasmversion=$(nasm -v | awk '{print $3'}) | nasmversion=$(nasm -v | awk '{print $3'}) | ||||||
| compiledate=$(date +"%d/%m/%y") | compiledate=$(date +"%d/%m/%y") | ||||||
| compiletime=$(date +"%T") | compiletime=$(date +"%T") | ||||||
| checksum=$(md5sum checksums.md5 | awk '{print $1}') | checksum=$(md5sum checksums.md5 | awk '{print $1}') | ||||||
| echo "{" > $outfile |  | ||||||
| echo "   Include->Asuro - Constants generated during pipeline/compilation for use at runtime." >> $outfile | [[ -n "$release" ]] && version="$version-$release" | ||||||
| echo "   @author(Autogenerated)" >> $outfile | cat > $outfile <<EOF | ||||||
| echo "}" >> $outfile | unit asuro; | ||||||
| echo "unit asuro;" >> $outfile |   | ||||||
| echo " " >> $outfile | interface | ||||||
| echo "interface" >> $outfile |   | ||||||
| echo " " >> $outfile | const | ||||||
| echo "const" >> $outfile |      VERSION       = '$version'; | ||||||
| echo "     VERSION       = '$major.$minor.$sub-$revision$release'; //The current full version as a string." >> $outfile |      VERSION_MAJOR = '$major'; | ||||||
| echo "     VERSION_MAJOR = '$major'; // Current major version as a string." >> $outfile |      VERSION_MINOR = '$minor'; | ||||||
| echo "     VERSION_MINOR = '$minor'; // Current minor version as a string." >> $outfile |      VERSION_SUB   = '$sub'; | ||||||
| echo "     VERSION_SUB   = '$sub'; // Current sub version as a string." >> $outfile |      REVISION      = '$revision'; | ||||||
| echo "     REVISION      = '$revision'; // Current revision as a string." >> $outfile |      RELEASE       = '$release'; | ||||||
| echo "     RELEASE       = '$release'; // Current release as a string." >> $outfile |      LINE_COUNT    = $linecount; | ||||||
| echo "     LINE_COUNT    = $linecount; // Project line count as compiled as a string." >> $outfile |      FILE_COUNT    = $sourcecount; | ||||||
| echo "     FILE_COUNT    = $sourcecount; // Project line count as compiled as a string." >> $outfile |      DRIVER_COUNT  = $drivercount; | ||||||
| echo "     DRIVER_COUNT  = $drivercount; // Number of baked drivers in the current binary." >> $outfile |      FPC_VERSION   = '$fpcversion'; | ||||||
| echo "     FPC_VERSION   = '$fpcversion'; // Version of the FreePascal Compiler used to compile the current binary." >> $outfile |      NASM_VERSION  = '$nasmversion'; | ||||||
| echo "     NASM_VERSION  = '$nasmversion'; // Version of the Netwide Assembler used to compile the multiboot stub." >> $outfile |      MAKE_VERSION  = '$makeversion'; | ||||||
| echo "     MAKE_VERSION  = '$makeversion'; // Version of MAKE used to link the current binary." >> $outfile |      COMPILE_DATE  = '$compiledate'; | ||||||
| echo "     COMPILE_DATE  = '$compiledate'; // Date in which the current binary was compiled." >> $outfile |      COMPILE_TIME  = '$compiletime'; | ||||||
| echo "     COMPILE_TIME  = '$compiletime'; // Time in which the current binary was compiled." >> $outfile |      CHECKSUM      = '$checksum'; | ||||||
| echo "     CHECKSUM      = '$checksum'; // MD5 pseduo-checksum of all of the sourcefiles together." >> $outfile |   | ||||||
| echo " " >> $outfile | implementation | ||||||
| echo "implementation" >> $outfile |   | ||||||
| echo " " >> $outfile | end. | ||||||
| echo "end." >> $outfile | EOF | ||||||
| echo "Generating release info..." | echo "Generating release info..." | ||||||
| wget -q https://img.shields.io/badge/version-$major.$minor.$sub--$revision$release-blue.svg -O release/version.svg 2>/dev/null | set +e # These can fail on branches and such, for now | ||||||
| wget -q https://img.shields.io/badge/revision-$revision-blue.svg -O release/revision.svg 2>/dev/null | wget -q https://img.shields.io/badge/version-$major.$minor.$sub--$revision$release-blue.svg -O release/version.svg | ||||||
| wget -q https://img.shields.io/badge/release-$release-blue.svg -O release/release.svg 2>/dev/null | wget -q https://img.shields.io/badge/revision-$revision-blue.svg -O release/revision.svg | ||||||
| wget -q https://img.shields.io/badge/lines-$linecount-blueviolet.svg -O release/lines.svg 2>/dev/null | wget -q https://img.shields.io/badge/release-$release-blue.svg -O release/release.svg | ||||||
| wget -q https://img.shields.io/badge/files-$sourcecount-blueviolet.svg -O release/files.svg 2>/dev/null | wget -q https://img.shields.io/badge/lines-$linecount-blueviolet.svg -O release/lines.svg | ||||||
| wget -q https://img.shields.io/badge/drivers-$drivercount-blueviolet.svg -O release/drivers.svg 2>/dev/null | wget -q https://img.shields.io/badge/files-$sourcecount-blueviolet.svg -O release/files.svg | ||||||
| wget -q https://img.shields.io/badge/FPC_version-$fpcversion-lightgrey.svg -O release/fpcversion.svg 2>/dev/null | wget -q https://img.shields.io/badge/drivers-$drivercount-blueviolet.svg -O release/drivers.svg | ||||||
| wget -q https://img.shields.io/badge/NASM_version-$nasmversion-lightgrey.svg -O release/nasmversion.svg 2>/dev/null | wget -q https://img.shields.io/badge/FPC_version-$fpcversion-lightgrey.svg -O release/fpcversion.svg | ||||||
| wget -q https://img.shields.io/badge/MAKE_version-$makeversion-lightgrey.svg -O release/makeversion.svg 2>/dev/null | wget -q https://img.shields.io/badge/NASM_version-$nasmversion-lightgrey.svg -O release/nasmversion.svg | ||||||
| wget -q https://img.shields.io/badge/release_date-$compiledate-lightgrey.svg -O release/date.svg 2>/dev/null | wget -q https://img.shields.io/badge/MAKE_version-$makeversion-lightgrey.svg -O release/makeversion.svg | ||||||
| wget -q https://img.shields.io/badge/fingerprint-$checksum-important.svg -O release/fingerprint.svg 2>/dev/null | wget -q https://img.shields.io/badge/release_date-$compiledate-lightgrey.svg -O release/date.svg | ||||||
|  | wget -q https://img.shields.io/badge/fingerprint-$checksum-important.svg -O release/fingerprint.svg | ||||||
| echo "Done versioning." | echo "Done versioning." | ||||||
|   | |||||||
| @@ -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`. | ||||||
| @@ -1776,14 +1776,15 @@ var | |||||||
|    fb: puint32; |    fb: puint32; | ||||||
|  |  | ||||||
| Begin | Begin | ||||||
|  |      Ready:= False; | ||||||
|      fb:= puint32(uint32(multibootinfo^.framebuffer_addr)); |      fb:= puint32(uint32(multibootinfo^.framebuffer_addr)); | ||||||
|      Console_Properties.Width:= multibootinfo^.framebuffer_width; |      Console_Properties.Width:= multibootinfo^.framebuffer_width; | ||||||
|      Console_Properties.Height:= multibootinfo^.framebuffer_height; |      Console_Properties.Height:= multibootinfo^.framebuffer_height; | ||||||
|      Console_Properties.BitsPerPixel:= multibootinfo^.framebuffer_bpp; |      Console_Properties.BitsPerPixel:= multibootinfo^.framebuffer_bpp; | ||||||
|      Console_Properties.MAX_CELL_X:= (Console_Properties.Width div 8) - 1; |      Console_Properties.MAX_CELL_X:= (Console_Properties.Width div 8) - 1; | ||||||
|      Console_Properties.MAX_CELL_Y:= (Console_Properties.Height div 16) - 1; |      Console_Properties.MAX_CELL_Y:= (Console_Properties.Height div 16) - 1; | ||||||
|      If Console_Properties.BitsPerPixel <> 16 then while true do begin |      If Console_Properties.BitsPerPixel <> 16 then begin | ||||||
|  |         exit; | ||||||
|      end; |      end; | ||||||
|      kpalloc(uint32(fb)); |      kpalloc(uint32(fb)); | ||||||
|      keyboard.hook(@keyhook); |      keyboard.hook(@keyhook); | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								src/cpu.pas
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/cpu.pas
									
									
									
									
									
								
							| @@ -291,6 +291,28 @@ begin | |||||||
|     end; |     end; | ||||||
| end; | end; | ||||||
|  |  | ||||||
|  | procedure enableAVX(); | ||||||
|  | begin | ||||||
|  |     if CPUID.Capabilities1^.AVX then begin | ||||||
|  |         asm | ||||||
|  |             PUSH EAX | ||||||
|  |             PUSH ECX | ||||||
|  |             PUSH EDX | ||||||
|  |             XOR ECX, ECX | ||||||
|  |             db $0F | ||||||
|  |             db $01 | ||||||
|  |             db $D0 | ||||||
|  |             OR EAX, 7 | ||||||
|  |             db $0F | ||||||
|  |             db $01 | ||||||
|  |             db $D1 | ||||||
|  |             POP EDX | ||||||
|  |             POP ECX | ||||||
|  |             POP EAX | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
| procedure init(); | procedure init(); | ||||||
| begin | begin | ||||||
|     terminal.registerCommand('CPU', @Terminal_Command_CPU, 'CPU Info.'); |     terminal.registerCommand('CPU', @Terminal_Command_CPU, 'CPU Info.'); | ||||||
| @@ -300,6 +322,7 @@ begin | |||||||
|     getCPUCapabilities; |     getCPUCapabilities; | ||||||
|     getCPUClockSpeed; |     getCPUClockSpeed; | ||||||
|     enableSSE; |     enableSSE; | ||||||
|  |     enableAVX; | ||||||
| end; | end; | ||||||
|  |  | ||||||
| end. | end. | ||||||
							
								
								
									
										100
									
								
								src/driver/video/doublebuffer.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								src/driver/video/doublebuffer.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->Doublebuffer - Implements a very basic double buffer, tested with VESA drivers. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit doublebuffer; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     lmemorymanager, tracer, videotypes, serial, util; | ||||||
|  |  | ||||||
|  | //Init the driver, and register with the video interface in a state ready for execution. | ||||||
|  | procedure init(Register : FRegisterDriver); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | function allocateBackBuffer(Width : uint32; Height : uint32; BitsPerPixel : uint8) : uint64; | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('doublebuffer.allocateBackBuffer.enter'); | ||||||
|  |     //This doesn't currently work... Needs a rework of lmemorymanager | ||||||
|  |     allocateBackBuffer:= uint64(klalloc((Width * Height) * BitsPerPixel)); | ||||||
|  |     tracer.push_trace('doublebuffer.allocateBackBuffer.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure initBackBuffer(VInterface : PVideoInterface; Width : uint32; Height : uint32; BitsPerPixel : uint8); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('doublebuffer.initBackBuffer.enter'); | ||||||
|  |     if not(VInterface^.BackBuffer.Initialized) then begin | ||||||
|  |         VInterface^.BackBuffer.Location:= allocateBackBuffer(Width, Height, BitsPerPixel); | ||||||
|  |         if (VInterface^.BackBuffer.Location <> 0) then begin | ||||||
|  |             VInterface^.BackBuffer.Width:= Width; | ||||||
|  |             VInterface^.BackBuffer.Height:= Height; | ||||||
|  |             VInterface^.BackBuffer.BitsPerPixel:= BitsPerPixel; | ||||||
|  |             VInterface^.BackBuffer.Initialized:= True; | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('doublebuffer.initBackBuffer.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure Flush(FrontBuffer : PVideoBuffer; BackBuffer : PVideoBuffer); | ||||||
|  | var | ||||||
|  |     idx : uint32; | ||||||
|  |     Back,Front : uint32; | ||||||
|  |     BufferSize : uint32; | ||||||
|  |  | ||||||
|  | const | ||||||
|  |     //COPY_WIDTH = 64; //Use this for 64bit copies | ||||||
|  |     COPY_WIDTH = 128; //Use this for SSE copies | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     //tracer.push_trace('doublebuffer.Flush.enter'); | ||||||
|  |     if not(BackBuffer^.Initialized) then exit; | ||||||
|  |     if ((FrontBuffer^.Width > BackBuffer^.Width) or (FrontBuffer^.Height > BackBuffer^.Height)) then exit; | ||||||
|  |     Back:= BackBuffer^.Location; | ||||||
|  |     Front:= FrontBuffer^.Location; | ||||||
|  |     BufferSize:= ( ( BackBuffer^.Width * BackBuffer^.Height * BackBuffer^.BitsPerPixel) div COPY_WIDTH ) - 1; | ||||||
|  |     for idx:=0 to BufferSize do begin | ||||||
|  |         //Front[idx]:= Back[idx]; | ||||||
|  |         // -- TODO: Get SSE working here for 128bit copies -- | ||||||
|  |         __SSE_128_memcpy(Back + (idx * 16), Front + (idx * 16));   | ||||||
|  |     end; | ||||||
|  |     //tracer.push_trace('doublebuffer.Flush.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function enable(VideoInterface : PVideoInterface) : boolean; | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('doublebuffer.enable.enter'); | ||||||
|  |     enable:= false; | ||||||
|  |     initBackBuffer(VideoInterface, VideoInterface^.FrontBuffer.Width, VideoInterface^.FrontBuffer.Height, VideoInterface^.FrontBuffer.BitsPerPixel); | ||||||
|  |     if VideoInterface^.BackBuffer.Initialized then begin | ||||||
|  |         VideoInterface^.DefaultBuffer:= @VideoInterface^.BackBuffer; | ||||||
|  |         VideoInterface^.DrawRoutines.Flush:= @Flush; | ||||||
|  |         enable:= true; | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('doublebuffer.enable.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(Register : FRegisterDriver); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('doublebuffer.init.enter'); | ||||||
|  |     Register('BASIC_DOUBLE_BUFFER', @enable); | ||||||
|  |     tracer.push_trace('doublebuffer.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										87
									
								
								src/driver/video/vesa.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								src/driver/video/vesa.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->VESA - VESA Display Driver. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit vesa; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     videotypes, tracer, multiboot, lmemorymanager; | ||||||
|  |  | ||||||
|  | //Init the driver, and register with the video interface in a state ready for execution. | ||||||
|  | procedure init(Register : FRegisterDriver); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     VESA8, VESA16, VESA24, VESA32; | ||||||
|  |  | ||||||
|  | procedure allocateVESAFrameBuffer(Address : uint32; Width : uint32; Height : uint32); | ||||||
|  | var | ||||||
|  |     LowerAddress, UpperAddress : uint32; | ||||||
|  |     Block : uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('VESA.allocateFrameBuffer.enter'); | ||||||
|  |     LowerAddress:= ((Address) SHR 22)-1; | ||||||
|  |     UpperAddress:= ((Address + (Width * Height)) SHR 22)+1; | ||||||
|  |     For Block:=LowerAddress to UpperAddress do begin | ||||||
|  |         kpalloc(Block SHL 22); | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('VESA.allocateFrameBuffer.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure initVESAFrameBuffer(VideoBuffer : PVideoBuffer; Location : uint64; Width : uint32; Height : uint32; BitsPerPixel : uint8); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('VESA.initVESAFrameBuffer.enter'); | ||||||
|  |     if not(VideoBuffer^.Initialized) then begin | ||||||
|  |         VideoBuffer^.Location:= Location; | ||||||
|  |         VideoBuffer^.BitsPerPixel:= BitsPerPixel; | ||||||
|  |         VideoBuffer^.Width:= Width; | ||||||
|  |         VideoBuffer^.Height:= Height; | ||||||
|  |         allocateVESAFrameBuffer(VideoBuffer^.Location, VideoBuffer^.Width, VideoBuffer^.Height); | ||||||
|  |         if VideoBuffer^.Location <> 0 then | ||||||
|  |             VideoBuffer^.Initialized:= True; | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('VESA.initVESAFrameBuffer.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function enable(VideoInterface : PVideoInterface) : boolean; | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('VESA.enable.enter'); | ||||||
|  |     initVESAFrameBuffer(@VideoInterface^.FrontBuffer, multiboot.multibootinfo^.framebuffer_addr, multiboot.multibootinfo^.framebuffer_width, multiboot.multibootinfo^.framebuffer_height, multiboot.multibootinfo^.framebuffer_bpp); | ||||||
|  |     case (VideoInterface^.FrontBuffer.BitsPerPixel) of | ||||||
|  |         08:VESA8.init(@VideoInterface^.DrawRoutines); | ||||||
|  |         16:VESA16.init(@VideoInterface^.DrawRoutines); | ||||||
|  |         24:VESA24.init(@VideoInterface^.DrawRoutines); | ||||||
|  |         32:VESA32.init(@VideoInterface^.DrawRoutines); | ||||||
|  |     end; | ||||||
|  |     enable:= VideoInterface^.FrontBuffer.Initialized;   | ||||||
|  |     tracer.push_trace('VESA.enable.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(Register : FRegisterDriver); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('VESA.init.enter'); | ||||||
|  |     if Register <> nil then | ||||||
|  |         Register('VESA', @enable);    | ||||||
|  |     tracer.push_trace('VESA.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										43
									
								
								src/driver/video/vesa16.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/driver/video/vesa16.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->VESA16 - Implementation of VESA 16bpp draw routines for the VESA Driver. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit vesa16; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     videotypes, vesa, tracer, color; | ||||||
|  |  | ||||||
|  | //Init the draw routines by providing what we support through the DrawRoutines struct. | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | procedure DrawPixel(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | begin | ||||||
|  |  | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('vesa16.init.enter');    | ||||||
|  |     tracer.push_trace('vesa16.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										43
									
								
								src/driver/video/vesa24.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/driver/video/vesa24.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->VESA24 - Implementation of VESA 24bpp draw routines for the VESA Driver. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit vesa24; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     videotypes, vesa, tracer, color; | ||||||
|  |  | ||||||
|  | //Init the draw routines by providing what we support through the DrawRoutines struct. | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | procedure DrawPixel(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | begin | ||||||
|  |  | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  | begin | ||||||
|  | 	tracer.push_trace('vesa24.init.enter'); | ||||||
|  | 	tracer.push_trace('vesa24.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										52
									
								
								src/driver/video/vesa32.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/driver/video/vesa32.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->VESA32 - Implementation of VESA 32bpp draw routines for the VESA Driver. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit vesa32; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     videotypes, vesa, tracer, color; | ||||||
|  |  | ||||||
|  | //Init the draw routines by providing what we support through the DrawRoutines struct. | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | procedure DrawPixel(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | var | ||||||
|  |     Location : PuInt32; | ||||||
|  |     LocationIndex : Uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     //tracer.push_trace('vesa32.DrawPixel.enter'); | ||||||
|  |     Location:= Puint32(Buffer^.Location); | ||||||
|  |     LocationIndex:= (Y * Buffer^.Width) + X; | ||||||
|  |     Location[LocationIndex]:= uint32(Pixel); | ||||||
|  |     //tracer.push_trace('vesa32.DrawPixel.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('vesa32.init.enter'); | ||||||
|  |     DrawRoutines^.DrawPixel:= @DrawPixel; | ||||||
|  |     tracer.push_trace('vesa32.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										43
									
								
								src/driver/video/vesa8.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/driver/video/vesa8.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->VESA8 - Implementation of VESA 8bpp draw routines for the VESA Driver. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit vesa8; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     videotypes, vesa, tracer, color; | ||||||
|  |  | ||||||
|  | //Init the draw routines by providing what we support through the DrawRoutines struct. | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | procedure DrawPixel(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | begin | ||||||
|  |  | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure init(DrawRoutines : PDrawRoutines); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('vesa8.init.enter');    | ||||||
|  |     tracer.push_trace('vesa8.init.exit');   | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										318
									
								
								src/driver/video/video.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										318
									
								
								src/driver/video/video.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,318 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->Video - Provides an abstract rasterization/drawing interface. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit video; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     lmemorymanager, tracer, color, videotypes, hashmap, util, texture; | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  | procedure DrawPixel(X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | procedure DrawLine(x1,y1,x2,y2 : uint32; thickness : uint32; Color : TRGB32); | ||||||
|  | procedure DrawRect(x1,y1,x2,y2 : uint32; line_thickness : uint32; Color : TRGB32); | ||||||
|  | procedure FillRect(x1,y1,x2,y2 : uint32; line_thickness : uint32; Line_Color : TRGB32; Fill_Color : TRGB32); | ||||||
|  | procedure Flush(); | ||||||
|  |  | ||||||
|  | function register(DriverIdentifier : pchar; EnableCallback : FEnableDriver) : boolean; | ||||||
|  | function enable(DriverIdentifier : pchar) : boolean; | ||||||
|  |  | ||||||
|  | function frontBufferWidth : uint32; | ||||||
|  | function frontBufferHeight : uint32; | ||||||
|  | function frontBufferBpp : uint8; | ||||||
|  | function backBufferWidth : uint32; | ||||||
|  | function backBufferHeight : uint32; | ||||||
|  | function backBufferBpp : uint8; | ||||||
|  |  | ||||||
|  | Procedure basicFDrawTexture(Buffer : PVideoBuffer; X : uint32; Y : uint32; Texture : PTexture); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | Procedure dummyFDrawPixel(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.dummyFDrawPixel.enter'); | ||||||
|  |     //Do nothing, this is the most basic function that must be implemented by a driver. | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure basicFFlush(FrontBuffer : PVideoBuffer; BackBuffer : PVideoBuffer); | ||||||
|  | var | ||||||
|  |     idx : uint32; | ||||||
|  |     Back,Front : puint32; | ||||||
|  |     BufferSize : uint32; | ||||||
|  |  | ||||||
|  | const | ||||||
|  |     COPY_WIDTH = 32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     //tracer.push_trace('video.basicFFlush.enter'); | ||||||
|  |     If not(FrontBuffer^.Initialized and BackBuffer^.Initialized) then exit; | ||||||
|  |     if (BackBuffer^.Width > FrontBuffer^.Width) or (BackBuffer^.Height > FrontBuffer^.Height) then exit; | ||||||
|  |     Back:= puint32(BackBuffer^.Location); | ||||||
|  |     Front:= puint32(FrontBuffer^.Location); | ||||||
|  |     BufferSize:= ( (BackBuffer^.Width * BackBuffer^.Height * BackBuffer^.BitsPerPixel ) div COPY_WIDTH ) - 1; | ||||||
|  |     for idx:=0 to BufferSize do begin | ||||||
|  |         Front[idx]:= Back[idx]; | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | Procedure basicFDrawTexture(Buffer : PVideoBuffer; X : uint32; Y : uint32; Texture : PTexture); | ||||||
|  | var | ||||||
|  |     i, j : uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     //Draw texture to Buffer at x and y | ||||||
|  |     for i:=0 to Texture^.Height - 1 do begin | ||||||
|  |         for j:=0 to Texture^.Width - 1 do begin | ||||||
|  |             DrawPixel(X + j, Y + i, Texture^.Pixels[(i * Texture^.Width) + j]); | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure basicFDrawLine(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; thickness : uint32; Color : TRGB32); | ||||||
|  | var | ||||||
|  |     X, Y, DX, DY, DX1, DY1, PX, PY, XE, YE, I : sint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.basicFDrawLine.enter'); | ||||||
|  |  | ||||||
|  |     if(x1 = x2) then begin | ||||||
|  |         for Y:=Y1 to Y2 do begin | ||||||
|  |             DrawPixel(X1,Y,Color); | ||||||
|  |         end; | ||||||
|  |     end else if (y1 = y2) then begin | ||||||
|  |         for X:=X1 to X2 do begin | ||||||
|  |             DrawPixel(X,Y1,Color); | ||||||
|  |         end; | ||||||
|  |     end else begin | ||||||
|  |         DX:= X2 - X1; | ||||||
|  |         DY:= Y2 - Y1; | ||||||
|  |  | ||||||
|  |         DX1:= util.abs(DX); | ||||||
|  |         DY1:= util.abs(DY); | ||||||
|  |  | ||||||
|  |         PX:= 2 * DY1 - DX1; | ||||||
|  |         PY:= 2 * DX1 - DY1; | ||||||
|  |  | ||||||
|  |         if (DY1 <= DX1) then begin | ||||||
|  |             if (dx >= 0) then begin | ||||||
|  |                 X:= X1; Y:= Y1; XE:= X2; | ||||||
|  |             end else begin | ||||||
|  |                 X:= X2; Y:= Y2; XE:= X1; | ||||||
|  |             end; | ||||||
|  |  | ||||||
|  |             DrawPixel(X, Y, Color); | ||||||
|  |  | ||||||
|  |             I:=0; | ||||||
|  |             while (x < xe) do begin | ||||||
|  |                 X:= X + 1; | ||||||
|  |                 if (PX < 0) then begin | ||||||
|  |                     PX:= PX + 2 + DY1;  | ||||||
|  |                 end else begin | ||||||
|  |                     if(((dx < 0) and (dy < 0)) OR ((dx > 0) and (dy > 0))) then begin | ||||||
|  |                         Y:= Y + 1;   | ||||||
|  |                     end else begin | ||||||
|  |                         Y:= Y - 1; | ||||||
|  |                     end; | ||||||
|  |                     PX:= PX + 2 * (DY1 - DX1); | ||||||
|  |                 end; | ||||||
|  |                 DrawPixel(X,Y,Color); | ||||||
|  |                 I:= I + 1; | ||||||
|  |             end; | ||||||
|  |         end else begin | ||||||
|  |             if (DY >= 0) then begin | ||||||
|  |                 X:= X1; Y:= Y1; YE:= Y2;  | ||||||
|  |             end else begin | ||||||
|  |                 X:= X2; Y:= Y2; YE:= Y1; | ||||||
|  |             end; | ||||||
|  |  | ||||||
|  |             DrawPixel(X, Y, Color); | ||||||
|  |  | ||||||
|  |             I:=0; | ||||||
|  |             while (Y < YE) do begin | ||||||
|  |                 Y:= Y + 1; | ||||||
|  |                 if (PY <= 0) then begin | ||||||
|  |                     PY:= PY + 2 * DX1; | ||||||
|  |                 end else begin | ||||||
|  |                     if (((dx < 0) and (dy < 0)) OR ((dx > 0) and (dy > 0))) then begin | ||||||
|  |                         X:= X + 1;  | ||||||
|  |                     end else begin | ||||||
|  |                         X:= X - 1; | ||||||
|  |                     end; | ||||||
|  |                     PY:= PY + 2 * (dx1 - dy1); | ||||||
|  |                 end; | ||||||
|  |                 DrawPixel(X,Y,Color); | ||||||
|  |                 I:= I + 1; | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure basicFDrawRect(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; line_thickness : uint32; Color : TRGB32); | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.basicFDrawRect.enter'); | ||||||
|  |     DrawLine(x1,y1,x2,y1,line_thickness,Color); | ||||||
|  |     DrawLine(x1,y2,x2,y2,line_thickness,Color); | ||||||
|  |     DrawLine(x1,y1,x1,y2,line_thickness,Color); | ||||||
|  |     DrawLine(x2,y1,x2,y2,line_thickness,Color); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure basicFFillRect(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; line_thickness : uint32; Line_Color : TRGB32; Fill_Color : TRGB32); | ||||||
|  | var | ||||||
|  |     Y : uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.basicFFillRect.enter');    | ||||||
|  |     for Y:=y1 to y2 do begin | ||||||
|  |         DrawLine(x1,y,x2,y,line_thickness,Fill_Color); | ||||||
|  |     end; | ||||||
|  |     DrawRect(x1,y1,x2,y2,line_thickness,Line_Color); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | var | ||||||
|  |     VideoInterface : TVideoInterface; | ||||||
|  |     DriverMap      : PHashMap; | ||||||
|  |  | ||||||
|  | procedure init(); | ||||||
|  | var | ||||||
|  |     RGB : TRGB32; | ||||||
|  |     x,y : uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.init.enter'); | ||||||
|  |     //Ensure the frontbuffer is empty & nil, ready for initialization by a driver. | ||||||
|  |     VideoInterface.FrontBuffer.Initialized:= false; | ||||||
|  |     VideoInterface.FrontBuffer.Width:= 0; | ||||||
|  |     VideoInterface.FrontBuffer.Height:= 0; | ||||||
|  |     VideoInterface.FrontBuffer.BitsPerPixel:= 0; | ||||||
|  |     VideoInterface.FrontBuffer.Location:= 0; | ||||||
|  |  | ||||||
|  |     //Ensure the backbuffer is empty & nil, ready for initialization by a driver. | ||||||
|  |     VideoInterface.BackBuffer.Initialized:= false; | ||||||
|  |     VideoInterface.BackBuffer.Width:= 0; | ||||||
|  |     VideoInterface.BackBuffer.Height:= 0; | ||||||
|  |     VideoInterface.BackBuffer.BitsPerPixel:= 0; | ||||||
|  |     VideoInterface.BackBuffer.Location:= 0; | ||||||
|  |  | ||||||
|  |     //Set the default buffer to be the FrontBuffer, assume no double buffering to begin with. | ||||||
|  |     VideoInterface.DefaultBuffer:= @VideoInterface.FrontBuffer; | ||||||
|  |  | ||||||
|  |     { Set the draw routines to point to dummy/empty routines. | ||||||
|  |       Calls will still succeed but do nothing until a driver has registered. } | ||||||
|  |     VideoInterface.DrawRoutines.DrawPixel:= @dummyFDrawPixel; | ||||||
|  |     VideoInterface.DrawRoutines.Flush:= @basicFFlush; | ||||||
|  |     VideoInterface.DrawRoutines.DrawLine:= @basicFDrawLine; | ||||||
|  |     VideoInterface.DrawRoutines.DrawRect:= @basicFDrawRect; | ||||||
|  |     VideoInterface.DrawRoutines.FillRect:= @basicFFillRect; | ||||||
|  |  | ||||||
|  |     //Initialize our 'DriverMap', a hashmap of loadable display drivers. | ||||||
|  |     DriverMap:= hashmap.new; | ||||||
|  |  | ||||||
|  |     tracer.push_trace('video.init.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function register(DriverIdentifier : pchar; EnableCallback : FEnableDriver) : boolean; | ||||||
|  | var | ||||||
|  |     Value : Void; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.register.enter'); | ||||||
|  |     register:= false; | ||||||
|  |     Value:= Hashmap.get(DriverMap, DriverIdentifier); | ||||||
|  |     if (Value = nil) then begin | ||||||
|  |         Hashmap.add(DriverMap, DriverIdentifier, void(EnableCallback)); | ||||||
|  |         register:= true; | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('video.register.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function enable(DriverIdentifier : pchar) : boolean; | ||||||
|  | var | ||||||
|  |     Value : Void; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     tracer.push_trace('video.enable.enter'); | ||||||
|  |     enable:= false; | ||||||
|  |     Value:= Hashmap.get(DriverMap, DriverIdentifier); | ||||||
|  |     if (Value <> nil) then begin | ||||||
|  |         enable:= FEnableDriver(Value)(@VideoInterface); | ||||||
|  |     end; | ||||||
|  |     tracer.push_trace('video.enable.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure DrawPixel(X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  | begin | ||||||
|  |     //tracer.push_trace('video.DrawPixel.enter'); | ||||||
|  |     VideoInterface.DrawRoutines.DrawPixel(VideoInterface.DefaultBuffer, X, Y, Pixel); | ||||||
|  |     //tracer.push_trace('video.DrawPixel.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure Flush(); | ||||||
|  | begin | ||||||
|  |     //tracer.push_trace('video.Flush.enter'); | ||||||
|  |     VideoInterface.DrawRoutines.Flush(@VideoInterface.FrontBuffer, @VideoInterface.BackBuffer); | ||||||
|  |     //tracer.push_trace('video.Flush.exit'); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure DrawLine(x1,y1,x2,y2 : uint32; thickness : uint32; Color : TRGB32); | ||||||
|  | begin | ||||||
|  |     VideoInterface.DrawRoutines.DrawLine(VideoInterface.DefaultBuffer,x1,y1,x2,y2,thickness,Color); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure DrawRect(x1,y1,x2,y2 : uint32; line_thickness : uint32; Color : TRGB32); | ||||||
|  | begin | ||||||
|  |     VideoInterface.DrawRoutines.DrawRect(VideoInterface.DefaultBuffer,x1,y1,x2,y2,line_thickness,color); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | procedure FillRect(x1,y1,x2,y2 : uint32; line_thickness : uint32; Line_Color : TRGB32; Fill_Color : TRGB32); | ||||||
|  | begin | ||||||
|  |     VideoInterface.DrawRoutines.FillRect(VideoInterface.DefaultBuffer,x1,y1,x2,y2,line_thickness,Line_Color,Fill_Color); | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function frontBufferWidth : uint32; | ||||||
|  | begin | ||||||
|  |     frontBufferWidth:= VideoInterface.FrontBuffer.Width; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function frontBufferHeight : uint32; | ||||||
|  | begin | ||||||
|  |     frontBufferHeight:= VideoInterface.FrontBuffer.Height; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function frontBufferBpp : uint8; | ||||||
|  | begin | ||||||
|  |     frontBufferBpp:= VideoInterface.FrontBuffer.BitsPerPixel; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function backBufferWidth : uint32; | ||||||
|  | begin | ||||||
|  |     backBufferWidth:= VideoInterface.BackBuffer.Width; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function backBufferHeight : uint32; | ||||||
|  | begin | ||||||
|  |     backBufferHeight:= VideoInterface.BackBuffer.Height; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | function backBufferBpp : uint8; | ||||||
|  | begin | ||||||
|  |     backBufferBpp:= VideoInterface.BackBuffer.BitsPerPixel; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										92
									
								
								src/driver/video/videotypes.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								src/driver/video/videotypes.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Driver->Video->Videotypes - Provides types relating to the video framework & driver interface. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit videotypes; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     color; | ||||||
|  |  | ||||||
|  | type | ||||||
|  |     //Arbitrary pointer to a raw video buffer in memory | ||||||
|  |     VideoBuffer = uint32; | ||||||
|  |  | ||||||
|  |     //Struct representing a Memory Mapped Video Buffer | ||||||
|  |     TVideoBuffer = record | ||||||
|  |         //Has this buffer been initialized? Has it been paged/created in memory? | ||||||
|  |         Initialized     : Boolean; | ||||||
|  |         //Location of the video buffer in memory as a QWORD. | ||||||
|  |         Location        : VideoBuffer; | ||||||
|  |         //How many bits per pixel? | ||||||
|  |         BitsPerPixel    : uint8; | ||||||
|  |         //Width of the buffer. | ||||||
|  |         Width           : uint32; | ||||||
|  |         //Height of the buffer. | ||||||
|  |         Height          : uint32; | ||||||
|  |     end; | ||||||
|  |     //Pointer to a video buffer | ||||||
|  |     PVideoBuffer = ^TVideoBuffer; | ||||||
|  |  | ||||||
|  |     //(Abstract) Draw a pixel to screenspace | ||||||
|  |     FDrawPixel = procedure(Buffer : PVideoBuffer; X : uint32; Y : uint32; Pixel : TRGB32); | ||||||
|  |     //(Abstract) Flush backbuffer to MMIO Buffer | ||||||
|  |     FFlush     = procedure(FrontBuffer : PVideoBuffer; BackBuffer : PVideoBuffer); | ||||||
|  |     //(Abstract) Draw a line to the screen | ||||||
|  |     FDrawLine = procedure(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; thickness : uint32; Color : TRGB32); | ||||||
|  |     //(Abstract) Draw a rect to the screen | ||||||
|  |     FDrawRect = procedure(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; line_thickness : uint32; Color : TRGB32); | ||||||
|  |     //(Abstract) Draw a filled rect to the screen | ||||||
|  |     FFillRect = procedure(Buffer : PVideoBuffer; x1,y1,x2,y2 : uint32; line_thickness : uint32; Line_Color : TRGB32; Fill_Color : TRGB32); | ||||||
|  |  | ||||||
|  |     //Routines for drawing to the screen | ||||||
|  |     TDrawRoutines = record | ||||||
|  |         DrawPixel : FDrawPixel; | ||||||
|  |         Flush     : FFlush; | ||||||
|  |         DrawLine  : FDrawLine; | ||||||
|  |         DrawRect  : FDrawRect; | ||||||
|  |         FillRect  : FFillRect; | ||||||
|  |     end; | ||||||
|  |     //Pointer to drawing routines | ||||||
|  |     PDrawRoutines = ^TDrawRoutines; | ||||||
|  |  | ||||||
|  |     //Struct representing the whole video driver. | ||||||
|  |     TVideoInterface = record | ||||||
|  |         //Default buffer to be used when rendering, front buffer for no double buffering, back buffer otherwise. | ||||||
|  |         DefaultBuffer   : PVideoBuffer; | ||||||
|  |         //Memory Mapped IO Buffer for raw rasterization. | ||||||
|  |         FrontBuffer     : TVideoBuffer; | ||||||
|  |         //Back buffer used for double buffering, this is flushed to FrontBuffer with flush(); | ||||||
|  |         BackBuffer      : TVideoBuffer; | ||||||
|  |         //Drawing Routines | ||||||
|  |         DrawRoutines    : TDrawRoutines; | ||||||
|  |     end; | ||||||
|  |     //Pointer to a video interface struct. | ||||||
|  |     PVideoInterface = ^TVideoInterface; | ||||||
|  |  | ||||||
|  |     //(Abstract) Enable method for a driver, called from video to enable driver. | ||||||
|  |     FEnableDriver = function(VideoInterface : PVideoInterface) : boolean; | ||||||
|  |     //(Abstract) Register driver, called from a driver to register with the video interface. | ||||||
|  |     FRegisterDriver = function(DriverIdentifier : pchar; EnableCallback : FEnableDriver) : boolean; | ||||||
|  |     //(Abstract) Init driver, called from _somewhere_ to start the driver and register it with the video interface. | ||||||
|  |     FInitDriver = procedure(Register : FRegisterDriver); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										63
									
								
								src/include/color.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								src/include/color.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | |||||||
|  | //  Copyright 2021 Kieron Morris | ||||||
|  | // | ||||||
|  | //  Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | //  you may not use this file except in compliance with the License. | ||||||
|  | //  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //  http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | //  Unless required by applicable law or agreed to in writing, software | ||||||
|  | //  distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | //  See the License for the specific language governing permissions and | ||||||
|  | //  limitations under the License. | ||||||
|  |  | ||||||
|  | {  | ||||||
|  | 	Include->Color - Provides types relating to color/graphics. | ||||||
|  | 	 | ||||||
|  | 	@author(Kieron Morris <kjm@kieronmorris.me>) | ||||||
|  | } | ||||||
|  | unit color; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | type | ||||||
|  |     TRGB32 = bitpacked record | ||||||
|  |         B : uint8; | ||||||
|  |         G : uint8; | ||||||
|  |         R : uint8; | ||||||
|  |         A : uint8; | ||||||
|  |     end; | ||||||
|  |     PRGB32 = ^TRGB32; | ||||||
|  |  | ||||||
|  |     TRGB24 = bitpacked record | ||||||
|  |         B : uint8; | ||||||
|  |         G : uint8; | ||||||
|  |         R : uint8; | ||||||
|  |     end; | ||||||
|  |     PRGB23 = ^TRGB24; | ||||||
|  |  | ||||||
|  |     TRGB16 = bitpacked record | ||||||
|  |         B : UBit5; | ||||||
|  |         G : UBit6; | ||||||
|  |         R : UBit5; | ||||||
|  |     end; | ||||||
|  |     PRGB16 = ^TRGB16; | ||||||
|  |  | ||||||
|  |     TRGB8 = bitpacked record | ||||||
|  |         B : UBit2; | ||||||
|  |         G : UBit4; | ||||||
|  |         R : UBit2; | ||||||
|  |     end; | ||||||
|  |     PRGB8 = ^TRGB8; | ||||||
|  |  | ||||||
|  | const | ||||||
|  |     black : TRGB32 = (B: 000; G: 000; R: 000; A: 000); | ||||||
|  |     white : TRGB32 = (B: 255; G: 255; R: 255; A: 000); | ||||||
|  |     red   : TRGB32 = (B: 000; G: 000; R: 255; A: 000); | ||||||
|  |     green : TRGB32 = (B: 000; G: 255; R: 000; A: 000); | ||||||
|  |     blue  : TRGB32 = (B: 255; G: 000; R: 000; A: 000); | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | end. | ||||||
| @@ -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. | ||||||
|   | |||||||
							
								
								
									
										67
									
								
								src/include/targa.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								src/include/targa.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | unit targa; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     lmemorymanager, texture; | ||||||
|  |  | ||||||
|  | type | ||||||
|  |     TTARGAColor = packed record | ||||||
|  |       b, g, r, a: uint8; | ||||||
|  |     end; | ||||||
|  |     PTARGAColor = ^TTARGAColor; | ||||||
|  |  | ||||||
|  |     TTARGAHeader = packed record | ||||||
|  |         Magic: uint8; | ||||||
|  |         ColorMapType: uint8; | ||||||
|  |         ImageType: uint8; | ||||||
|  |         ColorMapOrigin: uint16; | ||||||
|  |         ColorMapLength: uint16; | ||||||
|  |         ColorMapDepth: uint8; | ||||||
|  |         XOrigin: uint16; | ||||||
|  |         YOrigin: uint16; | ||||||
|  |         Width: uint16; | ||||||
|  |         Height: uint16; | ||||||
|  |         PixelDepth: uint8; | ||||||
|  |         ImageDescriptor: uint8; | ||||||
|  |         Data : PTARGAColor; | ||||||
|  |     end; | ||||||
|  |     PTARGAHeader = ^TTARGAHeader; | ||||||
|  |  | ||||||
|  | Function Parse(buffer : puint8; len : uint32) : PTexture; | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | Function Parse(buffer : puint8; len : uint32) : PTexture; | ||||||
|  | var | ||||||
|  |     header : PTARGAHeader; | ||||||
|  |     i, j : uint32; | ||||||
|  |     data : PTARGAColor; | ||||||
|  |     tex : PTexture; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     if (len < sizeof(TTARGAHeader)) then exit; | ||||||
|  |  | ||||||
|  |     header := PTARGAHeader(buffer); | ||||||
|  |     if (header^.Magic <> $0) or (header^.ImageType <> 2) or (header^.PixelDepth <> 32) then exit; | ||||||
|  |      | ||||||
|  |     //Create a new texture | ||||||
|  |     tex:= texture.newTexture(header^.Width, header^.Height); | ||||||
|  |     tex^.Width:= header^.Width; | ||||||
|  |     tex^.Height:= header^.Height; | ||||||
|  |      | ||||||
|  |     //Copy the data | ||||||
|  |     data := PTARGAColor(header^.Data); | ||||||
|  |     for i := 0 to header^.Height - 1 do begin | ||||||
|  |         for j := 0 to header^.Width - 1 do begin | ||||||
|  |             tex^.Pixels[i * header^.Width + j].r := data^.r; | ||||||
|  |             tex^.Pixels[i * header^.Width + j].g := data^.g; | ||||||
|  |             tex^.Pixels[i * header^.Width + j].b := data^.b; | ||||||
|  |             tex^.Pixels[i * header^.Width + j].a := data^.a; | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  |  | ||||||
|  |     Parse := tex; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
							
								
								
									
										34
									
								
								src/include/texture.pas
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								src/include/texture.pas
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | unit texture; | ||||||
|  |  | ||||||
|  | interface | ||||||
|  |  | ||||||
|  | uses | ||||||
|  |     lmemorymanager, color; | ||||||
|  |  | ||||||
|  | type | ||||||
|  |     TTexture = packed record | ||||||
|  |         Width  : uint32;  | ||||||
|  |         Height : uint32;  | ||||||
|  |         Size   : uint32; | ||||||
|  |         Pixels : PRGB32; | ||||||
|  |     end; | ||||||
|  |     PTexture = ^TTexture; | ||||||
|  |  | ||||||
|  | Function newTexture(width, height: uint32): PTexture; | ||||||
|  |  | ||||||
|  | implementation | ||||||
|  |  | ||||||
|  | Function newTexture(width, height: uint32): PTexture; | ||||||
|  | var | ||||||
|  |     texture: PTexture; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     texture:= PTexture(kalloc(sizeof(TTexture))); | ||||||
|  |     texture^.Pixels:= PRGB32(kalloc(width * height * sizeof(TRGB32))); | ||||||
|  |     texture^.Width:= width; | ||||||
|  |     texture^.Height:= height; | ||||||
|  |     texture^.Size:= width * height; | ||||||
|  |     newTexture:= texture; | ||||||
|  | end; | ||||||
|  |  | ||||||
|  | end. | ||||||
| @@ -49,6 +49,7 @@ procedure io_wait; | |||||||
|  |  | ||||||
| procedure memset(location : uint32; value : uint8; size : uint32); | procedure memset(location : uint32; value : uint8; size : uint32); | ||||||
| procedure memcpy(source : uint32; dest : uint32; size : uint32); | procedure memcpy(source : uint32; dest : uint32; size : uint32); | ||||||
|  | procedure __SSE_128_memcpy(source : uint32; dest : uint32); | ||||||
|  |  | ||||||
| procedure printmemory(source : uint32; length : uint32; col : uint32; delim : PChar; offset_row : boolean); | procedure printmemory(source : uint32; length : uint32; col : uint32; delim : PChar; offset_row : boolean); | ||||||
| procedure printmemoryWND(source : uint32; length : uint32; col : uint32; delim : PChar; offset_row : boolean; WND : HWND); | procedure printmemoryWND(source : uint32; length : uint32; col : uint32; delim : PChar; offset_row : boolean; WND : HWND); | ||||||
| @@ -80,6 +81,8 @@ function RorDWord(AValue : uint32; Dist : uint8) : uint32; | |||||||
|  |  | ||||||
| function MsSinceSystemBoot : uint64; | function MsSinceSystemBoot : uint64; | ||||||
|  |  | ||||||
|  | function abs(x : sint32) : uint32; | ||||||
|  |  | ||||||
| var | var | ||||||
|     endptr : uint32; external name '__end'; |     endptr : uint32; external name '__end'; | ||||||
|     stack  : uint32; external name 'KERNEL_STACK'; |     stack  : uint32; external name 'KERNEL_STACK'; | ||||||
| @@ -89,6 +92,15 @@ implementation | |||||||
| uses | uses | ||||||
|     console, RTC, cpu, serial, strings, isr_types; |     console, RTC, cpu, serial, strings, isr_types; | ||||||
|  |  | ||||||
|  | function abs(x : sint32) : uint32; | ||||||
|  | var | ||||||
|  |     y : uint32; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     y:= x SHR 31; | ||||||
|  |     abs:= (x XOR y) - y; | ||||||
|  | end; | ||||||
|  |  | ||||||
| function MsSinceSystemBoot : uint64; | function MsSinceSystemBoot : uint64; | ||||||
| begin | begin | ||||||
|     MsSinceSystemBoot:= div6432(getTSC, (CPUID.ClockSpeed.Hz div 1000)); |     MsSinceSystemBoot:= div6432(getTSC, (CPUID.ClockSpeed.Hz div 1000)); | ||||||
| @@ -116,6 +128,14 @@ begin | |||||||
|     div6432:= (r0 SHL 32) OR r4; |     div6432:= (r0 SHL 32) OR r4; | ||||||
| end; | end; | ||||||
|  |  | ||||||
|  | procedure __SSE_128_memcpy(source : uint32; dest : uint32); assembler; | ||||||
|  | asm | ||||||
|  |     MOV EAX, Source | ||||||
|  |     MOVAPS XMM1, [EAX] | ||||||
|  |     MOV EAX, Dest | ||||||
|  |     MOVAPS [EAX], XMM1 | ||||||
|  | end; | ||||||
|  |  | ||||||
| function switchendian16(b : uint16) : uint16; | function switchendian16(b : uint16) : uint16; | ||||||
| begin | begin | ||||||
|     switchendian16:= ((b AND $FF00) SHR 8) OR ((b AND $00FF) SHL 8); |     switchendian16:= ((b AND $FF00) SHR 8) OR ((b AND $00FF) SHL 8); | ||||||
|   | |||||||
| @@ -54,7 +54,8 @@ uses | |||||||
|      base64, |      base64, | ||||||
|      rand, |      rand, | ||||||
|      terminal, |      terminal, | ||||||
|      hashmap, vfs; |      hashmap, vfs,  | ||||||
|  |      video, vesa, doublebuffer, color; | ||||||
|   |   | ||||||
| procedure kmain(mbinfo: Pmultiboot_info_t; mbmagic: uint32); stdcall; | procedure kmain(mbinfo: Pmultiboot_info_t; mbmagic: uint32); stdcall; | ||||||
|   |   | ||||||
| @@ -124,7 +125,15 @@ var | |||||||
|  |  | ||||||
|    HM              : PHashMap; |    HM              : PHashMap; | ||||||
|  |  | ||||||
|  |    colour          : TRGB32; | ||||||
|  |  | ||||||
|  |    array1          : Array[0..255] of char; | ||||||
|  |    array2          : Array[0..255] of char; | ||||||
|  |     | ||||||
| begin | begin | ||||||
|  |      { Init the base system unit } | ||||||
|  |      System.init(); | ||||||
|  |  | ||||||
|      { Serial Init } |      { Serial Init } | ||||||
|      serial.init(); |      serial.init(); | ||||||
|  |  | ||||||
| @@ -132,6 +141,8 @@ begin | |||||||
|      multibootinfo:= mbinfo; |      multibootinfo:= mbinfo; | ||||||
|      multibootmagic:= mbmagic; |      multibootmagic:= mbmagic; | ||||||
|  |  | ||||||
|  |     //video.init(); | ||||||
|  |  | ||||||
|      { Ensure tracer is frozen } |      { Ensure tracer is frozen } | ||||||
|      tracer.freeze(); |      tracer.freeze(); | ||||||
|  |  | ||||||
| @@ -198,6 +209,53 @@ begin | |||||||
|      { Call Tracer } |      { Call Tracer } | ||||||
|      tracer.init(); |      tracer.init(); | ||||||
|  |  | ||||||
|  |      video.init(); | ||||||
|  |      vesa.init(@video.register); | ||||||
|  |      doublebuffer.init(@video.register); | ||||||
|  |      video.enable('VESA'); | ||||||
|  |      video.enable('BASIC_DOUBLE_BUFFER'); | ||||||
|  |      colour:= color.white; | ||||||
|  |  | ||||||
|  |     //  serial.sendHex(uint32(@array1[8])); | ||||||
|  |     //  serial.sendHex(uint32(@array2[8])); | ||||||
|  |     //  for i:=8 to 23 do begin | ||||||
|  |     //     array2[i]:= '?'; | ||||||
|  |     //  end; | ||||||
|  |     //  array2[24]:= #0; | ||||||
|  |  | ||||||
|  |     //  array1[8]:= 'H'; | ||||||
|  |     //  array1[9]:= 'e'; | ||||||
|  |     //  array1[10]:= 'l'; | ||||||
|  |     //  array1[11]:= 'l'; | ||||||
|  |     //  array1[12]:= 'o'; | ||||||
|  |     //  array1[13]:= 'w'; | ||||||
|  |     //  array1[14]:= 'o'; | ||||||
|  |     //  array1[15]:= 'r'; | ||||||
|  |     //  array1[16]:= 'l'; | ||||||
|  |     //  array1[17]:= 'd'; | ||||||
|  |     //  array1[18]:= '1'; | ||||||
|  |     //  array1[19]:= '2'; | ||||||
|  |     //  array1[20]:= '3'; | ||||||
|  |     //  array1[21]:= '4'; | ||||||
|  |     //  array1[22]:= '5'; | ||||||
|  |     //  array1[23]:= '!'; | ||||||
|  |     //  __SSE_128_memcpy(uint32(@array1[8]), uint32(@array2[8])); | ||||||
|  |     //  serial.sendString(pchar(@array2[8])); | ||||||
|  |  | ||||||
|  |      for i:=0 to video.frontBufferWidth-1 do begin | ||||||
|  |         for z:=0 to video.frontBufferHeight-1 do begin | ||||||
|  |             video.DrawPixel(i, z, colour); | ||||||
|  |         end; | ||||||
|  |      end; | ||||||
|  |  | ||||||
|  |      video.DrawLine(50,50,100,100,1,color.black); | ||||||
|  |      video.DrawRect(50,150,100,200,1,color.black); | ||||||
|  |      video.FillRect(50,250,100,300,1,color.black,color.red); | ||||||
|  |      video.DrawLine(50,350,100,350,1,color.black); | ||||||
|  |      video.Flush(); | ||||||
|  |  | ||||||
|  |      while true do begin end; | ||||||
|  |  | ||||||
|      { VFS Init } |      { VFS Init } | ||||||
|      vfs.init(); |      vfs.init(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -77,9 +77,9 @@ dd 0 | |||||||
| dd 0 | dd 0 | ||||||
| dd 0 | dd 0 | ||||||
| dd 0 | dd 0 | ||||||
| dd 1280 | dd 1600 | ||||||
| dd 1024 | dd 1200 | ||||||
| dd 16 | dd 32 | ||||||
|  |  | ||||||
| ; | ; | ||||||
| ; Entrypoint | ; Entrypoint | ||||||
|   | |||||||
							
								
								
									
										58
									
								
								virtualbox-wrapper.ps1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								virtualbox-wrapper.ps1
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | |||||||
|  | <#  | ||||||
|  | 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 | ||||||
|  |   } | ||||||
|  | } elseif ($Command -eq 'down') { | ||||||
|  |   Write-Output "Stopping $MachineName" | ||||||
|  |   VBoxManage.exe controlvm $MachineName poweroff | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user