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 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 0
    dnes 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 0
    včera 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 21
    včera 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    včera 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

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

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 10
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1630 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    user@linux:binfmt_misc $ ./exec_spolkne_cokoliv.exe

    19.5.2006 09:47 | Přečteno: 1393×

    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ file vim.exe
    vim.exe: MS-DOS executable (EXE), OS/2 or MS Windows
    
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ ./vim.exe --version |head -n 2
    VIM - Vi IMproved 6.3 (2004 June 7, compiled Jun  7 2004 14:13:59)
    32 bitová verze pro MS Windows konzolu
    

    Ne, to není kouzlo, to je binfmt_misc!

    Bleskový návod pro nedočkavé

    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ ls -l vim.exe
    -r-xr-xr-x 1 root root 1042432 2004-06-07 14:14 vim.exe
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ file vim.exe
    vim.exe: MS-DOS executable (EXE), OS/2 or MS Windows
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ hexdump -C -n 5 vim.exe
    00000000  4d 5a 90 00 03                                    |MZ...|
    00000005
    
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ su
    Password:
    root@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 # cd /proc/sys/fs
    root@cz2cbjmc:/proc/sys/fs # modprobe binfmt_misc
    root@cz2cbjmc:/proc/sys/fs # mount none -t binfmt_misc /proc/sys/fs/binfmt_misc
    root@cz2cbjmc:/proc/sys/fs # cd binfmt_misc/
    root@cz2cbjmc:/proc/sys/fs/binfmt_misc # ls
    register  status
    
    root@cz2cbjmc:/proc/sys/fs/binfmt_misc # echo ':DOSWin:M::MZ::/usr/bin/wine:' > register
    root@cz2cbjmc:/proc/sys/fs/binfmt_misc # ls
    DOSWin  register  status
    root@cz2cbjmc:/proc/sys/fs/binfmt_misc # cat DOSWin
    enabled
    interpreter /usr/bin/wine
    flags:
    offset 0
    magic 4d5a
    root@cz2cbjmc:/proc/sys/fs/binfmt_misc # exit
    
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $ ./vim.exe --version |head -n 2
    VIM - Vi IMproved 6.3 (2004 June 7, compiled Jun  7 2004 14:13:59)
    32 bitová verze pro MS Windows konzolu
    petr@cz2cbjmc:/mnt/win/Program Files/Vim/vim63 $
        

    Následující text je volným překladem dokumentace k jadernému modulu binfmt_misc, jenž dlí ve zdrojácích Linuxu v souboru Documentation/binfmt_misc.txt. Jeho autorem je Richard Günther.

    Binfmt_misc: Podpora jádra pro rozličné binární formáty

    Tato funkce jádra vám umožní pustit téměř každý program (omezení jsou popsána níže) pouhým napsáním jeho jména do shellu.

    Abyste toho dosáhli, musíte říci binfmt_misc, který interpretr má být aplikován na kterou binárku. Binfmt_misc rozpozná druh binárky porovnáním několika prvních bytů souboru s magickou sekvencí, kterou mu před tím poskytnete. Binfmt_misc se také umí řídit podle přípon souboru, jako jsou .com nebo .exe.

    Jak na to

    Nejprve připojíte pseudosouborový systém binfmt_misc:

    mount none -t binfmt_misc /proc/sys/fs/binfmt_misc
        

    Pak zaregistrujete nový binární typ. Pro to musíte sestavit řetězec ve tvaru :jméno:metoda:offset:magic:maska:interpretr:příznaky (pokud budete potřebovat, můžete místo znaku : (dvojtečka) použít něco jiného) a zapsat jej do /proc/sys/fs/binfmt_misc/register.

    Tady je význam jednotlivých políček:

    jméno
    Identifikátor nového typu. Po registraci vznikne v /proc/sys/fs/binfmt_misc nový soubor nesoucí toto jméno.
    metoda
    Určuje podle čeho se bude rozpoznávat předložený program. Zadejte M pro magický řetězec, E pro příponu.
    offset
    Definuje první byte, od kterého se bude porovnávat magický řetězec a maska. Pokud jej vynecháte, použije se 0 (t.j. jméno:typ::magic:…).
    magic
    Je onen magický řetězec, podle kterého se binfmt_misc dokáže rozhodnout. Řetězec smí obsahovat hexadecimálně kódované znaky jako \0xa nebo \xA4. Pokud jste zvolili rozhodování podle přípony, pak se význam tohoto pole mění na příponu, kterou musí mít testovaný soubor (přípona se zadává bez tečky, hexadecimální zápis znaků není povolen). U přípon se hledí i na velikost písmen.
    maska
    Není povinná (výchozí hodnota jsou samé jedničky). Tímto můžete při porovnávání ignorovat některé bity. Maska musí být stejně dlouhá jako magický řetězec. Před samotným porovnáním je mezi bity masky a souboru proveden logický AND.
    interpretr
    Jedná se o absolutní cestu k programu, který bude bude ve skutečnosti spuštěn. Jako první parametr dostane jméno původního binárky.
    příznaky
    Představují nepovinné pole. Ovlivňují, jak bude interpretr spuštěn. Zapisují se jako řetězec velkých písmen, každé písmeno ovládá jednu volbu. Možné jsou následující volby:
    P (preserve argv[0])
    Zachovává nultý argument. Výchozí chování je přepsaní původního argv[0] celou cestou k binárce. Pokud bude tento příznak zadán, binfmt_misc přidá další argument do vektoru argumentů, čímž zachová nultý argument.
    O (open binary)
    Standardně je interpeteru binárka předána jako absolutní cesta v argumentu. Pokud je tento příznak uveden, binfmt_misc otevře binárku pro čtení a předá její deskriptor jako argument namísto cesty k ní. To umožňuje spouštět programy, ke které uživatel nemůže číst. Tato funkce by měla být používána s rozmyslem – interpretr by neměl za žádných okolností vyzradit obsah spouštěného programu.
    C (credentials)
    Běžně jsou práva a bezpečnostní tokeny nového procesu odvozena od interpretru. Pokud je tento příznak nastaven, budou odvozeny od spouštěné binárky. Tento příznak také implikuje příznak O. Tato funkce by měla být používána s rozmyslem, zvláště je-li binárka vlastněna rootem a má nastaven setuid bit. Interpretr pak poběží s právy roota.

    Některá omezení

    Dobře si rozmyslete v jakém pořadí zaregistrujete jednotlivé formáty. Uplatní se totiž poslední vyhovující záznam (záznamy jsou prohledávány pozpátku).

    Příklady registrace

    Následuje pár příkladů (za předpokladu, že se nacházíte v /proc/sys/fs/binfmt_misc):

    Jak spouštět javové programy je popsáno v Documentation/java.txt.

    Podporu pro jednotlivé formáty nebo celý binfmt_misc můžete zakázat nebo povolit zapsáním 0 nebo 1 do /proc/sys/fs/binfmt_misc/jméno resp. /proc/sys/fs/binfmt_misc/status. Současný stav získáte vypsáním daného souboru.

    Odregistrování konkrétního binárního formátu lze provézt zapsáním -1 do příslušného souboru. Chcete-li smazat všechny záznamy, zapište ji do /proc/sys/fs/binfmt_misc/status.

    Tipy na závěr

    Pokud potřebujete předávat interpretru další parametry, napište si wrapper (příklady jsou v Documentation/java.txt).

    Interpretr by neměl vyhledávat spouštěný soubor v proměnné prostředí PATH; jádro mu samo předá celou cestu (nebo deskriptor). Použití PATH může přinést neočekávané chování včetně bezpečnostních chyb.

    Projektu binfmt_misc se také věnuje webová stránka http://www.tat.physik.uni-tuebingen.de/~rguenth/linux/binfmt_misc.html.

           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    19.5.2006 09:52 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: user@linux:binfmt_misc $ ./exec_spolkne_cokoliv.exe
    Hezké, tolik let vidím v jádře podporu pro misc binárky a nenapadlo mě, že to může sloužit pro něco podobného.
    When your hammer is C++, everything begins to look like a thumb.
    19.5.2006 10:08 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: user@linux:binfmt_misc $ ./exec_spolkne_cokoliv.exe
    Ještě přiložím návod pro uživatele Debianu :-)
    aptitude install wine binfmt-support
    xvasek avatar 19.5.2006 10:54 xvasek | skóre: 21 | blog: | Zlín
    Rozbalit Rozbalit vše Re: user@linux:binfmt_misc $ ./exec_spolkne_cokoliv.exe
    Ve Fedoře je to tuším skryto pod yum install wine, ale ruku do ohně bych za to nedal.
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.