K cemu je asm ... no jak bych to tak rekl ... jednou jsem potreboval delat nejakou operaci nad velmi velkymi nascannovanymi obrazky a protoze jsem zaroven potreboval udelat do skoly semestralku na asm, tak jsem to zkusil.
Vymyslel jsem genialni optimalizaci, kdy se kazda 8-bit hodnota nacitala do cpu jenom 2x (potrebovalo to data z dalsiho radku obrazku) a vsechno bylo v registrech, coz bylo vzhledem ke zname zoufale zprasenosti architektury i386 zcela na hranici moznosti. Nakonec se to nepovedlo kvuli stupidni implementaci instrukce MUL. Abych vyhovel zadani semestralky, naprasil jsem to tak, ze jsem vysel z toho sveho optimalizovaneho, ale vzdal jsem kazdou optimalizaci, ktera mi stala v ceste k funkcnimu ASM, bez snahy o reoptimalizaci. Tahle cunarna byla stale 2x rychlejsi, nez totez napsane v gcc!
Uvazim-li, ze to jednu sadu obrazku delalo cca hodinu, tak uz je dvojnasobne zrychleni znat a kdyby to byl CPU s normalnim poctem registru, tak by ten kousek kodu byl napsany za hodinu.
Jsou okamziky, kdy ma ASM smysl i dnes.

