Difference between revisions of "IOP16 Timer Unit"

From Land Boards Wiki
Jump to navigation Jump to search
Line 38: Line 38:
 
== Resources (EP4CE15) ==
 
== Resources (EP4CE15) ==
  
* Logic Cells: 87
+
* Logic Cells: 89
 
* Registers: 49
 
* Registers: 49
 
* Memory Bits: 0
 
* Memory Bits: 0

Revision as of 19:26, 10 April 2022

Timer Unit

  • Operates as a One-shot counter with single value
  • Count uS, mSec or secs (allows for different resolutions)
  • Write to count value starts timer
  • Poll timer status
Address Value      Read/Write Data
0       uSec Count Write      0-255 uS count - write starts timer
1       mSec Count Write      0-255 mS count - write starts timer 
2       Sec Count  Write      0-255 sec count - write starts timer
3       Not Used   Write      Not used
0-3     Status     Read       1 = Count In progresss
                              0 = Done

Entity

-- ____________________________________________________________________________________
-- Timer Unit
w_timerAdr	<=	'1' when (w_peripAddr(7 downto 2) = "000010") else '0';
timerUnit : entity work.TimerUnit
  port map
  (
    -- Clock and Reset
    i_clk         => i_clock,
    i_n_reset     => w_resetClean_n,
    -- The key and LED on the FPGA card 
    i_timerSel    => w_timerAdr,
    i_writeStrobe => w_peripWr,
    i_regSel      => w_peripAddr(1 downto 0),
    i_dataIn      => w_peripDataFromCPU,
    o_dataOut    => w_timerOut
);

Resources (EP4CE15)

  • Logic Cells: 89
  • Registers: 49
  • Memory Bits: 0