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