eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikamikrokontroler military/(aero)space 8bitRe: mikrokontroler military/(aero)space 8bit
  • Path: news-archive.icm.edu.pl!news.gazeta.pl!newsfeed.pionier.net.pl!news.glorb.com!n
    x02.iad01.newshosting.com!209.197.12.242.MISMATCH!nx01.iad01.newshosting.com!ne
    wshosting.com!newsfeed.neostrada.pl!unt-exc-02.news.neostrada.pl!atlantis.news.
    neostrada.pl!news.neostrada.pl!not-for-mail
    From: SM <b...@k...com.pl>
    Newsgroups: pl.misc.elektronika
    Subject: Re: mikrokontroler military/(aero)space 8bit
    Date: Tue, 09 Feb 2010 11:59:55 +0100
    Organization: TP - http://www.tp.pl/
    Lines: 49
    Message-ID: <hkrfc1$c2b$1@atlantis.news.neostrada.pl>
    References: <hkpjgv$adi$1@nemesis.news.neostrada.pl> <7...@m...uni-berlin.de>
    <hkqt2i$2dc$1@nemesis.news.neostrada.pl> <7...@m...uni-berlin.de>
    NNTP-Posting-Host: bap92.neoplus.adsl.tpnet.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: atlantis.news.neostrada.pl 1265713345 12363 83.27.179.92 (9 Feb 2010
    11:02:25 GMT)
    X-Complaints-To: u...@n...neostrada.pl
    NNTP-Posting-Date: Tue, 9 Feb 2010 11:02:25 +0000 (UTC)
    User-Agent: Thunderbird 2.0.0.23 (Windows/20090812)
    In-Reply-To: <7...@m...uni-berlin.de>
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:581745
    [ ukryj nagłówki ]

    >...
    > No to masz szczęście, choć mnie to nie ominęło.
    > Pomysł z wielokrotnym zapisem programu jest niegłupi. Ewentualnie, jak już
    > chcesz robić voting, to dać flashe różnych producentów. Tylko kwestia wagi
    > całości. Pewnie wystarczy jeden.


    Pewnie tak. Kwestia prawdopodobieństwa zmiany FLASHa. Można by
    w jednym FLASHu wgrać ten sam soft np. 4 razy i w przypadku
    błędu przeprogramować zły sektor pobierając dane z 3 pozostałych
    dobrych banków programu (chociaż jeden z 3 pozostałych
    to już chyba na pewno będzie OK).

    W sumie to nawet nie trzeba robić interpretera języka
    wyższego poziomu. Wystarczyłby rdzeń jakiegoś procka z dodanym
    bajtem kontrolnym dla każdej instrukcji procesora.
    Sprawę również polepszy i uprości stała długość
    kodów rozkazu.

    To samo można by zrobić z RAM dla zmiennych.

    Dajemy 3 RAMy. Wspólna szyna adresowa, szyna danych
    (załóżmy 8 bitów D0..D7) każdej pamięci osobno, ale
    schodzi się razem za dwukierunkowymi buforami
    (coś w stylu 74245). Czyli FPGA ma szynę danych tylko 8 bit.
    Zapis odbywa się tak, że bufory otwieramy w kierunku
    do RAM, WR i CE sterujemy razem. Wszystkie 3 RAMy
    zostają zapisane tak samo.
    Odczyt otwiera tylko jeden bufor, po czym RD i CE
    znów sterujemy razem. Zwarcia na lini danych
    nie będzie, bo pozostałe dwa bufory nie puszczają.

    I teraz mały numer. Do linii danych pamięci RAM
    podłączamy komparatory 8 bit. Jeden porównuje
    8bit D0..D7 pamięci nr 1 z pamięcią nr 2.
    Drugi porównuje 8bit D0..D7 pamięci nr 2 z 3,
    a trzeci 1 z 3. Każdy z 3 komparatorów daje
    sygnał do FPGA że jest nierówność. FPGA wtedy
    wie, która kość ma złą (zmienioną) wartość -
    tylko jedno wejście będzie sygnalizować równość.
    Wtedy procek ponawia odczyt ale z buforem
    otwartym tylko na jednej z dwóch dobrych RAM, po czym
    od razu robi zapis "naprawiający" do wszystkich
    trzech RAM.

    Szybkie, łatwe, sprzętowe, nie wymaga dodatkowych
    obliczeń (jakaś CRC), i do tego "naprawialne".

    SM

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: