-
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
- antena gsm - kabel - antena gsm
- PID - jeszcze raz
- Zlacze w mikrofonie z lat 80-tych
- Żywica żółknie od UV i wody :(
- Zawory termostatyczne
- Schemat automatyki
- Teoretyczne zagadnienie - ogrzewanie budynku
- Zagadka radiowa
- Prostownik
- Nowy akumulator Donut Lab
- Pilot do zamka/bramy
- Jaka myjka ultradźwiękowa?
- Retro organizer ale współcześnie
- Skąd diody LED 1,5V?
- Apollo Comm
Najnowsze wątki
- 2026-01-23 antena gsm - kabel - antena gsm
- 2026-01-22 Złomnik ty pisowska SZMATO! ;-)
- 2026-01-22 PID - jeszcze raz
- 2026-01-22 konkret24.tvn24.pl "gwarantuje": za SAMO wylanie gnojówki pod domem tusk-ministra aresztu nie będzie! ;-)
- 2026-01-22 Prawo na wesoło: nakaz rozbiórki "dwóch przyczep samochodowych" jako budynku ;-)
- 2026-01-22 Airtagi
- 2026-01-22 Warszawa => Full Stack Developer (Go/React) <=
- 2026-01-22 Warszawa => Senior Account Manager <=
- 2026-01-21 Nissan Leaf II 40kWh - degradacja baterii, SOH, uszkodzona bateria
- 2026-01-21 Fwd: zarzuty dla kulsonów
- 2026-01-21 Koniec Eldorado :)
- 2026-01-21 Warszawa => Senior Account Manager <=
- 2026-01-21 Gdańsk => Frontend Developer React <=
- 2026-01-21 Zakazy dla małolatów
- 2026-01-20 Majo przesrane :)




Fakturzystka, fakturzysta