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í
×
    včera 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    včera 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

    Ladislav Hagara | Komentářů: 8
    včera 00:11 | Nová verze

    Byla vydána (𝕏) červnová aktualizace aneb nová verze 1.102 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.102 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    10.7. 21:00 | Bezpečnostní upozornění

    Byla vydána nová verze 2.4.64 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 8 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 4
    10.7. 15:22 | Nová verze

    Společnost xAI na síti 𝕏 představila Grok 4, tj. novou verzi svého AI LLM modelu Grok.

    Ladislav Hagara | Komentářů: 11
    10.7. 12:55 | Bezpečnostní upozornění

    Ministerstvo vnitra odhalilo závažný kyberincident v IT systému resortu. Systém, do kterého se dostal útočník bez oprávnění, byl odpojen a nedošlo k odcizení dat [𝕏].

    Ladislav Hagara | Komentářů: 16
    10.7. 11:55 | Humor

    Před rokem byla streamovací služba HBO Max přejmenována na Max. Dle managementu slovo HBO v názvu nebylo důležité. Včera byl Max přejmenován zpět na HBO Max. Kolik milionů dolarů to stálo? 😂

    Ladislav Hagara | Komentářů: 10
    10.7. 02:11 | Nová verze

    Byla vydána nová major verze 8.0.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v oficiálním oznámení a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    10.7. 01:11 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.4. Přehled novinek s náhledy a videi v oznámení na blogu.

    Ladislav Hagara | Komentářů: 1
    10.7. 00:11 | IT novinky

    Instituce státní správy nebudou smět využívat produkty, aplikace, řešení, webové stránky a webové služby poskytované čínskou společností DeepSeek. Na doporučení Národního úřadu pro kybernetickou a informační bezpečnost rozhodla o jejich zákazu vláda Petra Fialy na jednání ve středu 9. července 2025.

    Ladislav Hagara | Komentářů: 7
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 383 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Co vám prozradí ARM ETM trace

    14.2.2021 01:42 | Přečteno: 2759× | 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.