

**All Sections** 

These questions are presented under the following assumptions:

- They may be selected to be part of the final exam
- Responses must be posted by the students (not me)
- I will call your attention to any mistakes or wrong content posted in response

Consider the ASMD chart represented below, which specifies the behaviour of a debouncing circuit based on a FSMD architecture, and its explicit and implicit datapath descriptions, as represented in listings 6.1 and 6.2 (attached).

- 1. What differences would a user notice in the circuit behaviour, if "q\_next" was replaced by "q\_reg" in the decision boxes of states wait1 and wait0?
- 2. Modify the ASMD chart in order to ensure that the "db\_tick" output pulse rises together with the "db\_level" output, instead of immediately before.
- 3. Modify the ASMD chart in order to generate a "db\_tick" pulse also in the case of falling edges of the "db\_level" output.
- 4. Why is it necessary to include the "q\_next" signals in the sensitivity list of the "next-state & datapath functional units/routing" process in the implicit VHDL description? (listing 6.2, line 104 in the attached file)



(img source: P. Chu's **FPGA** prototyping by VHDL examples , Figure 6.6, p. 133)



