С Новым годом! Форум программистов, компьютерный форум, киберфорум
Assembler: Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.66/29: Рейтинг темы: голосов - 29, средняя оценка - 4.66
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
NASM

Запуск другой программы

06.08.2018, 18:44. Показов 6285. Ответов 30
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
section .data
 
    file db "b.sh"
section .text
    global _start
_start:
         mov ecx, 5
         cmp ecx, 2
         jg  jamp
         int 0x80
jamp:
          mov eax, 11
          mov ebp, file
          int 0x80
 
        mov eax, 1
        int 0x80
не могу понять почему не запускается скрипт.
везде спрашивал-все молчат. одна надежда на Вас

Добавлено через 28 минут
если без условного перехода, то запуститься
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 
section .data
 
    file db "b.sh"
section .text
    global _start
_start:
        
          mov eax, 11
          mov ebp, file
          int 0x80
 
        mov eax, 1
        int 0x80
Добавлено через 45 минут
я же не код банковской карты у Вас спрашиваю. так молчите, что похоже на это.


просто напишите , не поленитесь , где я ошибся
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.08.2018, 18:44
Ответы с готовыми решениями:

Компиляция и запуск программы в GUI TASM
Здравствуйте. Скачал турбо ассемблер 64 вот с этой ссылки https://sourceforge.net/projects/guitasm8086/files/ Установил. Написал...

Запуск программы только из другой программы
Здравствуйте уважаемые программисты, сегодня столкнулся с проблемой, естественно первым делом прогуглил и нечего толкового не нашёл....

Запуск внешней программы из другой программы
День добрый! Мне нужно запустить exeшник Hello world программы при компиляции другой программы. Пробовал делать через Winexec,...

30
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
06.08.2018, 19:26
pcmax, я не могу понять сразу причин. Но предлагаю вам лично научиться пользоваться отладчиком и выполнить программу по шагам. Увидите все переходы, значения флагов.

Я не издеваюсь - но раз вы пытаетесь учиться, то осваивайте инструментарий. В Linux есть gdb и оболочки над gdb.
Выполняйте по шагам.
1
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
06.08.2018, 19:32  [ТС]
спасибо за совет
попытаюсь освоить


но думаю, что в nano от gdb толку будет мало.


любые предположения от Вас, по поводу ошибок в этом фрагменте кода, приму как помощь
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
06.08.2018, 19:37
pcmax, я не знаю почему не выполняется команда 11. Мог бы при наличии Linux выполнить по шагам и следить, что всё-таки выполняется, содержимое регистров, флагов.

Я всегда так делаю - думаете, что все исходники сразу работают после набора? Нет, их проверяю, исправляю, выполняю по шагам.

Чем вы лучше меня?
1
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
06.08.2018, 19:39
Цитата Сообщение от pcmax Посмотреть сообщение
не могу понять почему не запускается скрипт
Проблема в том, что ты вряд ли понимаешь, что делает программа, которую ты написал. А когда не понимаешь, как должен работать код, то можно до упаду выполнять пошагово из-под отладчика и всё равно не понять, почему оно не работает. Для начала разберись, что делает каждая инструкция из твоего кода. Затем разберись, что такое в линуксе системные вызовы (syscall, system call). Под конец разберись, что вообще делает твоя программа

Не по теме:

Очень напоминает последний мини-фильм из фильма "криминальное чтиво"

3
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
06.08.2018, 19:52
Ага, нашёл на другом форуме ответ, данный Black Fregat для pcmax
Assembler
1
2
3
4
5
6
7
8
9
10
11
  section .data
name: db "./test.sh",0
 
  section .text
  global _start
_start:
  mov edx, 0
  mov ecx, 0
  mov ebx, name
  mov eax, 11
  int 0x80
Если этот ответ верный, то причина неработоспособности программы ТС банальна - плохое зрение и неродной алфавит исходников. Родной, наверное, не основан на кириллице или латинице, поэтому так много опечаток (как на этикетках к китайским товарам).
1
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
06.08.2018, 19:59
Лучший ответ Сообщение было отмечено ФедосеевПавел как решение

Решение

Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
причина неработоспособности программы ТС банальна
У него же есть второй фрагмент, который работает. Он тоже написан неправильно (не все параметры поданы в системный вызов execve). Правда во втором фрагменте нету записи константы 5 в регистр %ecx, что в общем-то тоже могло повлиять. Предположительно, на этом регистре передаётся параметр argv, для которого значение 5 гарантированно некорректно, а вот неинициализированное значение, вероятно, могло привести к тому, что по счастливому стечению обстоятельств в регистре %ecx находилось нечто, что очень похоже на argv. Вполне возможно, что в точке входа в программу на регистре %ecx передаётся именно argv. Но это может быть и envp, что по структуре не сильно отличается от argv
4
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
06.08.2018, 20:07  [ТС]
запустилась)))
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
06.08.2018, 20:19
Цитата Сообщение от pcmax Посмотреть сообщение
запустилась
Это не отменяет того, что всё равно надо пытаться понять, что конкретно тут делается
2
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
07.08.2018, 01:24  [ТС]
согласен

Добавлено через 4 часа 15 минут
Цитата Сообщение от Evg Посмотреть сообщение
Это не отменяет того, что всё равно надо пытаться понять, что конкретно тут делается

убедили . давайте пожалуйста разбираться


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
section .bss
 
     elb resb 10
section .data
       file "b.sh", 0
       file1 "p.py", 0
section .text
       global _start
_start:
 
        mov eax, 3
        mov ebx, 0
        mov ecx, elb
        mov edx, 10
        int 0x80
    
         mov ebp, 100
         cmp ebp, [elb]
         je jamp
         int 0x80
         jmp tojamp
 
jamp:
          mov eax, 11
          mov ebx, file
          xor ecx, ecx
          xor edx, edx
          int 0x80
          jmp stop
 
tojamp:
           mov eax, 11
           mov ebx, file1
           xor ecx, ecx
           xor edx, edx
           int 0x80
           jmp stop
 
stop:
           mov eax, 1
            int 0x80

что надо тут? посути же jmp tojamp это должно быть как иначе, как else, а je , как if(elb==100) иначе прыжок на toojamp
ребята, без объяснения на форуме, сложно будет понять этот замечательный язык.
почему -то его никто ни где не хочет раскрывать. если не на форумах, то где?
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
07.08.2018, 11:32
pcmax, пошаговое выполнение в gdb покажет соответствие или несоответствие ваших представлений о содержимом [elb] и ходе исполнения программы.

Не сопротивляйтесь - используйте отладчик.
У меня нет Linux и отладить за вас я не в силах. У многих дела обстоят аналогично. Поэтому бессмысленно вываливать сюда неработающий код для Linux.

УЧИТЕСЬ ИСПОЛЬЗОВАТЬ ОТЛАДЧИК

Добавлено через 29 минут
Думаю, что ошибка в данном случае в следующем:
- строки 11-15: ввод строки elb длиной не более 10 символов
- строки 17-18: сравнение первого символа строки elb с числом 100 (ASCII символ "d")
- строка 19: если равны, то переход к метке
- строка 20: если не равны, то со случайными параметрами выполняется обращение к ОС Linux

Т.е. если введена строка elb не начинающаяся с символа "d", то выполнится случайная функция ОС.
2
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
07.08.2018, 12:34  [ТС]
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
Т.е. если введена строка elb не начинающаяся с символа "d", то выполнится случайная функция ОС.

да , но она не выполняется....


поэтому я опять в панике.

на изучение отладчика уйдет год. лучше это время потратить на изучение языка Assembler

Добавлено через 1 минуту
Цитата Сообщение от politoto Посмотреть сообщение
От ассемблера не много пользы, если не знаешь язык машины, для которой собираешься программировать, и среду ,в которой будет выполняться программа.


я изучаю , потому что нравится Assembler.

не для выгоды это

Добавлено через 1 минуту
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
Т.е. если введена строка elb не начинающаяся с символа "d", то выполнится случайная функция ОС

почему случайная? так же системный вызов 11
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
07.08.2018, 12:44
Всё покажет исполнение в отладчике.
Вы увидите код символа, значения регистров и прочее.

Я бы и за вас это (выполнение в отладчике) сделал - но "нет такой счастливой возможности".

Раз вы не можете пользоваться отладчиком - будем ждать, пока кто-то с Linux забредёт в раздел.
1
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
07.08.2018, 12:47
Согласен. Если удалить 20-ю строчку с int 0x80, код будет выглядеть более осмысленно.
Хотя об ожидаемом поведении программы мы может только догадываться.

Получится что-то вроде
C
1
2
3
4
 char elb[10];
 
read( 0, elb, 10 );
( 100 == elb[0] ) ? execve( "b.sh", 0, 0 ) : execve( "p.py", 0, 0 );
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
07.08.2018, 13:05
И ещё.

Это корректно? Это точно описание массивов байт
Assembler
4
5
6
section .data
       file "b.sh", 0
       file1 "p.py", 0
1
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
07.08.2018, 13:19  [ТС]
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
то корректно? Это точно описание массивов байт

нет , это не корректно. но без этого не компилится. сразу выдает ошибку


врял ли кто-то зайдет сюда под Линукс.

одна надежда, что способом перебора получиться узнать Ассемблер
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
07.08.2018, 13:36
Изучите заодно методом перебора какой-нибудь отладчик или трассировщик.
Дело пойдёт быстрее и веселее уж точно!

Добавлено через 3 минуты
Если нет линукса, то есть браузер!

Добавлено через 1 минуту
Code
1
2
3
4
[B]$nasm -f elf *.asm; ld -m elf_i386 -s -o demo *.o[/B]
main.asm:5: error: parser: instruction expected
main.asm:6: error: parser: instruction expected
ld: cannot find *.o: No such file or directory
1
 Аватар для pcmax
443 / 74 / 7
Регистрация: 29.01.2018
Сообщений: 1,274
07.08.2018, 13:45  [ТС]
и в чем проблема на Ваш взгляд?
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
07.08.2018, 13:48
db при копипастах потерялась?

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
section .bss
 
     elb resb 10
section .data
       file db "date", 0
       file1 db "ls", 0
section .text
       global _start
_start:
 
        mov eax, 3
        mov ebx, 0
        mov ecx, elb
        mov edx, 10
        int 0x80
       
        
         mov ebp, 100
         cmp ebp, [elb]
         
         je jamp
         
         jmp tojamp
 
jamp:
          mov eax, 11
          mov ebx, file
          xor ecx, ecx
          xor edx, edx
          int 0x80
          jmp stop
 
tojamp:
           mov eax, 11
           mov ebx, file1
           xor ecx, ecx
           xor edx, edx
           int 0x80
           jmp stop
 
stop:
           mov eax, 1
            int 0x80
Ассемблировать онлайн можно, например, тут:
https://www.tutorialspoint.com... online.php
Жаль, что тут же нет отладчика! Есть в другом месте, но там нет nasm
2
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8647 / 4482 / 1669
Регистрация: 01.02.2015
Сообщений: 13,888
Записей в блоге: 11
07.08.2018, 13:57
Цитата Сообщение от pcmax Посмотреть сообщение
нет , это не корректно. но без этого не компилится. сразу выдает ошибку
А как вам удавалось в первом сообщении темы правильно объявить массив с названием имени запускаемого файла?

Решение: посмотреть и сделать по образцу.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.08.2018, 13:57
Помогаю со студенческими работами здесь

[Emu8086] Запуск из программы другой программы
Доброе утро, форумчане! Задача следующая: Есть Emu8086. Нужно написать программу, которая запускает другую программу (/путь/name.exe). ...

Запуск из программы другой программы с параметрами
Исходные данные: 1)ОС Linux ubuntu, xubuntu; 2)Есть некоторая простенькая написанная программка; 3)Есть авиасимулятор (игра), который...

Запуск программ из другой программы?
Можно ли как-то написать программу, которая запускает другие программы? К примеру, у меня написан ряд программ, код откомпилированн,...

Запуск функции другой программы
Как как программа может запустить функцию другой программы? Пояснение: //Программа функцию которой нужно запустить int f2(char*...

Программный запуск другой программы
Добрый день! В своей программе я должен запустить другую, довольно старую программу, написанную на фортране, которая выполняет...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru