184 lines
6.5 KiB
PHP
184 lines
6.5 KiB
PHP
;=----------------------------------------------------------------------------=;
|
|
; GNU GPL OS/K ;
|
|
; ;
|
|
; Desc: Basic Colored VGA Terminal Long mode Driver ;
|
|
; (x86_64 architecture only) ;
|
|
; ;
|
|
; ;
|
|
; Copyright © 2018-2019 The OS/K Team ;
|
|
; ;
|
|
; This file is part of OS/K. ;
|
|
; ;
|
|
; OS/K is free software: you can redistribute it and/or modify ;
|
|
; it under the terms of the GNU General Public License as published by ;
|
|
; the Free Software Foundation, either version 3 of the License, or ;
|
|
; (at your option) any later version. ;
|
|
; ;
|
|
; OS/K is distributed in the hope that it will be useful, ;
|
|
; but WITHOUT ANY WARRANTY; without even the implied warranty of ;
|
|
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;
|
|
; GNU General Public License for more details. ;
|
|
; ;
|
|
; You should have received a copy of the GNU General Public License ;
|
|
; along with OS/K. If not, see <https://www.gnu.org/licenses/>. ;
|
|
;=----------------------------------------------------------------------------=;
|
|
|
|
[BITS 64]
|
|
[section .text]
|
|
|
|
;;VIDEO
|
|
%define TRAM 0xB8000 ; [T]ext[RAM]
|
|
%define VRAM 0xA0000 ; [V]ideo[RAM]
|
|
%define VGA_HEIGHT 80
|
|
|
|
;; GLOBAL DATA
|
|
NextTRAM dq 0xB8000 ; Last position of cursor
|
|
NextTRAM32 dq 0xB8000 ; Last position of cursor
|
|
VGA_X32 dq 0
|
|
VGA_HEIGHT64 dq VGA_HEIGHT
|
|
VGA_X dq 0
|
|
|
|
|
|
testf:
|
|
push rsi
|
|
push rbx
|
|
mov esi, teststr
|
|
mov bl, 0xF
|
|
call write
|
|
pop rsi
|
|
pop rbx
|
|
ret
|
|
teststr: db "Salut",0
|
|
|
|
|
|
;-----------------------------------------------------------------------;
|
|
; x64/LM Clear Text Screen Function ;
|
|
;-----------------------------------------------------------------------;
|
|
clear:
|
|
mov qword [NextTRAM], TRAM
|
|
mov edi, TRAM
|
|
push rsi
|
|
push rdi
|
|
push rcx
|
|
mov ah, 0
|
|
mov al, 0
|
|
mov rcx, 0x4000 ; traditionnal value
|
|
rep stosw ; fill screen with al while cx > 0
|
|
pop rcx
|
|
pop rsi
|
|
pop rdi
|
|
ret
|
|
|
|
|
|
;-----------------------------------------------------------------------;
|
|
; x64/LM Text Printing Functions ;
|
|
; bl : color code ;
|
|
; esi : string address ;
|
|
;-----------------------------------------------------------------------;
|
|
write:
|
|
mov edi, [NextTRAM] ; TRAM ADDRESS
|
|
push rsi
|
|
push rdi
|
|
.pLoop:
|
|
lodsb
|
|
cmp al, 0 ; while @al, i.e. while we're not hitting '\0'
|
|
je .pEnd
|
|
cmp al, 0x0A ; LF
|
|
je .lf
|
|
cmp al, 0x0D ; CR
|
|
je .cr
|
|
stosb ; text subpixel
|
|
mov al, bl
|
|
stosb ; color subpixel
|
|
add qword [NextTRAM], 0x2 ; Cursor moving
|
|
add qword [VGA_X], 0x2 ; coord + 2 because 2 subpixels
|
|
jmp .pLoop
|
|
.pEnd:
|
|
pop rdi
|
|
pop rsi
|
|
ret
|
|
.lf:
|
|
mov rax, [VGA_HEIGHT64]
|
|
add [NextTRAM], rax ; Cursor moving
|
|
add [NextTRAM], rax
|
|
add edi, eax ; Address moving
|
|
add edi, eax
|
|
jmp .pLoop
|
|
.cr:
|
|
push rax
|
|
mov rax, qword [VGA_X]
|
|
sub qword [NextTRAM], rax ; pos = X + Y * VGA_HEIGHT64. Donc pos - X = début de ligne
|
|
sub edi, edx
|
|
mov qword [VGA_X], 0
|
|
pop rax
|
|
jmp .pLoop
|
|
.scroll:
|
|
; XXX I don't think I'll implement this, but never know...;
|
|
jmp .pLoop
|
|
|
|
dump:
|
|
;-----------------------------------------------------------------------;
|
|
; x64/LM Dump 512 bytes of a buffer ;
|
|
; bl : color code ;
|
|
; esi : buffer address ;
|
|
;-----------------------------------------------------------------------;
|
|
mov edi, [NextTRAM] ; TRAM ADDRESS
|
|
push rsi
|
|
push rdi
|
|
push rcx
|
|
mov rcx, 512
|
|
.pLoop:
|
|
lodsb
|
|
stosb ; text subpixel
|
|
mov al, bl
|
|
stosb ; color subpixel
|
|
loop .pLoop
|
|
pop rcx
|
|
pop rdi
|
|
pop rsi
|
|
add qword [NextTRAM], 1000 ; Cursor moving : 1120 = 80 * 2 * 7 lignes
|
|
ret
|
|
|
|
[BITS 32]
|
|
;-----------------------------------------------------------------------;
|
|
; x32 Text Printing Functions ;
|
|
; bl : color code ;
|
|
; esi : string address ;
|
|
;-----------------------------------------------------------------------;
|
|
write32:
|
|
mov edi, TRAM ; TRAM ADDRESS
|
|
push esi
|
|
push edi
|
|
.pLoop:
|
|
lodsb
|
|
cmp al, 0 ; while @al, i.e. while we're not hitting '\0'
|
|
je .pEnd
|
|
stosb ; text subpixel
|
|
mov al, bl
|
|
stosb ; color subpixel
|
|
jmp .pLoop
|
|
.pEnd:
|
|
pop edi
|
|
pop esi
|
|
ret
|
|
|
|
disable_cursor:
|
|
pushf
|
|
push eax
|
|
push edx
|
|
|
|
mov dx, 0x3D4
|
|
mov al, 0xA ; low cursor shape register
|
|
out dx, al
|
|
|
|
inc dx
|
|
mov al, 0x20 ; bits 6-7 unused, bit 5 disables the cursor, bits 0-4 control the cursor shape
|
|
out dx, al
|
|
|
|
pop edx
|
|
pop eax
|
|
popf
|
|
|
|
ret
|
|
|
|
[BITS 64]
|