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

    Byla vydána verze 1.93.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 5
    dnes 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    dnes 10:22 | Zajímavý software

    Technologie Skip pro multiplatformní mobilní vývoj, která umožňuje vývojářům vytvářet iOS a Android aplikace z jediné Swift a SwiftUI kódové základny, se s vydáním verze 1.7 stala open source.

    Ladislav Hagara | Komentářů: 3
    dnes 03:33 | Zajímavý software Ladislav Hagara | Komentářů: 1
    dnes 00:11 | Nová verze

    Byla vydána nová major verze 34.0.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 16:11 | Humor

    Win8DE je desktopové prostředí pro Wayland, inspirované nechvalně proslulým uživatelským rozhraním Metro z Windows 8. Nabízí dlaždicové rozhraní s velkými tlačítky a jednoduchou navigací, optimalizované pro dotyková zařízení. Cílem projektu je přetvořit design operačního systému Windows 8 do funkčního a minimalistického rozhraní vhodného pro každodenní použití na Linuxu.

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

    Laboratoře CZ.NIC vydaly Datovku 4.28.0 a Mobilní Datovku 2.6.0. Hlavní novinkou je ukládání rozpracovaných datových zpráv do konceptů. Datovka je svobodné multiplatformní aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi.

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

    Unix Pipe Game je vzdělávací karetní hra zaměřená na děti a rodiče, která děti učí používat unixové příkazy prostřednictvím interaktivních úkolů. Klíčovým prvkem hry je využití symbolu | pro pipeline neboli 'rouru', který umožňuje propojit výstupy a vstupy jednotlivých unixových příkazů, v tomto případě vytištěných na kartičkách. Předpokládá se, že rodič má alespoň nějaké povědomí o unixových příkazech a jejich provazování pomocí |.

    … více »
    NUKE GAZA! 🎆 | Komentářů: 3
    včera 13:55 | Zajímavý software

    PCIem je linuxový framework, který vytváří virtuální zařízení PCIe pomocí technik, které umožňují hostitelskému operačnímu systému rozpoznat tyto syntetické 'neexistující' karty jako fyzické zařízení přítomné na sběrnici. Framework PCIem je primárně zamýšlen jako pomůcka pro vývoj a testování ovladačů bez nutnosti použít skutečný hardware. Dle tvrzení projektu si fungování PCIem můžeme představit jako MITM (Man-in-the-Middle), který se nachází mezi ovladači a kernelem.

    NUKE GAZA! 🎆 | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (5%)
     (0%)
     (10%)
     (21%)
     (3%)
     (5%)
     (2%)
     (11%)
     (36%)
    Celkem 573 hlasů
     Komentářů: 17, poslední dnes 15:24
    Rozcestník

    Dotaz: Position dependent code a sdílená knihovna

    1.3.2013 23:09 Logik
    Position dependent code a sdílená knihovna
    Přečteno: 488×
    Mám knihovnu (64bit linux), zkompilovanou bez přepínače -fPIC. Zdrojáky k ní nemám. Chtěl bych z ní udělat pomocí f2py rozšíření do pythonu: to je ale sdílená knihovna a tedy použití -fPIC vyžaduje. Neznáte někdo nějakou cestu, jak to obejít?

    Napadlo mě např. nějaká transformace knihovny na PIC code? Nebo nějakej PIC wraper a vhodná kombinace přepínačů linkeru tak, by to šlo přeložit?

    Jediné co mě napadlo je to spustit v podprocesu, ale vzhledem k tomu, že to je řešič a jako argument tomu lezou desítky megabajtů, tak bych se rád vyhnul zbytečný duplikaci obsazený paměti a rád bych to spustil ve stejnym adresnim prostoru.

    Odpovědi

    1.3.2013 23:20 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    PS: Ještě jsem našel toto, http://eli.thegreenplace.net/2011/11/11/position-independent-code-pic-in-shared-libraries-on-x64/ ale mimo to, že netuším, jestli by python s takovouto knihovnou správně kooperoval, tak mi to odmítá můj soubor zkompilovat.
    1.3.2013 23:20 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    PS: Ještě jsem našel toto, http://eli.thegreenplace.net/2011/11/11/position-independent-code-pic-in-shared-libraries-on-x64/ ale mimo to, že netuším, jestli by python s takovouto knihovnou správně kooperoval, tak mi to odmítá můj soubor zkompilovat a hlásí to:

    internal compiler error: in cselib_hash_rtx, at cselib.c:741 Please submit a full bug report, with preprocessed source if appropriate.
    3.3.2013 15:48 graviton
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Jak taková "knihovna" vypadá? Obávám se, že bez podstatného upřesnění se nikdo nechytne.

    Jak to tady čtu, tak f2py popadne zdrojáky ve fortranu a vygeneruje z nich sdílenou knihovnu (je to tento případ? asi ne, že?). Strkat do f2py sdílenou knihovnu se mi zdá poněkud proti proudu.
    4.3.2013 00:26 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Knihovna je prostě balíček objektových (.o) souborů zabalených pomocí ar do .a souboru.

    S f2py ses trefil přesně - právě on dělá tu sdílenou knihovnu a já v ideálním případě potřebuju nějakou kombinaci přepínačů tak, aby do ní uměl naliknovat i ten position dependent code z té knihovny, popř. nějakou transformaci té knihovny tak, aby byla PIC.

    Konkrétně jde o jadamilu řešič: http://homepages.ulb.ac.be/~jadamilu/ a já hledám nějaký rozumný způsob, jakým volat z Pythonu (2.5), popř. Cythonu ten řešič. Varianta, že uložím zadání do souboru a spustím child process tu sice je, ale moc mě neláká.

    Na sdílenou knihovnu jsem se ptal, protože pokud udělám sdílenou knihovnu, tak tu už nějak z pythonu zavolám (přinejhorším tak, že z Cythonu zavolám C kód volající knihovnu), popř. z toho jak se dělá vyšaším, jaký parametry procpat do f2py, aby to jelo.

    Tak díky moc za pomoc.
    4.3.2013 07:16 graviton
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    http://www.technovelty.org/c/position-independent-code-and-x86-64-libraries.html <- nějaké další vysvětlivky k té sdílené knihovně - moc nadějí bych do toho nevkládal.

    Varianta vedlejší proces+shared memory? Sice se data budou muset alespoň jednou kopírovat a pokud se jedná o stovky mega, tak si uživatel bude možná muset přenastavit v systému nějaké limity, ale rychlostně by to zas tak tragické být nemuselo.
    10.3.2013 05:38 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Knihovna je prostě balíček objektových (.o) souborů zabalených pomocí ar do .a souboru.
    Dělá to na mě dojem, že to je prostě statická knihovna.

    Mělo by se to ale dát celkem jednoduše přelinkovat do dynamického .so s -fPIC. Podívej se na tohle (druhá odpověď), imho velmi podobný problém.
    10.3.2013 21:38 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Možná mělo, ale nedá. :-) Při linkování do sdílené knihovny to zařve, že je to position dependent code (tu hlášku si přesně nepamatuju a makefile už mám jinej, je to něco s R_X86_64_PC32). Btw. kdyby to bylo tak jednoduchý, tak bych se asi neptal :-), protože f2py nedělá nic jinýho, než že k funkcím vygeneruje wrappery a celý to zabalí do jedný sdílený knihovny.

    fPIC je záležitost kompilace, nikoli linkování - musí se změnit způsob odkazování na globální symboly - takže "přelinkovat" pos-dependent code na independent jednoduše nelze.

    rADOn avatar 11.3.2013 18:08 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    AFAIK pokud ten kód používá registr kde je globální offset, tak nic nenaděláš. A to by musel být hodně primitivní kód aby nechával ležet ladem nevyužitý registry :-)
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    3.3.2013 18:33 ivan
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Nejsem si uplne jistej, ale myslim, ze -fPIC je na 64bit architekture implicitni. Co to vlastne doopravdy mas? Mas .obj soubory anebo statickou .a knihovnu?
    3.3.2013 19:08 potato
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    AFAIK x86_64 používá relativní offsety na data, to se ale netýká funkcí.
    4.3.2013 00:28 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Implicitní není, musí se zadávat.

    Mám .a knihovnu, ale ta je jen balíček .o souborů, takže mám defakto i objektový soubory. Ale jsou prokazatelně non-PIC (nebo PDC? jakej je tu vlastně správnej termit?)
    5.3.2013 10:46 Ivan
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    Aha tak to jsem byl vedle. Me to jednou fungovalo i bez -fPIC u knihovny v C++. To ze mi tam ten option chybi jsem zjistil az kdyz jsem to portoval na 32bit Linux - sam jsem se divil jakto, ze to muze fungovat.

    Mam jeste jeden napad. Napis tem autorum - na webu pisou: "If you don't find in this list the combination that matches your need, you may contact the authors providing them a temporarily login on your machine; we shall use it to generate the libraries, that will be subsequently post on the web to benefit the whole community. "

    Kdyz jim nabidnes wrapper pro python tak ti snad nedaji kosem.

    5.3.2013 14:41 Logik
    Rozbalit Rozbalit vše Re: Position dependent code a sdílená knihovna
    To uz jsem udelal, poslali mi ale jen kody pro simple eigenvalue problem a ja potrebuju general eigenvalue problem (pritom v ty knihovne jsou). Na dalsi mail zatim neodpovedeli (tak doufám, že jsem )

    PS: Na 32bit linuxu by to právě bez toho fPIC fungovat mělo, problém to je akorát na 64bit, nepřehodil's to?

    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.