Системные вызовы дисковой подсистемы (DSS) v1.6
Системные вызовы


   Если программа выполняет не только некую математическую задачу на ассемблере, то в ней придется столкнуться с такими вещами, как получение ввода пользователя, выполнение вывода результатов и завершение своей работы. Для этого, необходимо обратиться к сервисам DSS. Фактически, программирование на языке ассемблера одинаково для любых систем, если не пользоваться их сервисами.    Вызов функций DSS в системе Estex выполняется из ассемблера. Необходимые параметры указываются в различных регистрах, регистр C используется для указания номера функции.  Так, наша программа для Estex будет выглядеть наподобие: 

        ORG     #8100   ;адрес точки входа

        LD      HL,MSG  ;сообщение для вывода
        LD      C,5Ch   ;номер системного вызова (PCHARS)
        RST     10h     ;вызов подсистемы

        LD      C,41h   ;номер системного вызова (EXIT)
        RST     10h     ;вызов подсистемы

MSG     db      "Hello, world!",0Dh,0Ah     ;наша стока
        db      0                           ;конец строки

Следом за таблицей есть пояснение по двум новым функциям 0Ch и 0Dh.
Далее идет список категорий функций DSS для системы Estex
 HYPERLINK "" \l "version" Функции идентификации системы
 HYPERLINK "" \l "disk_io" Функции для работы с диском
 HYPERLINK "" \l "file_io" Функции для работы с файлами
 HYPERLINK "" \l "date_time" Функции для работы с датой и временем
 HYPERLINK "" \l "memory" Функции управления памятью
 HYPERLINK "" \l "keyboard" Функции ввода с клавиатуры
 HYPERLINK "" \l "execute" Функции для исполнения программ
 HYPERLINK "" \l "cmdline" Функции для работы со строками и командной строкой
 HYPERLINK "" \l "var" Функции для работы с переменными
 HYPERLINK "" \l "screen" Функции работы с экраном
 HYPERLINK "" \l "printer" Функции для печати на принтере
 HYPERLINK "" \l "tocversion" Функции идентификации системы 

00h (00) VERSION (Версия DSS)

Входные значения: C - 00h
Выходные значения: D - номер версии E - модификация

 HYPERLINK "" \l "tocdisk_io" Функции для работы с диском 

01h (01) CHDISK (Смена текущего диска)

Входные значения: A - номер диска (0-A,1-B...) C - 01h
Выходные значения: A - код ошибки, если CF=1 A - максимальный номер диска, если CF=0

02h (02) CURDISK (Номер текущего диска)

Входные значения: C - 02h
Выходные значения: A - код ошибки, если CF=1 A - текущий номер диска (0-A,1-B...), если CF=0

03h (03) DSKINFO (Информация о диске)

Входные значения: A - номер диска (0-A,1-B...0FFh-текущий) C - 03h
Выходные значения: A - код ошибки, если CF=1 A - размер кластера в секторах, если CF=0 HL - общее кол-во кластеров DE - свободных кластеров BC - размер сектора в байтах

09h (09) BOOTDSK (Номер системного диска)

Входные значения: C - 09h B = 0
Выходные значения: A - код ошибки, если CF=1 A - номер системного диска (0-A,1-B...), если CF=0

 HYPERLINK "" \l "tocfile_io" Функции для работы с файлами 

0Ah (10) CREATE (Создание файла)

Входные значения: HL - указатель на файловую спецификацию A - атрибут файла C - 0Ah
Выходные значения: A - код ошибки, если CF=1 A - файловый манипулятор, если CF=0

0Bh (11) CREATE NEW FILE (Создание нового файла)

Входные значения: HL - указатель на файловую спецификацию A - атрибут файла C - 0Bh
Выходные значения: A - код ошибки, если CF=1 A - файловый манипулятор, если CF=0

0Eh (14) DELETE (Удаление файла)

Входные значения: HL - указатель на файловую спецификацию C - 0Eh
Выходные значения: A - код ошибки, если CF=1

10h (16) RENAME (Переименование файла)

Входные значения: HL - указатель на старое имя файла DE - указатель на новое имя файла C - 10h
Выходные значения: A - код ошибки, если CF=1

11h (17) OPEN (Открытие файла)

Входные значения: HL - указатель на файловую спецификацию A - режим доступа A=0 чтение/запись A=1 чтение A=2 запись C - 11h
Выходные значения: A - код ошибки, если CF=1 A - файловый манипулятор, если CF=0

12h (18) CLOSE (Закрытие файла)

Входные значения: A - файловый манипулятор C - 12h
Выходные значения: A - код ошибки, если CF=1


13h (19) READ (Чтение из файла)

Входные значения: A - файловый манипулятор HL - адрес в памяти DE - количество читаемых байт C - 13h
Выходные значения: A - код ошибки, если CF=1 DE - реальное количество прочитанных байт если CF=0: A = 0 прочитаны все байты A = 0FFh прочитано меньшее число байт

14h (20) WRITE (Запись в файл)

Входные значения: A - файловый манипулятор HL - адрес в памяти DE - количество записываемых байт C - 14h
Выходные значения: A - код ошибки, если CF=1 DE - реальное количество записанных байт

15h (21) MOVE_FP (Перемещение указателя в файле)

Входные значения: A - файловый манипулятор HL:IX - смещение указателя в файле B - способ перемещения: B=0 от начала файла B=1 от текущего значения указателя B=2 от конца файла C - 15h
Выходные значения: A - код ошибки
 если CF=1 HL:IX - новое значение указателя

16h (22) ATTRIB (Получение/изменение атрибута файла)

Входные значения: HL - указатель на файловую спецификацию B - режим доступа B = 0 получить атрибут B = 1 установить атрибут A - атрибут файла C - 16h
Выходные значения: A - код ошибки, если CF=1 A - атрибут файла, если CF=0

17h (23) GET_D_T (Информация о дате и времени файла)

Входные значения: A - файловый манипулятор C - 17h
Выходные значения: A - код ошибки, если CF=1 D - день E - месяц IX - год H - час L - минуты B - секунды

18h (24) PUT_D_T (Изменение даты и времени файла)

Входные значения: A - файловый манипулятор D - день E - месяц IX - год H - час L - минуты B - секунды C - 18h
Выходные значения: A - код ошибки, если CF=1

19h (25) F_FIRST (Поиск первого совпадающего файла)

Входные значения: HL - указатель на файловую спецификацию DE - рабочий буфер 44 байта, если B=0, иначе 256 байт A - атрибуты, используемые при поиске B = 0 - имя найденного файла в формате 11 байт "FilenameExt" B = 1 - имя найденного файла в формате DOS "filename.ext",0 C - 19h
Выходные значения: A - код ошибки, если CF=1

1Ah (26) F_NEXT (Поиск следующего совпадающего файла)

Входные значения: DE - указатель на рабочий буфер C - 1Ah
Выходные значения: A - код ошибки, если CF=1




1Bh (27) MKDIR (Создание каталога)

Входные значения: HL - указатель на файловую спецификацию C - 1Bh
Выходные значения: A - код ошибки, если CF=1

1Ch (28) RMDIR (Устранение каталога)

Входные значения: HL - указатель на файловую спецификацию C - 1Ch
Выходные значения: A - код ошибки, если CF=1

1Dh (29) CHDIR (Смена текущего каталога)

Входные значения: HL - указатель на файловую спецификацию C - 1Dh
Выходные значения: A - код ошибки, если CF=1

1Eh (30) CURDIR (Информация о текущем каталоге)

Входные значения: HL - буфер в памяти 256 байт C - 1Eh
Выходные значения: A - код ошибки, если CF=1

 HYPERLINK "" \l "tocdate_time" Функции для работы с датой и временем 

21h (33) SYSTIME (Текущая дата и время)

Входные значения: C - 21h
Выходные значения: D - день E - месяц IX - год H - час L - минуты B - секунды C - день недели

22h (34) SETTIME (Установить текущую дату и время)

Входные значения: D - день E - месяц IX - год H - час L - минуты B - секунды C - 22h
Выходные значения: A - код ошибки, если CF=1

 HYPERLINK "" \l "tocmemory" Функции управления памятью 

38h (56) SETWIN (Подключение страницы памяти)

Входные значения: A - идентификатор блока памяти B - номер страницы в блоке (0,1,2...) H - биты 6 и 7 задают номер окна, в которое будет подключена страница C - 38h
Выходные значения: A - код ошибки, если CF=1 A - номер замещенной страницы, если CF=0

39h (57) SETWIN1 (Подключение страницы памяти в первое окно)

Входные значения: A - идентификатор блока памяти B - номер страницы в блоке (0,1,2...) C - 39h
Выходные значения: A - код ошибки, если CF=1 A - номер замещенной страницы, если CF=0

3Ah (58) SETWIN2 (Подключение страницы памяти во второе окно)

Входные значения: A - идентификатор блока памяти B - номер страницы в блоке (0,1,2...) C - 39h
Выходные значения: A - код ошибки, если CF=1 A - номер замещенной страницы, если CF=0

3Bh (59) SETWIN3 (Подключение страницы памяти в третье окно)

Входные значения: A - идентификатор блока памяти B - номер страницы в блоке (0,1,2...) C - 3Bh
Выходные значения: A - код ошибки, если CF=1 A - номер замещенной страницы, если CF=0

3Ch (60) INFOMEM (Информация о памяти)

Входные значения: C - 3Ch
Выходные значения: HL - общее количество страниц BC - количество свободных страниц

3Dh (61) GETMEM (Выделение блока памяти)

Входные значения: B - размер блока в страницах по 16 килобайт C - 3Dh
Выходные значения: A - код ошибки, если CF=1 A - идентификатор блока памяти, если CF=0

3Eh (62) FREEMEM (Освобождение блока памяти)

Входные значения: A - идентификатор блока памяти C - 3Eh
Выходные значения: A - код ошибки, если CF=1

3Fh (63) SETMEM (Изменение блока памяти)

Входные значения: A - идентификатор блока памяти B - новый размер блока C - 3Fh

Выходные значения: A - код ошибки, если CF=1

 HYPERLINK "" \l "tockeyboard" Функции ввода с клавиатуры 

30h (48) WAITKEY (Ожидание символа с клавиатуры)

Входные значения: C - 30h
Выходные значения: A - код символа D - позиционный код Е - ASCII код C - режим клавиатуры: bit7 - RUS/LAT bit3 - Num Lock bit2 - Scroll Lock bit1 - Insert bit0 - Caps Lock B - состояние shift'ов: bit7 - Left Shift bit6 - Right Shift bit5 - Ctrl bit4 - Alt bit3 - Left Ctrl bit2 - Left Alt bit1 - Right Ctrl bit0 - Right Alt
31h (49) SCANKEY (Опрос клавиатуры без ожидания)

Входные значения: C - 31hВыходные значения: ZF = 1 - нет клавиш A - код символа D - позиционный код Е - ASCII код C - режим клавиатуры: bit7 - RUS/LAT bit3 - Num Lock bit2 - Scroll Lock bit1 - Insert bit0 - Caps Lock B - состояние shift'ов: bit7 - Left Shift bit6 - Right Shift bit5 - Ctrl bit4 - Alt bit3 - Left Ctrl bit2 - Left Alt bit1 - Right Ctrl bit0 - Right Alt
32h (50) ECHOKEY (Ожидание символа с клавиатуры с печатью)

Входные значения: C - 32h
Выходные значения: A - код символа D - позиционный код Е - ASCII код C - режим клавиатуры: bit7 - RUS/LAT bit3 - Num Lock bit2 - Scroll Lock bit1 - Insert bit0 - Caps Lock B - состояние shift'ов: bit7 - Left Shift bit6 - Right Shift bit5 - Ctrl bit4 - Alt bit3 - Left Ctrl bit2 - Left Alt bit1 - Right Ctrl bit0 - Right Alt
33h (51) CTRLKEY (Получить состояние клавиатуры)

Входные значения: C - 33h
Выходные значения: A = 0 - нет символов в буфере C - режим клавиатуры: bit7 - RUS/LAT bit3 - Num Lock bit2 - Scroll Lock bit1 - Insert bit0 - Caps Lock B - состояние shift'ов: bit7 - Left Shift bit6 - Right Shift bit5 - Ctrl bit4 - Alt bit3 - Left Ctrl bit2 - Left Alt bit1 - Right Ctrl bit0 - Right Alt
35h (53) K_CLEAR (Очистить буфер клавиатуры и выполнить функцию)

Входные значения: B - номер фун
ции 30h, 31h, 32h, 33h или 34h C - 35h
Выходные значения: В зависимости от указанной функции в регистре B.

36h (54) K_SETUP (Управление настройками клавиатуры)

Входные значения: B - номер подфункции C - 36h  B = 0, установить раскладку клавиатуры A - номер раскладки 
0 - normal 1 - shift 2 - caps lock 3 - caps lock + shift 4 - normal (альтернативная кл.) 5 - shift (альтернативная кл.) 6 - caps lock (альтернативная кл.) 7 - caps lock + shift (альтернативная кл.)
B = 1, получить состояние звуковых переменных B = 2, установить звуковые переменные A - значение переменной bit0 - сигнал переполнения буфера клавиатуры bit1 - сигнал переключения на альтернативную раскладку клавиатуры
Выходные значения: В зависимости от указанной функции в регистре B.

37h (55) TESTKEY (Опрос буфера клавиатуры)

Входные значения: C - 37h
Выходные значения: ZF = 1 - нет символов в буфере A - код символа D - позиционный код Е - ASCII код C - режим клавиатуры: bit7 - RUS/LAT bit3 - Num Lock bit2 - Scroll Lock bit1 - Insert bit0 - Caps Lock B - состояние shift'ов: bit7 - Left Shift bit6 - Right Shift bit5 - Ctrl bit4 - Alt bit3 - Left Ctrl bit2 - Left Alt bit1 - Right Ctrl bit0 - Right Alt

 HYPERLINK "" \l "tocexecute" Функции для исполнения программ 

40h (64) EXEC (Выполнить файл)

Входные значения: HL - указатель на файловую спецификацию B = 0 - загрузить и выполнить программу C - 40h
Выходные значения: A - код ошибки, если CF=1 A - код завершения, если CF=0

41h (65) EXIT (Завершение программы)

Входные значения: B - код завершения C - 41h
Выходные значения: A - код ошибки, если CF=1 A - код завершения, если CF=0

42h (66) WAIT (Получить код завершения программы)

Входные значения: C - 42h
Выходные значения: A - код завершения

 HYPERLINK "" \l "toccmdline" Функции для работы со строками и командной строкой 

43h (67) GSWITCH (Выделить параметр командной строки)

Входные значения: HL - указатель командной строки DE - буфер для выделяемого параметра C - 43h 
Выходные значения: HL - указатель на следующий параметр командной строки CF = 0 - конец строки не достигнут (есть другие параметры) CF = 1 - конец строки (в буфер перенесён последний параметр или ноль)

44h (68) DOSNAME (Преобразовать имя файла)

Входные значения: C - 44h B = 0, преобразовать из 11 символьного формата в формат ДОС HL - 11 символов имени файла DE - буфер для имени в формате ДОС B = 1, преобразовать из формата ДОС в 11 символьный формат HL - имя файла в формате ДОС DE - 11 символов имени файла
Выходные значения: A - код ошибки, если CF=1

45h (69) EXCMDLN (Разбор командной строки)

Входные значения: HL - указатель командной строки DE - указатель на буфер пользователя C - 45h B - номер подфункции:
0 - Разобрать строку; 1 - Выделить имя диска; 2 - Выделить директорию; 3 - Выделить имя файла; 4 - Выделить расширение файла; 5 - Выделить имя диска, путь к файлу, имя файла и расширение файла; 6 - Зарезервирована; 7 - Выделить параметр командной строки; 8 - Преобразовать из 11 символьного формата в формат ДОС; 9 - Преобразовать из формата ДОС в 11 символьный формат;

Подфункция 0 - Разобрать строку:

Входные значения: HL - указатель командной строки C - 45h B = 0 - Разобрать строку
Выходные значения: A - код ошибки, если CF=1 A - результат разбора, если CF=0 bit7 - В строке обнаружены символы ? или * bit3 - В строке указано имя диска; bit2 - В строке указан путь к файлу; bit1 - В строке указано расширение файла; bit0 - В строке указано имя файла;

Подфункция 1 - Выделить имя диска:

Входные значения: HL - указатель командной строки DE - буфер (макс. 13 байт) C - 45h B = 1 - Выделить имя диска
Выходные значения: A - код ошибки, если CF=1 A - номер диска (0 - A, 1 - B, 2 - C и т.д.), если CF=0 буфер - имя диска "A:",0

Подфункция 2 - Выделить директорию:

Входные значения: HL - указатель командной строки DE - буфер (макс. 256 байт) C - 45h B = 2 - Выделить директорию
Выходные значения: A - код ошибки, если CF=1 A - результат разбора, если CF=0 bit7 - В строке обнаружены символы ? или * bit3 - В строке указано имя диска; bit2 - В строке указан путь к файлу; bit1 - В строке указано расширение файла; bit0 - В строке указано имя файла; буфер - директория "DIR1\DIR2\DIR3\",0

Подфункция 3 - Выделить имя файла:

Входные значения: HL - указатель командной строки DE - буфер (макс. 13 байт) C - 45h B = 3 - Выделить имя файла
Выходные значения: A - код ошибки, если CF=1 A - результат разбора, если CF=0 bit7 - В строке обнаружены символы ? или * bit3 - В строке указано имя диска; bit2 - В строке указан путь к файлу; bit1 - В строке указано расширение файла; bit0 - В строке указано имя файла; буфер - имя файла "FILE.EXT",0

Подфункция 4 - Выделить расширение файла:

Входные значения: HL - указатель командной строки DE - буфер (макс. 4 байт) C - 45h B = 4 - Выделить расширение файла
Выходные значения: A - код ошибки, если CF=1 A - результат разбора, если CF=0 bit7 - В строке обнаружены символы ? или * bit3 - В строке указано имя диска; bit2 - В строке указан путь к файлу; bit1 - В строке указано расширение файла; bit0 - В строке указано имя файла; буфер - расширение "TXT",0 или "C ",0

Подфункция 5 - Выделить имя диска, путь к файлу, имя файла и расширение файла:

Входные значения: HL - указатель командной строки DE - буфер (макс. 8 байт) DE+0 адрес буфера для имени диска (макс. 13 байт) DE+2 адрес буфера для директории (макс. 256 байт) DE+3 адрес буфера для имени файла (макс. 13 байт) DE+4 адрес буфера для расширения файла (макс. 4 байта) C - 45h B = 5 - Выделить имя диска, путь к файлу, имя файла и расширение файла
Выходные значения: A - код ошибки, если CF=1 A - результат разбора, если CF=0 bit7 - В строке обнаружены символы ? или * bit3 - В строке указано имя диска; bit2 - В строке указан путь к файлу; bit1 - В строке указано расширение файла; bit0 - В строке указано имя файла;

Подфункция 7 - Выделить параметр командной строки

Входные значения: HL - указатель командной строки DE - буфер для выделяемого параметра C - 45h B = 7 - Выделить параметр командной строки
Выходные значения: HL - указатель на следующий параметр командной строки CF = 0 - конец строки не достигнут (есть другие параметры) CF = 1 - конец строки (в буфер перенесён последний параметр или ноль)

Подфункция 8 - Преобразовать из 11 символьного формата в формат ДОС

Входные значения: C - 45h B = 8 - преобразовать из 11 символьного формата в формат ДОС HL - 11 символов имени файла DE - буфер для имени в формате ДОС
Выходные значения: A - код ошибки, если CF=1

Подфункция 9 - Преобразовать из формата ДОС в 11 символьный формат

Входные значения: C - 45h B = 9 - преобразовать из формата ДОС в 11 символьный формат HL - имя файла в формате ДОС DE - буфер для 11 символов имени файла
Выходные значения: A - код ошибки, если CF=1





 HYPERLINK "" \l "tocvar" Функции для работы с переменными 

46h (70) ENVIRON (Системное окружение)

Входные значения: B - номер подфункции C - 46h B=0 Получение системного окружения HL - буфер B=1 Получить переменную окружения HL - имя переменной DE - буфер для значения переменной B=2 Установить/удалить переменную окружения HL - имя переменной и значение, разделенные символом '=', (ПЕРЕМЕННАЯ=ЗНАЧЕНИЕ)
Выходные значения: A - состояние, если CF=0 A=0 - переменная обнаружена A=0FFh - переменная не обнаружена DE - указывает на конец буфера A - код ошибки, если CF=1

47h (71) APPINFO (Получение информации приложения)

Входные значения: B - номер подфункции C - 47h HL - буфер данных B=0 - получение параметров командной строки B=1 - получение полного пути к каталогу программы B=2 - получение полного пути и имени файла программы
Выходные значения:: A - код ошибки, если CF=1

 HYPERLINK "" \l "tocscreen" Функции работы с экраном 

50h (80) SETVMOD (Выбор режима экрана)

Входные значения: A - режим экрана    02h - текстовый 40x32x16 цветов    03h - текстовый 80x32x16 цветов    81h - графический 320x256x256 цветов    82h - графический 640x256x16 цветов B - страница экрана 0/1 C - 50h
Выходные значения: A - код ошибки, если CF=1

51h (81) GETVMOD (Получить текущий режим экрана)

Входные значения: C - 51h
Выходные значения: A - код ошибки, если CF=1 A - текущий режим экрана, если CF=0 B - страница экрана 0/1

52h (82) LOCATE (Установить позицию курсора)

Входные значения: D - строка курсора E - столбец курсора C - 52h
Выходные значения: нет

53h (83) CURSOR (Получить текущую позицию курсора)

Входные значения: C - 53h
Выходные значения: D - строка курсора E - столбец курсора

54h (84) SELPAGE (Выбрать активную страницу экрана)

Входные значения: B - страница экрана 0/1 C - 54h
Выходные значения: A - код ошибки, если CF=1

55h (85) SCROLL (Прокрутка окна)

Входные значения: D - строка левого верхнего угла окна E - столбец левого верхнего угла окна H - высота окна L - ширина окна B = 1 - прокрутка вверх B = 2 - прокрутка вниз A = 0 - очищать строку C - 55h
Выходные значения: нет

56h (86) CLEAR (Очистка окна)

Входные значения: D - строка левого верхнего угла окна E - столбец левого верхнего угла окна H - высота окна L - ширина окна B - атрибут заполнитель A - символ заполнитель C - 56h
Выходные значения: нет

57h (87) RDCHAR (Считать символ с экрана)

Входные значения: D - строка E - столбец C - 57h
Выходные значения: A - символ B - атрибут

58h (88) WRCHAR (Напечатать символ на экране)

Входные значения: D - строка E - столбец A - символ B - атрибут C - 58h
Выходные значения: нет

59h (89) WINCOPY (Запомнить окно экрана)

Входные значения: D - строка E - столбец левого верхнего угла окна H - высота окна L - ширина окна B - страница буфера IX - адрес буфера C - 59h
Выходные значения: нет

5Ah (90) WINREST (Восстановить окно экрана)

Входные значения: D - строка E - столбец левого верхнего угла окна H - высота окна L - ширина окна B - страница буфера IX - адрес буфера C - 5Ah
Выходные значения: нет

5Bh (91) PUTCHAR (Напечатать символ в текущей позиции курсора)

Входные значения: A - символ C - 5Bh
Выходные значения: нет

5Ch (92) PCHARS (Напечатать строку символов в текущей позиции курсора)

Входные значения: HL - указатель на начало строки символов C - 5Ch
Выходные значения: нет

 HYPERLINK "" \l "tocprinter" Функции для печати на принтере 

5Fh (95) PRINT (Вывод символа на принтер без ожидания)

Входные значения: A - символ C - 5Fh
Выходные значения: B - символ CF = 1 - принтер не готов






