--------------------------------------------------------------------------------
--   PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL DIGI-KEY
--   ANY CLAIMS FOR INDEMNITY OR CONTRIBUTION, OR OTHER SIMILAR COSTS.
    enable  : IN     STD_LOGIC;                             --initiate transaction
    cont    : IN     STD_LOGIC;                             --continuous mode command
    clk_div : IN     INTEGER;                               --system clock cycles per 1/2 period of sclk
    miso    : IN     STD_LOGIC;                             --master in, slave out
    mosi    : OUT    STD_LOGIC;                             --master out, slave in
    busy    : OUT    STD_LOGIC;                             --busy / data ready signal
--   TYPE machine IS(ready, convert , execute);                           --state machine data type
   TYPE machine IS(ready, execute);                           --state machine data type
  SIGNAL state  ,   next_state  : machine;                              --current state
  SIGNAL slave       : INTEGER;                              --slave selected for current transaction
  SIGNAL count       : INTEGER;                              --counter to trigger sclk from system clock
  SIGNAL clk_toggles : INTEGER RANGE 0 TO d_width*2 + 1;     --count spi clock toggles
  SIGNAL assert_data : STD_LOGIC;                            --'1' is tx sclk toggle, '0' is rx sclk toggle
  SIGNAL continue    : STD_LOGIC;                            --flag to continue transaction
  SIGNAL rx_buffer   : STD_LOGIC_VECTOR(d_width-1 DOWNTO 0); --receive data buffer
  SIGNAL tx_buffer   : STD_LOGIC_VECTOR(d_width-1 DOWNTO 0); --transmit data buffer
  SIGNAL last_bit_rx : INTEGER RANGE 0 TO d_width*2;         --last rx data bit location
                      slave <= addr;         --clock in current slave selection if valid
                      count <= 1;            --initiate system-to-spi clock counter
                      count <= clk_div;      --initiate system-to-spi clock counter
                tx_buffer <= tx_data;    --clock in data for transmit into buffer
                last_bit_rx <= d_width*2 + conv_integer(cpha) - 1; --set last rx data bit
--                     ss_n <= (OTHERS => '1');    --deassert all slave select lines
                    count <= 1;                     --reset system-to-spi clock counter
                    assert_data <= NOT assert_data; --switch transmit/receive indicator
                              clk_toggles <= 0;               --reset spi clock toggles counter
                              clk_toggles <= clk_toggles + 1; --increment spi clock toggles counter
                            IF(clk_toggles <= d_width*2 AND ss_n(slave) = '0') THEN 
                            IF(assert_data = '0' AND clk_toggles < last_bit_rx + 1 AND ss_n(slave) = '0') THEN 
                              rx_buffer <= rx_buffer(d_width-2 DOWNTO 0) & miso; --shift in received bit
                            IF(assert_data = '1' AND clk_toggles < last_bit_rx) THEN 
                              mosi <= tx_buffer(d_width-1);                     --clock out data bit
                              tx_buffer <= tx_buffer(d_width-2 DOWNTO 0) & '0'; --shift data transmit buffer
                          tx_buffer <= tx_data;                       --reload transmit buffer
                          clk_toggles <= last_bit_rx - d_width*2 + 1; --reset spi clock toggle counter
                          continue <= '1';                            --set continue flag
                      busy <= '0';          --clock out signal that first receive data is ready
                      rx_data <= rx_buffer; --clock out received data to output port    
                      rx_data <= rx_buffer;    --clock out received data to output port
--------------------------------------------------------------------------------
--
--   FileName:         pmod_dac_ad5628.vhd
--   Dependencies:     spi_master.vhd
--------------------------------------------------------------------------------
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY pmod_dac_ads8661 IS
  GENERIC(
    clk_freq    : INTEGER := 100;  --system clock frequency in MHz
    spi_clk_div : INTEGER := 1; --spi_clk_div = clk_freq/100 (answer rounded up)
    --------------------added --------------------------------------------
    ----rst_pwrctl_reg 
    rst_pwrctl_reg_ms_addr  : std_logic_Vector( 7 downto 0)  :=x"05" ;
     rst_pwrctl_reg_ms_data  : std_logic_Vector( 7 downto 0)  :=x"69" ;  ---first data need to send 
    rst_pwrctl_reg_ls_addr  : std_logic_Vector( 7 downto 0)  :=x"04" ;
    rst_pwrctl_reg_ls_data  : std_logic_Vector( 7 downto 0)  :=x"00" ;  ----- enable vdd alarm , input alarm  , por reset,disable nap mode , put converter in active mode 
   ------------sdi control register 
    sdi_ctl_reg_addr : std_logic_vector ( 7 downto 0) := x"08" ;
     sdi_mode :std_logic_vector (1 downto 0) :="00" ;     ------spi mode cpol=0 cphase=0
    
    
----- sdo-ctl-reg---=====0ch =========================
 sdo_ctl_reg_addr : std_logic_vector ( 7 downto 0) :=x"0C" ;
  ssync_clk :std_logic :='1' ;     --- 0 external clock  1- internal clock
  sdo_mode :std_logic_vector(1 downto 0) :="11" ;      ----0X   follow same spi protocols that used for sdi mode     USE 11 FOR THE SOURCE SYNCHRONOUS
    
      --------dataout control register ---- 11h
 dataout_ctl_reg_ms_addr : std_logic_vector( 7 downto 0) :=x"11" ;     --------------1st addr  
  device_addr_inc :std_logic :='0' ;     --- '0' do not include the register value '1' include the register value 
  vdd_active_alarm_inc :std_logic_vector (1 downto 0) :="11" ;     ---"11" include both vdd_h_flag and vdd_l_flag 
  in_active_alarm_inc :std_logic_vector (1 downto 0) :="11" ;       ---"11" include both vdd_h_flag and vdd_l_flag 
  range_inc :std_logic :='1' ;      ----- include range configuration value 
 dataout_ctl_reg_ls_addr : std_logic_vector ( 7 downto 0) :=x"10" ;     ---------second addr  ----------
  par_en :std_logic :='0' ;     --- 0 disable 1 enable
  data_val :std_logic_vector (2 downto 0) :="0XX" ;     ---------conversion data   ,100  all zero , 101  all 1  , 110   0 and 1 alternate , 111  00 and 11 
   
    -----------range selection register  --- 14h
 range_sel_addr : std_logic_vector ( 7 downto 0) :=x"14" ;     --------
  intref_dis:std_logic :='0' ;     --- 0 disable 1 enable
  range_sel:std_logic_vector(3 downto 0) :="0000" ;   ---------range _+ 3*vref
     
      write_MS  : std_logic_vector ( 7 downto 0) :=  "11010010" ;      ---ms of the 16 bit only written on the specified register address 
      write_LS  : std_logic_vector ( 7 downto 0) :=  "11010100";      ---ls of the 16 bit only written on the specified register address 
      write_hword : std_logic_vector ( 7 downto 0) :="11010000"    ---write half word on the specified memory location 
    
    );
    
  PORT(
                clk        : IN      STD_LOGIC;                      --system clock
                reset_n    : IN      STD_LOGIC;                      --active low asynchronous reset
                dac_tx_ena : IN      STD_LOGIC;                      --enable transaction with DAC
                rvs_in  :  in   std_logic ; 
                rvs_out : out std_logic ; 
                data_in_0   :  IN      STD_LOGIC;                      --channel 0 serial data from ADC  ----added 
                adc_0_data  :  OUT     STD_LOGIC_VECTOR(11 DOWNTO 0);  --channel 0 ADC result     ----added    
                busy       : OUT     STD_LOGIC;                      --indicates when transactions with DAC can be initiated
                mosi       : OUT     STD_LOGIC;                      --SPI bus to DAC: master out, slave in (DIN)
                sclk       : BUFFER  STD_LOGIC;                      --SPI bus to DAC: serial clock (SCLK)
                ss_n       : BUFFER  STD_LOGIC_VECTOR(0 DOWNTO 0)
                );  --SPI bus to DAC: slave select (~SYNC)
END pmod_dac_ads8661;
ARCHITECTURE Behavioral OF pmod_dac_ads8661 IS
  TYPE machine IS(start, nopb1, nopb2 , 
rst_pwr_configb11 , rst_pwr_configb12 , 
rst_pwr_configb21 , rst_pwr_configb22 , 
sdi_configb1 ,     sdi_configb2 ,
data_out_configb11, data_out_configb12 ,
data_out_configb21,  data_out_configb22,
range_configb1,   range_configb2,
sdo_configb1 , sdo_configb2 ,
read_commandb1 ,  read_commandb2 ,
 read_data ,output_result, pause,  stop
  ); --needed states
  
  SIGNAL state  ,next_state       : machine := start;                    --state machine
    SIGNAL  spi_rx_data_0  : STD_LOGIC_VECTOR(15 DOWNTO 0);  --latest channel 0 data received    
    
  SIGNAL spi_busy_prev : STD_LOGIC;                           --previous value of the SPI component's busy signal
  SIGNAL spi_busy      : STD_LOGIC;                           --busy signal from SPI component
  SIGNAL spi_ena       : STD_LOGIC;                           --enable for SPI component
  SIGNAL spi_tx_data   : STD_LOGIC_VECTOR(15 DOWNTO 0);       --transmit data for SPI component
attribute keep : string;
attribute keep of state : signal is "true";
  --declare SPI Master component
  COMPONENT spi_master_ads8661 IS
    GENERIC(
      slaves  : INTEGER := 1;   --number of spi slaves
      d_width : INTEGER := 16); --data bus width
    PORT(
      clock   : IN     STD_LOGIC;                             --system clock
      reset_n : IN     STD_LOGIC;                             --asynchronous reset
      enable  : IN     STD_LOGIC;                             --initiate transaction
      cpol    : IN     STD_LOGIC;                             --spi clock polarity
      cpha    : IN     STD_LOGIC;                             --spi clock phase
      cont    : IN     STD_LOGIC;                             --continuous mode command
      clk_div : IN     INTEGER;                               --system clock cycles per 1/2 period of sclk
      addr    : IN     INTEGER;                               --address of slave
      tx_data : IN     STD_LOGIC_VECTOR(d_width-1 DOWNTO 0);  --data to transmit
      miso    : IN     STD_LOGIC;                             --master in, slave out
      sclk    : BUFFER STD_LOGIC;                             --spi clock
      ss_n    : BUFFER STD_LOGIC_VECTOR(slaves-1 DOWNTO 0);   --slave select
      mosi    : OUT    STD_LOGIC;                             --master out, slave in
      busy    : OUT    STD_LOGIC;                             --busy / data ready signal
      rx_data : OUT    STD_LOGIC_VECTOR(d_width-1 DOWNTO 0)); --data received
  END COMPONENT spi_master_ads8661;
------------------added ---signal ----------------------------------
  SIGNAL spi_cont           : STD_LOGIC;                              --continuous mode signal for SPI component
signal  rst_data1, rst_data2, sdi_data , sdo_data , data_out1, data_out2, range_data : std_logic_vector(15 downto 0) ; 
signal rvs_reg : std_logic ; 
------added signal end -----------------------
BEGIN
  --instantiate the SPI Master component
  spi_master_u1:  spi_master_ads8661
    GENERIC MAP(slaves => 1, d_width => 16)
    PORT MAP(clock => clk, reset_n => reset_n, enable => spi_ena, cpol => '0', cpha => '0',
             cont => '0', clk_div => spi_clk_div, addr => 0, tx_data => spi_tx_data, miso => data_in_0,
             sclk => sclk, ss_n => ss_n, mosi => mosi, busy => spi_busy, rx_data => spi_rx_data_0);
process ( clk ,reset_n) 
begin 
    if ( reset_n='0')  then  
        rvs_reg  <='0' ; 
    elsif rising_edge ( clk ) then 
       rvs_reg <=rvs_in ; 
      end if ; 
      
  end process ; 
  
  rvs_out <= rvs_reg ; 
  
PROCESS(clk, reset_n)
    VARIABLE count : INTEGER RANGE 0 TO clk_freq*100 := 0; --counter
  BEGIN
  
    IF(reset_n = '0') THEN              --reset activated
      spi_ena <= '0';                     --clear SPI component enable
   spi_cont <= '0';   
      spi_tx_data <= (OTHERS => '0');     --clear SPI component transmit data
      busy <= '1';                        --indication component is unavailable
      sdo_data<=(OTHERS=>'0') ; 
      state <= start;                     --restart state machine
--      next_state <=rst_pwr_config1 ; 
   next_state <= nopb1 ; 
    ELSIF(clk'EVENT AND clk = '1') THEN --rising edge of system clock
      spi_busy_prev <= spi_busy;          --collect previous spi_busy
   
      CASE state IS                       --state machine
        --entry state, give DAC 100us to power up before communicating
        WHEN start =>
          busy <= '1';                     --component is busy, DAC not yet available
          IF(count < clk_freq*100) THEN    --100us not yet reached
--          IF(count < 3) THEN    --100us not yet reached
            count := count + 1;              --increment counter
          ELSE                             --100us reached
            count := 0;                      --clear counter
            state <= pause;                --advance to configure the DAC
            next_state <= nopb1 ; 
            
          END IF;
          
             --perform SPI transaction to turn on internal voltage reference  
        WHEN nopb1 =>
          if ( dac_tx_ena='1') then  ----------------for trigger option 
                   IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                    spi_ena <= '1';                                      --enable transaction with DAC
                    spi_cont <= '1';   
                    spi_tx_data <= x"0000" ; ---- nop command first byte          
                  ELSIF(spi_busy = '1') THEN                           --transaction underway
                    spi_ena <= '0';                                      --clear transaction enable
                  ELSE                                                 --transaction complete
                    state <= pause;                                      --advance to pause state
                    next_state <= nopb2  ; 
                  END IF;       
           end if ; 
          
          
          
                 --perform SPI transaction to turn on internal voltage reference  
        WHEN nopb2=>
          IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
            spi_ena <= '1';                                      --enable transaction with DAC
            spi_cont <= '1';   
            spi_tx_data <= x"0000" ; ---- nop command first byte          
          ELSIF(spi_busy = '1') THEN                           --transaction underway
            spi_ena <= '0';                                      --clear transaction enable
          ELSE                                                 --transaction complete
            state <= pause;                                      --advance to pause state
--            next_state <= rst_pwr_configb11  ; 
                next_state <=    sdi_configb1;
          END IF;       
          
--------------------------------1st byte rst ---------------
        --perform SPI transaction to turn on internal voltage reference  
        WHEN rst_pwr_configb11 =>
          IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
            spi_ena <= '1';                                      --enable transaction with DAC
            spi_cont <= '1';   
--            spi_tx_data <= write_ms  &  rst_pwrctl_reg_ms_addr  & rst_pwrctl_reg_ms_data  & x"00" ;    --data to set specified range        
             spi_tx_data <= write_hword  &  rst_pwrctl_reg_ms_addr   ;    --data to set specified range        
          ELSIF(spi_busy = '1') THEN                           --transaction underway
            spi_ena <= '0';                                      --clear transaction enable
          ELSE                                                 --transaction complete
            state <= pause;                                      --advance to pause state
--            next_state <= rst_pwr_config2  ; 
            next_state <= rst_pwr_configb12  ; 
          END IF;       
          
          WHEN rst_pwr_configb12=>
                  IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                    spi_ena <= '1';                                      --enable transaction with DAC
                     spi_cont <= '1';   
--                    spi_tx_data <= write_ms  &  rst_pwrctl_reg_ls_addr  & rst_pwrctl_reg_ls_data  & x"00" ;
                   spi_tx_data <=  rst_pwrctl_reg_ms_data  & x"00" ;    --data to set specified range        
                  ELSIF(spi_busy = '1') THEN                           --transaction underway
                    spi_ena <= '0';                                      --clear transaction enable
                  ELSE                                                 --transaction complete
                    state <= pause;                                      --advance to pause state
--                    next_state <= sdi_config ; 
                     next_state <= rst_pwr_configb21 ; 
                  END IF;       
                  
                  
               ------------------------rst 2nd byte ----------------
               
          
--------------------------------1st byte rst ---------------
        --perform SPI transaction to turn on internal voltage reference  
        WHEN rst_pwr_configb21 =>
          IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
            spi_ena <= '1';                                      --enable transaction with DAC
            spi_cont <= '1';   
  
                              spi_tx_data <= write_hword  &  rst_pwrctl_reg_ls_addr ;
          ELSIF(spi_busy = '1') THEN                           --transaction underway
            spi_ena <= '0';                                      --clear transaction enable
          ELSE                                                 --transaction complete
            state <= pause;                                      --advance to pause state
--            next_state <= rst_pwr_config2  ; 
            next_state <= rst_pwr_configb22  ; 
          END IF;       
          
          WHEN rst_pwr_configb22=>
                  IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                    spi_ena <= '1';                                      --enable transaction with DAC
                     spi_cont <= '1';   
                    spi_tx_data <=   x"00" & rst_pwrctl_reg_ls_data   ;  
                  ELSIF(spi_busy = '1') THEN                           --transaction underway
                    spi_ena <= '0';                                      --clear transaction enable
                  ELSE                                                 --transaction complete
                    state <= pause;                                      --advance to pause state
--                    next_state <= sdi_config ; 
                     next_state <= sdi_configb1 ; 
                  END IF;       
               
               -------------xxx--------------------------   
                  
                  
                  
                  
                  
           WHEN sdi_configb1=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
--                                  spi_tx_data  <= write_ms  &  sdi_ctl_reg_addr  & "000000"  & sdi_mode    & x"00" ;   
                                 spi_tx_data  <= write_hword  &  sdi_ctl_reg_addr ; 
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= sdi_configb2 ; 
                                  END IF;        
                                  
                          WHEN sdi_configb2=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
                                  spi_tx_data  <=     x"00" & "000000"  & sdi_mode    ;   
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= sdo_configb1  ; 
                                  END IF;                    
                                  
                                  
                                  
                                  
                                            
            WHEN sdo_configb1=>
                    IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                    spi_ena <= '1';                                      --enable transaction with DAC
                  spi_cont <= '1';   
--                    spi_tx_data<= write_ms  &  sdo_ctl_reg_addr  & "0"  &  ssync_clk & "0000" &  sdo_mode    & x"00" ;   
                    spi_tx_data<= write_hword  &  sdo_ctl_reg_addr ;    
                    ELSIF(spi_busy = '1') THEN                           --transaction underway
                    spi_ena <= '0';                                      --clear transaction enable
                    ELSE                                                 --transaction complete
                    state <= pause;                                      --advance to pause state
                    next_state <= sdo_configb2   ; 
                    END IF;          
                    
                   WHEN sdo_configb2=>
                    IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                    spi_ena <= '1';                                      --enable transaction with DAC
                  spi_cont <= '1';   
--                    spi_tx_data<= write_ms  &  sdo_ctl_reg_addr  & "0"  &  ssync_clk & "0000" &  sdo_mode    & x"00" ;   
                    spi_tx_data<= x"00" &  "0"  &  ssync_clk & "0000" &  sdo_mode      ;    
                    ELSIF(spi_busy = '1') THEN                           --transaction underway
                    spi_ena <= '0';                                      --clear transaction enable
                    ELSE                                                 --transaction complete
                    state <= pause;                                      --advance to pause state
                    next_state <= data_out_configb11   ; 
                    END IF;       
                    
                    
                    
                      
                    
           WHEN data_out_configb11=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
--                                  spi_tx_data  <= write_ms  &  dataout_ctl_reg_ms_addr   & '0'  &   device_addr_inc  &  vdd_active_alarm_inc  &  in_active_alarm_inc  &  '0'  &    range_inc  & x"00" ;
                                       spi_tx_data  <= write_hword  &  dataout_ctl_reg_ms_addr  ;
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= data_out_configb12  ; 
                                  END IF;        
                                  
                          
                             WHEN data_out_configb12=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
--                                  spi_tx_data  <= write_ms  &  dataout_ctl_reg_ms_addr   & '0'  &   device_addr_inc  &  vdd_active_alarm_inc  &  in_active_alarm_inc  &  '0'  &    range_inc  & x"00" ;
                                       spi_tx_data  <= '0'  &   device_addr_inc  &  vdd_active_alarm_inc  &  in_active_alarm_inc  &  '0'  &    range_inc  & x"00" ;
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= data_out_configb21  ; 
                                  END IF;       
                                
           WHEN data_out_configb21=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                               spi_cont <= '1';   
--                                  spi_tx_data <= write_ms  &  dataout_ctl_reg_ms_addr   & "0000"   &     par_en   &  data_val  &  x"00" ;
                                          spi_tx_data <= write_hword  &  dataout_ctl_reg_ls_addr ; 
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= data_out_configb22  ; 
                                  END IF;       
                                  
                                  
                               WHEN data_out_configb22=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                               spi_cont <= '1';   
--                                  spi_tx_data <= write_ms  &  dataout_ctl_reg_ms_addr   & "0000"   &     par_en   &  data_val  &  x"00" ;
                                          spi_tx_data <= x"00" &  "0000"   &     par_en   &  data_val   ;
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= range_configb1  ; 
                                  END IF;        
                                   
                                  
                                  
        WHEN range_configb1=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
--                                  spi_tx_data <= write_ms    &  range_sel_addr     & '0'   &   intref_dis   &  "00"   &   range_sel &  x"00" ;
                                      spi_tx_data <= write_hword    &  range_sel_addr   ;
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= range_configb2 ; 
                                  END IF;     
                                  
                                     
                  WHEN range_configb2=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                spi_cont <= '1';   
                                  spi_tx_data <=  x"00"   &  '0'   &   intref_dis   &  "00"   &   range_sel ;
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <=read_data   ; --- read_commandb1 ; 
                                  
                                  END IF;                            
                                  
                                  
          
          
          WHEN read_commandb1=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                  spi_cont <= '1';   
--                                  spi_tx_data <= "11001XX0" & sdo_ctl_reg_addr & X"0000" ; 
                                    spi_tx_data <= "11001000" & sdo_ctl_reg_addr  ; 
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= read_commandb2; 
                                  END IF;        
                                  
                                  
                                  
                                   WHEN read_commandb2=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                  spi_cont <= '1';   
                                  spi_tx_data <= X"0000" ; 
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                  state <= pause;                                      --advance to pause state
                                  next_state <= read_data; 
                                  END IF;        
                             
                             
              WHEN read_data=>
                                IF(spi_busy = '0' AND spi_busy_prev = '0') THEN      --no command sent
                                  spi_ena <= '1';                                      --enable transaction with DAC
                                  spi_cont <= '1';   
--                                 sdo_data  <= spi_rx_data_0;    --latch in first received acceleration data
                          adc_0_data <= spi_rx_data_0(15 downto 4) ;    --latch in first received acceleration data
                                ELSIF(spi_busy = '1') THEN                           --transaction underway
                                  spi_ena <= '0';                                      --clear transaction enable
                                ELSE                                                 --transaction complete
                                   STATE <=  pause  ;
                                    next_state <= read_data;   ---output_result ;    ---default 
                                  END IF;                          
                                  
                  
          
            
        --outputs acceleration data
        WHEN output_result =>
          adc_0_data <=  sdo_data(15 DOWNTO 4); --assign channel 0 ADC data bits to output   
            state <= pause;                        --return to pause state
            next_state <=read_data;
        
     
         
        --pauses 20ns between SPI transactions
        WHEN pause =>
          IF(count < clk_freq/5) THEN   --less than 20ns
            count := count + 1;            --increment counter
          ELSE                           --20ns has elapsed
            count := 0;                    --clear counter
            busy <= '0';                   --indicate component is ready for a transaction
            state <=next_state;   
          END IF;
          
       when stop => 
            state <= stop ; 
        --default to start state
        WHEN OTHERS => 
          state <= start;
      END CASE;      
    END IF;
  END PROCESS;
  
END Behavioral;
No comments:
Post a Comment