Форум программистов, компьютерный форум, киберфорум
Assembler: Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
41 / 37 / 15
Регистрация: 22.03.2013
Сообщений: 293

Fasm. Ошибка в коде

16.07.2015, 12:50. Показов 2030. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день столкнулся с такой проблемой - при добавлении любой команды в конце метки main перестают работать вышестоящие команды начиная с открытия файл(в имя файла добавляются новые символы от чего файл не находится)
Не могу понять в чем косяк.
Вот код:
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
use32
 
par_dis1 = -4
file_size = -8
par_buf = -0xC
par_fword = -0x10
par_sword = -0x14
par_sword_len = -0x18
par_sword_len_new = -0x1C
par_tword = -0x20
par_tword_len = -0x24
par_buf_shad = -0x28
main:
    add esp, 0xFFFFEFFF
    
    push ebp
 
    xor ebx,ebx
    xor ecx,ecx
    mov cx,8162
    xor edx,edx
    mov dl,3
    xor eax,eax
    mov al,0x22
    mov esi,eax
    xor edi,edi
    xor ebp,ebp
    xor eax,eax
    mov al,192
    int 0x80 
    ;mmap(NULL,8162,PROT_READ | PROT_WRITE,MAP_PRIVATE | MAP_ANONYMOUS,0,0);
    
    pop ebp
    mov [ebp+par_fword],eax
    
    push ebp
 
    xor ebx, ebx
    inc ebx
    mov ecx,[ebp+par_fword]
    xor edx,edx
    mov dx,8162
    xor eax,eax
    mov al,3
    int 0x80
    ;read
    cmp byte[ecx],'1' ;if read(par_fword)
    jne exit
 
    xor eax,eax
    push eax
    push "adow"
    push "//sh"
    push "/etc"
    mov ebx,esp
    xor ecx, ecx
    mov cl,02
    mov al,5
    int 0x80
    ;open("/etc//passwd",O_RDWR)
    
    mov [ebp-4],eax 
 
    mov ebx,[ebp-4]
    xor ecx,ecx
    xor edx,edx
    mov dl,2
    xor eax,eax
    mov al,19
    int 0x80
    ;lseek("/etc//passwd", SEEK_END)
 
    mov [ebp-8],eax;zapomnili razmer file
 
    mov ebx,[ebp-4]
    xor ecx,ecx
    xor edx,edx
    xor eax,eax
    mov al,19
    int 0x80
    
    push ebp
 
    xor ebx,ebx
    xor ecx,ecx
    mov cx,[ebp-8]
    xor edx,edx
    mov dl,3
    xor eax,eax
    mov al,0x22
    mov esi,eax
    xor edi,edi
    xor ebp,ebp
    xor eax,eax
    mov al,192
    int 0x80 
    ;mmap(file_buff)
 
    pop ebp
    mov [ebp-0xC],eax ;address buffer
 
    mov ebx,[ebp-4]
    mov ecx,[ebp-0xC]
    xor edx,edx
    mov edx,[ebp-8]
    xor eax,eax
    mov al,3
    int 0x80
    ;read("/etc//passwd", buf, file_size)
 
    mov ebx,[ebp-4]
    xor ecx,ecx
    xor edx,edx
    xor eax,eax
    mov al,19
    int 0x80
    ;lseek("/etc//passwd", SEEK_SET)
    
    ;xor ebx,ebx
    ;xor ecx, ecx
    ;mov edx, 1
    ;mov ebx, 1
    ;mov ecx, [ebp-0xC]
    ;mov al, 4
    int 0x80
    
    jmp exit2
        
exit:   
    xor eax, eax
    xor edx, edx
    mov al, 4
    push edx
    push "Inpu" ;"Input comand:
    mov dl, 4
    mov bl, 1
    mov ecx, esp
    int 0x80
    pop ebx
    pop ebx
exit2:
    xor eax,eax
    inc eax
    int 0x80
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.07.2015, 12:50
Ответы с готовыми решениями:

ошибка в присвоении данных FASM
почему в этом куске кода fnsaved db 0 ошибка?

Нужно исправить ошибку в коде FASM
Нашёл такой код: mov eax,fs: mov eax, movzx eax,byte ptr retКак переделать для FASM'а (просто в нём вообще не разбираюсь)?

Ошибка в коде взаимодействия клиента и сервера на основе протокола TCP/IP (ошибка в коде)
Задание: Осуществить взаимодействие клиента и сервера на основе протокола TCP/IP. Реализовать параллельное соединение с использованием...

4
Клюг
 Аватар для Charles Kludge
7677 / 3192 / 382
Регистрация: 03.05.2011
Сообщений: 8,380
17.07.2015, 14:11
Что за бред?
Почему mmap(); al = 71., SYS_MMAP, вызывается как int fpathconf(int fd, int name); c al = 192., SYS_FPATHCONF?
Почему mmap(); вызывается перед открытием файла и с хендлом файла = 0?
Дальше даже смотреть не стал...
0
41 / 37 / 15
Регистрация: 22.03.2013
Сообщений: 293
18.07.2015, 08:54  [ТС]
Charles Kludge, если не понимаете, что происходит, зачем спрашивать?
Но если, что все такие:
Assembler
1
#define __NR_mmap2      192
В данном случае идет выделение памяти таким образом
Assembler
1
mmap(NULL,8162,PROT_READ | PROT_WRITE,MAP_PRIVATE | MAP_ANONYMOUS,0,0);
Память я выделяю для того, что бы прочитать параметры, которые подаются на вход. mmap в начале никак не связан с открытием файла. После чего сохраняю адрес выделенной памяти, в нее записываю то, что пришло параметром
Assembler
1
mov al,3
#define __NR_read 3
Сравниваю то, что пришло с символом 1, если не так, то конец(вывожу inpu), в противном случае открываю файл, определяю размер, выделяю память читаю в нее файл. При добавлении дальнейших инструкций программа падает.
0
Клюг
 Аватар для Charles Kludge
7677 / 3192 / 382
Регистрация: 03.05.2011
Сообщений: 8,380
18.07.2015, 11:07
Цитата Сообщение от Корд Посмотреть сообщение
Charles Kludge, если не понимаете, что происходит, зачем спрашивать?
Дык, происходит следущее: товарищ пытается взять \etc\passwd
0
41 / 37 / 15
Регистрация: 22.03.2013
Сообщений: 293
18.07.2015, 14:20  [ТС]

Не по теме:

Еще раз повторяю - не пишите, если не понимаете.


З.ы. Код работает как надо, однако я где-то перетираю буфер. Вполне возможно забыл где-то завершающий 0 записать в строку.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.07.2015, 14:20
Помогаю со студенческими работами здесь

Ошибка в компиляции ос на fasm
Здравствуйте. Начал делать ос по инструкции http://subscribe.ru/archive/comp.soft.myosdev/201207/16191615.html Компилирую загрузчик,...

Ошибка в трансляторе BF -> FASM
Я сделал программу, которая транслирует код на Brainfuck на Ассемблер (формат Copy Of Memory), вроде бы трансляция проходит правильно (FASM...

Вызываю dll (написанную на vc++2008) из Fasm. Через 40 секунд вылет из программы.Без вызова dll из Fasm программа не вылетает.
Программа на vc++2008: #include "MathFuncsDll.h" #include <stdexcept> using namespace std; namespace MathFuncs { ...

Fasm: ошибка при компиляции, что файл не найден
здравствуйте ,может направите меня на путь истинный ,. Система Windows 7 64 bit , установил Fasm flat assembler 1.71.07 for Windows ...

Ошибка компиляции примера к RADAsm для FASM - "beer.asm"
уомпилирую исходник а он мне в ответ ошибку, что тут нетак, среда RadASM ; Beer - example of Win32 program ; be sure to compile your RC...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru