-
Data: 2009-09-11 14:58:16
Temat: Re: avr-gcc wielkość kodu
Od: Norbert Jaros <n...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 11 Wrz, 16:11, Grzegorz Kurczyk
<g...@c...slupsk.pl> wrote:
> Użytkownik pawel napisał:
>
> > Witam.
>
> > Mam dwie zmienne lokalne typu
> > unsigned int a,b;
> > i dwa wskaźniki typu
> > char *wsk1,*wsk2;
>
> > Zmienne te wykorzystuję w jednej funkcji.
> > Chcąc wykorzystać je globalnie w innych funkcjach przeniosłem je do
> > globalnych.
> > Dlaczego po samym przeniesieniu ich rozmiar kodu urósł aż o 44 bajty?
>
> Operacje na zmiennych lokalnych wykonywane są w miarę możliwości
> bezpośrednio na rejestrach. Są to rozkazy dwu-bajtowe (jedno słowo).
> Przeniesienie zmiennych do globalnych wymusza odwoływanie się do nich za
> pośrednictwem czterobajtowych rozkazów LD i ST. Przykładowo
> inkrementacja zmiennej lokalnej typu char przechowywanej w rejestrze to
> jeden rozkaz np:
> INC R16
> zajmujący dwa bajty.
> Dla zmiennej globalnej zapamiętanej w pamięci RAM będzie to już
> sekwencja trzech rozkazów np:
> LD R16, [zmienna] // 4 bajty
> INC R16 // 2 bajty
> ST [zmienna], R16 // 4 bajty
> czyli z dwóch bajtów zrobiło się dziesięć.
>
> Dla zmiennych typu int i wskaźników sprawa wygląda odpowiednio gorzej.
> Kompilator stara się to możliwie optymalizować wykonując co się da na
> rejestrach i dopiero na koniec zapamiętuje wynik w pamięci RAM pod
> adresem zmiennej.
>
> Pozdrawiam
> Grzegorz
.... jest jeszcze gorzej , bo jeżeli chcesz użyć LD to najpierw trzeba
adres zmiennej załadować do X,Y lub Z
a jeżeli użyjesz LDS to zajmujesz 2 słowa ale sądząc po tych " // 4
bajty " to chyba o LDS koledze wlasnie chodzilo.... :)
Pozdrawiam
Norbert
Następne wpisy z tego wątku
- 15.09.09 09:11 Grzegorz Kurczyk
- 16.09.09 19:47 Adam Dybkowski
Najnowsze wątki z tej grupy
- SFP, 10G, simplex sc/apc
- [słabe wiatry powodują - przyp. JMJ] Energetyczny paraliż w Niemczech
- NxtPaper
- Programiści nie przestają zadziwiać świat
- Długi kabel zasilający a na końcu procek
- Dlaczego nam nie idzie
- Co czujnik to inna temperatura
- Jak naprawić pilota
- Dlaczego TMP wer. 2.0 nie może być sprzedawany jako patyk USB lub karta PCIe 1x?!?
- produkcja w UE
- Pamięć SRAM nie działa z Z80182
- plyta indukcyjna - naprawa
- założyłem kamerę
- syrenki alarmów
- Czym obecnie programuje się EPROM-y?
Najnowsze wątki
- 2025-09-15 Warszawa => Specjalista rekrutacji IT <=
- 2025-09-15 Warszawa => International Freight Forwarder <=
- 2025-09-15 Lublin => ERP Implementation Consultant (AP Module) <=
- 2025-09-15 Warszawa => Engineering Manager (doświadczenie w branży lotniczej lu
- 2025-09-15 "Jestem z ..."
- 2025-09-15 jak sprawdzić czy zerwałem gwint
- 2025-09-14 UWAGA: MAM PODEJRZENIE, ŻE onet.pl DOKONUJE ATAKÓW!!!
- 2025-09-14 zarobki w 1995r
- 2025-09-13 Korea Południowa odpowie za niewolnictwo seksualne armii USA
- 2025-09-13 Zatrzymano zabójcę Charliego Kirka
- 2025-09-13 Wrześniowe promocje na ładowarkach
- 2025-09-13 Warszawa => BI Developer <=
- 2025-09-13 Warszawa => Sales Assistant <=
- 2025-09-13 Warszawa => Lead SAP PP Consultant <=
- 2025-09-13 Jestem pod wrażeniem. Komputery bankowe w łikendy nie odpoczywają ;-)