Thông báo

Collapse
No announcement yet.

AES ( advanced encryption standard ) - use FPGA - ask & answer

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

  • AES ( advanced encryption standard ) - use FPGA - ask & answer

    Em mở mục này ra để thảo luận về vấn đề này.

    Nếu ai có ý định làm về cái này hoặc đã làm rồi, nhào zo để cùng thảo luận

    http://www.csrc.nist.gov/publication...7/fips-197.pdf
    http://www.cs.eku.edu/faculty/styer/...pt/JS-AES.html

  • #2
    S- Box. Thiết kế thế nào cho hợp lý

    Câu hỏi đầu tiên em muốn mọi người cùng thảo luận về khối S-Box.
    Khối em đang làm là dùng case When ứng với 256 dòng lệnh cho từng đầu vào. Cách này rất tốn bộ nhớ.

    Có một cách thứ hai là lệnh xor. Nhưng không hỉu là toàn chạy lỗi.
    theo link dưới đây: http://en.wikipedia.org/wiki/Rijndael_S-box

    PHP Code:
        buff_data_out(0) <= data_in(0) xor data_in(4) xor data_in(5) xor data_in (6) xor data_in(7) xor '1' ;
        
    buff_data_out(1) <= data_in(0) xor data_in(1) xor data_in(5) xor data_in (6) xor data_in(7) xor '1' ;
        
    buff_data_out(2) <= data_in(0) xor data_in(1) xor data_in(2) xor data_in (6) xor data_in(7)  ;
        
    buff_data_out(3) <= data_in(0) xor data_in(1) xor data_in(2) xor data_in (3) xor data_in(7) ;
        
    buff_data_out(4) <= data_in(0) xor data_in(1) xor data_in(2) xor data_in (3) xor data_in(4) ;    
        
    buff_data_out(5) <= data_in(1) xor data_in(2) xor data_in(3) xor data_in (4) xor data_in(5) xor '1';
        
    buff_data_out(6) <= data_in(2) xor data_in(3) xor data_in(4) xor data_in (5) xor data_in(6) xor '1';
        
    buff_data_out(7) <= data_in(3) xor data_in(4) xor data_in(5) xor data_in (6) xor data_in(7) ; 
    Last edited by FFGmember; 07-04-2006, 12:07.

    Comment


    • #3
      Lỗi gì thế bạn
      Vẫn biết mỗi lần xa là một lần về lại...

      Comment


      • #4
        Nguyên văn bởi qmk
        Lỗi gì thế bạn
        Khi test em không ra được bảng S-box như bảng mẫu. Mà rỗ ràng là đã ráp đúng công thức rồi ?????

        Comment


        • #5
          Một design dùng Virtext 4.

          Các chức năng của mạch: nhận chuỗi data từ PC mã hoá/giải mâ rồi truyền ngươc trở lại cho PC. Áp dụng cho 128 key bit. Tốc độ 200Mb/s cho tần số thạch anh 100MHz, ứng với một chu kỳ mất 44clock
          Dung lượng : total slice register 2615

          Bác nào có ý định làm về đề tài này thì chúng ta có thể thảo luận dưới đây. Cùng nhau chia sẻ kiến thức
          Attached Files

          Comment


          • #6
            Tôi đã làm qua 1 thời gian, nhưng không thành công. Tuy nhiên xin đóng góp vài ý kiến.
            1. 44 chu kỳ xung clock là chuyện chỉ co 1 thể làm mô phỏng, còn chạy trên FPGA thì không thể. Tiêu chí luôn là nhỏ gọn. một số hãng đã làm thành công với Spartan (~50k gate). Với 44 chu kỳ clk thì e Virtes 4 cũng không đủ. Đừng tham xử lý quá nhiều bit 1 lần như trong Standard, phải tự tìm cách chia nhỏ quá trình. Theo tôi biết thì cần không dưới 100 clk cho 1 chu kỳ xử lý.
            2. Nếu làm trên FPGA thì phải tính phương án thích hợp với FPGA, trừ khi bạn muốn làm chip riêng (!), không thì phải tìm hiểu thanh phần Ram trên Virtex để tận dụng, nó là mấu chốt để giải quyết S Box.
            3. Trước tiên, phải dùng C hay ngôn ngữ cấp cao bạn biết để lập trình thử, chạy xong rồi, đúng kết quả thì mới có thể làm với VHDL hay Verilog. nhào vô viết ngay HDL là tự sát. Quá trình viết HDL sẽ tập trung vào tối ưu hóa. Đùng coi thường C model !!!
            4. Hết sức quan trọng, bạn đã có kinh nghiệm viết HDL chưa, design ko dễ dàng tí nào. Viết code là bước cuối cùng của quá trinh design, có thể nói là ko khó. khó là viết cái gì, theo hướng nào .
            Vài ý kiến nhỏ, nếu tinh toán sai, giải thuật không tốt thì viết xong chỉ chạy đuợc mô phỏng!!! Lên board thì debug điên luôn. Có thể search các phương án trên mạng và lựa ra đề nghị tốt nhất mà nghiên cứu.

            Comment


            • #7
              Chào anh. Anh nói đúng quá trình viết không hề đơn giản chút nào. Để làm cái này em đã mất 3 thàng làm một cách liên tuc. Đã làm thành công, đã được các thầy các anh chuyên môn xem xét và chấp nhân. 44 chu kỳ clock của em vẫn còn có thể giảm xuống còn 22 chu kỳ nữa, nhưng em vãn chưa làm thành công, vì chưa có thời gian đầu tư và nâng cấp tiếp.

              AES ở trên TG họ chỉ làm có 11 chu kỳ mà thôi, và tốc độ đã lên tới hàng Gb/s, cái của em làm là quá nhỏ bé so với họ

              Một lần nữa anh lại đúng là FPGA ko thể đứng một mình nó đẻ tạo ra sản phẩm được hì, em đang đầu tư vào các khác, - những cái mà FPGA là công cụ phụ trợ cho nó.

              FFGmember

              Comment


              • #8
                Có thể cho tôi hỏi thử, bạn đã chạy trên kit chưa. Trước kia tôi làm là để chạy trên FPGA nên tốc độ càng chậm thì càng dễ nạp nên bay giờ thắc mắc. Tốc độ cao quá hẳn bạn làm pipeline rất tốt !

                Comment


                • #9
                  Nguyên văn bởi TA
                  Có thể cho tôi hỏi thử, bạn đã chạy trên kit chưa. Trước kia tôi làm là để chạy trên FPGA nên tốc độ càng chậm thì càng dễ nạp nên bay giờ thắc mắc. Tốc độ cao quá hẳn bạn làm pipeline rất tốt !
                  Vâng tất nhiên là chạy trên kít rồi. Cái pipline đó giá mà em làm được thì tốc độ đã lên tới hàng GHz roài, em cũng muốn tìm hiểu cái này hik nhưng chưa có thời gian đầu tư tiếp, đã mất quá nhiều thời gian cho cái này roài. Anh đã làm về pipeline trên FPGA chưa, thực sự em còn mù tịt về công nghệ này :

                  Comment


                  • #10
                    xin hỏi bây giờ em muốn làm bộ mã hóa AES sử dụng FPGA thì phải bắt đầu từ cái gì vậy anh?
                    Anh đã làm rùi có thể chỉ cho em được không?
                    |

                    Comment


                    • #11
                      Ý định chỉ là mã hóa hay ***** AES?

                      Comment


                      • #12
                        Vâng,em đang định thực hiện một bộ mã hóa và giải mã AES, viết bằng Verilog.Nhưng bây giờ không biết bắt đầu ra sao?Anh có thể chỉ cho em được không?
                        |

                        Comment


                        • #13
                          chào các bạn, mình đang làm btl về bộ mã hóa AES, project mình làm chỉ đơn giản ở mức
                          mô phỏng nên mình cũng chưa quan tâm lắm đến vấn đề tốc độ mã hóa của nó ra sao, hì hì
                          các bạn có thể xem qua tài liệu trên trang http://cegt201.bradley.edu/projects/proj2005/aes128/
                          ở đây có cả code và documents rất hữu ích cho những ai mới bắt đầu với AES.
                          Khi nào project hoàn thành mình sẽ post lên cho pà con tham khảo sau.

                          Chúc mọi người học tốt!

                          Comment


                          • #14
                            Bạn có thể dùng BRAM thay cho khối "case When" ở trong khối S-Box

                            Comment

                            Về tác giả

                            Collapse

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

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

                            Collapse

                            • tuyennhan
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi tuyennhan
                              Cái thư sai ngay câu chào Dear sir mới đúng Hi chỉ dùng cho người quen , các vấn đề về kỹ thuật nó không trả lời hoặc nói loanh quanh tránh ảnh hưởng đến công ty .
                              Giup1 người cần không giúp người không cần với lại văn mình vợ người nha đừng quên .
                              hôm nay, 07:44
                            • vi van pham
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi vi van pham
                              Cám ơn những lời chúc tốt đẹp của em.

                              Việc em làm giống như chê sếp dốt, chẳng những không có miếng xôi nào để ăn mà còn chịu nhiều trù dập lên bờ , xuống ruộng.

                              Hãy tránh vết xe đổ của tui đi. Dành thời gian lo cho gia đình....
                              hôm nay, 02:00
                            • nhathung1101
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi nhathung1101
                              Ngoại ngữ là không thể thiếu, nhất là làm việc với công nghệ.

                              Nhưng học để tán gái hay để đọc datasheet, manual là chuyện cần quan tâm.

                              Và đọc ở nguồn nào đáng tin cậy, chứ cứ lên tictok hay facebook học lỏm thì...
                              Hôm qua, 22:18
                            • dinhthuong80
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi dinhthuong80
                              Bác nói rất khách quan và chính xác. Ngoại ngữ là chìa khóa thăng tiến dù làm gì. Chả thế mà nay nước mình dạy tiếng Anh từ tiểu học.

                              Nhớ hồi năm 2006 em ra Hải Phòng, Hải Dương tìm việc, thời đó ở Bình Dương lương công...
                              Hôm qua, 14:51
                            • dinhthuong80
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi dinhthuong80
                              Cảm ơn bạn, ĐT cũng có ý nghĩ như vậy.

                              Thực ra, lỗi của hãng đó ( gọi là hãng vì không chỉ một model sản phẩm) là về phần cứng, ĐT tuy không biết về lập trình phần mềm nhưng cũng thấy rằng sẽ chẳng khó khăn gì đáng...
                              Hôm qua, 14:39
                            • dinhthuong80
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi dinhthuong80
                              Dạ, bác bảy mấy tuổi đời rồi cũng không kém bố cháu bao nhiêu. Tuổi nghề thì bác cũng đáng tuổi cha chú.

                              Nhưng 2 điều trên thì chưa hẳn đã đáng quí và đáng tôn trọng bằng việc bác rất nhiệt tình chia sẻ kinh nghiệm chuyên...
                              Hôm qua, 14:28
                            • bqviet
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi bqviet
                              Đúng, nếu chú tâm thì chỉ cần mỗi tiếng Việt là đã khá đủ để làm đa số công việc thông thường, ở thời đại ngày nay khi tài liệu sách vở phương tiện thông tin liên lạc đã nhiều. Nhưng cũng chính ở thời nay giao lưu các nước nhiều...
                              21-02-2025, 20:26
                            • mèomướp
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi mèomướp
                              Dạ cháu nghĩ chú dinh... cứ mạnh dạn gửi thư đi ạ, chú có thể gửi bằng văn bản in chuyển phát nhanh sẽ có giá trị hơn. Vấn đề chưa hẳn là cần hãng làm gì đó, mà chỉ đơn giản là mình cảm thấy nhẹ lòng vì đã làm những việc bản...
                              21-02-2025, 12:32
                            • vi van pham
                              Trả lời cho Tiếng Anh cho người Việt
                              bởi vi van pham
                              Những lần hắt hơi sổ mũi làm tôi mệt lã, phải dùng rượu uống để ngũ. Tôi cũng đang uống rượu 1 mình, viết vài dòng này cho em ( có lẽ dt chỉ bằng tuổi em tôi).

                              Dinh thuong dang đi vào vết xe đổ của tôi. Càng chứng minh, có...
                              20-02-2025, 21:31
                            • bqviet
                              Trả lời cho Hỏi về cách hàn linh kiện ( giúp tớ với )
                              bởi bqviet
                              Thiết nghĩ thi thoảng bác lên đây chia xẻ ít kinh nghiệm cũng vui rồi. Còn chuyện con người sinh lão bệnh tử là thường, sống cùng với quy luật đó thôi. Bqv nhớ trước đây bác từng kể về chuyện rang chì ô-xít bằng chảo để phục hồi bình điện, đấy cũng là thành quả đáng nể phục ở thời kỳ thiếu thốn đó.
                              20-02-2025, 17:22
                            Đang tải...
                            X