eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaXilinx Spartan 3, "komponent" BSCAN i komunikacja przez JTAGXilinx Spartan 3, "komponent" BSCAN i komunikacja przez JTAG
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!takemy.news.tel
    efonica.de!telefonica.de!feeder2.ecngs.de!ecngs!feeder.ecngs.de!81.171.118.64.M
    ISMATCH!peer04.fr7!news.highwinds-media.com!newsfeed.neostrada.pl!unt-exc-01.ne
    ws.neostrada.pl!unt-spo-a-02.news.neostrada.pl!news.neostrada.pl.POSTED!not-for
    -mail
    Newsgroups: pl.misc.elektronika
    X-Mozilla-News-Host: news://news.tpi.pl:119
    From: Grzegorz Kurczyk <g...@c...usun.slupsk.pl>
    Subject: Xilinx Spartan 3, "komponent" BSCAN i komunikacja przez JTAG
    Date: Fri, 18 Sep 2015 23:44:30 +0200
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101
    Thunderbird/38.2.0
    MIME-Version: 1.0
    Content-Type: text/plain; charset=iso-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    Lines: 93
    Message-ID: <55fc85be$0$602$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 46.170.136.234
    X-Trace: 1442612670 unt-rea-a-01.news.neostrada.pl 602 46.170.136.234:49748
    X-Complaints-To: a...@n...neostrada.pl
    X-Received-Bytes: 4323
    X-Received-Body-CRC: 1453004382
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:686146
    [ ukryj nagłówki ]

    Witam.
    Mam pytanie do Kolegów rzeźbiących w FPGA Xilinxa. Próbuję wykombinować
    loader umożliwiający mi za pośrednictwem JTAG-a wrzucenie danych do
    wewnętrznej pamieci BlockRAM w FPGA. Poniżej fragment opisujący obsługę
    sygnałów z BSCAN

    reg [31:0] JTAG_SR;
    reg [31:0] JTAG_OUT;

    BSCAN_SPARTAN3 BSCAN_SPARTAN3_inst (
    .CAPTURE(BS_CAPTURE), // CAPTURE output from TAP controller
    .DRCK2(BS_DRCK2), // Data register output for USER2 functions
    .SEL2(BS_SEL2), // USER2 active output
    .SHIFT(BS_SHIFT), // SHIFT output from TAP controller
    .TDI(BS_TDI), // TDI output from TAP controller
    .UPDATE(BS_UPDATE), // UPDATE output from TAP controller
    .TDO2(JTAG_SR[0]) // Data input for USER2 function
    );

    always @(posedge BS_DRCK2) begin
    if(BS_SHIFT) begin
    JTAG_SR <= {BS_TDI, JTAG_SR[31:1]};
    end
    end

    always @(posedge BS_UPDATE) begin
    if(BS_SEL2) begin
    JTAG_OUT <= JTAG_SR;
    end
    end

    =====

    Próbuję to potraktować za pośrednictwem programu iMPACT w trybie
    wsadowym. Wsad wygląda tak (w łańcuchu JTAG mam jeszcze pamięć
    konfiguracyjną)

    setMode -bs
    setCable -port auto

    bsdebug -start
    bsdebug -reset

    # pamięć na BYPASS, FPGA na USER2
    bsdebug -scanir 11111111000011 -irlength 14

    # dane do przeslania, pierwszy bit to BYPASS pamieci konfiguracyjnej
    bsdebug -scandr 000000000000000000000111100001111 -drlength 33
    bsdebug -scandr 000000000000000010000011111101100 -drlength 33
    bsdebug -scandr 000000000000000100000111100001111 -drlength 33
    bsdebug -scandr 000000000000000110000011001101010 -drlength 33
    bsdebug -scandr 000000000000001000000111100001111 -drlength 33
    bsdebug -scandr 000000000000001010000011010000001 -drlength 33
    bsdebug -scandr 000000000000001100000111100001111 -drlength 33
    bsdebug -scandr 000000000000001110000011010000110 -drlength 33
    bsdebug -scandr 000000000000010000000111100001111 -drlength 33
    bsdebug -scandr 000000000000010010000011010001011 -drlength 33
    bsdebug -scandr 000000000000010100000111100001111 -drlength 33
    bsdebug -scandr 000000000000010110000011010010000 -drlength 33
    bsdebug -scandr 000000000000011000000111100001111 -drlength 33
    bsdebug -scandr 000000000000011010000011010011000 -drlength 33
    bsdebug -scandr 000000000000011100000111100001111 -drlength 33
    bsdebug -scandr 000000000000011110000011011011111 -drlength 33
    bsdebug -scandr 000000000000100001010000111111111 -drlength 33
    bsdebug -scandr 000000000000100011101000100010000 -drlength 33
    bsdebug -scandr 000000000000100100111000000110000 -drlength 33
    bsdebug -scandr 000000000000100111100000100000001 -drlength 33
    ... duuuuuuużo linijek z scandr
    bsdebug -scandr 000001111111110110000000000000000 -drlength 33
    bsdebug -scandr 000001111111111000000000000000000 -drlength 33
    bsdebug -scandr 000001111111111010000000000000000 -drlength 33
    bsdebug -scandr 000001111111111100000000000000000 -drlength 33
    bsdebug -scandr 000001111111111110000000000000000 -drlength 33

    bsdebug -stop
    closeCable
    quit

    =======

    Programator USB DLC9G. Robię kilka prób z tym samym plikiem wsadowym.
    Czasem to zadziała (zwłaszcza jak jest niewiele linii bsdebug -scandr),
    ale najczęściej przejdzie kilkadziesiąt pierwszych słów 32-bitowych i
    przestają się pojawiać sygnały DRCK2 i UPDATE. Często dochodzi do resetu
    układu lub niekiedy nawet jego przeprogramowania.


    P.S. Na tym samym sprzęcie (komputer/programator/Xilinx) układ FPGA
    poprawnie przyjmuje "wsad" przez JTAG-a.

    --
    Pozdrawiam
    Grzegorz

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: