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 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

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

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 0
    dnes 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

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

    Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    dnes 00:22 | Nová verze

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | Nová verze

    Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 4
    včera 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 10
    včera 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 32
    včera 09:33 | IT novinky

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

    Ladislav Hagara | Komentářů: 0
    včera 00:22 | Nová verze

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1056 hlasů
     Komentářů: 26, poslední dnes 08:56
    Rozcestník

    Co vám prozradí ARM ETM trace

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