Форум программистов, компьютерный форум, киберфорум
Assembler: DOS/Real Mode/16-bits
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.69/29: Рейтинг темы: голосов - 29, средняя оценка - 4.69
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
TASM

Запуск command.com с параметрами, используя int 21/function 4Bh

03.05.2019, 22:05. Показов 6337. Ответов 36
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.

Столкнулся с таким заданием: необходимо средствами asm запустить новый процесс command.com, и в нем команду, например "DIR C:". Результат вывести на экран (для пользователя).
Я уже выяснил, что за запуск программы в asm отвечает int 21/function 4Bh. Изучение документации для этой функции не дало результата – я не понимаю сам алгоритм, вернее, в каком порядке и какие действия нужно проделать, чтобы данная функция сработала в соответствии с заданием. Хотя бы по минимуму (основные необходимые шаги алгоритма).
В разных источниках также пишут, что необходимо для дочернего процесса command.com предварительно выделить память, однако никаких пояснений – как, для чего, сколько именно.

Использую TASM в DOSBox.
Признаю – плохо работаю с источниками. Поэтому прошу помощи, подсказки. Заранее благодарю за ответ.
Также, если данный вопрос уже рассматривался на форуме, прошу ссылку (самостоятельно не нашел).
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.05.2019, 22:05
Ответы с готовыми решениями:

Что означает ошибка too few arguments to function ‘int my_func(int, int)’ (язык C++)?
В чём проблема? #include <iostream> int my_func (int i, int j){ int z; z=i+j; return z; } int main(){ ...

Как правильно создать объект Command при помощи мастера с параметрами
Здравствуйте. Делаю программу демонстрирующую объекты Command с использованием именованных параметров на примере простой авторизации. ...

Запуск скрипта через оболочку (command line)
Добрый вечер. Терпение лопнуло, весь исписохвался...Читаю Лутца у него в оболочке код вида PP4E\System> set...

36
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
03.05.2019, 22:59
Обычно когда под MS-DOS запускается программа, то ей выделяется вся наличная память до самого конца 640 кило. Если тебе из под твоей программы надо запускать другую, то нужно просто обрезать выделенную твоей программе память до того размера который ей действительно нужен, чтобы остальное было свободно.
Проще всего сделать это создавая com-программу. Тут даже думать не нужно, обрезать ей память до размера 64 кило и все.

Добавлено через 1 минуту
http://www.codenet.ru/progr/dos/dos_0077.php

Добавлено через 3 минуты
При старте com-программы CS=DS=ES=SS = сегменту PSP. Этот сегмент, точнее начиная с этого сегмента и выделена программе конвенционная память (той которой 640к) до ее конца, этот сегмент и надо укоротить. Так-что начни com-программу с
mov bx,1000h ; 64k в параграфах
mov ah,4Ah
int 21h
и готово. Пишу по памяти могу чего и засклерозить.

Добавлено через 4 минуты
Это вот рабочее, но грубое решение, делая красиво нужно своей программе обрезать память по минимуму, а для этого и указатель стеке переставить и посчитать сколько действительно параграфов ей хватит в обрез и программу писать так чтобы код который к моменту запуска дочерней программы уже отработал и больше не понадобится в памяти не маячил.
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
03.05.2019, 23:21  [ТС]
Цитата Сообщение от Ethereal Посмотреть сообщение
Это вот рабочее, но грубое решение
С этим разобрался, благодарю.

Память выделил, дальше нужно запустить command.com с параметрами...
Согласно инструкции в описании {DOS Fn 4bH}:
1) Выставить DS: DX на адрес строки, содержащей путь к исполняемому файлу, в моем случае
Assembler
1
2
3
4
...
mov si,offset Str1
...
Str1 db "Z:\command.com",0
2) Установить EPB+2 на сегмент и смещение следующей строки команд: 0eH,"/C DIR C:",0dH (в моем случае) – этот пункт вообще не понял, если честно! Объясните, пожалуйста, как в коде будет выглядеть передача функции параметров запуска.
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
03.05.2019, 23:35
Еще простое решение для EXE-программ. В заголовке EXE есть два поля - минимум и максимум выделяемых параграфов. Минимум выставляется компилятором - это минимальное число параграфов необходимых программе. А в максимум компилятор по умолчанию пихает FFFF, что означает давай сколько можешь. Можно вручную число из минимума параграфов скопировать в максимум, тогда в программе возиться с памятью будет вообще не нужно. MS-DOS при запуске выделить программе столько сколько нужно и ничего сверху.

Добавлено через 6 минут
Вот тут почитай
http://www.frolov-lib.ru/books/bsp/v01a/ch3_4.htm
1
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
03.05.2019, 23:36  [ТС]
Цитата Сообщение от Ethereal Посмотреть сообщение
Спасибо, ушел пробовать. Отпишусь, когда/если получу результат.
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
03.05.2019, 23:47
Там в первом примере запускается программа parm.com с параметром "Parm Str"

Добавлено через 7 минут
Только память не освобождается. Я так понял эта фраза При редактировании был указан стандартный для Quick C 2.01 размер памяти, требуемый для программы. и есть про указать в заголовке EXE максимум параграфов равный минимуму.
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 00:01  [ТС]
Вот, что получилось. Компилируется, запускает экземпляр DOS, но не команду. Где ошибся?... {Скриншот результата}
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
.model tiny  
.code
begin: 
    jmp start
    PATH        db  "Z:\command.com",00h
    PARAM       db  0Eh,"/C DIR C:",0Dh 
    EPB         dw  2
start:  
    ; инициализация
    mov     ax,@code        ; установить DS на начало сегмента кода
    mov     ds,ax
 
    ; выделение памяти подпрограмме
    mov     bx,1000h        ; 64k в параграфах
    mov     ah,4Ah
    int     21h
    
    ; установка EPB
    mov     bx,offset PARAM
    
    ; запуск COMMAND.COM
    mov     ah,4Bh          ; функция exec
    mov     al,0            ; подфункция 0 (вызов и выполнение)
    mov     bx,offset EPB
    mov     dx,offset PATH
    int     21h
    
    ; снять программу с выполнения
    mov     ax,4C00h    
    int     21h         
end start
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
04.05.2019, 00:22
Цитата Сообщение от karuagal Посмотреть сообщение
EPB dw 2
Блок EPB 7 слов, а не одно и в некоторые слова тебе надо занести значения, а некоторые можно оставить нулевыми. Так-что для начала 7 нулевых слов :
Assembler
1
2
3
4
5
6
7
EBP dw 0
    dw 0
    dw 0
    dw 0
    dw 0
    dw 0
    dw 0
Теперь тем словам куда надо занести значение адреса строки параметров для запуска дадим говорящие метки :
Assembler
1
2
3
4
5
6
7
EBP     dw 0
par_off dw 0
par_seg dw 0
        dw 0
        dw 0
        dw 0
        dw 0
Добавлено через 4 минуты
А теперь сегмент твоей строки с параметрами заносим куда надо :
mov par_seg,ds ;в com-программе без разницы можно также cs или es или ss
и смещение
mov par_off,offset PARAM
А вот теперь вызывай запуск.
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 04:47  [ТС]
Cработало! Команда DIR прошла. Большое спасибо за помощь!

Итоговый код:
Кликните здесь для просмотра всего текста
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
.model tiny 
.code
begin: 
    jmp start
    path        db  "Z:\command.com",00h
    param       db  08h,"/C DIR",0Dh
    EPB         dw  0
    par_off     dw  0
    par_seg     dw  0
                dw  0
                dw  0
                dw  0
                dw  0
 
start:  
    ; инициализация
    mov     ax,@code        ; установить DS на начало сегмента кода
    mov     ds,ax
 
    ; выделение памяти подпрограмме
    mov     bx,1000h        ; 64k в параграфах
    mov     ah,4Ah
    int     21h
    
    ; установка EPB
    mov     bx,offset param
    mov     par_off,bx       ; строки для блока EPB
    mov     par_seg,ds
    mov     ax,ds
    mov     es,ax
    
    ; запуск COMMAND.COM
    mov     ah,4Bh          ; функция exec
    mov     al,0            ; подфункция 0 (вызов и выполнение)
    mov     bx,offset EPB
    mov     dx,offset path
    int     21h
    
    ; снять программу с выполнения
    mov     ax,4C00h    
    int     21h
    
end start



Только одно осталось: после выполнения команды DIR вызванный экземпляр command.com просто завис. Что нужно сделать чтобы его завершить?

Добавлено через 31 минуту
Вдобавок к тому, что я не могу заставить подпрограмму завершиться, появилась еще одна проблема:
команда /c DIR проходит как надо (отображает содержимое каталога), но /c DIR *.asm, которая должна показать все файлы asm, работает так же как и обычный /c DIR, несмотря на то, что будучи запущенной обычным образом, она работает как надо.

Добавлено через 17 минут
Дебаг показал, что программа фризится на команде int21 в строке 37. Дальнейший код программа не видит и не воспринимает. Полагаю, что выполнение command.com с параметрами происходит некорректно, но в чем конкретно дело, я даже не догадываюсь...

Добавлено через 3 часа 32 минуты
Возможно, после выполнения дочернего процесса программа возвращается не туда куда надо.
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6213 / 2447 / 403
Регистрация: 29.07.2014
Сообщений: 3,178
Записей в блоге: 4
04.05.2019, 06:55
Цитата Сообщение от karuagal Посмотреть сообщение
Полагаю, что выполнение command.com с параметрами происходит некорректно, но в чем конкретно дело, я даже не догадываюсь...
есть ещё int-2eh, которая на автомате запускает command.com и ждёт от тебя только параметры:
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
; INT-2Eh выполнит команду DOS так же,
; как если-бы вы ввели её в ком/строке DOS.
; параметры в DS:SI (с первым байтом, указывающим длину строки, включая 13=Enter).
; прерывание уничтожает все регистры, включая SS:SP.
; убедитесь, что вы освободили память для cammand.com
;-----------------------------------
; выполнение команды 'dir/p'
; fasm-code
;------------
org  100h            ; СОМ-программа
jmp  start
 
shell   db    6,'dir /p',13        ; параметры
SaveSS  dw    0
SaveSP  dw    0
 
start:  mov   sp,len+100h           ; хвост программы
        mov   bx,len+100h shr 4     ;  ..в параграфах
        mov   ah,4Ah                ;
        int   21h                   ; освободить память!
 
        mov  [SaveSS],ss            ; (-)запомнить стек родителя
        mov  [SaveSP],sp            ;
        mov   si,shell              ; параметры для command.com
        int   2Eh                   ;
        mov   ss,[SaveSS]           ; (+)восстановить стек
        mov   sp,[SaveSP]           ;
 
        xor   ax,ax                 ; ждём клаву..
        int   16h                   ;
        int   20h                   ; на выход!
len:                                ; (хвост для освобождения памяти)
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 16:08  [ТС]
R71MT, я переделал вашу программу под TASM.
Выяснилось,, что строки с прерываниями 16h и 20h попросту намертво вешают систему, приходится рестартить. Вместо них поместил стандартный выход из приложения. С ним программа выполняется до конца, но без какого-либо результата.
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
.model tiny
.code
jmp  start
org  100h            ; СОМ-программа
 
shell   db    6,'dir /p',13        ; параметры
SaveSS  dw    0
SaveSP  dw    0
 
start:  lea   sp,len+100h           ; хвост программы
        lea   bx,len+100h shr 4     ;  ..в параграфах
        mov   ah,4Ah                ;
        int   21h                   ; освободить память!
 
        mov  [SaveSS],ss            ; (-)запомнить стек родителя
        mov  [SaveSP],sp            ;
        lea   si,shell              ; параметры для command.com
        int   2Eh                   ;
        mov   ss,[SaveSS]           ; (+)восстановить стек
        mov   sp,[SaveSP]           ;
        
        mov   ax,4C00h  
        int   21h   
len:                                ; (хвост для освобождения памяти)
end
Добавлено через 5 минут
R71MT, в этом источнике пишут, что
Do not try this in a Windows NT (2000) DOS box.
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6213 / 2447 / 403
Регистрация: 29.07.2014
Сообщений: 3,178
Записей в блоге: 4
04.05.2019, 16:19
Цитата Сообщение от karuagal Посмотреть сообщение
в этом источнике пишут, что
насчёт досбокса не знаю, но в консоли XP всё-прекрасно работает
вот пример с параметром shell db 9,'dir *.asm',13
Миниатюры
Запуск command.com с параметрами, используя int 21/function 4Bh  
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 16:22  [ТС]
R71MT, возможно, прерывание 2Eh как раз и не досовое. Попробую собрать с помощью fasm ваш код и запустить под Windows.
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6213 / 2447 / 403
Регистрация: 29.07.2014
Сообщений: 3,178
Записей в блоге: 4
04.05.2019, 16:30
Цитата Сообщение от karuagal Посмотреть сообщение
прерывание 2Eh как раз и не досовое.
не досовские они до 20-ти, а 20 и выше - дос

Добавлено через 3 минуты
а в своей тасмовской программе из #9 - сохрани SS:SP, а после command.com опять восстанови
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 16:34  [ТС]
Цитата Сообщение от R71MT Посмотреть сообщение
а 20 и выше - дос
Скомпилировал ваш код из #10 для DOS.
На виртуальной машине с DOS 6.22 действительно успешно выполняется команда "dir /p", но после этого каретка смещается на новую строку и система намертво виснет. Это можно как-то исправить?

{Скриншот}
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6213 / 2447 / 403
Регистрация: 29.07.2014
Сообщений: 3,178
Записей в блоге: 4
04.05.2019, 16:43
Цитата Сообщение от karuagal Посмотреть сообщение
Это можно как-то исправить?
int-16h ждёт нажатия любой клавиши.. убери её и оставь только int-20h (в com-файлах можно заменить на ret)
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 16:49  [ТС]
Цитата Сообщение от R71MT Посмотреть сообщение
а в своей тасмовской программе из #9 - сохрани SS:SP, а после command.com опять восстанови
Результат не изменился. Висит.

Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
...
    savess      dw  ?
    savesp      dw  ?
...
...
    ; запуск COMMAND.COM
    mov     ah,4Bh          ; функция exec
    mov     al,0            ; подфункция 0 (вызов и выполнение)
    mov     bx,offset EPB
    mov     dx,offset path
    mov     [savess],ss
    mov     [savesp],sp
    int        21h
    mov ss,[savess]
    mov sp,[savesp]
Добавлено через 3 минуты
Цитата Сообщение от R71MT Посмотреть сообщение
убери её и оставь только int-20h (в com-файлах можно заменить на ret)
Сделал так. Не помогло, всё еще висит после dir. Попробую посмотреть турбо дебаггером...
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6213 / 2447 / 403
Регистрация: 29.07.2014
Сообщений: 3,178
Записей в блоге: 4
04.05.2019, 16:51
это эмуляторы и вирт.машины глючат, т.к. (повторюсь) у меня работает нормально
смотри свой код под отладчиком..
0
1 / 1 / 0
Регистрация: 03.05.2019
Сообщений: 19
04.05.2019, 16:52  [ТС]
{Скриншот}


Что интересно, подпрограмма завершилась успешно! Значит висяк уже в основной программе. Может потому что не хватает стандартного завершения?
Assembler
1
2
mov   ax,4C00h
int   21h
Миниатюры
Запуск command.com с параметрами, используя int 21/function 4Bh  
0
04.05.2019, 16:58

Не по теме:

Цитата Сообщение от karuagal Посмотреть сообщение
{Скриншот}
грузи картинки на форум (скрепка в окне сообщения)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.05.2019, 16:58
Помогаю со студенческими работами здесь

Можно ли реализовать Function / Sub с именованными параметрами ...
подобно встроенным функциям, например: GetSetting Application:='Appl', Section:='Sec', Default='' Спасибо

Аргумент типа int не совместим с параметрами типа int*
помогите, ошибка в программе "аргумент типа int не совместим с параметрами типа int*" #include <stdio.h> #include...

Аргумент типа int не совместим с параметрами типа int**
Помогите, решить проблему с указателями #include <iostream> #include "pch.h" #include <cstdlib> #include <ctime> ...

Не выполняется запуск программы на удалённом компьютере командлетом Invoke-Command
Уважаемые форумчане. Прошу знающих Powershell помочь в такой проблеме. Есть доменная сеть с компьютерами. Все компьютеры находятся в одном...

Запуск файла с сетевой папки через Invoke-command на удаленном компьютере
Здравствуйте. Помогите разобраться с доступом к шаре через invoke. Ситуация 1: необходимо запустить скрипт на удаленном пк, с теми же...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru