Escolar Documentos
Profissional Documentos
Cultura Documentos
Ciro Ceissler
clac@cin.ufpe.br / ciro.ceissler@gmail.com
Assembly é uma linguagem de baixo
nível, chamada freqüentemente de
“linguagem de montagem”
Assembly
A linguagem Assembly é atrelada à
arquitetura de uma certa CPU, ou seja,
ela depende completamente do hardware
Cada família de processador tem sua
própria linguagem assembly (Ex. X86,
ARM, SPARC, MIPS)
Por essa razão Assembly não é uma
linguagem portável, ao contrário da
maioria das linguagens de alto nível
Assembly
Antes do assembly:
Assembly
As primeiras linguagens Assembly
surgiram na década de 50, na chamada
segunda geração das linguagens de
programação
Assembly - História
Assembly foi muito usada para várias
aplicações até os anos 80, quando foi
substituída pelas linguagens de alto nível
Assembly - História
Atualmente Assembly é usada para
manipulação direta de hardware e para
sistemas que necessitem de performance
crítica
Assembly - História
A linguagem Assembly é de baixo nível,
porém ainda precisa ser transformada na
linguagem que a máquina entende
Assembly - Assembler
Exemplo:
Assembly - Assembler
Byte, Word e Dword são blocos de dados
básicos. O processador trabalha com o
tamanho de dados adequados para
executar as instruções
Assembly - Fundamentos
Em Assembly é comum representar os
números na forma hexadecimal. Isso
acontece porque é interessante visualizar
o número na forma de dados
Assembly - Fundamentos
Um algarismo hexadecimal pode ser
representado por quatro algarismos
binários
Assembly - Fundamentos
Binário Hexa Decimal Tipo
10000000 80 128 byte
10000000000000
8001 32.769 word
01
11111111111111
11
FFFF 65.535 word
11111111111111
11111111111111
FFFFFFFF 4.294.967. dword
1111 295
Assembly - Fundamentos
Registradoressão áreas especiais dentro
do processador que são mais rápidas que
operandos de memória.
Assembly - Registradores
São eles:
EAX, EBX, ECX, EDX, ESI, EDI, ESP, EBP
Assembly - Registradores
Assembly - Registradores
Nos registradores de uso geral (Exceto
ESI e EDI) é permitido usar três
modos de acesso diferentes, ilustrados
pela figura abaixo:
EAX -> Chamado de “Acumulador”,
geralmente é usado para operações
aritméticas e para guardar resultados
Assembly - Registradores
ECX -> Chamado de “Contador”, como o
nome já diz é usado como contador,
principalmente para controlar loops
Assembly - Registradores
ESI e EDI -> Respectivamente “Source
Index” e “Destination Index”, são menos
usados do que os registradores descritos
anteriormente. Geralmente usa-se ESI e
EDI para movimentação de dados, com
ESI guardando o endereço fonte de uma
variável e EDI guardando o endereço
destino. Não podem ser acessados em
nível de Byte.
Assembly - Registradores
ESP e EBP -> Respectivamente “Stack
Pointer” e “Base Pointer”, só devem ser
usados para manipulação da pilha. O
Registrador ESP guarda a referência para
o topo da pilha, enquanto o registrador
EBP é usado para “andar” pela pilha
Assembly - Registradores
Entre os registradores que não são de uso
geral, existe um registrador muito
relevante para o programador, o
registrador flags
Assembly - Registradores
Assembly - Registradores
O => Overflow
D => Direction
I => Interrupt Enable
T => Trap
S => Signal
Assembly - Registradores
Z => Zero
A => Auxiliar Carry
P => Parity
C => Carry
Todos os programas fazem uso da pilha
em tempo de execução, porém nas
linguagens de alto nível não é preciso se
preocupar com o funcionamento da pilha
Assembly - Pilha
A pilha é uma área de dados existente na
memória em tempo de execução, na qual
seu programa pode armazenar dados
temporariamente
Assembly - Pilha
As principais funcionalidades da pilha são:
Assembly - Pilha
Movimentação de dados:
Assembly - Instruções
Intel AT&T
Assembly - Instruções
Instrução de soma:
Assembly - Instruções
Instrução de subtração:
Assembly - Instruções
Instruções de operações lógicas:
Assembly - Instruções
Instrução de comparação:
Assembly - Instruções
Instruções de jump:
“Pulo” incondicional:
Assembly - Instruções
“Pulo” condicional:
Assembly - Instruções
Instruções de manipulação da pilha:
Assembly - Instruções
O código Assembly é dividido em seções.
As principais seções no Linux são:
Assembly - Seções
- Exemplo:
section .data
mensagem: db 'Hello world!'
msglength: equ 12
Assembly - Seções
- section .bss -> É a seção usada para
declarar as variáveis do programa
- Exemplo:
section .bss
nomearq: resb 230 ;Reserva 230
bytes
numero: resb 1 ;Reserva 1 byte
array: resw 10 ;Reserva 10 words
Assembly - Seções
- section .text -> Essa é a seção onde o código do
programa é escrito
- Exemplo:
section .text
global _start
_start: . . .
. . .
. . .
Assembly - Seções
Interrupções são chamadas ao
processador requisitando um serviço
Assembly - Interrupções
Quando isso acontece, o processador
salva o processo atual e executa a rotina
daquela interrupção
Assembly - Interrupções
Para se chamar uma interrupção no Linux,
é feito o seguinte processo:
- Coloca-se o número da interrupção no
registrador EAX
- Coloca-se os argumentos requeridos
pela interrupção nos devidos registradores
- Chama-se a interrupção
O resultado geralmente será retornado
em EAX
Assembly - Interrupções
- Exemplo (Sintaxe Intel):
mov eax,1 ; Interrupção Exit
mov ebx,0 ; Argumento em EBX
int 80h ; Chamada da interrupção
Assembly - Interrupções
Um programa é constituido por várias
regiões de memória.
◦ Pilha
◦ Heap
◦ Código
◦ Dados
Assembly – Organização do
Programa
Hello World (Sintaxe Intel)
section .data
hello: db 'Hello world!',10 ; A string 'Hello World!‘ e um linefeed
helloLenght: equ $-hello ; Tamanho da string hello
section .text
global _start
_start:
mov eax,4 ; Interrupção de escrita (sys_write)
mov ebx,1 ; Argumento que indica modo de escrita
mov ecx,hello ; Argumento que indica o endereço da string
mov edx,helloLenght ; Argumento que indica o tamanho da string
int 80h ; Chamada da interrupção
mov eax,1 ; Interrupção exit (sys_exit)
mov ebx,0 ; Argumento da interrupção
int 80h ; Chamada da interrupção
Assembly - Exemplo
Hello World (Sintaxe AT&T)
.data hello:
.string "Hello World!\n"
.text
.globl main
main:
mov $4,%eax
mov $1,%ebx
mov $hello,%ecx
mov $13,%edx
int $0x80
mov $1,%eax
mov $0,%ebx
int $0x80
Assembly - Exemplo
www.cin.ufpe.br/~lab3
Assembly – Referências