hp-saturn/saturn_decoder_block_vars.v

207 lines
5.2 KiB
Coq
Raw Normal View History

/*
(c) Raphaël Jacquot 2019
This file is part of hp_saturn.
hp_saturn is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
any later version.
hp_saturn is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Foobar. If not, see <https://www.gnu.org/licenses/>.
*/
2019-02-19 16:16:32 +01:00
`ifndef _SATURN_DECODER_BLOCK_VARS
`define _SATURN_DECODER_BLOCK_VARS
/*
*
* Block vars registers
*
*/
reg block_0x;
wire do_block_0x;
assign do_block_0x = do_on_other_nibbles && block_0x;
reg block_0Efx;
wire do_block_0Efx;
assign do_block_0Efx = do_on_other_nibbles && block_0Efx;
reg block_1x;
wire do_block_1x;
assign do_block_1x = do_on_other_nibbles && block_1x;
reg block_save_to_R_W;
wire do_block_save_to_R_W;
assign do_block_save_to_R_W = do_on_other_nibbles && block_save_to_R_W;
reg block_rest_from_R_W;
wire do_block_rest_from_R_W;
assign do_block_rest_from_R_W = do_on_other_nibbles && block_rest_from_R_W;
reg block_exch_with_R_W;
wire do_block_exch_with_R_W;
assign do_block_exch_with_R_W = do_on_other_nibbles && block_exch_with_R_W;
wire do_block_Rn_A_C;
assign do_block_Rn_A_C = do_on_other_nibbles &&
( block_save_to_R_W ||
block_rest_from_R_W ||
block_exch_with_R_W );
reg block_13x;
wire do_block_13x;
assign do_block_13x = do_on_other_nibbles && block_13x;
reg block_14x_15xx;
wire do_block_14x_15xx;
assign do_block_14x_15xx = do_on_other_nibbles && block_14x_15xx;
reg block_15xx;
wire do_block_15xx;
assign do_block_15xx = do_on_other_nibbles && block_15xx;
2019-02-15 11:55:58 +01:00
reg block_pointer_arith_const;
wire do_block_pointer_arith_const;
assign do_block_pointer_arith_const = do_on_other_nibbles && block_pointer_arith_const;
2019-02-15 11:55:58 +01:00
reg block_2x;
wire do_block_2x;
assign do_block_2x = do_on_other_nibbles && block_2x;
2019-02-15 11:55:58 +01:00
reg block_3x;
wire do_block_3x;
assign do_block_3x = do_on_other_nibbles && block_3x;
2019-02-15 11:55:58 +01:00
// reg block_jmp2_cry_set;
// reg block_jmp2_cry_clr;
2019-02-15 11:55:58 +01:00
reg block_8x;
wire do_block_8x;
assign do_block_8x = do_on_other_nibbles && block_8x;
reg block_80x;
wire do_block_80x;
assign do_block_80x = do_on_other_nibbles && block_80x;
reg block_80Cx;
wire do_block_80Cx;
assign do_block_80Cx = do_on_other_nibbles && block_80Cx;
2019-02-19 16:16:32 +01:00
reg block_81x;
wire do_block_81x;
assign do_block_81x = do_on_other_nibbles && block_81x;
reg block_81Ax;
wire do_block_81Ax;
assign do_block_81Ax = do_on_other_nibbles && block_81Ax;
reg block_81Af0x;
wire do_block_81Af0x;
assign do_block_81Af0x = do_on_other_nibbles && block_81Af0x;
reg block_81Af1x;
wire do_block_81Af1x;
assign do_block_81Af1x = do_on_other_nibbles && block_81Af1x;
reg block_81Af2x;
wire do_block_81Af2x;
assign do_block_81Af2x = do_on_other_nibbles && block_81Af2x;
reg block_81Afx;
wire do_block_81Afx;
assign do_block_81Afx = do_on_other_nibbles && block_81Afx;
reg block_82x;
wire do_block_82x;
assign do_block_82x = do_on_other_nibbles && block_82x;
reg block_8Ax;
wire do_block_8Ax;
assign do_block_8Ax = do_on_other_nibbles && block_8Ax;
reg block_jump_test;
reg block_jump_test2;
wire do_block_jump_test;
wire do_block_jump_test2;
assign do_block_jump_test = do_on_other_nibbles && block_jump_test;
assign do_block_jump_test2 = do_on_other_nibbles && block_jump_test2;
reg block_9x;
wire do_block_9x;
assign do_block_9x = do_on_other_nibbles && block_9x;
reg block_9ax;
wire do_block_9ax;
assign do_block_9ax = do_on_other_nibbles && block_9ax;
reg block_9bx;
wire do_block_9bx;
assign do_block_9bx = do_on_other_nibbles && block_9bx;
reg block_Ax;
wire do_block_Ax;
assign do_block_Ax = do_on_other_nibbles && block_Ax;
reg block_Aax;
wire do_block_Aax;
assign do_block_Aax = do_on_other_nibbles && block_Aax;
reg block_Abx;
wire do_block_Abx;
assign do_block_Abx = do_on_other_nibbles && block_Abx;
reg block_Bx;
wire do_block_Bx;
assign do_block_Bx = do_on_other_nibbles && block_Bx;
reg block_Bax;
wire do_block_Bax;
assign do_block_Bax = do_on_other_nibbles && block_Bax;
reg block_Bbx;
wire do_block_Bbx;
assign do_block_Bbx = do_on_other_nibbles && block_Bbx;
reg block_Cx;
wire do_block_Cx;
assign do_block_Cx = do_on_other_nibbles && block_Cx;
2019-02-15 11:55:58 +01:00
reg block_Dx;
wire do_block_Dx;
assign do_block_Dx = do_on_other_nibbles && block_Dx;
reg block_Fx;
wire do_block_Fx;
assign do_block_Fx = do_on_other_nibbles && block_Fx;
reg go_fields_table;
/*
* subroutines
*/
reg block_load_reg_imm;
wire do_load_reg_imm;
assign do_load_reg_imm = do_on_other_nibbles && block_load_reg_imm;
reg block_jmp;
wire do_block_jmp;
assign do_block_jmp = do_on_other_nibbles && block_jmp;
reg block_sr_bit;
wire do_block_sr_bit;
assign do_block_sr_bit = do_on_other_nibbles && block_sr_bit;
wire in_fields_table;
assign in_fields_table = go_fields_table && !fields_table_done;
2019-02-19 16:16:32 +01:00
`endif