-
Data: 2017-09-09 00:17:32
Temat: Re: [OT] (announce) organic asm
Od: fir <p...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu piątek, 8 września 2017 01:27:29 UTC+2 użytkownik fir napisał:
> W dniu piątek, 8 września 2017 01:12:35 UTC+2 użytkownik fir napisał:
> > jutro jeszcze (zapewne) opisze jeszcze smutne kwestie multipasow i fixupow
(ciekawe tylko jesli ktos chce wiedziec jak dziala asm, mi samemu przyda si o tym
wspomniec by uzyskac wieksza jasnosc jak to dziala a jest to troche zagmatwane
> >
> > moze w sumie pare slow juz teraz
> >
> > 1) na poczatku skanujac zrodlo buduje sekcje importow - oprocz samego binarnego
bloku tejh sekcji mam tez funkcja podajaca dla danego importu (podawanego po nazwie)
wartosc relatywnego wskaznika
> > wskazujacego miejsce gdzie lezy pointer do tej funkcji (ktory zostanie wypelniony
> > przez loader windy)
> > Oprocz tego istatna dana jest tez koncowy rozmiar tej sekcji
> >
> > 2) skanujac zrodlo buduje sekcje data oprocz niej mam funkcje ktora dla danego
labelu z sekcji data podaje re;atywny wskaznik do adekwatnej komorki w tej sekcji -
oprocz tego wazna dana jest finalny rozmiar tej sekcji
> >
> > 3) skanuje zrodlo i asembl;uje mnemoniki,
> > oprocz samych mnemonikow w zrodla mozna tam napotkac 4 rzeczy
> > l) label okreslajacy miejsce w kodzie (definicja np poczatku procedury)
> > c) odwolanie do labelu w kodzie (w przod lub w tyl) (glownie przez skoki)
> > d) odwolanie do labelu w danych (glownie przez mov)
> > i) odwolanie do importu (glownie przez call)
> >
> > o tym co trzeba z tym zrobic moze jutro
> >
> > (wlasciwie zadnego z tych labeli nie mozna przetlumaczyc na inta w pierwszym
podejsciu:
> > l) te labele trzeba zrzucic do tablicy razem z ich wartosciami (ktore
przynajmniej mozna od razu wyznaczyc)
> > c) odwolanie trzeba zrzucic do tablicy
> > razem z miejscem w kodzie ktore trzeba wypwlnic (ktore to miejsce tez na
szczescie mozna od razu ustalic)
> > d) odwolanie do danych tez trzeba zrzucic do tablicy razem z miejscem w kodzie
ktore trzeba wypelnic
> > i) odwolania do importow trzeba zrzucic do tablicy (azem zmiejscami ktore trzeba
wypelnic)
> >
> > po zasemblowaniu tego otrzymuje sie rozmar sekcji kodu, ktory trzeba wyrownac w
gore co pozwala uzyskac polozenie sekcji importow, dodanie rozmiary wyrownanego w
gore rozmiaru sekcji importow daje adres poczatku sekcji data
> >
> > teraz z tego co sie orientuje trzeba przeiterowac wszystkie 4 tabele i zarzucic
te fixupy, w wyniku czego powinnq powstac poprawnie wypelniona sekcja kodu, ktora
razem z sekcja importow i danych zapisuje sie na dyck
> > i zrobione
> >
> > niby nie takie trudne ale obraz troche
> > komplikuja lekkie subtelnosci, glowni eto ze aligmenty sekcji w ramie sa ine niz
w pliku a same adresy czasem podaje sie w postaci relatywnych offsetow (zdaje sie ze
wiekszosc w sekcji importow juz nie pamietam a te w sekcji kodu raczej w postaci
pelnych absolutnych wskaznikow) idzie sie pogubic
> >
> > do tego trzeba jeszcze poustawiac odpowiednie pola w naglowkach pe co tez jest co
nieco nieczytelee i dziwne
> >
> > wiekszosc tego mam zrobione ale polozenie sekcji data i imports wklepalem na
sztywno (dzieki czemu nie musialem robic tabel fixupow dla danych i importow) i teraz
wlasnie musze to pewnie w weekend poprawic bytan asm wlasni enie mial ograniczen
> >
> > (wogole szczerze mowiac nawet nieco dziwne mozna powiedziec jest to ze jak
kodowalem tego asma to wiekszosc problemow jakie tu wspomnialem udawalo sie jakos
zakodowac jakby w transie bez myslania o nich, jest to ciekawa zdolnosc , zdolnosc
do kodowania nez myslania o czyms o czym wydawaloby sie trzeba pomyslec) (pozniej
jednak, czyli teraz kapka myslania na te tematy sie przydaje - zeby miec jasnosci i
nie przeoczyc moze czegos, i moe tez po to by sie troche tego jak to dziala nauczyc
na pamiec)
>
> tak naprawde chyab to jest jeszcze bardziej skomplikowane, mianowicie zawartosc
sekcji importow zalezy od jej polozenia, a jej polozenie zalezy od rozmiaru sekcji
kodu - co wymusza inna kolejnosc niz pisalem
>
> zdaje sie
> - najpierw cod
> - pozniej importy
> - pozniej dane
> - na koniec fixupy
>
> idzie sie z leka pochlastac (zwlaszcza ze musze to przerabiac w stosunku do wersji
z polozeniemi sekcji wkodowanymi 'na sztywno')
nowsza wersja
minddetonator.htw.pl/organic8.zip
wiekszosc constraintow usunieta - jeszcze cos tam zostalo i asm pewnie wywali sie na
zbyt duzej asemblacji ale jestem zbyt 'sterany' by to dzis poprawic, ale jako ze
zdaje sie wiekszosc roboty zrobiona spokojnie poprawi sie to jutro i asm juz bedzie w
koncu 'limitless' (jeszcze mi tylko zostanie wtedy doklepac reszte opkodow)
Następne wpisy z tego wątku
- 09.09.17 14:20 fir
- 09.09.17 21:57 wół, wół roboczy, wół dojno roboczo obronny 'POPIS/EU
- 10.09.17 01:50 fir
- 10.09.17 11:33 fir
- 11.09.17 16:55 fir
- 11.09.17 17:03 fir
- 12.09.17 14:57 M.M.
- 12.09.17 16:59 fir
- 13.09.17 23:59 fir
- 14.09.17 21:11 wół, wół roboczy, wół dojno roboczo obronny 'POPIS/EU
- 14.09.17 22:08 fir
- 15.09.17 21:43 wół, wół roboczy, wół dojno roboczo obronny 'POPIS/EU
- 15.09.17 21:46 wół, wół roboczy, wół dojno roboczo obronny 'POPIS/EU
- 15.09.17 22:16 fir
- 22.12.17 12:18 AK
Najnowsze wątki z tej grupy
- 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?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-01-06 Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- 2025-01-06 Ostrów Wielkopolski => Area Sales Manager OZE <=
- 2025-01-06 Do IO i innych elektrooszolomow, tu macie prawdziwe smrody
- 2025-01-06 Białystok => Full Stack .Net Engineer <=
- 2025-01-06 Kraków => Business Development Manager - Network and Network Security
- 2025-01-06 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-01-06 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-06 Lublin => Programista Delphi <=
- 2025-01-06 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-06 śnieg
- 2025-01-05 Żarówka do lampy z czujnikiem ruchu
- 2025-01-05 Rozkręcają się
- 2025-01-04 pozew za naprawę sprzętu na youtube
- 2025-01-04 gasik
- 2025-01-04 13. Raport Totaliztyczny: Powszechna Deklaracja Praw Człowieka Nie Chroni Przed Wyzyskiem Ani Przed Eksploatacją