abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 11:11 | Nová verze

    Byla vydána nová verze 36.0, tj. první stabilní verze nové řady 36, svobodného multimediálního centra MythTV (Wikipedie). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Nová verze

    Byl vydán LineageOS 23.2 (Mastodon). LineageOS (Wikipedie) je svobodný operační systém pro chytré telefony, tablety a set-top boxy založený na Androidu. Jedná se o nástupce CyanogenModu.

    Ladislav Hagara | Komentářů: 1
    dnes 03:44 | IT novinky

    Od března budou mít uživatelé Discordu bez ověření věku pouze minimální práva vhodná pro teenagery.

    Ladislav Hagara | Komentářů: 3
    včera 23:43 | IT novinky

    Evropská komise (EK) předběžně shledala čínskou sociální síť pro sdílení krátkých videí TikTok návykovým designem v rozporu s unijním nařízením o digitálních službách (DSA). Komise, která je exekutivním orgánem Evropské unie a má rozsáhlé pravomoci, o tom informovala v tiskovém sdělení. TikTok v reakci uvedl, že EK o platformě vykreslila podle něj zcela nepravdivý obraz, a proto se bude bránit.… více »

    Ladislav Hagara | Komentářů: 7
    včera 18:33 | Nová verze

    Offpunk byl vydán ve verzi 3.0. Jedná se o webový prohlížeč běžící v terminálu a podporující také protokoly Gemini, Gopher a RSS. Přibyl nástroj xkcdpunk pro zobrazení XKCD v terminálu.

    Ladislav Hagara | Komentářů: 0
    včera 18:22 | Zajímavý projekt

    Promethee je projekt, který implementuje UEFI (Unified Extensible Firmware Interface) bindingy pro JavaScript. Z bootovacího média načítá a spouští soubor 'script.js', který může používat UEFI služby. Cílem je vytvořit zavaděč, který lze přizpůsobit pomocí HTML/CSS/JS. Repozitář se zdrojovými kódy je na Codebergu.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 12:44 | Bezpečnostní upozornění

    Zpráva Justičního výboru Sněmovny reprezentantů upozorňuje na cenzurní kampaň Evropské komise, mířenou proti svobodě projevu na sociálních sítích. V dokumentu se uvádí, že se Evropská komise během posledních šesti let účastnila více než 100 uzavřených jednání, během nichž po platformách požadovala úpravy pravidel moderování obsahu, přičemž toto úsilí Komise zahrnovalo i cenzuru politických názorů a pravdivých informací. Výbor zdůrazňuje, že tento přístup Bruselu ohrožuje ústavou zaručená práva Američanů na svobodu projevu.

    NUKE GAZA! 🎆 | Komentářů: 11
    včera 04:33 | Nová verze

    Linus Torvalds vydal jádro Linux 6.19. Podrobný výčet změn je ke zhlédnutí na stránce Kernel Newbies, stručné výběry v LWN (část první, druhá).

    |🇵🇸 | Komentářů: 0
    8.2. 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 8
    7.2. 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 3
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (11%)
     (26%)
     (3%)
     (5%)
     (2%)
     (12%)
     (28%)
    Celkem 822 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Co vám prozradí ARM ETM trace

    14.2.2021 01:42 | Přečteno: 2802× | programování | Výběrový blog | poslední úprava: 14.2.2021 02:20

    ARM ETM trace je velmi silný nástroj, který je součástí mnoha moderních ARM procesorů, paradoxně je nejtěžší získat správnou desku, která ma ETM+debug port správně vyveden z pinů procesoru. Ale když už to máte, tak lze dělat velmi dobrá meření.

    Příklad 1 - záznam všech vykonaných instrukcí

    JTrace adaptér v Ozone umí zaznamenat do 10 milionů posledních vykonaných instrukcí, takže víte, kudy přesne kód jel. JTrace je bohužel jediný multiplatformní JTAG/SWD adaptér, který funguje i pod Linuxem a Mac OS (Keil Ulink a Lauterbach jen pod Windows a ty nástroje vůbec neumí pracovat s nějakými Makefile nebo ELF souborama).

    Především s interrupty je to neocenitelný debugovací nástroj, protože na interruptech nelze dělat breakpointy bez toho, že se to komplet rozbije.

    Proti další ukázce z ITM trace (z orbtop je méně presná, statistický sampling) to neumí měřit spánek procesoru (ITM trace to umí), ale to až tak moc nevadí:


    Příklad 2 - execution profile

    Zde je např. celkem jasně vidět, kde se pálí čas procesoru, i když se tak trochu předpokládá, že každá instrukce trvá stejně dlouho. A neumí to počítat do celkového času sleep (WFI a podobné instrukce).


    Vývojové desky STM32 nemají správně vyveden ETM port

    Pokud se budete snažit rozběhnout ETM na vývojových deskách STM Discovery, budete velmi sklamáni. Nemají správně vyveden ETM port (zlé časování, zlé kapacity, ... - ETM běží na 200+ MHz na 4 linkách + hodiny). Prý se to samým inženýrům z ST povedlo max na 8 MHz clock speed procesoru. Tudíž to rozhodně chce správnou desku.


    Správné resetování CPU s periferiemi z Ozone

    Ozone má jednou nepříjemou vlastnost proti JLink Commanderu, že neumí správně resetovat CPU, se to jenom tak tváří skákáním po adresách reset vectorů. Zatím jsem s tím zvítězil tímhle hackem (reset přes SYSRESETREQ + VECTRESET bity), které zresetují i periferie, jinak se to seká na inicializaci TRNG například:
    void TargetReset (void) {                                           
    unsigned int AIRCR;
    unsigned int SCB_AIRCR_VECTKEY;
    unsigned int SCB_AIRCR_VECTRESET;
    
    AIRCR = 0xE000ED0C;
    SCB_AIRCR_VECTKEY = 0x5fa0000;
    SCB_AIRCR_VECTRESET = 0x1;
    
    *AIRCR = SCB_AIRCR_VECTRESET | SCB_AIRCR_VECTRESET;
    //                                                                    
    //  unsigned int SP;                                                  
    //  unsigned int PC;                                                  
    //  unsigned int VectorTableAddr;                                     
    //                                                                    
    //  VectorTableAddr = Program.GetBaseAddr();                          
    //                                                                    
    //  if (VectorTableAddr != 0xFFFFFFFF) {                              
    //    SP = Target.ReadU32(VectorTableAddr);                           
    //    Target.SetReg("SP", SP);                                      
    //  } else {                                                          
    //    Util.Log("Project file error: failed to get program base");   
    //  }                                                                 
    //                                                                    
    //  PC = Elf.GetEntryPointPC();                                       
    //                                                                    
    //  if (PC != 0xFFFFFFFF) {                                           
    //    Target.SetReg("PC", PC);                                      
    //  } else if (VectorTableAddr != 0xFFFFFFFF) {                       
    //    PC = Target.ReadU32(VectorTableAddr + 4);                       
    //    Target.SetReg("PC", PC);                                      
    }
    
    void AfterTargetReset (void) {
      unsigned int SP;                                                
      unsigned int PC;                                                
      unsigned int VectorTableAddr;                                   
                                                                      
      VectorTableAddr = 0x8000000; //boardloader vector offset
                                                                      
      if (VectorTableAddr != 0xFFFFFFFF) {                            
        SP = Target.ReadU32(VectorTableAddr);                         
        Target.SetReg("SP", SP);                                    
      } else {                                                        
        Util.Log("Project file error: failed to get program base"); 
      }                                                               
                                                                      
        PC = Target.ReadU32(VectorTableAddr + 4);                     
        Target.SetReg("PC", PC);                                    
    }
    

    Špatná indentace i ten komentář tam musí zůstat, jinak se z toho rozbije parser z nějakého důvodu. Don't ask. No idea why.

    Poznámka na závěr k ARM dokumentaci

    Nespoléhejte se na to, co je napsáno v obecné ARM dokumentaci nebo dokumentaci ke konkrétnímu procesoru. Např. System Control Block by měl být writable, ale není writable zevnitř procesoru, jenom přes JTAG adaptér. (Důvod této nekonečné srandy je že hledám úplne jiný hack na úplně jinou blbost, kde je user přílíš líný vytáhnout kabel).

           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.