• Články
  • Zprávičky
  • Fórum
  • Podpořte Root
  • Školení
  • Galerie
  • Blogy
  • Knihy
  • Jak na Linux
  • Zdroják
    • Hledat

    Root.cz  »  Témata

    Assembler

    31–60 / 161
    První strana Předchozí strana 1 2 3 4 5 6 Následující strana Poslední strana
    • Od grafické karty VGA k vyšším rozlišením i většímu množství barev

      Stará VGA grafická karta do sběrnice ISA
      Už jsme se setkali s problematikou grafického subsystému. Dnes si ukážeme využití VBE (VESA BIOS Extension) pro nastavení grafických režimů s vyšším rozlišením a/nebo počtem barev, než nabízel standard VGA.
      Pavel Tišnovský
      10. 6. 2025
      Doba čtení: 68 minut
    • Problematika ukazatelů v překladačích jazyka C pro systém DOS

      Jaký byl největší problém systému DOS? Neexistence pokročilejších funkcí, nutnost explicitní konfigurace hardwaru, či něco jiného? Z pohledu programátorů se jednalo o práci s pamětí organizované systémem segment:offset.
      Pavel Tišnovský
      3. 6. 2025
      Doba čtení: 41 minut

    • Volání subrutin naprogramovaných v assembleru z jazyka Python: knihovna PeachPy

      Dnes si představíme knihovnu nazvanou PeachPy, která umožňuje realizovat kooperaci mezi skripty v Pythonu a strojovým kódem zapsaným formou strojových instrukcí. PeachPy je v praxi relativně často používána pro „místní“ optimalizace.
      Pavel Tišnovský
      29. 5. 2025
      Doba čtení: 28 minut
    • Volání subrutin naprogramovaných v assembleru z jazyka Python

      Už jsme se setkali s propojením Pythonu s nativními knihovnami naprogramovanými (například) v jazyku C. Dnes si ukážeme jeden z alternativních způsobů, kterým lze z Pythonu volat podprogramy (subrutiny, funkce) v assembleru.
      Pavel Tišnovský
      20. 5. 2025
      Doba čtení: 24 minut
    • Překladače na platformě IBM PC: od assembleru k C

      Prozatím jsme se zaměřili na assembler. Proč se však více nepoužívaly překladače vyšších programovacích jazyků? Dnes se na tuto otázku pokusíme částečně odpovědět otestováním několika dobových překladačů jazyka C.
      Pavel Tišnovský
      13. 5. 2025
      Doba čtení: 38 minut

    • Rozšíření instrukční sady AVX a programy v assembleru

      Dnes si ukážeme základy práce s instrukcemi AVX v assembleru, konkrétně v Netwide Assembleru běžícího v Linuxu. Samotné AVX (Advanced Vector Extensions) rozšiřuje možnosti vektorových instrukcí na x86 i x86–64.
      Pavel Tišnovský
      15. 4. 2025
      Doba čtení: 72 minut
    • Rozšíření instrukční sady SSE2 v programech psaných v assembleru (dokončení)

      Na předchozí dvojici článků o rozšíření instrukční sady SSE2 dnes navážeme. Popíšeme si zbývající instrukce ze sady SSE2, které slouží pro operace prokládání prvků, extrakci či naopak spojování prvků vektorů a podobně.
      Pavel Tišnovský
      8. 4. 2025
      Doba čtení: 70 minut
    • Rozšíření instrukční sady SSE2 (2. část)

      Dnes si popíšeme a zejména otestujeme vybrané instrukce ze sady SSE2. Řekneme si, jaký je rozdíl mezi trojicí PAND, ANDNPS a ANDPD, způsob provedení bitových a bajtových posunů, ale i specifické vlastnosti vybraných konverzních instrukcí.
      Pavel Tišnovský
      27. 3. 2025
      Doba čtení: 70 minut
    • Instrukční sady SIMD a automatické vektorizace prováděné překladačem GCC (3)

      Dnes se budeme zabývat vektorizací smyček, v nichž se zpracovávají pole (vektory), což vyžaduje instrukce SSE2 nebo AVX. Důležité bude taktéž zjištění, jak je vektorizován přístup k prvkům pole s volitelným krokem (stride).
      Pavel Tišnovský
      25. 3. 2025
      Doba čtení: 40 minut
    • Instrukční sady SIMD a automatické vektorizace prováděné překladačem GCC (2)

      Na úvodní článek o automatických vektorizacích prováděných překladači dnes navážeme. Opět se zaměříme na autovektorizace prováděné překladačem GCC, dnes si ale otestujeme poněkud komplikovanější funkce, které se mají optimalizovat.
      Pavel Tišnovský
      20. 3. 2025
      Doba čtení: 30 minut
    • Od instrukční sady SSE k sadě SSE2

      Proč se většina nově přidaných instrukcí SSE omezuje na práci s hodnotami typu single, když je mnoho aplikací založených na celočíselných datech nebo naopak používá typ double? Odpovědí byla instrukční sada SSE2.
      Pavel Tišnovský
      13. 3. 2025
      Doba čtení: 68 minut
    • Pokročilejší SSE operace: přeskupení, promíchání a rozbalování prvků vektorů

      Dokončíme popis rozšíření instrukční sady SSE. Ukážeme si některé netriviální operace, které je možné provádět se skaláry a především s vektory. Jedná se o konverzní operace a taktéž o rozbalování a zabalování prvků vektorů.
      Pavel Tišnovský
      11. 3. 2025
      Doba čtení: 66 minut
    • SIMD instrukce v rozšíření SSE (2. část)

      Popíšeme si zbylé instrukce pro provádění numerických výpočtů. Také se zmíníme o instrukci pro porovnání prvků vektorů, která má celkem osm různých variant. A nezapomeneme ani na problematiku nekonečných hodnot a hodnot NaN.
      Pavel Tišnovský
      4. 3. 2025
      Doba čtení: 63 minut
    • Programovatelné IO na mikrořadičích RP2040: komunikace s PIO a ovládání PIO

      Raspberry Pi Pico s řadičem RP2040
      Ukážeme si základní způsoby komunikace hlavního programu běžícího na mikrořadiči s PIO programy. Pro tyto účely se používají fronty (FIFO) a vstupní i výstupní posuvné registry.
      Pavel Tišnovský
      27. 2. 2025
      Doba čtení: 30 minut
    • SIMD instrukce v rozšíření SSE

      Po úspěšném a navíc i relativně bezproblémovém zavedení rozšíření MMX vzniklo u konkurence (AMD) rozšíření 3DNow!. To sice nebylo příliš populární, ovšem jednalo se o první krok k rozšíření nazvanému SSE (Streaming SIMD Extension).
      Pavel Tišnovský
      25. 2. 2025
      Doba čtení: 64 minut
    • SIMD instrukce na 80×86: dokončení popisu MMX, instrukce 3DNow!

      Intel microprocessor Pentium MMX 233 s architekturou P5 (P55C)
      Dnes si popíšeme zbylé MMX instrukce a většinu instrukcí použijeme v příkladech. Také si popíšeme instrukční sadu 3DNow! společnosti AMD. Ta nebyla přímou konkurencí MMX, ale spíše první vlaštovkou vedoucí k SSE a AVX.
      Pavel Tišnovský
      18. 2. 2025
      Doba čtení: 67 minut
    • Programovatelné IO na mikrořadičích RP2040 – praktické použití

      Raspberry Pi Pico s řadičem RP2040
      Na úvodní článek o PIO na mikrořadičích Raspberry Pi Pico dnes navážeme. Pokusíme se propojit znalosti o PIO (interní architektura, způsob propojení s mikrořadičem i s GPIO, instrukční soubor) s vlastnostmi MicroPythonu.
      Pavel Tišnovský
      13. 2. 2025
      Doba čtení: 27 minut
    • SIMD instrukce na platformě 80×86: instrukční sada MMX

      Intel microprocessor Pentium MMX 233 s architekturou P5 (P55C)
      Navážeme na článek o vektorových instrukcích na platformě 80×86. Popíšeme si další instrukce MMX, konkrétně všechny aritmetické instrukce, logické instrukce i instrukci, která kombinuje násobení prvků vektorů s jejich součtem.
      Pavel Tišnovský
      11. 2. 2025
      Doba čtení: 66 minut
    • Programovatelné IO na mikrořadičích RP2040 v Raspberry Pi Pico

      Raspberry Pi Pico s řadičem RP2040
      Dnes se seznámíme s unikátní vlastností Raspberry Pi Pico. Tyto jednodeskové mikropočítače obsahují PIO (Programmable IO), což jsou bloky ovládající vstupně-výstupní piny (GPIO). Ty se chovají jako samostatně programovatelné procesory.
      Pavel Tišnovský
      6. 2. 2025
      Doba čtení: 23 minut
    • SIMD instrukce na platformě 80×86: nepřímý důsledek platnosti Mooreova zákona

      Intel microprocessor Pentium MMX 233 s architekturou P5 (P55C)
      Začneme se seznamovat se SIMD instrukcemi pro platformu 80×86, které jsou souhrnně nazývány, i když ne zcela přesně, vektorové instrukce. První na řadě je technologie MMX.
      Pavel Tišnovský
      4. 2. 2025
      Doba čtení: 69 minut
    • Matematické koprocesory na platformě x86: vše se komplikuje

      Práce s hodnotami s plovoucí řádovou čárkou sice může vypadat jednoduše, ovšem není tomu tak, protože se musí pracovat s nekonečny, hodnotami NaN atd. Navíc musí FPU spolupracovat s mikroprocesorem.
      Pavel Tišnovský
      28. 1. 2025
      Doba čtení: 65 minut
    • Matematické koprocesory na platformě 80×86 prakticky

      Na praktických příkladech si ověříme základní funkce poskytované matematickým koprocesorem Intel 8087, na který navazuje řada čipů 80287 a 80387. Posléze se tyto funkce staly přímo součástí hlavního mikroprocesoru.
      Pavel Tišnovský
      21. 1. 2025
      Doba čtení: 61 minut
    • Matematické koprocesory na 80×86 pro výpočty s plovoucí řádovou čárkou

      Nedílnou součástí prakticky všech procesorů je modul pro operace s plovoucí řádovou čárkou. Na platformě IBM PC se jednalo o řadu matematických koprocesorů označovaných čísly 8087, 80287, 80387 a (nepřesně) 80487.
      Pavel Tišnovský
      14. 1. 2025
      Doba čtení: 57 minut
    • Nové vlastnosti čipů 80386: stránkování a virtuální režim 8086

      Seznámíme se s dvěma technologiemi, které byly součástí mikroprocesoru Intel 80386. Tento v několika ohledech přelomový čip totiž kromě dalších vylepšení nabízel možnost stránkování (paging) a nový virtuální režim.
      Pavel Tišnovský
      7. 1. 2025
      Doba čtení: 57 minut
    • Od reálného režimu k režimu chráněnému na procesorech 80286 a 80386 (2.část)

      Přechod do chráněného režimu (a zpět) na mikroprocesorech Intel se podobá složitému rituálu. Všechny operace je nutné vykonat v určitém pořadí a naslepo: bez možnosti ladění nebo sledování činnosti PC.
      Pavel Tišnovský
      31. 12. 2024
      Doba čtení: 63 minut
    • Od reálného režimu k režimu chráněnému na 80286 a 80386

      Seznámíme se s vlastnostmi čipů 80286 a 80386, které souvisejí s reálným režimem, nereálným (unreal) režimem a režimem chráněným. Zabývat se budeme cachí s deskriptory segmentů, která se projevuje i v reálném režimu.
      Pavel Tišnovský
      17. 12. 2024
      Doba čtení: 65 minut
    • 640K by mělo stačit každému: skutečně?

      Billu Gatesovi se připisuje výrok „640K ought to be enough for anybody“, který ovšem pravděpodobně nikdy neřekl. Na počítačích IBM PC se skutečně dlouhou dobu bojovalo s omezenými možnostmi adresování většího paměťového rozsahu.
      Pavel Tišnovský
      10. 12. 2024
      Doba čtení: 56 minut
    • Vývoj mikroprocesorů z rodiny 80×86: 32bitové čipy 80386 a 80486

      Dnes se budeme zabývat těmi novými instrukcemi, které byly přidány do třetí generace mikroprocesorů rodiny 80×86, tj. konkrétně do čipů Intel 80386 (a posléze i Intel 80486). Prozatím se zaměříme především na reálný režim.
      Pavel Tišnovský
      5. 12. 2024
      Doba čtení: 55 minut
    • Vývoj mikroprocesorů z rodiny 80×86: od Intelu 8086 k čipu 80286

      Většina příkladů, které jsme si až doposud ukazovali, využívala pouze instrukce a registry dostupné na původních mikroprocesorech 8086 a 8088. Ovšem možnosti instrukčních sad se postupně s příchodem dalších čipů řady x86 rozšiřovaly.
      Pavel Tišnovský
      3. 12. 2024
      Doba čtení: 52 minut
    • Časovač 8253 a systém přerušení na IBM PC

      Při programování IBM PC je třeba zajistit volání nějakého podprogramu v pravidelných intervalech. Realizace formou čekacích smyček je většinou nepraktická, proto je výhodnější využít časovač představovaný čipem 8253.
      Pavel Tišnovský
      19. 11. 2024
      Doba čtení: 54 minut
    31–60 / 161
    První strana Předchozí strana 1 2 3 4 5 6 Následující strana Poslední strana