Passa al contingut principal

Programació en assemblador

Com em torna a picar el cuquet de programar en assemblador (asm a partir d'ara), i sempre la gent em preguta per què? quina utilitat té... doncs bé, la justificació teòrica (dels llibres) què donen, és què tens un major control de la màquina, pots optimitzar codi... Fent una analogia mecànica, sempre comparen un canvi de marxes manual (asm) i  un automàtic (C++),  no vull ni pensar que seria el VB.NET actual... potser conduir amb la ment.
Anem a posar un exemple, si tinguem este programa en C:


#include <stdio.h>
void main(){
     int i;
     int vector[10];
     for(i=0;i<=9;i++) vector[i]=0;
}

fem una compilació per veure que s'executa realment (gcc -S) i obtenim el següent codi en asm:
        .file   "prova.c"
        .text
.globl main
        .type   main, @function
main:
        pushl   %ebp
        movl    %esp, %ebp
        subl    $48, %esp
        movl    $0, -4(%ebp)
        jmp     .L2
.L3:
        movl    -4(%ebp), %eax
        movl    $0, -44(%ebp,%eax,4)
        addl    $1, -4(%ebp)
.L2:
        cmpl    $9, -4(%ebp)
        jle     .L3
        leave
        ret


Si observerm, el codi de la copia del vector (inicialitzar a 0),  es fa entre .L3, i  .L2. Realment podriem fer-ho amb menys instruccions, per exemple:
   lea edi, vector
   mov ecx,9
   xor eax,eax
   repsz stosd


Possiblement no siga un bon exemple per què simplement ens estalviariem una instrucció o dos ;), però per a certes coses, no és "recomanat", si no imprescindible, sobretot la interacció amb els hardware. Realment es fa farragosa amb llenguatges com C, quan és molt senzilla en asm. Encara que la millor cosa és juntar-les les dos. Fer parts no crítiques en llenguatges d'alt nivell, i parts crítiques (que necessiten optimització, d'accés al hardware...) en asm. I després mesclar-ho tot.

Un ús curiós és el shellcode, que s'usa en programes maliciosos, per executar instruccions que no deurien de ser executades.  Es passa el shellcode com a paràmetre i es fa que "d'alguna manera" salte l'execució del programa del fil normal fins al paràmetre. Eixe codi pot obrir un shell, o qualsevol altra cosa que "considerem convenient". Llàstima que vaig pedre el meu PFC, sóc un desastre, però tractava sobre el tema, a veure si em torne a reenganxar ;).


Comentaris

Entrades populars d'aquest blog

TDDs + reutilització d'objectes en Visual Studio 2012

Doncs això, mai m'he mostrat partidari de cap metodologia de programació, ni tan sols de la programació orientada a objectes... però deu ser que em faig major ;) Anem a matar en un post dos pardals d'un tir. Anem a gastar una de les bases de les metodologies àgils (en realitat no té per què, es pot emprar en qualsevol metodologia) i anem a començar a veure com fer codi "multiplataforma". Anem a gastar Visual Studio 2012. Creem una solució de Portable Class Library (en C#): Creem una nova classe, Dau: namespace RollDice {     public class Dau     {     } Sense cap mètode. Per què sense cap mètode? Ahí està la gràcia dels TDD (Test Driven Development, Desenvolupament Orientat a Test). Anirem omplint la classe segons fallen els tests. Ara anem a afegir una nova solució, què serà de test c#: Ens crearà una classe de test buida, li canviarem el namespace per a que siga el mateix que la classe dau: [TestClass]     public class testDau     {          [TestMethod

Hui he vist la por als ulls

Estic trist ,molt trist.Vinc de la manifestació del 9 d'octubre i, puc dir que he vist moltes coses, però el que no he vist és democràcia. He vist moltes banderes d'Espanya i blaveres dels increpadors, però no he vist democràcia. Les seues paraules eren "ven aquí fuera", "te voy a meter esa bandera por el coño", etc. He vist com manifestants fàcilment identificables entraven a provocar i la Policia Nacional no feia res per evitar-ho, però no he vist democràcia. He vist com un pare utilitzava al seu fill per provocar, i amb actitud agresiva (inclús anava a pegar-li manotada a un), però no he vist democràcia. He vist com es permetia una manifestació no autoritzada que podia alterar l'ordre públic. Segons la sacrosanta Constitució Espanyola, això és il·legal, però no he vist democràcia. He vist com la Policia Nacional tractava respectuosament, i inclús es coordinava amb els feixites. A nosaltres ens miraven amb cara de fàstic, però no he vist democràc

Reciclant un vell portàtil (i 3)

O també podria titular-se, la primera aplicació en Android. Crec que vaig a deixar d'intentar reciclar este ordinador, no pot amb l'eclipse, he intentat fer esta aplicació i m'ha costat déu i ajuda. Provaré a fer coses que necessiten entorn gràfic en un altre ordinador. Quan comence la part de servidor, si que podré gastar-lo de nou, ja que node.js (Recomanat pel meu amic Jaume) és molt lleuger, i amb la llibreta que duu windows es podrà fer els programes de sobra ;). Bo, la primera aplicació l'he modificada un poc de l'anterior (l'aspecte), i l'he deixat com en la figura. Simplement he posat un botó, i dos textView. No vaig a entrar en detalls de com es fa, de posar noms adients ni res per l'estil, ja que és una aplicació menuda i de prova. l'objectiu serà que en el textView2 (que no es veu, està davall del textView1) aparega un missatge "has apretat el botó" en el moment que apretes el botó. Anirem al fitxer principal en java, en el