Portál AbcLinuxu, 12. května 2025 05:30

Dotaz: adresa glob. proměnné v dyn. linkované knihovně

10.4.2006 10:46 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
adresa glob. proměnné v dyn. linkované knihovně
Přečteno: 116×
Odpovědět | Admin
Řekněme, že budu mít dynamicky linkovanou knihovnu (sám si ji napíšu, takže budu mít k dispozici i mapu proměnných, která vyleze z gcc při překladu). Je možné nějak určit, jakou absolutní adresu bude mít globální proměnná v této knihovně za běhu programu jenom z relativní adresy získané z mapy proměnných?

Jde mi o to, jestli je možné z mapy proměnných knihovny vyzobat relativní adresy globálních proměnných a uložit si do nějakého souboru informaci typu: jméno proměnné/adresa/typ proměnné. Pak by program, který používá onu dynamickou knihovnu, dostal adresu nějaké globální proměnné, převedl by relativní adresu na absolutní (jak?), a (např.) by na terminál vypsal hodnotu této proměnné.

Otázka tedy zní: jde (a pokud ano, tak jak) převést relativní adresu globální proměnné na absolutní?
Užívej dne – možná je tvůj poslední.
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

10.4.2006 11:35 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ně jak nechápu co tím chce básník říci.

Adresa bude pokaždé jiná protože se ta knihovna pokaždé nahraje do jiného pamětového prostoru.

Samozřejmě pokud program co tu knihovnu používá může zjistit adresu proměnné pokud ji může používat a je mu ta proměnná dostupná.
10.4.2006 11:58 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Adresa bude pokaždé jiná, protože se ta knihovna pokaždé nahraje do jiného pamětového prostoru.
A na to se právě ptám. Adresa je v knihovně relativní vůči nějaké jiné adrese. Pokud tu „jinou adresu“ budu znát, pak stačí k relativní adrese (kterou znám z mapy proměnných) přičíst offset (který nevím jak za běhu programu zjistit) a dostanu skutečnou adresu proměnné.

Program může zjistit adresu proměnné nějak takhle: p_foo = &foo;, ale to znamená mu při psaní programu říct, aby zjistil adresu této konkrétní proměnné (foo); já to ale potřebuju zajistit obecně pro libovolnou globální proměnnou. Navíc program (ten, který používá sdílenou knihovnu) nezná její globální proměnné, takže k nim takhle přistupovat nemůže.

Já potřebuju programu předat relativní adresu, program by si ji přepočítal na absolutní a na základě absolutní adresy libovolné glob. proměnné by přečetl (přepsal) její obsah. Otázka zní, jak z relativní adresy získat adresu absolutní.
Užívej dne – možná je tvůj poslední.
10.4.2006 12:38 rastos | skóre: 63 | blog: rastos
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Najprv som si myslel, že tvoj problém jednoducho vyrieši extern:
extern int prem;

Ale po vete

Navíc program (ten, který používá sdílenou knihovnu) nezná její globální proměnné,

som prestal chápať. Možno by pomohlo pozrieť sa na výstup programu objdump, alebo nm.

10.4.2006 13:35 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Ne, extern int proměnná mi nepomůže, protože já při psaní programu, který výše zmíněnou knihovnu bude používat, nevím, jak se proměnné budou jmenovat, jakého budou typu ani kolik jich bude. Vím jenom, že k nim budu potřebovat přistupovat (neřešme proč a jak moc velká je to prasárna).

Program nm mi sice vypíše seznam symbolů, které jsou v knihovně definované, ale to mi moc nepomůže, totéž zjistím i z mapy proměnných.

Příklad: mám knihovnu s jednou globální proměnnou a jednou funkcí:
int g_var;

int foo(void) {
  return g_var;
}
Knihovnu přeložím a vznikne mi soubor lib.so. Programem nm zjistím tohle:
# nm lib.so | grep g_var
000018bc B g_var
V paměti ale nebude proměnná g_var na adrese 18bc, ale na aderese offset + 18bc. Já chci zjistit ten offset, abych v programu (který tu knihovnu bude používat) mohl napsat např. něco jako
p_gvar = (int *)(0x18bc + offset)
printf("Obsah promenne: %d\n", *p_gvar);
Užívej dne – možná je tvůj poslední.
10.4.2006 13:57 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Navíc program (ten, který používá sdílenou knihovnu) nezná její globální proměnné,
A jak potom tu knihovnu chceš používat ?

Přece ke každé knihovně existuje její hlavičkový soubor *.h kde jsou funkce a proměnné té knihovny popsané takže ty proměnné znáš. Jak jinak by jsi věděl co v té knihovně je ?
10.4.2006 14:28 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Tohle jsem tu sice nechtěl řešit, ale budiž: má představa je taková, že knihovna bude fungovat jako jakýsi plug-in: program si z konfiguráku přečte, kterou z dostupných knihoven má dneska používat a její funkce pak bude volat. Jaké bude mít knihovna globální proměnné už bude její věc (každá taková knihovna bude dělat něco jiného a bude mít tedy jiné globální proměnné; knihovny by se shodovaly jen v několika funkcích, které by tvořily rozhraní pro program).
Užívej dne – možná je tvůj poslední.
10.4.2006 14:48 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
No ale v tom případě vás nějaké proměnné nezajímají.

Funkce znáte tak je používejte.

Pokud potřebujete přistupovat k RAM jedno čeho tak si tam dopište funkci která vám vrátí adresu té proměnné.
10.4.2006 15:24 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Proměnné mě budou zajímat, hlavně z ladicích důvodů. Standardní debugger nebude možné použít (ten program nepoběží na standardním PC, ale to je jedno).

Funkci, která mi vrátí adresu té proměnné bych si napsal rád, ale zatím nevím jak (doufal jsem, že odpověď dostanu tady :). Znám jen název proměnné, její relativní adresu v knihovně a její typ. Já ale potřebuju znát její absolutní adresu, tzn. potřebuju funkci
void *abs_addr(unsigned int rel_addr)
nebo
void *abs_addr(char *var_name)
Užívej dne – možná je tvůj poslední.
10.4.2006 15:04 mike
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
zkus dlopen(), dlsym()
10.4.2006 15:28 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Fce dlsym() vypadá, že by mohla vyřešit můj problém, díky!
Užívej dne – možná je tvůj poslední.
10.4.2006 17:23 michich
Rozbalit Rozbalit vše Re: adresa glob. proměnné v dyn. linkované knihovně
Jak jste chtěl ten plugin v hlavním programu načítat? Bez použití dlopen() a dlsym() to snad ani nejde, nebo jo?

Založit nové vláknoNahoru

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

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.