Assembly DOCS

This commit is contained in:
german 2026-03-08 17:32:42 +04:00
parent fce6aa1630
commit 49f9a68638
6 changed files with 50 additions and 7 deletions

41
ASM.md
View File

@ -1,10 +1,43 @@
# Assemly NTSYS # Assemly NTSYS
Это справочник по ассемблеру в **NTSYS**. Тут представлены основные комманды и описание синтаксиса. Это справочник по ассемблеру в **NTSYS**. Тут представлены основные комманды и описание синтаксиса.
## Операторы ## Операторы
Основной программной единицей является оператор. Это одно из зарезервированных слов. Названия операторов те же, что и в [BINCOM](https://gitlabor.ru/German/ntsys/src/branch/main/BINCOM.md), но в нижнем регистре. Основной программной единицей является оператор. Это одно из зарезервированных слов. Названия операторов те же, что и в [BINCOM](https://gitlabor.ru/German/ntsys/src/branch/main/BINCOM.md), но в нижнем регистре (нижнее подчеркивание заменено точкой). Их синтаксис следующий:
## Метки
Метки используются для относительного перехода в любое место программы. Они состоят из алфавитно-цифровых символов, двоеточия и переноса строки:
```asm ```asm
имя_метки: оператор операнд1, операнд2, ... операндN
```
Операнды нужны для передачи данных в операторы.
## Метки
Метки используются для относительного перехода в любое место программы. Они состоят из алфавитно-цифровых символов, а также нижнего подчеркивания и знака минус, двоеточия и переноса строки:
```asm
ИмяМетки:
; ... код ; ... код
``` ```
Для записи метки используется специальный тип данных - **db**:
```asm
main:
push db main
jmp
```
## Комментарии
Комментарий нужен для создания пояснения к коду. Любой текст в комментарии игнорируется.
Пример:
```asm
; Это комментарий
; Это тоже
```
## Типы данных
Основные типы данных:
- ```byte``` - 8bit без знака
- ```word``` - 16bit без знака
- ```dword``` - 32bit без знака
- ```qword``` - 64bit без знака
- ```sbyte``` - 8bit знаковый
- ```sword``` - 16bit знаковый
- ```sdword``` - 32bit знаковый
- ```sqword``` - 64bit знаковый
- Строки - [ASCIIZ-строка](https://ru.wikipedia.org/wiki/%D0%9D%D1%83%D0%BB%D1%8C-%D1%82%D0%B5%D1%80%D0%BC%D0%B8%D0%BD%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D0%B0%D1%8F_%D1%81%D1%82%D1%80%D0%BE%D0%BA%D0%B0?ysclid=mmhsfli7p5897685524)
Строки заключаются в двойные кавычки:
```
push.string "Строка"
```
Поддерживаются следующие управляющие символы: ```\0, \a, \b, \t, \n, \v, \f, \r, \\, \"```.

View File

@ -4,6 +4,7 @@
- ```--asm / -a - compile assembler program``` - ```--asm / -a - compile assembler program```
- ```--out / -o - set output file name``` - ```--out / -o - set output file name```
- ```--debug / -d - display debugging info``` - ```--debug / -d - display debugging info```
- ```--mem / -m - asm output memory size```
## Опция HELP ## Опция HELP
Может быть вызвана как ```--help``` или ```-h```. Может быть вызвана как ```--help``` или ```-h```.
Эта опция выводит краткую справку. Эта опция выводит краткую справку.
@ -19,3 +20,7 @@
## Опция DEBUG ## Опция DEBUG
Может быть вызвана как ```--debug``` или ```-d```. Может быть вызвана как ```--debug``` или ```-d```.
Эта опция включает режим отладчика. В этом режиме комманды будут выполняться по запросу пользователя и создавать дамп памяти. Эта опция включает режим отладчика. В этом режиме комманды будут выполняться по запросу пользователя и создавать дамп памяти.
## Опция MEM
Может быть вызвана как ```--mem``` или ```-m```.
Эта опция меняет размер памяти, выделяймой под программу при компиляции ассемблера.
Рекомендуется к использованию всегда.

3
loop.asm Normal file
View File

@ -0,0 +1,3 @@
main:
push db main
jmp

BIN
loop.exe Normal file

Binary file not shown.

BIN
ntsys

Binary file not shown.

View File

@ -84,7 +84,8 @@ static void __help(void) {
" " "--version / -v - show version" "\n" " " "--version / -v - show version" "\n"
" " "--asm / -a - compile assembler program" "\n" " " "--asm / -a - compile assembler program" "\n"
" " "--out / -o - set output file name" "\n" " " "--out / -o - set output file name" "\n"
" " "--debug / -d - display debugging info" "\0" " " "--debug / -d - display debugging info" "\n"
" " "--mem / -m - asm output memory size" "\0"
); );
} }
static int __exe_run(__e_byte_t* memory, unsigned int memorysize, unsigned long filesize, FILE* fp, __e_byte_t debug) { static int __exe_run(__e_byte_t* memory, unsigned int memorysize, unsigned long filesize, FILE* fp, __e_byte_t debug) {
@ -230,6 +231,7 @@ int _lib_ntsys_main(int argc, char** argv) {
break; break;
case 'm': case 'm':
mem = 1; mem = 1;
mode = 'A';
break; break;
default: default:
ntsys_error("Unknown option!"); ntsys_error("Unknown option!");