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 15:33 | Humor

    PimpMyGRC upravuje vzhled toolkitu GNU Radio a přidává alternativní barevná témata. Primárním cílem autora bylo pouze vytvořit tmavé prostředí vhodné pro noční práci, nicméně k dispozici je nakonec celá škála barevných schémat včetně možností různých animací a vizuálních efektů (plameny, matrix, bubliny...), které nepochybně posunou uživatelský zážitek na zcela jinou úroveň. Témata jsou skripty v jazyce Python, které nahrazují

    … více »
    NUKE GAZA! 🎆 | Komentářů: 2
    dnes 14:33 | Nová verze Ladislav Hagara | Komentářů: 0
    dnes 12:33 | Zajímavý projekt

    FRANK OS je open-source operační systém pro mikrokontrolér RP2350 (s FRANK M2 board) postavený na FreeRTOS, který přetváří tento levný čip na plně funkční počítač s desktopovým uživatelským rozhraním ve stylu Windows 95 se správcem oken, terminálem, prohlížečem souborů a knihovnou aplikací, ovládaný PS/2 myší a klávesnicí, s DVI video výstupem. Otázkou zůstává, zda by 520 KB SRAM stačilo každému 😅.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 22:55 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa by měla dostat zhruba deset miliard dolarů (asi 214 miliard Kč) za zprostředkování dohody o převzetí kontroly nad aktivitami sociální sítě TikTok ve Spojených státech.

    Ladislav Hagara | Komentářů: 1
    včera 21:33 | Nová verze

    Projekt Debian aktualizoval obrazy stabilní větve „Trixie“ (13.4). Shrnuje opravy za poslední dva měsíce, 111 aktualizovaných balíčků a 67 bezpečnostních hlášení. Opravy se týkají mj. chyb v glibc nebo webovém serveru Apache.

    |🇵🇸 | Komentářů: 2
    včera 13:00 | Humor

    Agent umělé inteligence Claude Opus ignoroval uživatelovu odpověď 'ne' na dotaz, zda má implementovat změny kódu, a přesto se pokusil změny provést. Agent si odpověď 'ne' vysvětlil následovně: Uživatel na mou otázku 'Mám to implementovat?' odpověděl 'ne' - ale když se podívám na kontext, myslím, že tím 'ne' odpovídá na to, abych žádal o svolení, tedy myslí 'prostě to udělej, přestaň se ptát'.

    NUKE GAZA! 🎆 | Komentářů: 12
    včera 00:44 | IT novinky

    Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.

    Ladislav Hagara | Komentářů: 7
    včera 00:33 | IT novinky

    V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.

    Ladislav Hagara | Komentářů: 5
    13.3. 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 17
    13.3. 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

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

    Dotaz: framebufer - nemůžu smazat celou obrazovku.

    2.11.2016 17:39 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    framebufer - nemůžu smazat celou obrazovku.
    Přečteno: 437×
    Příloha:
    Mám program pro kreslení na obrazovce a nemůžu smazat poslední řádky, vyhodí to chybu:
    The framebuffer device was opened successfully.
    1366x768, 32bpp
    The framebuffer device was mapped to memory successfully.
    Neoprávněný přístup do paměti (SIGSEGV) (core dumped [obraz paměti uložen])
    
    Ale když v funkci nebudu chtít smazat posledních 6 řádků "vinfo.yres-6" tak to funguje OK.
    void clear_fb(int r, int g, int b)
    {
    int y_pom;
    int x_pom;
    
    for ( y_pom = 0; y_pom < vinfo.yres-6; y_pom++ )
            for ( x_pom = 0; x_pom < vinfo.xres; x_pom++ ) {
    
                location = (x_pom+vinfo.xoffset) * (vinfo.bits_per_pixel/8) +
                           (y_pom+vinfo.yoffset) * finfo.line_length;
    
                if ( vinfo.bits_per_pixel == 32 ) {
                    *(fbp + location) = b;        // Some blue
                    *(fbp + location + 1) = g;     // A little green
                    *(fbp + location + 2) = r;    // A lot of red
                    *(fbp + location + 3) = 0;      // No transparency
                } else  { //assume 16bpp
                    unsigned short int t = r<<11 | g << 5 | b;
                    *((unsigned short int*)(fbp + location)) = t;
                }
     }
    }
    
    Někde mám nějakou chybičku neporadíte kde?

    Celý program v příloze.

    Řešení dotazu:


    Odpovědi

    3.11.2016 08:32 MM
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Ahoj,

    Vypadá to, že zapisuješ do paměti, která ti nepatří

    já bych asi hledal kolem finfo.line_length (vypsat si), když mmapuješ, používáš screensize, který počítáš jinak než pak location v clear_fb a to může pak zapisovat do nemmapované paměti.

    Tzn. vypsat si celkový screensize a kontrolovat, že location ve funkcích není větší než... a když jo případně vypsat a nezapisovat do té paměti a hledat proč. Rozhodně počítat pokud možno stejným způsobem location a screensize

    3.11.2016 12:17 R
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Ano, line_length bude asi vacsi ako xres. 1366x768 je totiz debilne rozlisenie, sirka nie je nasobkom 8...
    3.11.2016 15:56 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Jo tady bude zrada nechal jsem si vypsat velikost řádku a je větší jak 1366x4 takže podle mě budu mít špatně spočítaný screensize.

    Díky za nakopnutí půjdu to přepočítat.....
    3.11.2016 16:37 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Je to tak, prostudoval jsem proměnné a screensize už nepočítám - vždyť v proměnných ho mám už spočítaný :-(
    screensize = finfo.smem_len;
    
    Jo třeba projít proměnné a použít správné :-)

    Díky za nakopnutí....

    Zdá se že už je to OK.

    Samozřejmě jsem blbě počítal screensize pak byl menší protože u nestandartního rozlišení je řádek větší v framebuferu než se skutečně zobrazuje.
    3.11.2016 14:52 Marek Sulik
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    hmm,

    tak ja tipujem, ze ten smernik fbp je typu (int*).

    takze potom: unsigned short int t = r<<11 | g << 5 | b;

    *((unsigned short int*)(fbp + location)) = t;

    Ide mimo rozsah, lebo tam bude dany pocet unsigned short int-ov.

    fpb + location

    sa posunie na lokalitu o location int-ov dalej.

    takze by som spravil na zaciatku premennu ( kvoli rychlosti ): unsigned short int *fbp_us = (unsigned short int*)fbp;

    a potom pouzival ju takto: *(fbp_us + location) = t;

    alebo iba jednoducho pretypovat na (unsinged short int*) pred operaciou + location;

    3.11.2016 15:12 dustin | skóre: 63 | blog: dustin
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Nejsem žádný C guru, ale když dumpuje core a zkompiloval by se s debug stringy (-g), tak by to v gdb nemusel být problém dohledat, ne?
    3.11.2016 15:49 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Je mi jasné že zapisuji mimo paměť asi to budu muset začít ladit tím že budu vypisovat kam to zapisuje do nějakého logu.

    Jinak to chci použít na RPI 3 tam to funguje OK sice tam používám menší rozlišení a pouze 16bpp.

    Takže zrada bude v tom počítání location.
    4.11.2016 11:01 Jirka
    Rozbalit Rozbalit vše Re: framebufer - nemůžu smazat celou obrazovku.
    Jak už zde naznačil předřečník, k ladění takových chyb obvykle stačí použít např. gdb nebo valgrind.

    Založit nové vláknoNahoru

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

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