2024-10-13 17:38:43 -05:00
|
|
|
PAGE_SIZE := 4096
|
|
|
|
MAX_ALLOC := 0xFF
|
|
|
|
|
|
|
|
alloc := fn($Expr: type, bytes: int): ^Expr {
|
|
|
|
pages := (1 + bytes) / PAGE_SIZE
|
|
|
|
if pages <= MAX_ALLOC {
|
|
|
|
return @bitcast(@inline(request_page, pages))
|
|
|
|
}
|
|
|
|
ptr := @inline(request_page, 0xFF)
|
|
|
|
remaining := pages - MAX_ALLOC
|
|
|
|
loop if remaining <= 0 break else {
|
|
|
|
if remaining < MAX_ALLOC {
|
|
|
|
request_page(remaining)
|
|
|
|
} else {
|
|
|
|
request_page(MAX_ALLOC)
|
|
|
|
}
|
|
|
|
remaining -= MAX_ALLOC
|
|
|
|
}
|
|
|
|
return @bitcast(ptr)
|
|
|
|
}
|
|
|
|
|
2024-07-07 08:35:07 -05:00
|
|
|
request_page := fn(page_count: u8): ^u8 {
|
2024-07-19 08:53:45 -05:00
|
|
|
msg := "\{00}\{01}xxxxxxxx\0"
|
|
|
|
msg_page_count := msg + 1;
|
|
|
|
*msg_page_count = page_count
|
2024-09-17 19:26:37 -05:00
|
|
|
return @eca(3, 2, msg, 12)
|
2024-07-07 08:35:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
release_page := fn(ptr: ^u8, page_count: u8): void {
|
2024-07-19 08:53:45 -05:00
|
|
|
msg := "\{01}\{00}xxxxxxxx\0"
|
2024-07-07 08:35:07 -05:00
|
|
|
|
2024-07-19 08:53:45 -05:00
|
|
|
msg_page_count := msg + 1;
|
|
|
|
*msg_page_count = page_count
|
2024-07-07 08:35:07 -05:00
|
|
|
|
2024-07-19 08:53:45 -05:00
|
|
|
msg_ptr := @as(^^u8, @bitcast(msg + 2));
|
|
|
|
*msg_ptr = ptr
|
|
|
|
|
2024-09-17 19:26:37 -05:00
|
|
|
return @eca(3, 2, msg, 12)
|
2024-07-23 19:37:43 -05:00
|
|
|
}
|
|
|
|
|
2024-09-30 15:45:57 -05:00
|
|
|
OutbMsg := packed struct {a: u8, b: u8, addr: u16, value: u8}
|
|
|
|
InbMsg := packed struct {a: u8, b: u8, addr: u16}
|
|
|
|
OutlMsg := packed struct {a: u8, b: u8, addr: u16, value: u32}
|
|
|
|
InlMsg := packed struct {a: u8, b: u8, addr: u16}
|
2024-09-16 14:45:19 -05:00
|
|
|
|
2024-08-31 09:38:15 -05:00
|
|
|
outb := fn(addr: u16, value: u8): void {
|
2024-09-17 12:08:19 -05:00
|
|
|
return @eca(3, 3, &OutbMsg.(1, 0, addr, value), @sizeof(OutbMsg))
|
2024-08-31 09:38:15 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
inb := fn(addr: u16): u8 {
|
2024-09-17 19:26:37 -05:00
|
|
|
return @eca(3, 3, &InbMsg.(0, 0, addr), @sizeof(InbMsg))
|
2024-08-31 09:38:15 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
outl := fn(addr: u16, value: u32): void {
|
2024-09-17 12:08:19 -05:00
|
|
|
return @eca(3, 3, &OutlMsg.(1, 2, addr, value), @sizeof(OutlMsg))
|
2024-07-23 19:37:43 -05:00
|
|
|
}
|
|
|
|
|
2024-08-31 09:38:15 -05:00
|
|
|
inl := fn(addr: u16): u32 {
|
2024-09-17 12:08:19 -05:00
|
|
|
return @eca(3, 3, &InlMsg.(0, 2, addr), @sizeof(InlMsg))
|
2024-10-13 17:38:43 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
CopyMsg := packed struct {a: u8, count: uint, src: uint, dest: ^u8}
|
|
|
|
copy := fn($Expr: type, src: ^Expr, dest: ^Expr, count: uint): void {
|
|
|
|
return @eca(3, 2, &CopyMsg.(4, count * @sizeof(Expr), @bitcast(src), @bitcast(dest)), @sizeof(CopyMsg))
|
|
|
|
}
|
|
|
|
|
|
|
|
SetMsg := packed struct {a: u8, count: uint, size: uint, dest: ^u8, src: ^u8}
|
|
|
|
set := fn($Expr: type, src: ^Expr, dest: ^Expr, count: uint): void {
|
|
|
|
return @eca(3, 2, &SetMsg.(5, count, @sizeof(Expr), @bitcast(dest), @bitcast(src)), @sizeof(SetMsg))
|
2024-07-20 12:54:58 -05:00
|
|
|
}
|