eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikalwIP - odbieranie danych przez TCPlwIP - odbieranie danych przez TCP
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.man.lodz.pl!newsfeed.pionier.net.p
    l!3.eu.feeder.erje.net!feeder.erje.net!news2.arglkargh.de!news.mixmin.net!newsr
    eader4.netcologne.de!news.netcologne.de!peer01.ams1!peer.ams1.xlned.com!news.xl
    ned.com!peer03.ams4!peer.am4.highwinds-media.com!news.highwinds-media.com!newsf
    eed.neostrada.pl!unt-exc-02.news.neostrada.pl!unt-spo-b-01.news.neostrada.pl!ne
    ws.neostrada.pl.POSTED!not-for-mail
    Date: Sat, 24 Sep 2022 17:58:49 +0200
    MIME-Version: 1.0
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101
    Thunderbird/91.13.0
    Newsgroups: pl.misc.elektronika
    Content-Language: pl
    From: Atlantis <m...@w...pl>
    Subject: lwIP - odbieranie danych przez TCP
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    Lines: 49
    Message-ID: <632f2939$0$455$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 83.27.19.159
    X-Trace: 1664035129 unt-rea-a-02.news.neostrada.pl 455 83.27.19.159:49968
    X-Complaints-To: a...@n...neostrada.pl
    X-Received-Bytes: 3461
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:774550
    [ ukryj nagłówki ]

    Chciałem ostatnio popchnąć trochę do przodu jeden ze swoich poprzednich
    projektów - sprzętowe radio internetowe o którym pisałem już wcześniej,
    tylko tym razem w wersji ze zaktualizowaną częścią hardware'ową.
    Poprzednia wersja była tworzona na PIC32, teraz powoli chciałem
    przenieść go na STM32.

    Większość softu właściwie już przeniosłem, teraz zostało najważniejsze -
    przeportowanie samej aplikacji odpowiedzialnej za odtwarzanie streamu z
    Internetu. W przypadku biblioteki MLA na PIC32 było to relatywnie
    proste. Socket sieciowy dysponuje buforem FIFO o zdefiniowanej
    pojemności - do niego trafiają dane przychodzące z serwera. Dane te
    pobieram i ładuję do bufora audio. Robię to jednak dopiero wtedy, gdy
    sterownik układu VS1003 stwierdzi, że dane są potrzebne.

    W przypadku PIC32 było to relatywnie proste. Miałem kilka funkcji:
    - TCPIsGetReady() - zwracała liczbę bajtów w buforze
    - TCPGetArray() - funkcja zapisywała pod podany adres w pamięci
    określoną maksymalną liczbę bajtów z bufora. Zwracała liczbę bajtów,
    które w rzeczywistości udało się pobrać.

    Sprawa była prosta - wystarczyło albo pobrać wszystkie dostępne dane,
    ale (jeśli było ich za dużo) tylko tyle, żeby wypełnić dostępne miejsce.
    W tym drugim przypadku nadwyżka pozostawała w buforze gniazda sieciowego
    i była sukcesywnie uzupełniania o kolejne przychodzące dane, które
    mogłem pobrać wtedy, gdy znów były potrzebne.

    Widzę, że w przypadku lwIP (RAW API) sprawa nie jest już tak prosta.
    Zamiast tego muszę zarejestrować callback, który jest wołany za każdym
    razem, gdy przyjdą nowe dane. Callback otrzymuje w jednym z parametrów
    wskaźnik do struct ptr, w której mam m.in.
    - void* paylod
    - int len
    - int tot_len
    - struct pbuf* next

    Istnieje więc możliwość, że wszystko co będę musiał zrobić to pobranie
    skopiowanie len bajtów spod adresu na który wskazuje payload. Istnieje
    jednak szansa, że danych jest więcej - wtedy tot_len > len i kolejnej
    porcji danych trzeba szukać w kolejnej strukturze, na którą wskazuje
    wskaźnik next.

    Jeśli już zakończymy odczytywać dane, trzeba zawołać tcp_recved
    informując stos, że czekamy na kolejną paczkę. Tu jeszcze jest wszystko
    jasne.

    Co jednak w sytuacji, gdy powiedzmy do zakończenia wypełniania bufora
    pozostało mi 100 bajtów, a w otrzymanej struct pbuf mam ich 500? Na
    PIC32 po prostu pobierałem 100, a reszta czekała na swoją kolej. W jaki
    sposób uzyskuje się podobny efekt na lwIP?

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: