eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaProblem lekko OT, ale w WinAVR ;-) › Re: Problem lekko OT, ale w WinAVR ;-)
  • Path: news-archive.icm.edu.pl!newsfeed.gazeta.pl!wsisiz.edu.pl!newsfeed.neostrada.pl!
    atlantis.news.neostrada.pl!news.neostrada.pl!not-for-mail
    From: "T.M.F." <t...@n...mp.pl>
    Newsgroups: pl.misc.elektronika
    Subject: Re: Problem lekko OT, ale w WinAVR ;-)
    Date: Fri, 12 Jun 2009 13:14:53 -0400
    Organization: TP - http://www.tp.pl/
    Lines: 75
    Message-ID: <h0tdf9$jpi$1@atlantis.news.neostrada.pl>
    References: <h0qku7$a6o$1@atlantis.news.neostrada.pl>
    <h0r3ok$c87$1@atlantis.news.neostrada.pl>
    <5...@4...com>
    <h0r8h1$fpo$1@nemesis.news.neostrada.pl> <h0rfu4$r83$1@news.mm.pl>
    <h0rjnq$etf$2@news.wp.pl> <h0rkmu$1ol$2@nemesis.news.neostrada.pl>
    <h0rkdf$4nb$2@news.mm.pl> <h0rti7$969$2@atlantis.news.neostrada.pl>
    <h0t1ob$o5f$1@atlantis.news.neostrada.pl>
    <h0t8g2$62t$1@nemesis.news.neostrada.pl>
    <h0tar0$ea1$1@atlantis.news.neostrada.pl>
    NNTP-Posting-Host: dvi241.neoplus.adsl.tpnet.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: atlantis.news.neostrada.pl 1244805417 20274 83.22.42.241 (12 Jun 2009
    11:16:57 GMT)
    X-Complaints-To: u...@n...neostrada.pl
    NNTP-Posting-Date: Fri, 12 Jun 2009 11:16:57 +0000 (UTC)
    User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1b3pre) Gecko/20090513
    Fedora/3.0-2.3.beta2.fc11 Thunderbird/3.0b2
    In-Reply-To: <h0tar0$ea1$1@atlantis.news.neostrada.pl>
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:565241
    [ ukryj nagłówki ]

    >>> Pomijając już tą nieszczęsną promocję do inta, to najbardziej w tym
    >>> kodzie rozwaliło mnie wyłuskiwanie 6 bitu.
    >>
    >> Promocja do int wynika ze standardu C wiec trudno tu robić zarzut
    >> kompilatorowi. Żeby to ominąć wystarczy explicite typecastowac.
    >
    > Wyraźnie napisałem, że nie promocja jest tu największym problemem.
    > Zresztą rzutowanie i tak tego nie poprawia.

    U mnie poprawia - najnowszy WinAVR.

    >>> Łatwo policzyć, że poniżej 8 parametrów bardziej opłaca się wersja z
    >>> rcall (program optymalizowany na rozmiar).
    >>
    >> Tu sprawa nie jest tak oczywista. Co prawda rcall są krótsze w sensie
    >> długości kodu, ale zajmuja 3 takty zegara.
    >
    > Specjalnie napisałem, że optymalizacja była ustawiona na rozmiar, więc
    > rcall powinno mieć pierwszeństwo.

    Tak, tylko developerzy sa skupieni na Os - tak to bywa, kiedy zasoby sa
    ograniczone.

    >> To zalezy zapewne od zdefiniowanej przez ciebie funkcji tab_size(tab).
    >> Kompilator za każdym obiegiem petli musi ja wywołać, żeby wilczyć
    >> wynik dla danego argumentu - dlaczego? Bo ja źle zdefiniowałeś.
    >
    > Zapomniałem wstawić. Oto kod:
    >
    > #define tab_size(__a) (sizeof(__a)/sizeof(__a[0]))
    >
    > Jeśli według ciebie jest źle zdefiniowana, to czekam na poprawki.

    To powinno w efekcie dac stala. Kiedy zastapilem wywolanie tab_size
    stala problem zniknal. Wiec byc moze uzywasz starej wersji?

    >> Sprawdziłem to u siebie i nic takiego się nie dzieje. Musiałem
    >> zdefiniować dodatkowo dziwna funkcje Babla bo mi kompilator to
    >> optymalizował i ją wywalał.
    >
    > Ja na potrzeby przykładu w ogóle jej nie zdefiniowałem (nie jest to
    > potrzebne, disasemblację zrobiłem po kompilacji, bez linkowania).

    To wtedy petla sie totalnie zoptymalizowala i wywalilo mi te wywolania w
    ogole.

    >>> A podobno gcc ma super optymalizator do pętli (widocznie moja wersja
    >>> gdzieś go zgubiła).
    >>
    >> Jak ci nie pasuje gcc to zaproponuj cos lepszego...
    >
    > Chciałeś przykłady, to ci je pokazałem. Nie jest w tym przypadku istotne
    > czy inne kompilatory zrobiłyby to lepiej (a myślę, że IAR byłby lepszy).

    IAR zwykle jest lepszy bo jest dostosowany do tej platformy, niestety
    uniwersalnosc gcc jest tu jego wada. Z drugiej strony wada ta jest
    kompensowana problemami na ktore sie natkniesz probujac przeniesc kod z
    IAR na inna platforme.

    >> Jak ci nie pasuje gcc to zaproponuj cos lepszego... nie mowiac juz o
    >> tym, ze masz kod źródłowy wiec możesz się wykazać dla potomności :)
    >
    > Dzięki, już kiedyś próbowałem (na innym porcie gcc). To nie jest robota
    > na 1 dzień, a ja mam swoją pracę.

    Owszem. Ale wystarczy nieco wiedzy jak kompilator generuje kod i
    wszystkie pokazane problemy znikaja. Sa co prawda inne, ktorych tak
    prosto wyeliminowac sie nie da, ale skoro ich nie pokazales, to pewnie
    nie sa dla ciebie tak klopotliwe :)

    --
    Inteligentny dom - http://idom.wizzard.one.pl
    http://idom.sourceforge.net/
    Teraz takze forum dyskusyjne
    Zobacz, wyslij uwagi, dolacz do projektu.

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: