-
X-Received: by 10.31.16.100 with SMTP id g97mr26829vki.5.1504797601422; Thu, 07 Sep
2017 08:20:01 -0700 (PDT)
X-Received: by 10.31.16.100 with SMTP id g97mr26829vki.5.1504797601422; Thu, 07 Sep
2017 08:20:01 -0700 (PDT)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!news.unit
0.net!peer01.am4!peer.am4.highwinds-media.com!peer01.iad!feed-me.highwinds-medi
a.com!news.highwinds-media.com!o200no198768itg.0!news-out.google.com!j49ni359qt
c.1!nntp.google.com!q8no640770qtb.0!postnews.google.com!glegroupsg2000goo.googl
egroups.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Thu, 7 Sep 2017 08:20:01 -0700 (PDT)
In-Reply-To: <f...@g...com>
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=37.47.11.188;
posting-account=Sb6m8goAAABbWsBL7gouk3bfLsuxwMgN
NNTP-Posting-Host: 37.47.11.188
References: <7...@g...com>
<oo6r6b$bcp$1@node1.news.atman.pl> <oohior$19n$1@node2.news.atman.pl>
<0...@g...com>
<ook8o5$gs1$2@node2.news.atman.pl>
<2...@g...com>
<ookj75$qs8$1@mx1.internetia.pl>
<8...@g...com>
<1...@g...com>
<0...@g...com>
<1...@g...com>
<8...@g...com>
<2...@g...com>
<f...@g...com>
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <b...@g...com>
Subject: Re: [OT] (announce) organic asm
From: fir <p...@g...com>
Injection-Date: Thu, 07 Sep 2017 15:20:01 +0000
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
X-Received-Body-CRC: 4171781190
X-Received-Bytes: 7013
Xref: news-archive.icm.edu.pl pl.comp.programming:211479
[ ukryj nagłówki ]W dniu środa, 6 września 2017 22:00:08 UTC+2 użytkownik fir napisał:
> tak wogole pisanie asma nie jest trudne choc ma troche trudniejsze kawalki
>
> moe przedstawic jeden problem bo zrobilem na odwal (tj pierwsza iteracje problemu)
> i musze tu troche poprawic
>
> najpierw asembler zbiera info nt importow
> (na co slkada sie lista nazw dll-ek i wywolywanych z nich funkcji)
>
> ja to zbieram do tablicy o stalym rozmarze (np 100 na 100) ktora ma taka zawartosc
>
> "moduleX", "fooA", "fooB", NULL, NULL, ...
> "moduleY", "fooG", "fooH", "fooI", NULL,
> ..
> "moduleZ", "fooP", "fooQ", "fooR", NULL, ...
>
> "moduleW", "fooI", NULL, NULL, NULL,
> "moduleT", "fooS", "fooT", NULL, NULL,
> NULL,
> NULL,
>
>
> i to jest jeden maly problem bo moze nastapic przepelnienie jesli importowanych
dll-ek bedzie wiecej niz 100 lub importowanych funkcji dla jednej dll-ki bedzie
wiecej niz 99
>
> taka tablica jest jednak wygodna
> i prosta
>
> sam to pewnie zostawie tak jak jest tylko rozmaiar zahardkoduje na wiekszy np 1000
na 1000 (jest to tablica wskaznikow wiec te pare mega mozna poswiecic ;c - ale nie
jest to ideologicznie czyste (w takich wypadkach jednak wole zrobic w pierwszej
iteracji cos co jest proste niz ogolne)
>
> dalej problem jest nawet wiekszy bo na podstawie zawartosci tej tablicy trzeba
zbudowac sekcje importow w exacu
>
> ta sekcja sklada sie z czegos takiego:
>
> 1)
> najpierw jest tablica (N+1)*20 bajtow
> gdzie N to liczna importowanych modulow
> gdzie ustawia sie pewne wskazniki
> - to sie buduje dosyc latwo
>
> dalej sa jeszcze dwie rzeczy to wpisania
>
> 2 trzebe przekopiowac te wszystki stringi z wspomnienej tablicy importow
>
> zdaje sie ze ich kolejnosc nie jest nawet zbyt wazna wiec moge jakby poleciec po
kolei wierszami ignorujac nule i wrzucajac strcpy (chyba moge zalozyc ze nazwy maja
max 32 znaki choc nie jestem pewien
>
> wymaga to jednach chyba napisania dosyc glupiej funkcji
>
> int RowColumn2LinearOrder(x,y)
>
> bo pozniej bede potrzebowal uzyskania dokladnego offsetu do tej nazyw dla
> ukladu modul-funkcja
>
> taka funkcja przeliczania z x y na ten linearny offset jest dosyc glupia, ale chyab
tak zrobie (glupia ale stosunkowo malo roboty a musze chodzic na kompromisy z wlasnym
lenistwem/ograniczeniami energetycznymi)
>
> 3) dalej trzeba jeszcze zbudowac listy wskaznikow na te nazwy, te listy wskaznikow
maja byc per-modul i bodajrze konczyc sie zerem na koncu listy funkci dla kazdego
modulu
>
> w sumie tutaj chyba moge wykorzystac ten sam liniowy porzadek korzystajac z tego ze
w tym liniowym listy nazw funkcji sa przetykane nazwami modulow, tylko zamiast
wskaznika na nazwe modulu dam zero
>
> to chyab da sie zrobic latwo jesli gdzies sie nie walne (ogolnie to nie jest trudne
ale problem jest ze zrozumieniem zasad tego formatu oraz z nie popelnieniem pomylki w
generowaniu tych danych)
>
> oprocz tego trzeba jeszcze zrobic identyczna kopie tej tablicy bo jedna trzyma
nazwy na stale a druga wypelnia
> prawdziwymi wskaznikami do implementacji
> loader windowsa
>
> na koniec w tej tablicy z punktu 1) wypelnie sie wskazniki do tych 2 list,
> i do nazwy modulu dla kazdego modulu
>
> w sumie to powinno dzialac sa tylko dwie wspomniene niedogodnosci
> 1) mozna osiagnac limit kwadratowej tablicy
> 2) ta funkcja przechodzenia z x,y na linerana kolejnosc jest drobinke
glupia/brzydka
>
> w sumie pewnie trzebbylo to zrobic inaczej tj budowac liste par modul-funkcja na
koniec ja posortowac i nie byloby straty pamieci i linearny porzadek
> sam by sie zrobil, ale chyba zalozylem ze kwadratowa tablica bedzie prostsza (nie
trzeba bylo pisac sortowania ;c
>
> na razie chyba zrobie na kwadratowej moze kiedys pozniej poprawie na ta liste 1d -
ew nastepnym razem bedzie wiadomo by takie przypadki robic od razu na liscie 1d
w sumei chyba dobrze ze sie nameczylem wklepujac ten opis bo sam sobie moge
odpowiedziec
1) co do tego dziwnego kodu z tlumaczeniem pozycji w 2 wymiarowej tablicy na linearny
to nie jest on az tak dziwny gdy 'wbudowac' to w kod ktory wstawia alementy do tej
tablicy (bo temu i tak sie przyda pamietanie ile elementow jest w wierszu)
2) problem z przepelnieniem sie statycznej tablicy dwuwymiarowej mozna zasadniczo
rozwiacac robiac z tego kontener typu "petla mallokow w malloku"
no i po prostu realokujac wiersze przy wstawianiu, to rozwiaze tez (czesciowo ;c)
problem z nadmierną zajatoscia pamieci na nic czyli NULLE, koszty czasowe czyli
pewnie ta milisekunde (czy pare czy ile to jest) na jako zejdzie wywolanie 1000
reallokow przy wstawianiu tysiaca nazw, moge sobie chyba darowac
byc moze moge sobie nawet tak naprawde napisac taki resizowalny kontener bazujac na
mojej idei czunkow ("resizable chunk of resizable chunks") moze pozniej zakoduje bo
to malo roboty
Następne wpisy z tego wątku
- 07.09.17 17:46 wloochacz
- 07.09.17 19:11 fir
- 07.09.17 19:52 fir
- 07.09.17 19:53 fir
- 07.09.17 20:17 wół, wół roboczy, wół dojno roboczo obronny 'POPIS/EU
- 08.09.17 01:12 fir
- 08.09.17 01:27 fir
- 09.09.17 00:17 fir
- 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.
Najnowsze wątki z tej grupy
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
Najnowsze wątki
- 2025-01-04 13. Raport Totaliztyczny: Powszechna Deklaracja Praw Człowieka Nie Chroni Przed Wyzyskiem Ani Przed Eksploatacją
- 2025-01-04 Zbieranie danych przez www
- 2025-01-04 reverse engineering i dodawanie elementów do istniejących zamkniętych produktów- legalne?
- 2025-01-04 w Nowym Roku 2025r
- 2025-01-04 Warszawa => Specjalista ds. IT - II Linia Wsparcia <=
- 2025-01-04 Warszawa => Java Developer <=
- 2025-01-04 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-04 Warszawa => System Architect (Java background) <=
- 2025-01-04 Wrocław => Application Security Engineer <=
- 2025-01-04 Chrzanów => Specjalista ds. public relations <=
- 2025-01-04 Katowice => Key Account Manager (ERP) <=
- 2025-01-03 Problem z odczytem karty CF
- 2025-01-03 Jazda z Warszawy do Krakowa teslą
- 2025-01-03 Wrocław => Konsultant Wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-01-03 Warszawa => International Freight Forwarder <=