eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaVHDL - RAM obsługujący read-during-writeVHDL - RAM obsługujący read-during-write
  • Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
    atman.pl!.POSTED!not-for-mail
    From: Jakub Rakus <s...@o...pl>
    Newsgroups: pl.misc.elektronika
    Subject: VHDL - RAM obsługujący read-during-write
    Date: Tue, 08 Jul 2014 21:07:54 +0200
    Organization: ATMAN - ATM S.A.
    Lines: 28
    Message-ID: <lphfia$oic$1@node2.news.atman.pl>
    NNTP-Posting-Host: staticline-31-183-74-163.toya.net.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: node2.news.atman.pl 1404846474 25164 31.183.74.163 (8 Jul 2014 19:07:54 GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Tue, 8 Jul 2014 19:07:54 +0000 (UTC)
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101
    Thunderbird/24.6.0
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:667502
    [ ukryj nagłówki ]

    Przeglądając tutoriale na temat sposobów pisania kodu HDL tak, żeby
    syntetyzator maksymalnie wykorzystał specjalizowane bloki FPGA natknąłem
    się na prosty przykład pamięci RAM obsługującej operacje typu read
    during write:

    ARCHITECTURE rtl OF single_clock_ram IS
    TYPE MEM IS ARRAY(0 TO 31) OF STD_LOGIC_VECTOR(2 DOWNTO 0);
    SIGNAL ram_block: MEM;
    BEGIN
    PROCESS (clock)
    BEGIN
    IF (clock'event AND clock = '1') THEN
    IF (we = '1') THEN
    ram_block(write_address) <= data;
    END IF;
    q <= ram_block(read_address);
    -- VHDL semantics imply that q doesn't get data
    -- in this clock cycle
    END IF; END PROCESS; END rtl;

    Nie do końca rozumiem dlaczego niby to:
    q <= ram_block(read_address);
    ma się wykonać dopiero przy następnym wejściu w proces? Że niby jak jest
    spełniony IF we='1' to wszystko poza nim się nie wykona?

    --
    Pozdrawiam
    Jakub Rakus

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: