-
Data: 2012-06-28 09:49:12
Temat: Re: PE a lib i obj
Od: "AK" <n...@n...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Użytkownik "Borneq" <b...@a...hidden.pl> napisał:
> Pliki Exe i Dll właściwie się nie różnią, oba mogą importować i eksportować
funkcje, mają sekcje
> zasobów, debuggera itp.
> A jak jest z plikami lib i obj? Jaka jest różnica między nimi a plikami
wykonywalnymi? W takim obj
> i lib nie ma ustalonych adresów.
Lib to nic wiecej niz pop rostu biblioteka obj-tow.
Obj (mowie o intelu x86/x64) to taki magazyn relokowalnych paczek
kody maszynowego i danych odpowiadajacych z grubsza strukturze
programu w pamieci x86/64 (segmenty (e)cs:kod = CODExx
(e)ds:DATA,_DATA bss:BSS,_BSS itp) + rozne mappingi symboli
(nazw z j.programowania) na adresy wzgledne w tychze, fuxupy itp.
Linker po prostu scala te czesci z roznych objtow i produkuje
exe (dwa pierwsze bajty to 'MZ') ktory jest zlozony z wielu segmentow,
(ale juz wewnetrznie spojnych) + tablica relokacji (offsety tychze).
"Drzewiej"produkowac mozna bylo tez .com ktory tym sie rozni
od execa, ze loader traktuje go jako jeden 'BLOB" (nie ma zadnych relokacji)
wczytuje go i skacze zwyklym jumpem na jego poczatek
(a dokladnie chyba na adres 0x400 - nie pamietam).
.Com z oczywistych wzgledow moze miec maksymalny rozmiar jednego
segmentu procesora intel.
Dla 16 bitowego adresowania bylo to wiec ~65000b - dosc malo:)
Taki com byl niekiedy bardzo wygodny przy pisaniu driverow/pluginow
itp (rozszerzenia byly czesto inne; .bin, .sys, .bgi itp itd).
Aby uzyskac pluginowa/driverowa dynamike uruchomienia drivera
po prostu czytalo sie taki twor ''in runtime" jakims (f)read i oddawalo
sie mu sterowanie zwyklym jmp seg:0x400.
(Ok ok :) wiem ze sa spawny i exec. Nie zawsze byly idealne.)
A wiec zadnej tajemnej i skomplikowanej wiedzy e tym nie ma.
Ba! Dzis ta "wiedza" jest jzu kompletnie zbedna (i baardzo dobrze),
co pod powazna rozwage Ci polecam (sa przyjemniejsze/potrezbniejsze
rzeczy w prog. niz grzebanei w takich bebechach)
AK
Następne wpisy z tego wątku
- 28.06.12 10:42 Borneq
- 28.06.12 13:46 AK
- 28.06.12 14:28 Borneq
- 28.06.12 14:59 AK
- 28.06.12 17:00 Adam Wysocki
- 28.06.12 17:31 AK
- 28.06.12 17:57 Jacek
- 28.06.12 17:59 AK
Najnowsze wątki z tej grupy
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
Najnowsze wątki
- 2025-03-29 Re: Kompensacja mocy biernej przy 230VAC
- 2025-03-29 Ostrów Wielkopolski => Konsultant Wdrożeniowy Comarch XL/Optima (Ksi
- 2025-03-29 Łożysko ślizgowe - jaki olej
- 2025-03-29 Re: Kompensacja mocy biernej przy 230VAC
- 2025-03-29 Warszawa => NMS System Administrator <=
- 2025-03-29 Warszawa => Laravel PHP Developer <=
- 2025-03-29 Re: Kompensacja mocy biernej przy 230VAC
- 2025-03-29 Warszawa => Java Full Stack Developer (Angular2+) <=
- 2025-03-29 Warszawa => Specjalista rekrutacji IT <=
- 2025-03-28 A gdyby to był elektryk?
- 2025-03-28 Współczesny falomierz
- 2025-03-28 Rzeszów => WEBCON Developer <=
- 2025-03-28 Szczecin => Specjalista ds. public relations <=
- 2025-03-28 Warszawa => Staż w dziale Sprzedaży B2B <=
- 2025-03-28 Warszawa => MENA New Business Manager <=