Thông báo

Collapse
No announcement yet.

Nhận dự liệu từ cổng nối tiếp RS232 trên board FPGA

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • #16
    Minh dang thu truyen du lieu qua cong RS 232 xuong KIT DE2.Sau do luu du lieu vao RAM.Da ai lam chua??? xin chi giao ho.

    Comment


    • #17
      Em cũng đang làm cái truyền file qua RS232 từ PC, thực hiện trên EDK làm uP nhúng chứ ko làm cứng bằng HDL. Gửi nhận 1 character thì đc rồi nhưng file thì vẫn chưa đc. Tại em cug mới lần đầu làm trên EDK nên chưa hỉu lắm. Em làm quá trình nhận như đã làm thành công PC-to-PC, tức là vất hàm nhận XUartLite_Recv() vào trong hàm xử lý ngắt nhận nhưng debug thì chỉ toàn thấy save được byte đầu tiên của mỗi lần đọc vào SRAM.

      Bác nào quan tâm hoặc làm rồi thì cùng trao đổi nhé
      Last edited by NEO3F; 27-04-2008, 00:34.

      Comment


      • #18
        Cho minh hoi sau khi DEII nhan data tu RS232 thi viec xu li thuc hien o dau va data muon truyen ra LCD thi lam the nao?Ban nao giup minh.

        Comment


        • #19
          Nguyên văn bởi duchut Xem bài viết
          Minh dang thu truyen du lieu qua cong RS 232 xuong KIT DE2.Sau do luu du lieu vao RAM.Da ai lam chua??? xin chi giao ho.
          Uhm, mình cũng đang làm tiếp vấn đề này...Ban đầu mình test nhận data từ PC và xuất trực tiếp ra các LED. Hiện tại cũng đang tìm hiểu SRAM trên board để lưu data...Có ji trao đổi thêm qua email: tienbkit@gmail.com nha

          Nguyên văn bởi thaohoa Xem bài viết
          Cho minh hoi sau khi DEII nhan data tu RS232 thi viec xu li thuc hien o dau va data muon truyen ra LCD thi lam the nao?Ban nao giup minh.
          Nếu chỉ xuất ra LCD thì bạn có thể làm trực tiếp luôn, ko cần thiết phải dùng thiết bị lưu trữ như SRAM hay SDRAM....Việc xuất ra LCD thì mình chưa thử làm...hihi,bạn làm làm rùi thì chia sẻ cho mọi người cùng tham khảo với nhé!!!

          Comment


          • #20
            Nguyên văn bởi duchut Xem bài viết
            chu de RS232 soi noi that.Minh da lam thu tren KIT DE2 cua Artera thi thay no chay dung.Thuc ra thi moi Kit cua moi hang khac nhau thi cung co cung mot nguyen tac.Minh post code RS_receive viet bang VHDL len anh em gop y nhe.Code nay minh lay tren trang http://www.fpga4fun.com/ExternalContributions/.Phan receiver minh co chinh sua mot ty thi no chay duoc tren KIT DE2 cua Artera.
            --
            -- UART: receiver
            --
            -- Copyrighted by Wincent Balin
            -- Idea by Jean P. Nicolle
            --

            library ieee;
            use ieee.std_logic_1164.all;
            use ieee.std_logic_arith.all;

            entity UARTReceiver is
            generic
            (
            frequency : integer:=50000000;
            baud : integer:=9600;
            oversampling : integer:=8
            );
            port
            (
            clk : in std_logic;
            rxd : in std_logic;
            rxd_data : out std_logic_vector(7 downto 0);
            rxd_data_ready : out std_logic
            );
            end entity UARTReceiver;

            architecture UARTReceiverArch of UARTReceiver is
            -- defining constants
            constant BIT_SPACE : integer := 10; -- 8 to 11 are common
            constant DIVISOR : integer := 1600;
            constant FREQ_INC : integer := (oversampling + 0) * baud / DIVISOR;
            constant FREQ_DIV : integer := frequency / DIVISOR;
            constant FREQ_MAX : integer := FREQ_DIV + FREQ_INC - 1;
            -- defining types
            type state_type is (idle, bit0, bit1, bit2, bit3, bit4, bit5, bit6, bit7, stop);
            -- defining signals
            signal state : state_type := idle; -- receiver's state
            signal rxd_sync_inv : std_logic_vector(1 downto 0);
            signal rxd_cnt_inv : std_logic_vector(1 downto 0);
            signal rxd_bit_inv : std_logic;
            signal baud_divider : integer range 0 to FREQ_MAX := 0;
            signal data : std_logic_vector(7 downto 0);
            signal baudover_tick : std_logic := '0';
            signal bit_spacing : integer range 0 to 15;
            signal next_bit : std_logic := '0';
            begin
            -- assignments
            next_bit <= '1' when bit_spacing = BIT_SPACE else '0';
            -- processes
            baud_gen : process(clk)--dung de bam xung, tao ra xung co tan so lon hon toc do baud
            begin
            if clk'event and clk = '1' then
            baud_divider <= baud_divider + FREQ_INC;
            if baud_divider >= FREQ_DIV then
            baud_divider <= 0;
            baudover_tick <= '1';
            else
            baudover_tick <= '0';
            end if;
            end if;
            end process baud_gen;
            --
            rxd_sync_inverted : process(clk) -- inverted to suppress phantom character
            begin
            if clk'event and clk = '1' then
            if baudover_tick = '1' then
            rxd_sync_inv <= rxd_sync_inv(0) & not rxd;
            end if;
            end if;
            end process rxd_sync_inverted;
            --
            rxd_counter_inverted : process(clk)
            begin
            if clk'event and clk = '1' then
            if baudover_tick = '1' then
            if rxd_sync_inv(1) = '1' and rxd_cnt_inv /= "11" then
            rxd_cnt_inv <= unsigned(rxd_cnt_inv) + 1;
            elsif rxd_sync_inv(1) = '0' and rxd_cnt_inv /= "00" then
            rxd_cnt_inv <= unsigned(rxd_cnt_inv) - 1;
            end if;

            if rxd_cnt_inv = "00" then
            rxd_bit_inv <= '0';
            elsif rxd_cnt_inv = "11" then
            rxd_bit_inv <= '1';
            end if;
            end if;
            end if;
            end process rxd_counter_inverted;
            --
            state_proc : process(clk)
            begin
            if clk'event and clk = '1' then
            if baudover_tick = '1' then
            case state is
            when idle =>
            if rxd_bit_inv = '1' then
            state <= bit0;
            end if;
            when bit0 =>
            if next_bit = '1' then
            state <= bit1;
            end if;
            when bit1 =>
            if next_bit = '1' then
            state <= bit2;
            end if;
            when bit2 =>
            if next_bit = '1' then
            state <= bit3;
            end if;
            when bit3 =>
            if next_bit = '1' then
            state <= bit4;
            end if;
            when bit4 =>
            if next_bit = '1' then
            state <= bit5;
            end if;
            when bit5 =>
            if next_bit = '1' then
            state <= bit6;
            end if;
            when bit6 =>
            if next_bit = '1' then
            state <= bit7;
            end if;
            when bit7 =>
            if next_bit = '1' then
            state <= stop;
            end if;
            when stop =>
            if next_bit = '1' then
            state <= idle;
            end if;
            end case;
            end if;
            end if;
            end process state_proc;
            --
            bit_spacing_proc : process(clk)
            begin
            if clk'event and clk = '1' then
            if state = idle then
            bit_spacing <= 0;
            elsif baudover_tick = '1' then
            if bit_spacing < 15 then
            bit_spacing <= bit_spacing + 1;
            else
            bit_spacing <= 8;
            end if;
            end if;
            end if;
            end process bit_spacing_proc;
            --
            shift_data_proc : process(clk)
            begin
            if clk'event and clk = '1' then
            if baudover_tick = '1' and next_bit = '1' and
            state /= idle and state /= stop then
            data <= not rxd_bit_inv & data(7 downto 1);
            end if;
            end if;
            end process shift_data_proc;
            --
            output_data_proc : process(clk)
            begin
            if clk'event and clk = '1' then
            if baudover_tick = '1' and next_bit = '1' and
            state = stop and rxd_bit_inv = '0' then
            rxd_data <= data;
            rxd_data_ready <= '1';
            else
            rxd_data_ready <= '0';
            end if;
            end if;
            end process output_data_proc;
            end UARTReceiverArch;
            Bạn có thể giải thích một chút về từng đoạn mã trên được không,mình đọc mãi mà vẫn không hiểu,nhất là đoạn bit_spacing_proc và đoạn rxd_counter_inverted,mình biết nhiều người mới tìm hiểu FPGA chắc cũng chưa thể hiểu được!
            Technical Institutes
            Mobile: 0983278725
            Email:

            Comment


            • #21
              Rs232

              Sao mình cũng làm như Code của bạn, thử nghiệm trên Spartan 3e kit nhưng chiều nhận dữ liệu từ máy tính không bao giờ đúng,dữ liệu luôn là "11111111".Chiều truyền thì rất đúng?
              Technical Institutes
              Mobile: 0983278725
              Email:

              Comment


              • #22
                chao cac ban! minh dang lam do an thu phat du lieu tu may tinh qua kit Spartan 3E voi phuong thuc truyen dung song RF, hien tai minh khong biet cach nhan du lieu tren kit nhu the nao, ban nao co phuong an giup do minh voi chan thanh cam on va xin hau ta

                Comment

                Về tác giả

                Collapse

                tienbkit Tìm hiểu thêm về tienbkit

                Bài viết mới nhất

                Collapse

                • mèomướp
                  Trả lời cho Sửa bộ nguồn DC 60V 45A
                  bởi mèomướp
                  Dạ hông dám làm thì chắc chắn sẽ mãi ko thể làm được đâu ạ. Nguồn xung dân dụng vài kw giờ rất nhìu ạ, sạc ô tô điện, máy hàn, lò vi sóng, âm ly... tùy chất lượng mà độ phức tạp sẽ khác nhau ạ. Và cái giá phải trả về kinh tế...
                  Hôm qua, 13:11
                • tuyennhan
                  Trả lời cho Sửa bộ nguồn DC 60V 45A
                  bởi tuyennhan
                  Sửa dạng này thì chuyên còn không dám chắc khộng cháy nổ với linh kiện bán ngoài chợ nói gì khộng chuyên .
                  Hôm qua, 09:25
                • tuyennhan
                  Trả lời cho Cần tư vấn cải thiện chất âm thanh loa SoNy.
                  bởi tuyennhan
                  Đúng rồi chọn mua theo tai . ca thì phải toàn dải nhạc thì chỉ cao và thấp thé nên loa ca thì nghe nhạc không hay và ngược lại .
                  Muốn ca và nhạc đều hay thì phải dúng 2 giàn , còn nếu chỉ có 1 thì phải chỉnh sửa lại sao cho ca và nhạc đều được không quá dở ....
                  Hôm qua, 09:10
                • Ng.Phuong.5
                  Vấn đề in lỗ khoan ra pdf ở Orcad 9.2
                  bởi Ng.Phuong.5
                  Vấn đề cũ: khi in mạch ra pdf và bấm chọn Keep Drill Holes Open, in ra thì pdf trắng đen các lỗ chân linh kiện như nhau. Mặc dù có linh kiện phần Drill là 1mm, có linh kiện thì là 3mm. Cho em hỏi cách sửa phần này ở Orcad 9.2 với ạ.
                  Mấy con...
                  09-01-2025, 19:44
                • viettinh
                  Trả lời cho Cần tư vấn cải thiện chất âm thanh loa SoNy.
                  bởi viettinh
                  Bác nói đúng quá. Cơ mà muốn mua hàng chính hãng, hàng thương hiệu mà tai lại hợp hàng tầu mới khổ chứ.
                  Đang tính mua cái loa tầu nữa cột đằng sau loa này, Loa sony chỉ để hát nhép thôi, có dc k các bác ...
                  09-01-2025, 18:12
                • nguyendinhvan
                  Trả lời cho Cần tư vấn cải thiện chất âm thanh loa SoNy.
                  bởi nguyendinhvan
                  Theo tôi thì khi hpj sản xuất ra cái loa đó, đã có nhiều chuyên gia kỹ thuật hiệu chỉnh, tính toán các phần tử kỹ lưỡng rồi.
                  Bây giờ tính toán hiệu chỉnh lại cần có đội ngũ tương đương với nhà sản xuất.
                  Cách đơn giản...
                  09-01-2025, 00:04
                • mèomướp
                  Trả lời cho Sửa bộ nguồn DC 60V 45A
                  bởi mèomướp
                  Dạ cháu có ý tốt muốn động viên chú ấy ngâm cứu khoa học thôi ạ. Về phần kiểm tra dao động thì chú ấy chưa biết thì sẽ tìm hiểu được là cần những gì ạ, chắc chắn là khi hướng dẫn phần ấy các cô chú nào đó sẽ lưu ý cần loại sò công suất ra tránh cháy nổ rồi ạ....
                  08-01-2025, 19:02
                • tuyennhan
                  Trả lời cho Sửa bộ nguồn DC 60V 45A
                  bởi tuyennhan
                  Chủ thớt hỏi có kiểm tra được dao động mà không cấp nguồn thì rõ trình ở mức nào mà mèo còn xúi ngâm cứu nữa ác vậy ....
                  08-01-2025, 15:43
                • tuyennhan
                  Trả lời cho Cần tư vấn cải thiện chất âm thanh loa SoNy.
                  bởi tuyennhan
                  Loa bass đấu trực tiếp không qua phân tần để thành loa toàn dải xem có thoát tiếng khộng , nếu không thoát cần phải sửa lại mạch cs hay âm sắc nếu đủ trình còn nếu thoát ca hay nhưng chưa vừa ý vì bass kém chăc thì đấu lại như cũ và đấu thêm loa mid treble bên ngoài .
                  08-01-2025, 15:28
                • mèomướp
                  Trả lời cho Cần tư vấn cải thiện chất âm thanh loa SoNy.
                  bởi mèomướp
                  Dạ loa tép bé xíu như ngón chân cái thôi ạ. Thiếu gì chỗ để đâu. Quan trọng là gắn thêm nó loa nghe ok hay ko thôi ạ...
                  08-01-2025, 11:44
                Đang tải...
                X