OpenCores
URL https://opencores.org/ocsvn/idea/idea/trunk

Subversion Repositories idea

[/] [idea/] [trunk/] [behavioral/] [main control/] [cbc.vbe] - Rev 9

Compare with Previous | Blame | View Log

-- VHDL data flow description generated from `cbc`
--              date : Sat Sep  1 20:12:27 2001


-- Entity Declaration

ENTITY cbc IS
  PORT (
  active : in BIT;      -- active
  clk : in BIT; -- clk
  cke : in BIT; -- cke
  ikey_ready : in BIT;  -- ikey_ready
  key_ready : in BIT;   -- key_ready
  dt_ready : in BIT;    -- dt_ready
  finish : in BIT;      -- finish
  e : in BIT;   -- e
  first_dt : inout BIT; -- first_dt
  e_mesin : out BIT;    -- e_mesin
  s_mesin : out BIT;    -- s_mesin
  s_gen_key : out BIT;  -- s_gen_key
  emp_buf : out BIT;    -- emp_buf
  cp_ready : out BIT;   -- cp_ready
  cke_b_mode : out BIT; -- cke_b_mode
  en_in : out BIT;      -- en_in
  en_iv : out BIT;      -- en_iv
  en_rcbc : out BIT;    -- en_rcbc
  en_out : out BIT;     -- en_out
  sel1 : out bit_vector(1 DOWNTO 0) ;   -- sel1
  sel2 : out bit_vector(1 DOWNTO 0) ;   -- sel2
  sel3 : out bit_vector(1 DOWNTO 0) ;   -- sel3
  vdd : in BIT; -- vdd
  vss : in BIT  -- vss
  );
END cbc;


-- Architecture Declaration

ARCHITECTURE VBE OF cbc IS
  SIGNAL current_state : REG_VECTOR(3 DOWNTO 0) REGISTER;       -- current_state
  SIGNAL current_state_s13 : BIT;               -- current_state_s13
  SIGNAL next_state_s13 : BIT;          -- next_state_s13
  SIGNAL current_state_s12 : BIT;               -- current_state_s12
  SIGNAL next_state_s12 : BIT;          -- next_state_s12
  SIGNAL current_state_s11 : BIT;               -- current_state_s11
  SIGNAL next_state_s11 : BIT;          -- next_state_s11
  SIGNAL current_state_s10 : BIT;               -- current_state_s10
  SIGNAL next_state_s10 : BIT;          -- next_state_s10
  SIGNAL current_state_s9 : BIT;                -- current_state_s9
  SIGNAL next_state_s9 : BIT;           -- next_state_s9
  SIGNAL current_state_s8 : BIT;                -- current_state_s8
  SIGNAL next_state_s8 : BIT;           -- next_state_s8
  SIGNAL current_state_s7 : BIT;                -- current_state_s7
  SIGNAL next_state_s7 : BIT;           -- next_state_s7
  SIGNAL current_state_s6 : BIT;                -- current_state_s6
  SIGNAL next_state_s6 : BIT;           -- next_state_s6
  SIGNAL current_state_s5 : BIT;                -- current_state_s5
  SIGNAL next_state_s5 : BIT;           -- next_state_s5
  SIGNAL current_state_s4 : BIT;                -- current_state_s4
  SIGNAL next_state_s4 : BIT;           -- next_state_s4
  SIGNAL current_state_s3 : BIT;                -- current_state_s3
  SIGNAL next_state_s3 : BIT;           -- next_state_s3
  SIGNAL current_state_s2 : BIT;                -- current_state_s2
  SIGNAL next_state_s2 : BIT;           -- next_state_s2
  SIGNAL current_state_s1 : BIT;                -- current_state_s1
  SIGNAL next_state_s1 : BIT;           -- next_state_s1
  SIGNAL current_state_s0 : BIT;                -- current_state_s0
  SIGNAL next_state_s0 : BIT;           -- next_state_s0
  SIGNAL next_state : BIT_VECTOR(3 DOWNTO 0);   -- next_state

BEGIN
  next_state(0) <= (next_state_s3 OR next_state_s5 OR next_state_s7 
OR next_state_s8 OR next_state_s9 OR next_state_s10
);
  next_state(1) <= (next_state_s2 OR next_state_s7 OR next_state_s10
 OR next_state_s11 OR next_state_s12 OR 
next_state_s13);
  next_state(2) <= (next_state_s0 OR next_state_s1 OR next_state_s3 
OR next_state_s9 OR next_state_s12 OR 
next_state_s13);
  next_state(3) <= (next_state_s0 OR next_state_s4 OR next_state_s8 
OR next_state_s9 OR next_state_s10 OR 
next_state_s11 OR next_state_s13);
  next_state_s0 <= (current_state_s0 AND (NOT(ikey_ready) OR NOT(cke
)));
  current_state_s0 <= (current_state(3) AND current_state(2) AND NOT(
current_state(1)) AND NOT(current_state(0)));
  next_state_s1 <= ((current_state_s0 AND ikey_ready AND cke) OR (
current_state_s1 AND (NOT(dt_ready) OR NOT(key_ready))));
  current_state_s1 <= (NOT(current_state(3)) AND current_state(2) AND 
NOT(current_state(1)) AND NOT(current_state(0)));
  next_state_s2 <= (current_state_s1 AND first_dt AND dt_ready AND 
key_ready);
  current_state_s2 <= (NOT(current_state(3)) AND NOT(current_state(2)) 
AND current_state(1) AND NOT(current_state(0)));
  next_state_s3 <= current_state_s2;
  current_state_s3 <= (NOT(current_state(3)) AND current_state(2) AND 
current_state(0));
  next_state_s4 <= (current_state_s3 OR (current_state_s4 AND NOT(
dt_ready)));
  current_state_s4 <= (current_state(3) AND NOT(current_state(2)) AND 
NOT(current_state(1)) AND NOT(current_state(0)));
  next_state_s5 <= ((current_state_s1 AND e AND NOT(first_dt) AND 
dt_ready AND key_ready) OR (current_state_s4 AND e AND 
dt_ready));
  current_state_s5 <= (NOT(current_state(3)) AND NOT(current_state(2)) 
AND NOT(current_state(1)) AND current_state(0));
  next_state_s6 <= ((current_state_s1 AND NOT(e) AND NOT(first_dt) 
AND dt_ready AND key_ready) OR (current_state_s4 AND
 NOT(e) AND dt_ready));
  current_state_s6 <= (NOT(current_state(3)) AND NOT(current_state(2)) 
AND NOT(current_state(1)) AND NOT(current_state(0)));
  next_state_s7 <= (current_state_s5 OR current_state_s6 OR (
current_state_s7 AND NOT(finish)));
  current_state_s7 <= (NOT(current_state(3)) AND current_state(1) AND 
current_state(0));
  next_state_s8 <= (current_state_s7 AND finish);
  current_state_s8 <= (current_state(3) AND NOT(current_state(2)) AND 
NOT(current_state(1)) AND current_state(0));
  next_state_s9 <= current_state_s8;
  current_state_s9 <= (current_state(3) AND current_state(2) AND 
current_state(0));
  next_state_s10 <= (current_state_s9 AND e);
  current_state_s10 <= (current_state(3) AND current_state(1) AND 
current_state(0));
  next_state_s11 <= (current_state_s9 AND NOT(e));
  current_state_s11 <= (current_state(3) AND NOT(current_state(2)) AND 
current_state(1) AND NOT(current_state(0)));
  next_state_s12 <= (current_state_s10 OR current_state_s11);
  current_state_s12 <= (NOT(current_state(3)) AND current_state(2) AND 
current_state(1));
  next_state_s13 <= (current_state_s12 OR current_state_s13);
  current_state_s13 <= (current_state(3) AND current_state(2) AND 
current_state(1));
  label0 : BLOCK ((NOT((clk'STABLE)) AND NOT(clk)) = '1')
  BEGIN
    current_state(0) <= GUARDED (next_state(0) AND NOT(active));
  END BLOCK label0;
  label1 : BLOCK ((NOT((clk'STABLE)) AND NOT(clk)) = '1')
  BEGIN
    current_state(1) <= GUARDED (next_state(1) AND NOT(active));
  END BLOCK label1;
  label2 : BLOCK ((NOT((clk'STABLE)) AND NOT(clk)) = '1')
  BEGIN
    current_state(2) <= GUARDED (next_state(2) OR active);
  END BLOCK label2;
  label3 : BLOCK ((NOT((clk'STABLE)) AND NOT(clk)) = '1')
  BEGIN
    current_state(3) <= GUARDED (next_state(3) OR active);
  END BLOCK label3;

sel3(0) <= '0';

sel3(1) <= NOT((current_state_s1 AND NOT(e) AND NOT(first_dt
) AND dt_ready AND key_ready AND NOT(active)) OR (
current_state_s4 AND NOT(e) AND dt_ready AND NOT(active)));

sel2(0) <= ((current_state_s1 AND e AND NOT(first_dt) AND 
dt_ready AND key_ready AND NOT(active)) OR (
current_state_s4 AND e AND dt_ready AND NOT(active)));

sel2(1) <= NOT((current_state_s1 AND e AND NOT(first_dt) AND
 dt_ready AND key_ready AND NOT(active)) OR (
current_state_s4 AND e AND dt_ready AND NOT(active)));

sel1(0) <= ((current_state_s1 AND dt_ready AND key_ready AND
 NOT(active)) OR (current_state_s2 AND NOT(active)
) OR (current_state_s3 AND NOT(active)) OR (
current_state_s4 AND NOT(active)) OR (current_state_s9 AND NOT(e)
 AND NOT(active)) OR (current_state_s12 AND NOT(
active)) OR (current_state_s13 AND NOT(active)));

sel1(1) <= NOT((current_state_s1 AND dt_ready AND key_ready 
AND NOT(active)) OR (current_state_s2 AND NOT(active
)) OR (current_state_s3 AND NOT(active)) OR (
current_state_s4 AND NOT(active)) OR (current_state_s9 AND NOT(
active)) OR (current_state_s12 AND NOT(active)) OR (
current_state_s13 AND NOT(active)));

en_out <= ((current_state_s8 AND NOT(active)) OR (
current_state_s9 AND NOT(active)));

en_rcbc <= (current_state_s7 AND finish AND NOT(active));

en_iv <= ((current_state_s2 AND NOT(active)) OR (
current_state_s10 AND NOT(active)) OR (current_state_s11 AND NOT(
active)) OR (current_state_s12 AND NOT(active)) OR (
current_state_s13 AND NOT(active)));

en_in <= ((current_state_s1 AND first_dt AND dt_ready AND 
key_ready AND NOT(active)) OR (current_state_s5 AND NOT(
active)) OR (current_state_s6 AND NOT(active)) OR (
current_state_s7 AND NOT(finish) AND NOT(active)));

cke_b_mode <= ((current_state_s0 AND ikey_ready AND cke AND NOT
(active)) OR (current_state_s1 AND cke AND NOT(
active)) OR (current_state_s2 AND cke AND NOT(active)) 
OR (current_state_s3 AND cke AND NOT(active)) OR (
current_state_s4 AND cke AND NOT(active)) OR (current_state_s5 
AND cke AND NOT(active)) OR (current_state_s6 AND 
cke AND NOT(active)) OR (current_state_s7 AND cke 
AND NOT(active)) OR (current_state_s8 AND cke AND 
NOT(active)) OR (current_state_s9 AND cke AND NOT(
active)) OR (current_state_s10 AND cke AND NOT(active))
 OR (current_state_s11 AND cke AND NOT(active)) OR
 (current_state_s12 AND cke AND NOT(active)) OR (
current_state_s13 AND cke AND NOT(active)));

cp_ready <= ((current_state_s10 AND NOT(active)) OR (
current_state_s11 AND NOT(active)) OR (current_state_s12 AND NOT(
active)) OR (current_state_s13 AND NOT(active)));

emp_buf <= ((current_state_s1 AND first_dt AND dt_ready AND 
key_ready AND NOT(active)) OR (current_state_s5 AND NOT(
active)) OR (current_state_s6 AND NOT(active)) OR (
current_state_s7 AND NOT(finish) AND NOT(active)));

s_gen_key <= NOT(active OR (current_state_s0 AND (NOT(
ikey_ready) OR NOT(cke)) AND NOT(active)));

s_mesin <= (current_state_s7 AND finish AND NOT(active));

e_mesin <= (active OR (current_state_s0 AND (e OR NOT(
ikey_ready) OR NOT(cke)) AND NOT(active)) OR (
current_state_s1 AND e AND NOT(active)) OR (current_state_s2 AND 
e AND NOT(active)) OR (current_state_s3 AND e AND 
NOT(active)) OR (current_state_s4 AND e AND NOT(
active)) OR (current_state_s5 AND e AND NOT(active)) OR
 (current_state_s6 AND e AND NOT(active)) OR (
current_state_s7 AND e AND NOT(active)) OR (current_state_s8 AND 
e AND NOT(active)) OR (current_state_s9 AND e AND 
NOT(active)) OR (current_state_s10 AND e AND NOT(
active)) OR (current_state_s11 AND e AND NOT(active)) 
OR (current_state_s12 AND e AND NOT(active)) OR (
current_state_s13 AND e AND NOT(active)));

first_dt <= (active OR (current_state_s0 AND NOT(active)) OR 
(current_state_s1 AND NOT(active)) OR (
current_state_s4 AND dt_ready AND NOT(active)));
END;

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.