eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaARM7 - nie działa wołanie metod wirtualnych.
Ilość wypowiedzi w tym wątku: 10

  • 1. Data: 2009-02-08 14:28:07
    Temat: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Witam.

    Takie coś:

    struct X
    {
    virtual void run() { do_something(); };
    void start() { run(); );
    }

    kod glowny:

    X x;

    x.run(); - dziala
    x.start(); - nie dziala

    Anzalizujac kod krok po kroku w OpenOCD widze, że wolanie run() z
    wnetrza start() prowadzi prosto pod adres NULL. Tak jak gdyby tablica
    wirtualna była uszkodzona. Z drugiej strony jednak zawołanie wprost
    run(); działa. Wygląda więc na to że nie działa wołanie metod
    wirtualnych z innych metod.

    arm-elf-g++ w wersji 3.4.3. RTTI włączone. Cpu AT91SAM7S.

    Gdzie szukać przyczyny? Może ktoś już się z tym spotkał? Google pytane
    pod róznymi hasłami kręci się w okolicy EABI ale żadnych konkretów. Mogę
    podać wszystko włacznie z kawałkami asm, sam niestety słabo znam asm
    arm7 żeby zabrać się za analizę.


  • 2. Data: 2009-02-08 19:53:46
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Krzysztof Rudnik <r...@k...net.pl>

    Sebastian Bialy wrote:

    > Witam.
    >
    > Takie coś:
    >
    > struct X
    > {
    > virtual void run() { do_something(); };
    > void start() { run(); );
    > }
    >
    > kod glowny:
    >
    > X x;
    >
    > x.run(); - dziala
    > x.start(); - nie dziala
    >
    > Anzalizujac kod krok po kroku w OpenOCD widze, Ĺźe wolanie run() z
    > wnetrza start() prowadzi prosto pod adres NULL. Tak jak gdyby tablica
    > wirtualna była uszkodzona. Z drugiej strony jednak zawołanie wprost

    A te zmienne sa statyczne czy automatyczne?

    > run(); działa. Wygląda więc na to że nie działa wołanie metod
    > wirtualnych z innych metod.

    Masz obiekt kompletny, wiec wywolanie x.run() realizowane jest bezposrednio, bez
    'wirtualnosci'. Wywolanie jest wirtualne (poprzez tablice) gdy wywolujesz metode ze
    wskaznika lub referencji. Wewnatrz start() masz wskaznik this.

    >
    > arm-elf-g++ w wersji 3.4.3. RTTI włączone. Cpu AT91SAM7S.
    >
    > Gdzie szukać przyczyny? Może ktoś już się z tym spotkał? Google pytane
    > pod róznymi hasłami kręci się w okolicy EABI ale żadnych konkretów. Mogę
    > podać wszystko włacznie z kawałkami asm, sam niestety słabo znam asm
    > arm7 żeby zabrać się za analizę.

    Jesli to sa zmienne statyczne to podejrzewalbym linkowanie i inicjalizacje.
    Kazdy plik .cpp zawiera wygenerowana przez kompilator funkcje inicjalizujaca obiekty
    globalne (wolajaca konstruktory).

    Krzysiek Rudnik


  • 3. Data: 2009-02-08 20:00:15
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Krzysztof Rudnik wrote:
    > A te zmienne sa statyczne czy automatyczne?

    Automatyczne, na stacku.

    > Masz obiekt kompletny, wiec wywolanie x.run() realizowane jest bezposrednio
    >, bez 'wirtualnosci'.

    Wiem, dlatego własnie podałem przykład z ominięciem tablicy wirtualnej
    żeby wykazać ze w niej jest problem.

    > Wywolanie jest wirtualne (poprzez tablice)
    > gdy wywolujesz metode ze wskaznika lub referencji. Wewnatrz start() masz wskaznik
    this.

    Tak, w dodatku funkcja start() prawidłowo dochodzi do miejsca
    w którym pobierany jest wskaźnik na run. Niestety jest on zerowy co
    może oznaczać, że nie został zainicjowany. Nie wiem gdzie (i kto) jest
    odpowiedzialny za prowidłwoe wypełnienie tej vtable. Wydawało mi się że
    konstruktor, ale jak widać chyba nie.

    > Jesli to sa zmienne statyczne to podejrzewalbym linkowanie i inicjalizacje.

    Nie. To zmienne na stosie. Dokładnie tak jak widać w kodzie.

    > Kazdy plik .cpp zawiera wygenerowana przez kompilator funkcje inicjalizujaca
    obiekty globalne (wolajaca konstruktory).

    Wiem, mój startup zawiera kod który wywołuje te konstruktory (fakt - nie
    pisany przez mnie). Jednak w tym wypadku nie ma mowy o statycznych
    zmiennych. Ponadto sprawdziłem - obiekt statyczny ma wołany konstruktor
    wiec tutaj chyba nie ma problemu.

    Będę jeszcze próbował gcc w jakiejś nowszej wersji z lini 4.x. Być może
    to bug.


  • 4. Data: 2009-02-08 20:59:21
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Jerry1111 <j...@w...pl.pl.wp>

    Sebastian Bialy wrote:
    > Będę jeszcze próbował gcc w jakiejś nowszej wersji z lini 4.x. Być może
    > to bug.

    Kiedys (pare lat juz bedzie) byla dyskusja z Piotrem Wyderskim o roznych
    przelacznikach do gcc na tej grupie. Sprobuj - a nuz...


    --
    Jerry1111


  • 5. Data: 2009-02-08 21:09:52
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Jerry1111 wrote:
    >> Będę jeszcze próbował gcc w jakiejś nowszej wersji z lini 4.x. Być
    >> może to bug.

    > Kiedys (pare lat juz bedzie) byla dyskusja z Piotrem Wyderskim o roznych
    > przelacznikach do gcc na tej grupie. Sprobuj - a nuz...

    Już się bawiłem rtti i okolicami. Cięzko trafić jesli to wina
    przełacznika sądząc po ich ogromie.

    PS. 4.x nie działa również, więc to jakiś problem raczej nie typu bug w gcc.


  • 6. Data: 2009-02-08 21:41:04
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Jerry1111 <j...@w...pl.pl.wp>

    Sebastian Bialy wrote:
    > Jerry1111 wrote:
    >>> Będę jeszcze próbował gcc w jakiejś nowszej wersji z lini 4.x. Być
    >>> może to bug.
    >
    >> Kiedys (pare lat juz bedzie) byla dyskusja z Piotrem Wyderskim o
    >> roznych przelacznikach do gcc na tej grupie. Sprobuj - a nuz...
    >
    > Już się bawiłem rtti i okolicami. Cięzko trafić jesli to wina
    > przełacznika sądząc po ich ogromie.
    >
    > PS. 4.x nie działa również, więc to jakiś problem raczej nie typu bug w
    > gcc.

    Moze opcje jakies defaultowo poustawiane? Wywolujesz kompilator z
    'palca' i w srodowisku nie masz nic na co on zareaguje?

    Jakby to byl blad, to by o tym powinno byc glosno. 3.4.3 nie takie nowe
    jest.


    --
    Jerry1111


  • 7. Data: 2009-02-08 21:47:32
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Jerry1111 wrote:
    > Moze opcje jakies defaultowo poustawiane? Wywolujesz kompilator z
    > 'palca' i w srodowisku nie masz nic na co on zareaguje?

    Hmmm nie wiem o czym mówisz, ale po prostu robie wszystko standardowo
    może poza -nodefaultlibs dzięki któremu zaoszczędzam na takich features
    jak fteel i podobnie bardzo istotnych funkcjach na uC. W zasadzie jedyne
    co jest podejrzane to startup wzięty "z internetu", acz działający we
    wszystkich aspektach. Mam też FreeRTOS ale go wyłaczyłem i wchodząc na
    czysto do funkcji main od razu mam taki problem jak niedziałanie
    wirtualnych wywołań. Ponieważ psuje się od razu w main to podejrzewam że
    startup czegoś nie ustawia.

    > Jakby to byl blad, to by o tym powinno byc glosno. 3.4.3 nie takie nowe
    > jest.

    Dlatego szukam błedu u siebie. Jest też inna sprawa że jestem być może
    jedyny na świecie który chce mieć C++ na ARM7...


  • 8. Data: 2009-02-08 22:39:51
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Sebastian Bialy wrote:
    > Dlatego szukam błedu u siebie.


    No i znalazłem. Oczywiście był tam gdzie nie spodziewałem się go znaleźć.

    Skrypt linkera nie posiadał 3 linijek:

    *(.rodata)
    *(.rodata*)
    *(.gnu.linkonce.r.*)

    Znalazłem to grzebiąc w asm i zauważając wskaźnik w okolicy konstruktora
    X który ewidentnie wskazywał w "dziurę" w której nie było żadnych
    danych. Dodanie tych sekcji "wypełniło" tą dziurę właściwymi strukturami
    vtable.


  • 9. Data: 2009-02-09 01:10:20
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Adam Dybkowski <a...@4...pl>

    Sebastian Bialy pisze:

    > No i znalazłem. Oczywiście był tam gdzie nie spodziewałem się go znaleźć.
    > Skrypt linkera nie posiadał 3 linijek:
    > *(.rodata)
    > *(.rodata*)

    No to nieźle. Jak do tej pory działały Ci chociażby zwykłe printf'y?
    Ciągi znaków pisane normalnie w cudzysłowach wpadają właśnie do sekcji
    .rodata, nie zacząłeś dochodzenia od wypisania czegokolwiek na debugu?

    --
    Adam Dybkowski
    http://dybkowski.net/

    Uwaga: przed wysłaniem do mnie maila usuń cyfry z adresu.


  • 10. Data: 2009-02-09 06:59:20
    Temat: Re: ARM7 - nie działa wołanie metod wirtualnych.
    Od: Sebastian Bialy <h...@p...onet.pl>

    Adam Dybkowski wrote:
    > No to nieźle. Jak do tej pory działały Ci chociażby zwykłe printf'y?
    > Ciągi znaków pisane normalnie w cudzysłowach wpadają właśnie do sekcji
    > .rodata, nie zacząłeś dochodzenia od wypisania czegokolwiek na debugu?

    Na razie debugowałem ledami :P

strony : [ 1 ]


Szukaj w grupach

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: