Giter VIP home page Giter VIP logo

asynchronous-fifo's Introduction

Asynchronous-FIFO

#About the project This project is mainly focus on build an asynchronous fifo in verilog and make further optimization. Also, this project is used as github 101 to let me familar with github.

#What is FIFO? FIFO means first in first out. a method for organizing and manipulating a data buffer. FIFOs are commonly used in electronic circuits for buffering and flow control between hardware and software. In its hardware form, a FIFO primarily consists of a set of read and write pointers, storage and control logic. Storage may be static random access memory (SRAM), flip-flops, latches or any other suitable form of storage. For FIFOs of non-trivial size, a dual-port SRAM is usually used, where one port is dedicated to writing and the other to reading.

#When use FIFO FIFOs are often used to safely pass data from one clock domain to another asynchronous clock domain. FIFO can also used between different date width.

#Metastability issues

Gray code Gray codes only allow one bit to change for each clock transition, eliminating the problem associated with trying to synchronize multiple changing signals on the same clock edge. Cons: Gray code counters must have power-of-2 counts in the sequence. (因为格雷码必须循环一个2^n,否则就不能保证两个相邻码元之间相差一位的条件)

In synchronous FIFO, when read pointer catches write pointer, FIFO will flag empty status. When wite pointer catches read pointer, FIFO will flag empty status. To distinguish between the two situations, a simple and robust solution is to add one extra bit for each read and write address which is inverted each time the address wraps. The condition changes to:

When the read address register equals the write address register, the FIFO is empty. When the read address LSBs equal the write address LSBs and the extra MSBs are different, the FIFO is full.

In asynchronous FIFO, empty flag occurs when write pointer catches up to the synchronized and sampled read pointer. Full flag occurs when read pointer catches up to the synchronized and sampled write pointer. The synchronized and sampled pointer might not reflect the current value of the actual pointer. When used gray code, the condition changes to:

When the read address register equals the write address register, the FIFO is empty. When the read address LSBs equal the last two write address LSBs and the two extra MSBs are either different, the FIFO is full.

#FIFO that is not in 2^n deep

#Synchronizer (2phase vs 3phase) 10m工作时钟写数20m时钟读,与10m时钟写数100m时钟读数的区别是什么? 从快时钟到慢时钟传输

#Different date width 异步FIFO有数据位转换功能,32b的数据入16b数据出

#泊松分布? Memory depth selection (FIFO 一个大的问题就是如何保证buffer长度适用于读写的速率差,buffer短了,写的太快,读的太慢就会丢失数据,buffer太长又是浪费,同时还要考虑,突发的爆发性写入速率,比如网页的访问和处理,应用里写入的速度很多是呈泊松分布的,这个方面有很多研究)

#Reference https://en.wikipedia.org/wiki/FIFO_(computing_and_electronics) Cummings, Clifford E. "Simulation and synthesis techniques for asynchronous FIFO design." SNUG 2002 (Synopsys Users Group Conference, San Jose, CA, 2002) User Papers. 2002. https://www.zhihu.com/question/32275527 http://blog.sina.com.cn/s/blog_603b57d50100dz5h.html

asynchronous-fifo's People

Contributors

jonathanjing avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.