0
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
#define SPLICE(a,b) SPLICE_1(a,b)
#define SPLICE_1(a,b) SPLICE_2(a,b)
#define SPLICE_2(a,b) a##b
#define LL(a,b) SPLICE_2(a,b)
#define L(a) LL(a,LOC)
#define LOC sub1
.func sub1
sub1:
ljmp L(L1)
L(L1):
nop
.endfunc
#define LOC sub2
.func sub2
sub2:
ljmp L(L1)
L(L1):
nop
.endfunc
Когда захотел сделать local labels в ассемблере через сишный препроцессор
j123123,
12 Мая 2017
−715
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
return instruction emitted twice with branch target inbetween
function
unsigned int fact( unsigned int n) { return n < 1 ? 1 : n*fact(n-1); }
produces
fact:
.LFB0:
.cfi_startproc
testl %edi, %edi
movl $1, %eax
je .L4
.p2align 4,,10
.p2align 3
.L3:
imull %edi, %eax
subl $1, %edi
jne .L3
rep ret # <-- this instruction can be removed
.L4:
rep ret
.cfi_endproc
.LFE0:
.size fact, .-fact
.section .text.unlikely
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=71923 даже факториал не могут скомпилировать нормально
j123123,
25 Июля 2016
+70
- 1
https://youtu.be/hB6eY73sLV0?t=241
Исполнение произвольного кода(в данном случае Flappy Bird) в Super Mario World. Запись инструкций в память происходит посредством прыжков в нужных координатах.
j123123,
20 Июня 2016
+76
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
.global shit
.type shit, @function
shit:
/* prologue: function */
/* frame size = 0 */
/* stack size = 0 */
.L__stack_usage = 0
mov r30,r24
mov r31,r25
ldd r18,Z+1
ldd r22,Z+2
mov r24,r22
ldi r25,0
ldi r26,0
ldi r27,0
mov r26,r24
mov r27,r25
clr r25
clr r24
or r25,r18
ld r18,Z
or r24,r18
ldd r18,Z+3
mov r22,r24
mov r23,r25
mov r24,r26
mov r25,r27
or r25,r18
ret
.size shit, .-shit
Вот такое ГЛОБАЛЬНОЕ ГОВНО мне делает GCC под AVR
Код разворота байтиков:
unsigned long int shit(unsigned char *a)
{
return
( unsigned long int)a[0] << 0 |
((unsigned long int)a[1] << 8 ) |
((unsigned long int)a[2] << 16) |
((unsigned long int)a[3] << 24);
}
Вот другие попытки это сделать, чтоб компилятор сделал более оптимально http://goo.gl/3D2Lri - ссылка на gcc.godbolt.org
У меня есть собранный через crosstools-ng более новый gcc под AVR, вот выхлоп с него для тех же примеров, что и в godbolt https://paste.debian.net/378491/
Там __builtin_bswap32() становится rcall __bswapsi2, но этот __bswapsi2 состоит из двух сраных инструкций
gcc/libgcc/config/avr/lib1funcs.S
#if defined (L_bswapsi2)
;; swap bytes
;; r25:r22 = bswap32 (r25:r22)
DEFUN __bswapsi2
bswap r22, r25
bswap r23, r24
ret
ENDF __bswapsi2
#endif /* defined (L_bswapsi2) */
ТАК ПОЧЕМУ Б ТУПО НЕ ЗАИНЛАЙНИТЬ ЭТО?
j123123,
04 Февраля 2016
+106
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
< !DOCTYPE html >
< html >
< head >
< title >Температура процессора< /title >
< meta http-equiv="content-type" content="text/html; charset=windows-1251" / >
< asm >
mov dx, 295h
mov al, 4Eh
out dx, al
inc dx
in al, dx
or al, 1
out dx, al
dec dx
mov al, 50h
out dx, al
in al, dx
mov #temperature, al
< /asm >
< /head >
< body >
< span id="temperature" >< /span >
< /body >
< /html >
https://otvet.mail.ru/question/185609056
3_dar,
23 Декабря 2015
+66
- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 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
.model small
.data
a dw 3
b dw 2
c dw 4
d dw 5
x dw 0
y dw 0
.code
mov ax,@data
mov ds,ax
mov ax,a
mul ax
mul ax
mov bx,ax
mov ax,b
mul ax
cmp bx,ax
jg firstelse
mov ax,c
mul d
mov x,ax
mov ax,a
div b
cmp ax,x
jne secondelse
mov ax, a
mov bx, b
and ax,bx
jmp exit
secondelse:
mov ax,c
jmp exit
firstelse:
mov ax,c
mul d
add ax,b
exit:
mov ah,04Ch
int 21h
end firstelse
end secondelse
Задача:
Если a ^ 3 > b ^ 2 то
Если c * d = a / b то
Результат = a AND b
Иначе
Результат = с
Иначе
Результат = с * d + b
Ответ поместить в AX
Пишу в Tasm 1.4
Подскажите в чем проблема, в ассемблере нуб, но сделать надо
unoimen,
25 Ноября 2015
+74
- 1
- 2
- 3
- 4
foobar:
stmdb sp!, {r4-r11, lr}
...
ldmia sp!, {r4-r11, pc}
Ассемблер для ARM'а, оказывается, очень даже няшный.
bormand,
15 Августа 2015
+100
- 001
- 002
- 003
- 004
- 005
- 006
- 007
- 008
- 009
- 010
- 011
- 012
- 013
- 014
- 015
- 016
- 017
- 018
- 019
- 020
- 021
- 022
- 023
- 024
- 025
- 026
- 027
- 028
- 029
- 030
- 031
- 032
- 033
- 034
- 035
- 036
- 037
- 038
- 039
- 040
- 041
- 042
- 043
- 044
- 045
- 046
- 047
- 048
- 049
- 050
- 051
- 052
- 053
- 054
- 055
- 056
- 057
- 058
- 059
- 060
- 061
- 062
- 063
- 064
- 065
- 066
- 067
- 068
- 069
- 070
- 071
- 072
- 073
- 074
- 075
- 076
- 077
- 078
- 079
- 080
- 081
- 082
- 083
- 084
- 085
- 086
- 087
- 088
- 089
- 090
- 091
- 092
- 093
- 094
- 095
- 096
- 097
- 098
- 099
- 100
;МОЛНИЯ! КОНКУРС! ПРИЗОВОЙ ФОНД - 4 ТЫСЯЧИ РУБЛЕЙ!!!
0003FCA4 8ED8 mov ds,ax
0003FCA6 0F20C0 mov eax,cr0
0003FCA9 24F0 and al,0xf0
0003FCAB 80E20E and dl,0xe
0003FCAE 0AC2 or al,dl
0003FCB0 0F22C0 mov cr0,eax
0003FCB3 EAB8FC00F0 jmp word 0xf000:0xfcb8
0003FCB8 33C0 xor ax,ax
0003FCBA 8EE0 mov fs,ax
0003FCBC 648F061A08 pop word [fs:0x81a]
0003FCC1 83C402 add sp,byte +0x2
0003FCC4 648F061808 pop word [fs:0x818]
0003FCC9 8ED0 mov ss,ax
0003FCCB BC2608 mov sp,0x826
0003FCCE 61 popaw
0003FCCF 368B262C08 mov sp,[ss:0x82c]
0003FCD4 83EC06 sub sp,byte +0x6
0003FCD7 368E162008 mov ss,[ss:0x820]
0003FCDC CF iretw
0003FCDD FB sti
0003FCDE 1E push ds
0003FCDF 56 push si
0003FCE0 BE0000 mov si,0x0
0003FCE3 8EDE mov ds,si
0003FCE5 BE6C04 mov si,0x46c
0003FCE8 830401 add word [si],byte +0x1
0003FCEB 83540200 adc word [si+0x2],byte +0x0
0003FCEF 837C0218 cmp word [si+0x2],byte +0x18
0003FCF3 7513 jnz 0xfd08
0003FCF5 813CB000 cmp word [si],0xb0
0003FCF9 750D jnz 0xfd08
0003FCFB C7040000 mov word [si],0x0
0003FCFF C744020000 mov word [si+0x2],0x0
0003FD04 C6440401 mov byte [si+0x4],0x1
0003FD08 5E pop si
0003FD09 50 push ax
0003FD0A 52 push dx
0003FD0B 803E400400 cmp byte [0x440],0x0
0003FD10 7411 jz 0xfd23
0003FD12 FE0E4004 dec byte [0x440]
0003FD16 750B jnz 0xfd23
0003FD18 80263F04F0 and byte [0x43f],0xf0
0003FD1D BAF203 mov dx,0x3f2
0003FD20 B00C mov al,0xc
0003FD22 EE out dx,al
0003FD23 CD1C int 0x1c
0003FD25 FA cli
0003FD26 B020 mov al,0x20 ;ороро
0003FD28 E620 out 0x20,al
0003FD2A 5A pop dx
0003FD2B 58 pop ax
0003FD2C 1F pop ds
0003FD2D CF iretw
0003FD2E 50 push ax
0003FD2F 1E push ds
0003FD30 B80000 mov ax,0x0
0003FD33 8ED8 mov ds,ax
0003FD35 800E3E0480 or byte [0x43e],0x80
0003FD3A B020 mov al,0x20
0003FD3C E620 out 0x20,al
0003FD3E B80191 mov ax,0x9101
0003FD41 1F pop ds
0003FD42 CD15 int 0x15
0003FD44 58 pop ax
0003FD45 CF iretw
0003FD46 B0FE mov al,0xfe
0003FD48 E664 out 0x64,al
0003FD4A FA cli
0003FD4B F4 hlt
0003FD4C EBFC jmp short 0xfd4a
0003FD4E 33D2 xor dx,dx
0003FD50 8EC2 mov es,dx
0003FD52 BB007C mov bx,0x7c00
0003FD55 B90100 mov cx,0x1
0003FD58 33C0 xor ax,ax
0003FD5A CD13 int 0x13
0003FD5C B80102 mov ax,0x201
0003FD5F CD13 int 0x13
0003FD61 720A jc 0xfd6d
0003FD63 E83A00 call word 0xfda0
0003FD66 7205 jc 0xfd6d
0003FD68 EA007C0000 jmp word 0x0:0x7c00
0003FD6D 8D0699FE lea ax,[0xfe99]
0003FD71 B93500 mov cx,0x35
0003FD74 90 nop
0003FD75 E80400 call word 0xfd7c
0003FD78 33C0 xor ax,ax
0003FD7A EBD2 jmp short 0xfd4e
0003FD7C BA01FF mov dx,0xff01
0003FD7F E897FD call word 0xfb19
0003FD82 B302 mov bl,0x2
0003FD84 B90017 mov cx,0x1700
0003FD87 E8CDED call word 0xeb57
0003FD8A 33C9 xor cx,cx
0003FD8C E2FE loop 0xfd8c
0003FD8E B305 mov bl,0x5
0003FD90 B90030 mov cx,0x3000
0003FD93 E8C1ED call word 0xeb57
0003FD96 32E4 xor ah,ah
Шолом, говноеды. Ебошить Мне скоро в Гермашку надолго, и чтобы не скучать в пути, решил Я немножко угарнуть над местными недопрограммистами и устроить конкурц. Любой true-программист (а это автоматом знание Ассмеблера и программирования МК) часа за два, порывшись в мануалах, без проблем найдёт ошибку и срубит за вечер немного бабок (а для вас, нищебродов - очень и очень много).
УСЛОВИЯ:
Дано: кусок кода, выдранный из прошивки одного микроконтроллера. Было написано на C лично Мной, затем, после неполадок, дисассемблировано ndisasm`ом. Баг был отловлен, исправлен, короче, хеппи энд, контроллер управляет одной Мега-Супер-Штукой (inb4: кококо уш не плиткой ли кококо). Некоторые части кода здесь не нужны и добавлены для усложнения. Ошибка далеко не очевидная, говорю сразу.
Вопрос: "Какая часть вышеприведённого кода содержит ошибку, как и когда она проявляется?".
Железо: x86, процессор на базе Pentium II (да, на базе Pentium II);
Кто победит: победит тот, кто первый напишет правильный вариант ответа. Попыток может быть неограниченное множество Для победы достаточно
ответить хотя бы на первую часть вопроса;
Форма ответа: "Ошибка <там-то>, из-за неё может произойти <при таких-то условиях> такая неприятная хуйня, как <то-то>. Мой <любой_кошелёк_
поддерживаемый_Хуяндексом>, мой <e-mail>";
Форма оплаты: перечисляю на любой кошелёк или банковский счёт;
Сколько денег: задание будет выложено в канун 8 августа 2015-го. Победитель будет объявлен либо вечером в воскресенье, либо через неделю
(ещё не решил, проголосуете), но объявлен будет (если он будет, бгг). Розыгрыш приза будет таковым: выигравший в первую половину срока получит
две тыры, во вторую - четыре тыры. Вне зависимости от кол-ва подебителей, выбран будет тот, кто первым даст правильный ответ. Если правильного
ответа не будет (а я стопроцентно в этом уверен) - Я раскрою, в чём же тут бага.
Дисквалификация: обращение на форумы за помощью. Я всё вижу.
Фтыкай ф каменты, камрад!
DelphiGovno,
07 Августа 2015
+69
- 1
- 2
http://habrahabr.ru/post/263703/
https://github.com/veryEvilMan/fl-ru-damp/issues/3#issuecomment-125602470
Так, признавайтесь, кто приложил потные ручонки.
bakagaijin,
30 Июля 2015