Add files via upload

This commit is contained in:
Ærþ 2022-04-16 01:22:30 +10:00 committed by GitHub
parent 615cc26672
commit b43d52bf2f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 100 additions and 11 deletions

View file

@ -1,8 +1,8 @@
#define ROM vm->devices[2] #define ROM vm->devices[2]
void rom_write(struct VMinst* vm, void* data, uint64_t length) { void rom_write(struct VMinst* vm, void* data, uint64_t length) {
printf("rom_write was called. [%p, %p, %lu]", vm, data, length); if (length == 0) ((uint64_t*)ROM.buffer)[0] = (uint64_t)data;
exit(-1); else fwrite(data, sizeof(uint8_t), length, ((FILE**)(ROM.buffer))[1024 * 256 / 8 - 1 - ((uint64_t*)ROM.buffer)[0]]);
} }
void rom_out(struct VMinst* vm) { void rom_out(struct VMinst* vm) {
@ -11,10 +11,11 @@ void rom_out(struct VMinst* vm) {
} }
void rom_read(struct VMinst* vm, void* buffer, uint64_t length, uint64_t where) { void rom_read(struct VMinst* vm, void* buffer, uint64_t length, uint64_t where) {
fread(buffer, sizeof(uint8_t), length, ((FILE**)(ROM.buffer))[1024 * 256 / 8 - 1 - ((uint64_t*)ROM.buffer)[0]]);
} }
void rom_wait(struct VMinst* vm, uint64_t data) { void rom_wait(struct VMinst* vm, uint64_t data) {
fseek(((FILE**)(ROM.buffer))[1024 * 256 / 8 - 1 - ((uint64_t*)ROM.buffer)[0]], data, SEEK_SET);
} }
void rom_poweroff(struct VMinst* vm) { void rom_poweroff(struct VMinst* vm) {
@ -29,6 +30,7 @@ void rom_poweroff(struct VMinst* vm) {
void setup_rom(struct VMinst* vm) { void setup_rom(struct VMinst* vm) {
ROM.buffer = malloc(1024 * 256); ROM.buffer = malloc(1024 * 256);
((uint64_t*)ROM.buffer)[0] = 0;
ROM.write = &rom_write; ROM.write = &rom_write;
ROM.out = &rom_out; ROM.out = &rom_out;
ROM.read = &rom_read; ROM.read = &rom_read;
@ -39,6 +41,6 @@ void setup_rom(struct VMinst* vm) {
exit(-1); exit(-1);
} }
for (int i = 0; i < DEV_ROM_COUNT; ++i) { for (int i = 0; i < DEV_ROM_COUNT; ++i) {
((uint64_t**)ROM.buffer)[1024 * 32 - 8 + i] = (uint64_t*) fopen(dev_rom[i], "rb+"); ((uint64_t**)ROM.buffer)[1024 * 256 / 8 - 1 - i] = (uint64_t*) fopen(dev_rom[i], "wb+");
} }
} }

View file

@ -2,10 +2,10 @@ local date = require"date"
local opcode = require"faxmopcode" local opcode = require"faxmopcode"
local FX = { local FX = {
--require"faxm/fraCinize", --require"faxm/fraCinize",
require"faxm/string", require"fraxinizator/string",
require"faxm/ximplifier", require"fraxinizator/ximplifier",
require"faxm/fraxevice", require"fraxinizator/fraxevice",
require"faxm/freeform" require"fraxinizator/freeform"
} }
@ -63,6 +63,7 @@ end
function parseCode(source, code, data) function parseCode(source, code, data)
for k, v in pairs(FX) do if v.source then source = v.source(source) end end for k, v in pairs(FX) do if v.source then source = v.source(source) end end
print(source)
local dminsize, cminsize, xtype = -1, -1, "8u" local dminsize, cminsize, xtype = -1, -1, "8u"
local section, segment local section, segment
local objects = {} local objects = {}
@ -99,7 +100,6 @@ function parseCode(source, code, data)
vdata = vdata:trim():gsub(",", " "):gsub("%s+", " ") vdata = vdata:trim():gsub(",", " "):gsub("%s+", " ")
for _, v in ipairs(vdata:split" ") do for _, v in ipairs(vdata:split" ") do
if v:sub(1, 1) == "|" then if v:sub(1, 1) == "|" then
for k, v_ in pairs(FX) do if v_.eval then v = v_.eval(v) end end
v = v:sub(2) v = v:sub(2)
if v:sub(1, 1) == "x" then v = "0" .. v end if v:sub(1, 1) == "x" then v = "0" .. v end
v = load("return " .. v)() v = load("return " .. v)()

View file

@ -0,0 +1,5 @@
return {
source = function(source)
return source
end
}

View file

@ -0,0 +1,14 @@
return {
source = function(source)
source = source:gsub("(%s*)console%.print%s+(%S+%s+%S+);", "%1console.write %2;%1console.out;")
source = source:gsub("(%a+)%.write", "write ____%1")
source = source:gsub("(%a+)%.out", "out ____%1")
source = source:gsub("(%a+)%.wait", "wait ____%1")
source = source:gsub("(%a+)%.read", "read ____%1")
source = source:gsub("____clock", "|0")
source = source:gsub("____timer", "|0")
source = source:gsub("____console", "|1")
source = source:gsub("____rom", "|2")
return source
end
}

11
fraxinizator/freeform.lua Normal file
View file

@ -0,0 +1,11 @@
return {
source = function(source)
return source:gsub("\n", "")
end,
any_line = function(line)
return line:trim():gsub("%s+", " "):gsub("%s+=%s+", "=")
end,
line = function(line)
return line:gsub(",", " "):gsub("%s+", " "):split" "
end
}

36
fraxinizator/string.lua Normal file
View file

@ -0,0 +1,36 @@
return {
source = function(source)
local tl = {}
while source:match[[|"[^"]+"]] do
local s = source:match[[|"[^"]+"]]
local ss = s
s = s:sub(3, #s - 1)
local r = {}
for i = 0, math.floor(#s / 8) do
local t = s:sub(i * 8 + 1, (i + 1) * 8)
while #t < 8 do t = t .. "\0" end
t = {string.byte(t, 1, -1)}
local rt = {}
for i = 1, 8 do rt[9 - i] = t[i] end
for i = 1, 8 do rt[i] = string.format("%02x", rt[i]) end
if table.concat(rt, "") ~= "0000000000000000" then
r[#r + 1] = "|x" .. table.concat(rt, "")
end
end
if #(r[#r]:gsub("000", "")) == #(r[#r]) then
r[#r + 1] = "|x0000000000000000"
end
local function regexEscape(str)
return str:gsub("[%(%)%.%%%+%-%*%?%[%^%$%]]", "%%%1")
end
local tt = table.concat(r, ", ")
tl[tt] = #r
source = source:gsub(regexEscape(ss), tt)
end
source = source:gsub("(string%s+(%w+)%s?:(%s+)([|xa-f0-9, ]+)[^;])", function(found)
found = "object" .. found:sub(7)
return found .. " ? length=|" .. tostring(tl[found:gsub("object%s+%w+%s?:(%s+)", "")] * 8)
end)
return source
end
}

View file

@ -0,0 +1,9 @@
return {
source = function(source)
source = source:gsub("%(([^)]+)%)", " %1")
source = source:gsub("([|%^#][%w.]+%s+)([a-z]+)", "%1;%2"):gsub(":", ":;")
source = source:gsub("object", ";object"):gsub("section", ";section"):gsub("%[", ";["):gsub("%]", "];")
source = source:gsub("(\n%s+);", ";%1"):gsub(";(%s+);", ";%1"):gsub("^;", "")
return source .. ";"
end
}

2
livm.c
View file

@ -30,7 +30,7 @@ struct VMinst {
char* dev_rom[] = {"sda"}; char* dev_rom[] = {"sda"};
#ifndef DEV_ROM_COUNT #ifndef DEV_ROM_COUNT
# define DEV_ROM_COUNT 0 # define DEV_ROM_COUNT 1
#endif #endif
#ifdef LIVMDEBUG #ifdef LIVMDEBUG

11
main.c
View file

@ -22,16 +22,27 @@ uint64_t str2u64(char* data) {
int main() { int main() {
time_t t[5];
t[0] = clock();
struct VMinst vm = createVM(512); // alloc 256 bytes struct VMinst vm = createVM(512); // alloc 256 bytes
uint64_t vmram[] = { // "proper" way to write out "Hello, LIVM!" uint64_t vmram[] = { // "proper" way to write out "Hello, LIVM!"
#include "out.fx" #include "out.fx"
}; };
t[1] = clock();
loadRAM(&vm, vmram, sizeof vmram / sizeof(uint64_t)); loadRAM(&vm, vmram, sizeof vmram / sizeof(uint64_t));
t[2] = clock();
//print_ullram(&vm); //print_ullram(&vm);
//uint64_t dt[] = {5485433203209299272, 7810728294139909705, 0}; //uint64_t dt[] = {5485433203209299272, 7810728294139909705, 0};
//puts(((char*)dt)); //puts(((char*)dt));
runVM(&vm); runVM(&vm);
t[3] = clock();
//print_ullram(&vm); //print_ullram(&vm);
deleteVM(&vm); deleteVM(&vm);
t[4] = clock();
printf("Full execution time: %d, %f\n", t[4] - t[0], (((double)t[4] - t[0])/((double)CLOCKS_PER_SEC)));
printf("Setup time: %d\n", t[1] - t[0]);
printf("Boot time: %d\n", t[2] - t[1]);
printf("Execution time: %d, %f\n", t[3] - t[2], (((double)t[3] - t[2])/((double)CLOCKS_PER_SEC)));
printf("Clean time: %d\n", t[4] - t[3]);
return 0; return 0;
} }

View file

@ -5,4 +5,5 @@ string hellohell: |"hell-oh!";
section start: section start:
console.print(^helloworld, #helloworld.length) console.print(^helloworld, #helloworld.length)
console.print(^hellohell, #hellohell.length) console.print(^hellohell, #hellohell.length)
rom.write ^hellohell, #hellohell.length
poff poff

2
out.fx
View file

@ -1 +1 @@
8, 1, 6, 1, 1, 16, 8, 1004, 8031924123371070824, 6581362, 2407296241712784744, 0, 0, 0, 0, 0, 399, 3, 1, 0, 30, 400, 1, 1, 399, 3, 1, 2, 31, 400, 1, 1, 10, 0, 0, 0, 0, 0, 16, 16 8, 1, 6, 1, 1, 16, 8, 1004, 8031924123371070824, 6581362, 2407296241712784744, 0, 0, 0, 0, 0, 399, 3, 1, 0, 35, 400, 1, 1, 399, 3, 1, 2, 36, 400, 1, 1, 399, 3, 2, 2, 37, 10, 0, 0, 0, 0, 0, 16, 16, 16