From 704dbd8c6dc50ba9bd4a078b2be5ece0aa20681c Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 23 Oct 2023 13:59:51 +0200 Subject: [PATCH 01/21] Add Verilog for Spinal USB Host to hw/future/ --- hw/future/UsbOhciAxi4.v | 12320 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 12320 insertions(+) create mode 100644 hw/future/UsbOhciAxi4.v diff --git a/hw/future/UsbOhciAxi4.v b/hw/future/UsbOhciAxi4.v new file mode 100644 index 00000000..17f70fc1 --- /dev/null +++ b/hw/future/UsbOhciAxi4.v @@ -0,0 +1,12320 @@ +// Generator : SpinalHDL dev git head : 670f089dc1c10f6c5d5d4232d87dd2aa80512357 +// Component : UsbOhciAxi4 +// Git hash : 7fd68af876aa409d1bd0ce9a51cd1c397cf4df7b + +`timescale 1ns/1ps + +module UsbOhciAxi4 ( + output io_dma_aw_valid, + input io_dma_aw_ready, + output [31:0] io_dma_aw_payload_addr, + output [7:0] io_dma_aw_payload_len, + output [2:0] io_dma_aw_payload_size, + output [3:0] io_dma_aw_payload_cache, + output [2:0] io_dma_aw_payload_prot, + output io_dma_w_valid, + input io_dma_w_ready, + output [31:0] io_dma_w_payload_data, + output [3:0] io_dma_w_payload_strb, + output io_dma_w_payload_last, + input io_dma_b_valid, + output io_dma_b_ready, + input [1:0] io_dma_b_payload_resp, + output io_dma_ar_valid, + input io_dma_ar_ready, + output [31:0] io_dma_ar_payload_addr, + output [7:0] io_dma_ar_payload_len, + output [2:0] io_dma_ar_payload_size, + output [3:0] io_dma_ar_payload_cache, + output [2:0] io_dma_ar_payload_prot, + input io_dma_r_valid, + output io_dma_r_ready, + input [31:0] io_dma_r_payload_data, + input [1:0] io_dma_r_payload_resp, + input io_dma_r_payload_last, + input io_ctrl_aw_valid, + output io_ctrl_aw_ready, + input [11:0] io_ctrl_aw_payload_addr, + input [7:0] io_ctrl_aw_payload_id, + input [3:0] io_ctrl_aw_payload_region, + input [7:0] io_ctrl_aw_payload_len, + input [2:0] io_ctrl_aw_payload_size, + input [1:0] io_ctrl_aw_payload_burst, + input [0:0] io_ctrl_aw_payload_lock, + input [3:0] io_ctrl_aw_payload_cache, + input [3:0] io_ctrl_aw_payload_qos, + input [2:0] io_ctrl_aw_payload_prot, + input io_ctrl_w_valid, + output io_ctrl_w_ready, + input [31:0] io_ctrl_w_payload_data, + input [3:0] io_ctrl_w_payload_strb, + input io_ctrl_w_payload_last, + output io_ctrl_b_valid, + input io_ctrl_b_ready, + output [7:0] io_ctrl_b_payload_id, + output [1:0] io_ctrl_b_payload_resp, + input io_ctrl_ar_valid, + output io_ctrl_ar_ready, + input [11:0] io_ctrl_ar_payload_addr, + input [7:0] io_ctrl_ar_payload_id, + input [3:0] io_ctrl_ar_payload_region, + input [7:0] io_ctrl_ar_payload_len, + input [2:0] io_ctrl_ar_payload_size, + input [1:0] io_ctrl_ar_payload_burst, + input [0:0] io_ctrl_ar_payload_lock, + input [3:0] io_ctrl_ar_payload_cache, + input [3:0] io_ctrl_ar_payload_qos, + input [2:0] io_ctrl_ar_payload_prot, + output io_ctrl_r_valid, + input io_ctrl_r_ready, + output [31:0] io_ctrl_r_payload_data, + output [7:0] io_ctrl_r_payload_id, + output [1:0] io_ctrl_r_payload_resp, + output io_ctrl_r_payload_last, + output io_interrupt, + input io_usb_0_dp_read, + output io_usb_0_dp_write, + output io_usb_0_dp_writeEnable, + input io_usb_0_dm_read, + output io_usb_0_dm_write, + output io_usb_0_dm_writeEnable, + input phy_clk, + input phy_reset, + input ctrl_clk, + input ctrl_reset +); + + wire front_dmaBridge_io_output_arw_ready; + wire front_ctrlBridge_io_axi_arw_payload_write; + wire back_phy_io_management_0_overcurrent; + wire front_dmaBridge_io_input_cmd_ready; + wire front_dmaBridge_io_input_rsp_valid; + wire front_dmaBridge_io_input_rsp_payload_last; + wire [0:0] front_dmaBridge_io_input_rsp_payload_fragment_opcode; + wire [31:0] front_dmaBridge_io_input_rsp_payload_fragment_data; + wire front_dmaBridge_io_output_arw_valid; + wire [31:0] front_dmaBridge_io_output_arw_payload_addr; + wire [7:0] front_dmaBridge_io_output_arw_payload_len; + wire [2:0] front_dmaBridge_io_output_arw_payload_size; + wire [3:0] front_dmaBridge_io_output_arw_payload_cache; + wire [2:0] front_dmaBridge_io_output_arw_payload_prot; + wire front_dmaBridge_io_output_arw_payload_write; + wire front_dmaBridge_io_output_w_valid; + wire [31:0] front_dmaBridge_io_output_w_payload_data; + wire [3:0] front_dmaBridge_io_output_w_payload_strb; + wire front_dmaBridge_io_output_w_payload_last; + wire front_dmaBridge_io_output_b_ready; + wire front_dmaBridge_io_output_r_ready; + wire front_ctrlBridge_io_axi_arw_ready; + wire front_ctrlBridge_io_axi_w_ready; + wire front_ctrlBridge_io_axi_b_valid; + wire [7:0] front_ctrlBridge_io_axi_b_payload_id; + wire [1:0] front_ctrlBridge_io_axi_b_payload_resp; + wire front_ctrlBridge_io_axi_r_valid; + wire [31:0] front_ctrlBridge_io_axi_r_payload_data; + wire [7:0] front_ctrlBridge_io_axi_r_payload_id; + wire [1:0] front_ctrlBridge_io_axi_r_payload_resp; + wire front_ctrlBridge_io_axi_r_payload_last; + wire front_ctrlBridge_io_bmb_cmd_valid; + wire front_ctrlBridge_io_bmb_cmd_payload_last; + wire [8:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_source; + wire [0:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_opcode; + wire [11:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_address; + wire [9:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_length; + wire [31:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_data; + wire [3:0] front_ctrlBridge_io_bmb_cmd_payload_fragment_mask; + wire front_ctrlBridge_io_bmb_rsp_ready; + wire streamArbiter_io_inputs_0_ready; + wire streamArbiter_io_inputs_1_ready; + wire streamArbiter_io_output_valid; + wire [11:0] streamArbiter_io_output_payload_addr; + wire [7:0] streamArbiter_io_output_payload_id; + wire [3:0] streamArbiter_io_output_payload_region; + wire [7:0] streamArbiter_io_output_payload_len; + wire [2:0] streamArbiter_io_output_payload_size; + wire [1:0] streamArbiter_io_output_payload_burst; + wire [0:0] streamArbiter_io_output_payload_lock; + wire [3:0] streamArbiter_io_output_payload_cache; + wire [3:0] streamArbiter_io_output_payload_qos; + wire [2:0] streamArbiter_io_output_payload_prot; + wire [0:0] streamArbiter_io_chosen; + wire [1:0] streamArbiter_io_chosenOH; + wire front_ohci_io_ctrl_cmd_ready; + wire front_ohci_io_ctrl_rsp_valid; + wire front_ohci_io_ctrl_rsp_payload_last; + wire [8:0] front_ohci_io_ctrl_rsp_payload_fragment_source; + wire [0:0] front_ohci_io_ctrl_rsp_payload_fragment_opcode; + wire [31:0] front_ohci_io_ctrl_rsp_payload_fragment_data; + wire front_ohci_io_phy_lowSpeed; + wire front_ohci_io_phy_usbReset; + wire front_ohci_io_phy_usbResume; + wire front_ohci_io_phy_tx_valid; + wire front_ohci_io_phy_tx_payload_last; + wire [7:0] front_ohci_io_phy_tx_payload_fragment; + wire front_ohci_io_phy_ports_0_removable; + wire front_ohci_io_phy_ports_0_power; + wire front_ohci_io_phy_ports_0_reset_valid; + wire front_ohci_io_phy_ports_0_suspend_valid; + wire front_ohci_io_phy_ports_0_resume_valid; + wire front_ohci_io_phy_ports_0_disable_valid; + wire front_ohci_io_dma_cmd_valid; + wire front_ohci_io_dma_cmd_payload_last; + wire [0:0] front_ohci_io_dma_cmd_payload_fragment_opcode; + wire [31:0] front_ohci_io_dma_cmd_payload_fragment_address; + wire [5:0] front_ohci_io_dma_cmd_payload_fragment_length; + wire [31:0] front_ohci_io_dma_cmd_payload_fragment_data; + wire [3:0] front_ohci_io_dma_cmd_payload_fragment_mask; + wire front_ohci_io_dma_rsp_ready; + wire front_ohci_io_interrupt; + wire front_ohci_io_interruptBios; + wire back_phy_io_ctrl_overcurrent; + wire back_phy_io_ctrl_tick; + wire back_phy_io_ctrl_tx_ready; + wire back_phy_io_ctrl_txEop; + wire back_phy_io_ctrl_rx_flow_valid; + wire back_phy_io_ctrl_rx_flow_payload_stuffingError; + wire [7:0] back_phy_io_ctrl_rx_flow_payload_data; + wire back_phy_io_ctrl_rx_active; + wire back_phy_io_ctrl_ports_0_reset_ready; + wire back_phy_io_ctrl_ports_0_suspend_ready; + wire back_phy_io_ctrl_ports_0_resume_ready; + wire back_phy_io_ctrl_ports_0_disable_ready; + wire back_phy_io_ctrl_ports_0_connect; + wire back_phy_io_ctrl_ports_0_disconnect; + wire back_phy_io_ctrl_ports_0_overcurrent; + wire back_phy_io_ctrl_ports_0_lowSpeed; + wire back_phy_io_ctrl_ports_0_remoteResume; + wire back_phy_io_usb_0_tx_enable; + wire back_phy_io_usb_0_tx_data; + wire back_phy_io_usb_0_tx_se0; + wire back_phy_io_management_0_power; + wire cc_input_overcurrent; + wire cc_input_tick; + wire cc_input_tx_ready; + wire cc_input_txEop; + wire cc_input_rx_flow_valid; + wire cc_input_rx_flow_payload_stuffingError; + wire [7:0] cc_input_rx_flow_payload_data; + wire cc_input_rx_active; + wire cc_input_ports_0_reset_ready; + wire cc_input_ports_0_suspend_ready; + wire cc_input_ports_0_resume_ready; + wire cc_input_ports_0_disable_ready; + wire cc_input_ports_0_connect; + wire cc_input_ports_0_disconnect; + wire cc_input_ports_0_overcurrent; + wire cc_input_ports_0_lowSpeed; + wire cc_input_ports_0_remoteResume; + wire cc_output_lowSpeed; + wire cc_output_usbReset; + wire cc_output_usbResume; + wire cc_output_tx_valid; + wire cc_output_tx_payload_last; + wire [7:0] cc_output_tx_payload_fragment; + wire cc_output_ports_0_removable; + wire cc_output_ports_0_power; + wire cc_output_ports_0_reset_valid; + wire cc_output_ports_0_suspend_valid; + wire cc_output_ports_0_resume_valid; + wire cc_output_ports_0_disable_valid; + wire back_native_0_dp_read; + wire back_native_0_dp_write; + wire back_native_0_dp_writeEnable; + wire back_native_0_dm_read; + wire back_native_0_dm_write; + wire back_native_0_dm_writeEnable; + wire back_buffer_0_dp_read; + wire back_buffer_0_dp_write; + wire back_buffer_0_dp_writeEnable; + wire back_buffer_0_dm_read; + wire back_buffer_0_dm_write; + wire back_buffer_0_dm_writeEnable; + wire back_native_0_dp_stage_read; + wire back_native_0_dp_stage_write; + wire back_native_0_dp_stage_writeEnable; + reg back_native_0_dp_writeEnable_regNext; + reg back_native_0_dp_write_regNext; + reg back_native_0_dp_stage_read_regNext; + wire back_native_0_dm_stage_read; + wire back_native_0_dm_stage_write; + wire back_native_0_dm_stage_writeEnable; + reg back_native_0_dm_writeEnable_regNext; + reg back_native_0_dm_write_regNext; + reg back_native_0_dm_stage_read_regNext; + wire back_buffer_0_dp_stage_read; + wire back_buffer_0_dp_stage_write; + wire back_buffer_0_dp_stage_writeEnable; + reg back_buffer_0_dp_writeEnable_regNext; + reg back_buffer_0_dp_write_regNext; + reg back_buffer_0_dp_stage_read_regNext; + wire back_buffer_0_dm_stage_read; + wire back_buffer_0_dm_stage_write; + wire back_buffer_0_dm_stage_writeEnable; + reg back_buffer_0_dm_writeEnable_regNext; + reg back_buffer_0_dm_write_regNext; + reg back_buffer_0_dm_stage_read_regNext; + + UsbOhciAxi4_BmbToAxi4SharedBridge front_dmaBridge ( + .io_input_cmd_valid (front_ohci_io_dma_cmd_valid ), //i + .io_input_cmd_ready (front_dmaBridge_io_input_cmd_ready ), //o + .io_input_cmd_payload_last (front_ohci_io_dma_cmd_payload_last ), //i + .io_input_cmd_payload_fragment_opcode (front_ohci_io_dma_cmd_payload_fragment_opcode ), //i + .io_input_cmd_payload_fragment_address (front_ohci_io_dma_cmd_payload_fragment_address[31:0] ), //i + .io_input_cmd_payload_fragment_length (front_ohci_io_dma_cmd_payload_fragment_length[5:0] ), //i + .io_input_cmd_payload_fragment_data (front_ohci_io_dma_cmd_payload_fragment_data[31:0] ), //i + .io_input_cmd_payload_fragment_mask (front_ohci_io_dma_cmd_payload_fragment_mask[3:0] ), //i + .io_input_rsp_valid (front_dmaBridge_io_input_rsp_valid ), //o + .io_input_rsp_ready (front_ohci_io_dma_rsp_ready ), //i + .io_input_rsp_payload_last (front_dmaBridge_io_input_rsp_payload_last ), //o + .io_input_rsp_payload_fragment_opcode (front_dmaBridge_io_input_rsp_payload_fragment_opcode ), //o + .io_input_rsp_payload_fragment_data (front_dmaBridge_io_input_rsp_payload_fragment_data[31:0]), //o + .io_output_arw_valid (front_dmaBridge_io_output_arw_valid ), //o + .io_output_arw_ready (front_dmaBridge_io_output_arw_ready ), //i + .io_output_arw_payload_addr (front_dmaBridge_io_output_arw_payload_addr[31:0] ), //o + .io_output_arw_payload_len (front_dmaBridge_io_output_arw_payload_len[7:0] ), //o + .io_output_arw_payload_size (front_dmaBridge_io_output_arw_payload_size[2:0] ), //o + .io_output_arw_payload_cache (front_dmaBridge_io_output_arw_payload_cache[3:0] ), //o + .io_output_arw_payload_prot (front_dmaBridge_io_output_arw_payload_prot[2:0] ), //o + .io_output_arw_payload_write (front_dmaBridge_io_output_arw_payload_write ), //o + .io_output_w_valid (front_dmaBridge_io_output_w_valid ), //o + .io_output_w_ready (io_dma_w_ready ), //i + .io_output_w_payload_data (front_dmaBridge_io_output_w_payload_data[31:0] ), //o + .io_output_w_payload_strb (front_dmaBridge_io_output_w_payload_strb[3:0] ), //o + .io_output_w_payload_last (front_dmaBridge_io_output_w_payload_last ), //o + .io_output_b_valid (io_dma_b_valid ), //i + .io_output_b_ready (front_dmaBridge_io_output_b_ready ), //o + .io_output_b_payload_resp (io_dma_b_payload_resp[1:0] ), //i + .io_output_r_valid (io_dma_r_valid ), //i + .io_output_r_ready (front_dmaBridge_io_output_r_ready ), //o + .io_output_r_payload_data (io_dma_r_payload_data[31:0] ), //i + .io_output_r_payload_resp (io_dma_r_payload_resp[1:0] ), //i + .io_output_r_payload_last (io_dma_r_payload_last ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_Axi4SharedToBmb front_ctrlBridge ( + .io_axi_arw_valid (streamArbiter_io_output_valid ), //i + .io_axi_arw_ready (front_ctrlBridge_io_axi_arw_ready ), //o + .io_axi_arw_payload_addr (streamArbiter_io_output_payload_addr[11:0] ), //i + .io_axi_arw_payload_id (streamArbiter_io_output_payload_id[7:0] ), //i + .io_axi_arw_payload_region (streamArbiter_io_output_payload_region[3:0] ), //i + .io_axi_arw_payload_len (streamArbiter_io_output_payload_len[7:0] ), //i + .io_axi_arw_payload_size (streamArbiter_io_output_payload_size[2:0] ), //i + .io_axi_arw_payload_burst (streamArbiter_io_output_payload_burst[1:0] ), //i + .io_axi_arw_payload_lock (streamArbiter_io_output_payload_lock ), //i + .io_axi_arw_payload_cache (streamArbiter_io_output_payload_cache[3:0] ), //i + .io_axi_arw_payload_qos (streamArbiter_io_output_payload_qos[3:0] ), //i + .io_axi_arw_payload_prot (streamArbiter_io_output_payload_prot[2:0] ), //i + .io_axi_arw_payload_write (front_ctrlBridge_io_axi_arw_payload_write ), //i + .io_axi_w_valid (io_ctrl_w_valid ), //i + .io_axi_w_ready (front_ctrlBridge_io_axi_w_ready ), //o + .io_axi_w_payload_data (io_ctrl_w_payload_data[31:0] ), //i + .io_axi_w_payload_strb (io_ctrl_w_payload_strb[3:0] ), //i + .io_axi_w_payload_last (io_ctrl_w_payload_last ), //i + .io_axi_b_valid (front_ctrlBridge_io_axi_b_valid ), //o + .io_axi_b_ready (io_ctrl_b_ready ), //i + .io_axi_b_payload_id (front_ctrlBridge_io_axi_b_payload_id[7:0] ), //o + .io_axi_b_payload_resp (front_ctrlBridge_io_axi_b_payload_resp[1:0] ), //o + .io_axi_r_valid (front_ctrlBridge_io_axi_r_valid ), //o + .io_axi_r_ready (io_ctrl_r_ready ), //i + .io_axi_r_payload_data (front_ctrlBridge_io_axi_r_payload_data[31:0] ), //o + .io_axi_r_payload_id (front_ctrlBridge_io_axi_r_payload_id[7:0] ), //o + .io_axi_r_payload_resp (front_ctrlBridge_io_axi_r_payload_resp[1:0] ), //o + .io_axi_r_payload_last (front_ctrlBridge_io_axi_r_payload_last ), //o + .io_bmb_cmd_valid (front_ctrlBridge_io_bmb_cmd_valid ), //o + .io_bmb_cmd_ready (front_ohci_io_ctrl_cmd_ready ), //i + .io_bmb_cmd_payload_last (front_ctrlBridge_io_bmb_cmd_payload_last ), //o + .io_bmb_cmd_payload_fragment_source (front_ctrlBridge_io_bmb_cmd_payload_fragment_source[8:0] ), //o + .io_bmb_cmd_payload_fragment_opcode (front_ctrlBridge_io_bmb_cmd_payload_fragment_opcode ), //o + .io_bmb_cmd_payload_fragment_address (front_ctrlBridge_io_bmb_cmd_payload_fragment_address[11:0]), //o + .io_bmb_cmd_payload_fragment_length (front_ctrlBridge_io_bmb_cmd_payload_fragment_length[9:0] ), //o + .io_bmb_cmd_payload_fragment_data (front_ctrlBridge_io_bmb_cmd_payload_fragment_data[31:0] ), //o + .io_bmb_cmd_payload_fragment_mask (front_ctrlBridge_io_bmb_cmd_payload_fragment_mask[3:0] ), //o + .io_bmb_rsp_valid (front_ohci_io_ctrl_rsp_valid ), //i + .io_bmb_rsp_ready (front_ctrlBridge_io_bmb_rsp_ready ), //o + .io_bmb_rsp_payload_last (front_ohci_io_ctrl_rsp_payload_last ), //i + .io_bmb_rsp_payload_fragment_source (front_ohci_io_ctrl_rsp_payload_fragment_source[8:0] ), //i + .io_bmb_rsp_payload_fragment_opcode (front_ohci_io_ctrl_rsp_payload_fragment_opcode ), //i + .io_bmb_rsp_payload_fragment_data (front_ohci_io_ctrl_rsp_payload_fragment_data[31:0] ) //i + ); + UsbOhciAxi4_StreamArbiter streamArbiter ( + .io_inputs_0_valid (io_ctrl_ar_valid ), //i + .io_inputs_0_ready (streamArbiter_io_inputs_0_ready ), //o + .io_inputs_0_payload_addr (io_ctrl_ar_payload_addr[11:0] ), //i + .io_inputs_0_payload_id (io_ctrl_ar_payload_id[7:0] ), //i + .io_inputs_0_payload_region (io_ctrl_ar_payload_region[3:0] ), //i + .io_inputs_0_payload_len (io_ctrl_ar_payload_len[7:0] ), //i + .io_inputs_0_payload_size (io_ctrl_ar_payload_size[2:0] ), //i + .io_inputs_0_payload_burst (io_ctrl_ar_payload_burst[1:0] ), //i + .io_inputs_0_payload_lock (io_ctrl_ar_payload_lock ), //i + .io_inputs_0_payload_cache (io_ctrl_ar_payload_cache[3:0] ), //i + .io_inputs_0_payload_qos (io_ctrl_ar_payload_qos[3:0] ), //i + .io_inputs_0_payload_prot (io_ctrl_ar_payload_prot[2:0] ), //i + .io_inputs_1_valid (io_ctrl_aw_valid ), //i + .io_inputs_1_ready (streamArbiter_io_inputs_1_ready ), //o + .io_inputs_1_payload_addr (io_ctrl_aw_payload_addr[11:0] ), //i + .io_inputs_1_payload_id (io_ctrl_aw_payload_id[7:0] ), //i + .io_inputs_1_payload_region (io_ctrl_aw_payload_region[3:0] ), //i + .io_inputs_1_payload_len (io_ctrl_aw_payload_len[7:0] ), //i + .io_inputs_1_payload_size (io_ctrl_aw_payload_size[2:0] ), //i + .io_inputs_1_payload_burst (io_ctrl_aw_payload_burst[1:0] ), //i + .io_inputs_1_payload_lock (io_ctrl_aw_payload_lock ), //i + .io_inputs_1_payload_cache (io_ctrl_aw_payload_cache[3:0] ), //i + .io_inputs_1_payload_qos (io_ctrl_aw_payload_qos[3:0] ), //i + .io_inputs_1_payload_prot (io_ctrl_aw_payload_prot[2:0] ), //i + .io_output_valid (streamArbiter_io_output_valid ), //o + .io_output_ready (front_ctrlBridge_io_axi_arw_ready ), //i + .io_output_payload_addr (streamArbiter_io_output_payload_addr[11:0] ), //o + .io_output_payload_id (streamArbiter_io_output_payload_id[7:0] ), //o + .io_output_payload_region (streamArbiter_io_output_payload_region[3:0]), //o + .io_output_payload_len (streamArbiter_io_output_payload_len[7:0] ), //o + .io_output_payload_size (streamArbiter_io_output_payload_size[2:0] ), //o + .io_output_payload_burst (streamArbiter_io_output_payload_burst[1:0] ), //o + .io_output_payload_lock (streamArbiter_io_output_payload_lock ), //o + .io_output_payload_cache (streamArbiter_io_output_payload_cache[3:0] ), //o + .io_output_payload_qos (streamArbiter_io_output_payload_qos[3:0] ), //o + .io_output_payload_prot (streamArbiter_io_output_payload_prot[2:0] ), //o + .io_chosen (streamArbiter_io_chosen ), //o + .io_chosenOH (streamArbiter_io_chosenOH[1:0] ), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_UsbOhci front_ohci ( + .io_ctrl_cmd_valid (front_ctrlBridge_io_bmb_cmd_valid ), //i + .io_ctrl_cmd_ready (front_ohci_io_ctrl_cmd_ready ), //o + .io_ctrl_cmd_payload_last (front_ctrlBridge_io_bmb_cmd_payload_last ), //i + .io_ctrl_cmd_payload_fragment_source (front_ctrlBridge_io_bmb_cmd_payload_fragment_source[8:0] ), //i + .io_ctrl_cmd_payload_fragment_opcode (front_ctrlBridge_io_bmb_cmd_payload_fragment_opcode ), //i + .io_ctrl_cmd_payload_fragment_address (front_ctrlBridge_io_bmb_cmd_payload_fragment_address[11:0]), //i + .io_ctrl_cmd_payload_fragment_length (front_ctrlBridge_io_bmb_cmd_payload_fragment_length[9:0] ), //i + .io_ctrl_cmd_payload_fragment_data (front_ctrlBridge_io_bmb_cmd_payload_fragment_data[31:0] ), //i + .io_ctrl_cmd_payload_fragment_mask (front_ctrlBridge_io_bmb_cmd_payload_fragment_mask[3:0] ), //i + .io_ctrl_rsp_valid (front_ohci_io_ctrl_rsp_valid ), //o + .io_ctrl_rsp_ready (front_ctrlBridge_io_bmb_rsp_ready ), //i + .io_ctrl_rsp_payload_last (front_ohci_io_ctrl_rsp_payload_last ), //o + .io_ctrl_rsp_payload_fragment_source (front_ohci_io_ctrl_rsp_payload_fragment_source[8:0] ), //o + .io_ctrl_rsp_payload_fragment_opcode (front_ohci_io_ctrl_rsp_payload_fragment_opcode ), //o + .io_ctrl_rsp_payload_fragment_data (front_ohci_io_ctrl_rsp_payload_fragment_data[31:0] ), //o + .io_phy_lowSpeed (front_ohci_io_phy_lowSpeed ), //o + .io_phy_tx_valid (front_ohci_io_phy_tx_valid ), //o + .io_phy_tx_ready (cc_input_tx_ready ), //i + .io_phy_tx_payload_last (front_ohci_io_phy_tx_payload_last ), //o + .io_phy_tx_payload_fragment (front_ohci_io_phy_tx_payload_fragment[7:0] ), //o + .io_phy_txEop (cc_input_txEop ), //i + .io_phy_rx_flow_valid (cc_input_rx_flow_valid ), //i + .io_phy_rx_flow_payload_stuffingError (cc_input_rx_flow_payload_stuffingError ), //i + .io_phy_rx_flow_payload_data (cc_input_rx_flow_payload_data[7:0] ), //i + .io_phy_rx_active (cc_input_rx_active ), //i + .io_phy_usbReset (front_ohci_io_phy_usbReset ), //o + .io_phy_usbResume (front_ohci_io_phy_usbResume ), //o + .io_phy_overcurrent (cc_input_overcurrent ), //i + .io_phy_tick (cc_input_tick ), //i + .io_phy_ports_0_disable_valid (front_ohci_io_phy_ports_0_disable_valid ), //o + .io_phy_ports_0_disable_ready (cc_input_ports_0_disable_ready ), //i + .io_phy_ports_0_removable (front_ohci_io_phy_ports_0_removable ), //o + .io_phy_ports_0_power (front_ohci_io_phy_ports_0_power ), //o + .io_phy_ports_0_reset_valid (front_ohci_io_phy_ports_0_reset_valid ), //o + .io_phy_ports_0_reset_ready (cc_input_ports_0_reset_ready ), //i + .io_phy_ports_0_suspend_valid (front_ohci_io_phy_ports_0_suspend_valid ), //o + .io_phy_ports_0_suspend_ready (cc_input_ports_0_suspend_ready ), //i + .io_phy_ports_0_resume_valid (front_ohci_io_phy_ports_0_resume_valid ), //o + .io_phy_ports_0_resume_ready (cc_input_ports_0_resume_ready ), //i + .io_phy_ports_0_connect (cc_input_ports_0_connect ), //i + .io_phy_ports_0_disconnect (cc_input_ports_0_disconnect ), //i + .io_phy_ports_0_overcurrent (cc_input_ports_0_overcurrent ), //i + .io_phy_ports_0_remoteResume (cc_input_ports_0_remoteResume ), //i + .io_phy_ports_0_lowSpeed (cc_input_ports_0_lowSpeed ), //i + .io_dma_cmd_valid (front_ohci_io_dma_cmd_valid ), //o + .io_dma_cmd_ready (front_dmaBridge_io_input_cmd_ready ), //i + .io_dma_cmd_payload_last (front_ohci_io_dma_cmd_payload_last ), //o + .io_dma_cmd_payload_fragment_opcode (front_ohci_io_dma_cmd_payload_fragment_opcode ), //o + .io_dma_cmd_payload_fragment_address (front_ohci_io_dma_cmd_payload_fragment_address[31:0] ), //o + .io_dma_cmd_payload_fragment_length (front_ohci_io_dma_cmd_payload_fragment_length[5:0] ), //o + .io_dma_cmd_payload_fragment_data (front_ohci_io_dma_cmd_payload_fragment_data[31:0] ), //o + .io_dma_cmd_payload_fragment_mask (front_ohci_io_dma_cmd_payload_fragment_mask[3:0] ), //o + .io_dma_rsp_valid (front_dmaBridge_io_input_rsp_valid ), //i + .io_dma_rsp_ready (front_ohci_io_dma_rsp_ready ), //o + .io_dma_rsp_payload_last (front_dmaBridge_io_input_rsp_payload_last ), //i + .io_dma_rsp_payload_fragment_opcode (front_dmaBridge_io_input_rsp_payload_fragment_opcode ), //i + .io_dma_rsp_payload_fragment_data (front_dmaBridge_io_input_rsp_payload_fragment_data[31:0] ), //i + .io_interrupt (front_ohci_io_interrupt ), //o + .io_interruptBios (front_ohci_io_interruptBios ), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_UsbLsFsPhy back_phy ( + .io_ctrl_lowSpeed (cc_output_lowSpeed ), //i + .io_ctrl_tx_valid (cc_output_tx_valid ), //i + .io_ctrl_tx_ready (back_phy_io_ctrl_tx_ready ), //o + .io_ctrl_tx_payload_last (cc_output_tx_payload_last ), //i + .io_ctrl_tx_payload_fragment (cc_output_tx_payload_fragment[7:0] ), //i + .io_ctrl_txEop (back_phy_io_ctrl_txEop ), //o + .io_ctrl_rx_flow_valid (back_phy_io_ctrl_rx_flow_valid ), //o + .io_ctrl_rx_flow_payload_stuffingError (back_phy_io_ctrl_rx_flow_payload_stuffingError), //o + .io_ctrl_rx_flow_payload_data (back_phy_io_ctrl_rx_flow_payload_data[7:0] ), //o + .io_ctrl_rx_active (back_phy_io_ctrl_rx_active ), //o + .io_ctrl_usbReset (cc_output_usbReset ), //i + .io_ctrl_usbResume (cc_output_usbResume ), //i + .io_ctrl_overcurrent (back_phy_io_ctrl_overcurrent ), //o + .io_ctrl_tick (back_phy_io_ctrl_tick ), //o + .io_ctrl_ports_0_disable_valid (cc_output_ports_0_disable_valid ), //i + .io_ctrl_ports_0_disable_ready (back_phy_io_ctrl_ports_0_disable_ready ), //o + .io_ctrl_ports_0_removable (cc_output_ports_0_removable ), //i + .io_ctrl_ports_0_power (cc_output_ports_0_power ), //i + .io_ctrl_ports_0_reset_valid (cc_output_ports_0_reset_valid ), //i + .io_ctrl_ports_0_reset_ready (back_phy_io_ctrl_ports_0_reset_ready ), //o + .io_ctrl_ports_0_suspend_valid (cc_output_ports_0_suspend_valid ), //i + .io_ctrl_ports_0_suspend_ready (back_phy_io_ctrl_ports_0_suspend_ready ), //o + .io_ctrl_ports_0_resume_valid (cc_output_ports_0_resume_valid ), //i + .io_ctrl_ports_0_resume_ready (back_phy_io_ctrl_ports_0_resume_ready ), //o + .io_ctrl_ports_0_connect (back_phy_io_ctrl_ports_0_connect ), //o + .io_ctrl_ports_0_disconnect (back_phy_io_ctrl_ports_0_disconnect ), //o + .io_ctrl_ports_0_overcurrent (back_phy_io_ctrl_ports_0_overcurrent ), //o + .io_ctrl_ports_0_remoteResume (back_phy_io_ctrl_ports_0_remoteResume ), //o + .io_ctrl_ports_0_lowSpeed (back_phy_io_ctrl_ports_0_lowSpeed ), //o + .io_usb_0_tx_enable (back_phy_io_usb_0_tx_enable ), //o + .io_usb_0_tx_data (back_phy_io_usb_0_tx_data ), //o + .io_usb_0_tx_se0 (back_phy_io_usb_0_tx_se0 ), //o + .io_usb_0_rx_dp (back_native_0_dp_read ), //i + .io_usb_0_rx_dm (back_native_0_dm_read ), //i + .io_management_0_overcurrent (back_phy_io_management_0_overcurrent ), //i + .io_management_0_power (back_phy_io_management_0_power ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_CtrlCc cc ( + .input_lowSpeed (front_ohci_io_phy_lowSpeed ), //i + .input_tx_valid (front_ohci_io_phy_tx_valid ), //i + .input_tx_ready (cc_input_tx_ready ), //o + .input_tx_payload_last (front_ohci_io_phy_tx_payload_last ), //i + .input_tx_payload_fragment (front_ohci_io_phy_tx_payload_fragment[7:0] ), //i + .input_txEop (cc_input_txEop ), //o + .input_rx_flow_valid (cc_input_rx_flow_valid ), //o + .input_rx_flow_payload_stuffingError (cc_input_rx_flow_payload_stuffingError ), //o + .input_rx_flow_payload_data (cc_input_rx_flow_payload_data[7:0] ), //o + .input_rx_active (cc_input_rx_active ), //o + .input_usbReset (front_ohci_io_phy_usbReset ), //i + .input_usbResume (front_ohci_io_phy_usbResume ), //i + .input_overcurrent (cc_input_overcurrent ), //o + .input_tick (cc_input_tick ), //o + .input_ports_0_disable_valid (front_ohci_io_phy_ports_0_disable_valid ), //i + .input_ports_0_disable_ready (cc_input_ports_0_disable_ready ), //o + .input_ports_0_removable (front_ohci_io_phy_ports_0_removable ), //i + .input_ports_0_power (front_ohci_io_phy_ports_0_power ), //i + .input_ports_0_reset_valid (front_ohci_io_phy_ports_0_reset_valid ), //i + .input_ports_0_reset_ready (cc_input_ports_0_reset_ready ), //o + .input_ports_0_suspend_valid (front_ohci_io_phy_ports_0_suspend_valid ), //i + .input_ports_0_suspend_ready (cc_input_ports_0_suspend_ready ), //o + .input_ports_0_resume_valid (front_ohci_io_phy_ports_0_resume_valid ), //i + .input_ports_0_resume_ready (cc_input_ports_0_resume_ready ), //o + .input_ports_0_connect (cc_input_ports_0_connect ), //o + .input_ports_0_disconnect (cc_input_ports_0_disconnect ), //o + .input_ports_0_overcurrent (cc_input_ports_0_overcurrent ), //o + .input_ports_0_remoteResume (cc_input_ports_0_remoteResume ), //o + .input_ports_0_lowSpeed (cc_input_ports_0_lowSpeed ), //o + .output_lowSpeed (cc_output_lowSpeed ), //o + .output_tx_valid (cc_output_tx_valid ), //o + .output_tx_ready (back_phy_io_ctrl_tx_ready ), //i + .output_tx_payload_last (cc_output_tx_payload_last ), //o + .output_tx_payload_fragment (cc_output_tx_payload_fragment[7:0] ), //o + .output_txEop (back_phy_io_ctrl_txEop ), //i + .output_rx_flow_valid (back_phy_io_ctrl_rx_flow_valid ), //i + .output_rx_flow_payload_stuffingError (back_phy_io_ctrl_rx_flow_payload_stuffingError), //i + .output_rx_flow_payload_data (back_phy_io_ctrl_rx_flow_payload_data[7:0] ), //i + .output_rx_active (back_phy_io_ctrl_rx_active ), //i + .output_usbReset (cc_output_usbReset ), //o + .output_usbResume (cc_output_usbResume ), //o + .output_overcurrent (back_phy_io_ctrl_overcurrent ), //i + .output_tick (back_phy_io_ctrl_tick ), //i + .output_ports_0_disable_valid (cc_output_ports_0_disable_valid ), //o + .output_ports_0_disable_ready (back_phy_io_ctrl_ports_0_disable_ready ), //i + .output_ports_0_removable (cc_output_ports_0_removable ), //o + .output_ports_0_power (cc_output_ports_0_power ), //o + .output_ports_0_reset_valid (cc_output_ports_0_reset_valid ), //o + .output_ports_0_reset_ready (back_phy_io_ctrl_ports_0_reset_ready ), //i + .output_ports_0_suspend_valid (cc_output_ports_0_suspend_valid ), //o + .output_ports_0_suspend_ready (back_phy_io_ctrl_ports_0_suspend_ready ), //i + .output_ports_0_resume_valid (cc_output_ports_0_resume_valid ), //o + .output_ports_0_resume_ready (back_phy_io_ctrl_ports_0_resume_ready ), //i + .output_ports_0_connect (back_phy_io_ctrl_ports_0_connect ), //i + .output_ports_0_disconnect (back_phy_io_ctrl_ports_0_disconnect ), //i + .output_ports_0_overcurrent (back_phy_io_ctrl_ports_0_overcurrent ), //i + .output_ports_0_remoteResume (back_phy_io_ctrl_ports_0_remoteResume ), //i + .output_ports_0_lowSpeed (back_phy_io_ctrl_ports_0_lowSpeed ), //i + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + assign front_dmaBridge_io_output_arw_ready = (front_dmaBridge_io_output_arw_payload_write ? io_dma_aw_ready : io_dma_ar_ready); + assign io_dma_aw_valid = (front_dmaBridge_io_output_arw_valid && front_dmaBridge_io_output_arw_payload_write); + assign io_dma_aw_payload_addr = front_dmaBridge_io_output_arw_payload_addr; + assign io_dma_aw_payload_len = front_dmaBridge_io_output_arw_payload_len; + assign io_dma_aw_payload_size = front_dmaBridge_io_output_arw_payload_size; + assign io_dma_aw_payload_cache = front_dmaBridge_io_output_arw_payload_cache; + assign io_dma_aw_payload_prot = front_dmaBridge_io_output_arw_payload_prot; + assign io_dma_w_valid = front_dmaBridge_io_output_w_valid; + assign io_dma_w_payload_data = front_dmaBridge_io_output_w_payload_data; + assign io_dma_w_payload_strb = front_dmaBridge_io_output_w_payload_strb; + assign io_dma_w_payload_last = front_dmaBridge_io_output_w_payload_last; + assign io_dma_b_ready = front_dmaBridge_io_output_b_ready; + assign io_dma_ar_valid = (front_dmaBridge_io_output_arw_valid && (! front_dmaBridge_io_output_arw_payload_write)); + assign io_dma_ar_payload_addr = front_dmaBridge_io_output_arw_payload_addr; + assign io_dma_ar_payload_len = front_dmaBridge_io_output_arw_payload_len; + assign io_dma_ar_payload_size = front_dmaBridge_io_output_arw_payload_size; + assign io_dma_ar_payload_cache = front_dmaBridge_io_output_arw_payload_cache; + assign io_dma_ar_payload_prot = front_dmaBridge_io_output_arw_payload_prot; + assign io_dma_r_ready = front_dmaBridge_io_output_r_ready; + assign io_ctrl_ar_ready = streamArbiter_io_inputs_0_ready; + assign io_ctrl_aw_ready = streamArbiter_io_inputs_1_ready; + assign io_ctrl_w_ready = front_ctrlBridge_io_axi_w_ready; + assign io_ctrl_b_valid = front_ctrlBridge_io_axi_b_valid; + assign io_ctrl_b_payload_id = front_ctrlBridge_io_axi_b_payload_id; + assign io_ctrl_b_payload_resp = front_ctrlBridge_io_axi_b_payload_resp; + assign io_ctrl_r_valid = front_ctrlBridge_io_axi_r_valid; + assign io_ctrl_r_payload_data = front_ctrlBridge_io_axi_r_payload_data; + assign io_ctrl_r_payload_id = front_ctrlBridge_io_axi_r_payload_id; + assign io_ctrl_r_payload_resp = front_ctrlBridge_io_axi_r_payload_resp; + assign io_ctrl_r_payload_last = front_ctrlBridge_io_axi_r_payload_last; + assign front_ctrlBridge_io_axi_arw_payload_write = streamArbiter_io_chosenOH[1]; + assign io_interrupt = front_ohci_io_interrupt; + assign back_phy_io_management_0_overcurrent = 1'b0; + assign back_native_0_dp_writeEnable = back_phy_io_usb_0_tx_enable; + assign back_native_0_dm_writeEnable = back_phy_io_usb_0_tx_enable; + assign back_native_0_dp_write = ((! back_phy_io_usb_0_tx_se0) && back_phy_io_usb_0_tx_data); + assign back_native_0_dm_write = ((! back_phy_io_usb_0_tx_se0) && (! back_phy_io_usb_0_tx_data)); + assign back_native_0_dp_stage_writeEnable = back_native_0_dp_writeEnable_regNext; + assign back_native_0_dp_stage_write = back_native_0_dp_write_regNext; + assign back_native_0_dp_read = back_native_0_dp_stage_read_regNext; + assign back_buffer_0_dp_writeEnable = back_native_0_dp_stage_writeEnable; + assign back_buffer_0_dp_write = back_native_0_dp_stage_write; + assign back_native_0_dp_stage_read = back_buffer_0_dp_read; + assign back_native_0_dm_stage_writeEnable = back_native_0_dm_writeEnable_regNext; + assign back_native_0_dm_stage_write = back_native_0_dm_write_regNext; + assign back_native_0_dm_read = back_native_0_dm_stage_read_regNext; + assign back_buffer_0_dm_writeEnable = back_native_0_dm_stage_writeEnable; + assign back_buffer_0_dm_write = back_native_0_dm_stage_write; + assign back_native_0_dm_stage_read = back_buffer_0_dm_read; + assign back_buffer_0_dp_stage_writeEnable = back_buffer_0_dp_writeEnable_regNext; + assign back_buffer_0_dp_stage_write = back_buffer_0_dp_write_regNext; + assign back_buffer_0_dp_read = back_buffer_0_dp_stage_read_regNext; + assign back_buffer_0_dp_stage_read = io_usb_0_dp_read; + assign back_buffer_0_dm_stage_writeEnable = back_buffer_0_dm_writeEnable_regNext; + assign back_buffer_0_dm_stage_write = back_buffer_0_dm_write_regNext; + assign back_buffer_0_dm_read = back_buffer_0_dm_stage_read_regNext; + assign back_buffer_0_dm_stage_read = io_usb_0_dm_read; + assign io_usb_0_dp_write = back_buffer_0_dp_stage_write; + assign io_usb_0_dp_writeEnable = back_buffer_0_dp_stage_writeEnable; + assign io_usb_0_dm_write = back_buffer_0_dm_stage_write; + assign io_usb_0_dm_writeEnable = back_buffer_0_dm_stage_writeEnable; + always @(posedge phy_clk) begin + back_native_0_dp_writeEnable_regNext <= back_native_0_dp_writeEnable; + back_native_0_dp_write_regNext <= back_native_0_dp_write; + back_native_0_dp_stage_read_regNext <= back_native_0_dp_stage_read; + back_native_0_dm_writeEnable_regNext <= back_native_0_dm_writeEnable; + back_native_0_dm_write_regNext <= back_native_0_dm_write; + back_native_0_dm_stage_read_regNext <= back_native_0_dm_stage_read; + back_buffer_0_dp_writeEnable_regNext <= back_buffer_0_dp_writeEnable; + back_buffer_0_dp_write_regNext <= back_buffer_0_dp_write; + back_buffer_0_dp_stage_read_regNext <= back_buffer_0_dp_stage_read; + back_buffer_0_dm_writeEnable_regNext <= back_buffer_0_dm_writeEnable; + back_buffer_0_dm_write_regNext <= back_buffer_0_dm_write; + back_buffer_0_dm_stage_read_regNext <= back_buffer_0_dm_stage_read; + end + + +endmodule + +module UsbOhciAxi4_CtrlCc ( + input input_lowSpeed, + input input_tx_valid, + output input_tx_ready, + input input_tx_payload_last, + input [7:0] input_tx_payload_fragment, + output input_txEop, + output input_rx_flow_valid, + output input_rx_flow_payload_stuffingError, + output [7:0] input_rx_flow_payload_data, + output input_rx_active, + input input_usbReset, + input input_usbResume, + output input_overcurrent, + output input_tick, + input input_ports_0_disable_valid, + output input_ports_0_disable_ready, + input input_ports_0_removable, + input input_ports_0_power, + input input_ports_0_reset_valid, + output input_ports_0_reset_ready, + input input_ports_0_suspend_valid, + output input_ports_0_suspend_ready, + input input_ports_0_resume_valid, + output input_ports_0_resume_ready, + output input_ports_0_connect, + output input_ports_0_disconnect, + output input_ports_0_overcurrent, + output input_ports_0_remoteResume, + output input_ports_0_lowSpeed, + output output_lowSpeed, + output output_tx_valid, + input output_tx_ready, + output output_tx_payload_last, + output [7:0] output_tx_payload_fragment, + input output_txEop, + input output_rx_flow_valid, + input output_rx_flow_payload_stuffingError, + input [7:0] output_rx_flow_payload_data, + input output_rx_active, + output output_usbReset, + output output_usbResume, + input output_overcurrent, + input output_tick, + output output_ports_0_disable_valid, + input output_ports_0_disable_ready, + output output_ports_0_removable, + output output_ports_0_power, + output output_ports_0_reset_valid, + input output_ports_0_reset_ready, + output output_ports_0_suspend_valid, + input output_ports_0_suspend_ready, + output output_ports_0_resume_valid, + input output_ports_0_resume_ready, + input output_ports_0_connect, + input output_ports_0_disconnect, + input output_ports_0_overcurrent, + input output_ports_0_remoteResume, + input output_ports_0_lowSpeed, + input phy_clk, + input phy_reset, + input ctrl_clk, + input ctrl_reset +); + + reg input_tx_ccToggle_io_output_ready; + wire input_lowSpeed_buffercc_io_dataOut; + wire input_usbReset_buffercc_io_dataOut; + wire input_usbResume_buffercc_io_dataOut; + wire output_overcurrent_buffercc_io_dataOut; + wire input_tx_ccToggle_io_input_ready; + wire input_tx_ccToggle_io_output_valid; + wire input_tx_ccToggle_io_output_payload_last; + wire [7:0] input_tx_ccToggle_io_output_payload_fragment; + wire input_tx_ccToggle_ctrl_reset_syncronized_1; + wire pulseCCByToggle_io_pulseOut; + wire pulseCCByToggle_phy_reset_syncronized_1; + wire output_rx_flow_ccToggle_io_output_valid; + wire output_rx_flow_ccToggle_io_output_payload_stuffingError; + wire [7:0] output_rx_flow_ccToggle_io_output_payload_data; + wire output_rx_active_buffercc_io_dataOut; + wire pulseCCByToggle_1_io_pulseOut; + wire input_ports_0_removable_buffercc_io_dataOut; + wire input_ports_0_power_buffercc_io_dataOut; + wire output_ports_0_lowSpeed_buffercc_io_dataOut; + wire output_ports_0_overcurrent_buffercc_io_dataOut; + wire pulseCCByToggle_2_io_pulseOut; + wire pulseCCByToggle_3_io_pulseOut; + wire pulseCCByToggle_4_io_pulseOut; + wire input_ports_0_reset_ccToggle_io_input_ready; + wire input_ports_0_reset_ccToggle_io_output_valid; + wire input_ports_0_suspend_ccToggle_io_input_ready; + wire input_ports_0_suspend_ccToggle_io_output_valid; + wire input_ports_0_resume_ccToggle_io_input_ready; + wire input_ports_0_resume_ccToggle_io_output_valid; + wire input_ports_0_disable_ccToggle_io_input_ready; + wire input_ports_0_disable_ccToggle_io_output_valid; + wire cc_input_tx_ccToggle_io_output_m2sPipe_valid; + wire cc_input_tx_ccToggle_io_output_m2sPipe_ready; + wire cc_input_tx_ccToggle_io_output_m2sPipe_payload_last; + wire [7:0] cc_input_tx_ccToggle_io_output_m2sPipe_payload_fragment; + reg cc_input_tx_ccToggle_io_output_rValid; + reg cc_input_tx_ccToggle_io_output_rData_last; + reg [7:0] cc_input_tx_ccToggle_io_output_rData_fragment; + wire when_Stream_l369; + + UsbOhciAxi4_BufferCC input_lowSpeed_buffercc ( + .io_dataIn (input_lowSpeed ), //i + .io_dataOut (input_lowSpeed_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC input_usbReset_buffercc ( + .io_dataIn (input_usbReset ), //i + .io_dataOut (input_usbReset_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC input_usbResume_buffercc ( + .io_dataIn (input_usbResume ), //i + .io_dataOut (input_usbResume_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC_3 output_overcurrent_buffercc ( + .io_dataIn (output_overcurrent ), //i + .io_dataOut (output_overcurrent_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_StreamCCByToggle input_tx_ccToggle ( + .io_input_valid (input_tx_valid ), //i + .io_input_ready (input_tx_ccToggle_io_input_ready ), //o + .io_input_payload_last (input_tx_payload_last ), //i + .io_input_payload_fragment (input_tx_payload_fragment[7:0] ), //i + .io_output_valid (input_tx_ccToggle_io_output_valid ), //o + .io_output_ready (input_tx_ccToggle_io_output_ready ), //i + .io_output_payload_last (input_tx_ccToggle_io_output_payload_last ), //o + .io_output_payload_fragment (input_tx_ccToggle_io_output_payload_fragment[7:0]), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ), //i + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized_1 (input_tx_ccToggle_ctrl_reset_syncronized_1 ) //o + ); + UsbOhciAxi4_PulseCCByToggle pulseCCByToggle ( + .io_pulseIn (output_txEop ), //i + .io_pulseOut (pulseCCByToggle_io_pulseOut ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized_1 (pulseCCByToggle_phy_reset_syncronized_1) //o + ); + UsbOhciAxi4_FlowCCByToggle output_rx_flow_ccToggle ( + .io_input_valid (output_rx_flow_valid ), //i + .io_input_payload_stuffingError (output_rx_flow_payload_stuffingError ), //i + .io_input_payload_data (output_rx_flow_payload_data[7:0] ), //i + .io_output_valid (output_rx_flow_ccToggle_io_output_valid ), //o + .io_output_payload_stuffingError (output_rx_flow_ccToggle_io_output_payload_stuffingError), //o + .io_output_payload_data (output_rx_flow_ccToggle_io_output_payload_data[7:0] ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (pulseCCByToggle_phy_reset_syncronized_1 ) //i + ); + UsbOhciAxi4_BufferCC_3 output_rx_active_buffercc ( + .io_dataIn (output_rx_active ), //i + .io_dataOut (output_rx_active_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_PulseCCByToggle_1 pulseCCByToggle_1 ( + .io_pulseIn (output_tick ), //i + .io_pulseOut (pulseCCByToggle_1_io_pulseOut ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (pulseCCByToggle_phy_reset_syncronized_1) //i + ); + UsbOhciAxi4_BufferCC input_ports_0_removable_buffercc ( + .io_dataIn (input_ports_0_removable ), //i + .io_dataOut (input_ports_0_removable_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC input_ports_0_power_buffercc ( + .io_dataIn (input_ports_0_power ), //i + .io_dataOut (input_ports_0_power_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC_3 output_ports_0_lowSpeed_buffercc ( + .io_dataIn (output_ports_0_lowSpeed ), //i + .io_dataOut (output_ports_0_lowSpeed_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_BufferCC_3 output_ports_0_overcurrent_buffercc ( + .io_dataIn (output_ports_0_overcurrent ), //i + .io_dataOut (output_ports_0_overcurrent_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_PulseCCByToggle_1 pulseCCByToggle_2 ( + .io_pulseIn (output_ports_0_connect ), //i + .io_pulseOut (pulseCCByToggle_2_io_pulseOut ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (pulseCCByToggle_phy_reset_syncronized_1) //i + ); + UsbOhciAxi4_PulseCCByToggle_1 pulseCCByToggle_3 ( + .io_pulseIn (output_ports_0_disconnect ), //i + .io_pulseOut (pulseCCByToggle_3_io_pulseOut ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (pulseCCByToggle_phy_reset_syncronized_1) //i + ); + UsbOhciAxi4_PulseCCByToggle_1 pulseCCByToggle_4 ( + .io_pulseIn (output_ports_0_remoteResume ), //i + .io_pulseOut (pulseCCByToggle_4_io_pulseOut ), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ), //i + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (pulseCCByToggle_phy_reset_syncronized_1) //i + ); + UsbOhciAxi4_StreamCCByToggle_1 input_ports_0_reset_ccToggle ( + .io_input_valid (input_ports_0_reset_valid ), //i + .io_input_ready (input_ports_0_reset_ccToggle_io_input_ready ), //o + .io_output_valid (input_ports_0_reset_ccToggle_io_output_valid), //o + .io_output_ready (output_ports_0_reset_ready ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ), //i + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (input_tx_ccToggle_ctrl_reset_syncronized_1 ) //i + ); + UsbOhciAxi4_StreamCCByToggle_1 input_ports_0_suspend_ccToggle ( + .io_input_valid (input_ports_0_suspend_valid ), //i + .io_input_ready (input_ports_0_suspend_ccToggle_io_input_ready ), //o + .io_output_valid (input_ports_0_suspend_ccToggle_io_output_valid), //o + .io_output_ready (output_ports_0_suspend_ready ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ), //i + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (input_tx_ccToggle_ctrl_reset_syncronized_1 ) //i + ); + UsbOhciAxi4_StreamCCByToggle_1 input_ports_0_resume_ccToggle ( + .io_input_valid (input_ports_0_resume_valid ), //i + .io_input_ready (input_ports_0_resume_ccToggle_io_input_ready ), //o + .io_output_valid (input_ports_0_resume_ccToggle_io_output_valid), //o + .io_output_ready (output_ports_0_resume_ready ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ), //i + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (input_tx_ccToggle_ctrl_reset_syncronized_1 ) //i + ); + UsbOhciAxi4_StreamCCByToggle_1 input_ports_0_disable_ccToggle ( + .io_input_valid (input_ports_0_disable_valid ), //i + .io_input_ready (input_ports_0_disable_ccToggle_io_input_ready ), //o + .io_output_valid (input_ports_0_disable_ccToggle_io_output_valid), //o + .io_output_ready (output_ports_0_disable_ready ), //i + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ), //i + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (input_tx_ccToggle_ctrl_reset_syncronized_1 ) //i + ); + assign output_lowSpeed = input_lowSpeed_buffercc_io_dataOut; + assign output_usbReset = input_usbReset_buffercc_io_dataOut; + assign output_usbResume = input_usbResume_buffercc_io_dataOut; + assign input_overcurrent = output_overcurrent_buffercc_io_dataOut; + assign input_tx_ready = input_tx_ccToggle_io_input_ready; + always @(*) begin + input_tx_ccToggle_io_output_ready = cc_input_tx_ccToggle_io_output_m2sPipe_ready; + if(when_Stream_l369) begin + input_tx_ccToggle_io_output_ready = 1'b1; + end + end + + assign when_Stream_l369 = (! cc_input_tx_ccToggle_io_output_m2sPipe_valid); + assign cc_input_tx_ccToggle_io_output_m2sPipe_valid = cc_input_tx_ccToggle_io_output_rValid; + assign cc_input_tx_ccToggle_io_output_m2sPipe_payload_last = cc_input_tx_ccToggle_io_output_rData_last; + assign cc_input_tx_ccToggle_io_output_m2sPipe_payload_fragment = cc_input_tx_ccToggle_io_output_rData_fragment; + assign output_tx_valid = cc_input_tx_ccToggle_io_output_m2sPipe_valid; + assign cc_input_tx_ccToggle_io_output_m2sPipe_ready = output_tx_ready; + assign output_tx_payload_last = cc_input_tx_ccToggle_io_output_m2sPipe_payload_last; + assign output_tx_payload_fragment = cc_input_tx_ccToggle_io_output_m2sPipe_payload_fragment; + assign input_txEop = pulseCCByToggle_io_pulseOut; + assign input_rx_flow_valid = output_rx_flow_ccToggle_io_output_valid; + assign input_rx_flow_payload_stuffingError = output_rx_flow_ccToggle_io_output_payload_stuffingError; + assign input_rx_flow_payload_data = output_rx_flow_ccToggle_io_output_payload_data; + assign input_rx_active = output_rx_active_buffercc_io_dataOut; + assign input_tick = pulseCCByToggle_1_io_pulseOut; + assign output_ports_0_removable = input_ports_0_removable_buffercc_io_dataOut; + assign output_ports_0_power = input_ports_0_power_buffercc_io_dataOut; + assign input_ports_0_lowSpeed = output_ports_0_lowSpeed_buffercc_io_dataOut; + assign input_ports_0_overcurrent = output_ports_0_overcurrent_buffercc_io_dataOut; + assign input_ports_0_connect = pulseCCByToggle_2_io_pulseOut; + assign input_ports_0_disconnect = pulseCCByToggle_3_io_pulseOut; + assign input_ports_0_remoteResume = pulseCCByToggle_4_io_pulseOut; + assign input_ports_0_reset_ready = input_ports_0_reset_ccToggle_io_input_ready; + assign output_ports_0_reset_valid = input_ports_0_reset_ccToggle_io_output_valid; + assign input_ports_0_suspend_ready = input_ports_0_suspend_ccToggle_io_input_ready; + assign output_ports_0_suspend_valid = input_ports_0_suspend_ccToggle_io_output_valid; + assign input_ports_0_resume_ready = input_ports_0_resume_ccToggle_io_input_ready; + assign output_ports_0_resume_valid = input_ports_0_resume_ccToggle_io_output_valid; + assign input_ports_0_disable_ready = input_ports_0_disable_ccToggle_io_input_ready; + assign output_ports_0_disable_valid = input_ports_0_disable_ccToggle_io_output_valid; + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + cc_input_tx_ccToggle_io_output_rValid <= 1'b0; + end else begin + if(input_tx_ccToggle_io_output_ready) begin + cc_input_tx_ccToggle_io_output_rValid <= input_tx_ccToggle_io_output_valid; + end + end + end + + always @(posedge phy_clk) begin + if(input_tx_ccToggle_io_output_ready) begin + cc_input_tx_ccToggle_io_output_rData_last <= input_tx_ccToggle_io_output_payload_last; + cc_input_tx_ccToggle_io_output_rData_fragment <= input_tx_ccToggle_io_output_payload_fragment; + end + end + + +endmodule + +module UsbOhciAxi4_UsbLsFsPhy ( + input io_ctrl_lowSpeed, + input io_ctrl_tx_valid, + output reg io_ctrl_tx_ready, + input io_ctrl_tx_payload_last, + input [7:0] io_ctrl_tx_payload_fragment, + output reg io_ctrl_txEop, + output reg io_ctrl_rx_flow_valid, + output reg io_ctrl_rx_flow_payload_stuffingError, + output reg [7:0] io_ctrl_rx_flow_payload_data, + output reg io_ctrl_rx_active, + input io_ctrl_usbReset, + input io_ctrl_usbResume, + output io_ctrl_overcurrent, + output io_ctrl_tick, + input io_ctrl_ports_0_disable_valid, + output io_ctrl_ports_0_disable_ready, + input io_ctrl_ports_0_removable, + input io_ctrl_ports_0_power, + input io_ctrl_ports_0_reset_valid, + output reg io_ctrl_ports_0_reset_ready, + input io_ctrl_ports_0_suspend_valid, + output io_ctrl_ports_0_suspend_ready, + input io_ctrl_ports_0_resume_valid, + output io_ctrl_ports_0_resume_ready, + output reg io_ctrl_ports_0_connect, + output io_ctrl_ports_0_disconnect, + output io_ctrl_ports_0_overcurrent, + output io_ctrl_ports_0_remoteResume, + output io_ctrl_ports_0_lowSpeed, + output reg io_usb_0_tx_enable, + output reg io_usb_0_tx_data, + output reg io_usb_0_tx_se0, + input io_usb_0_rx_dp, + input io_usb_0_rx_dm, + input io_management_0_overcurrent, + output io_management_0_power, + input phy_clk, + input phy_reset +); + localparam UsbOhciAxi4_txShared_frame_enumDef_BOOT = 4'd0; + localparam UsbOhciAxi4_txShared_frame_enumDef_IDLE = 4'd1; + localparam UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE = 4'd2; + localparam UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC = 4'd3; + localparam UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID = 4'd4; + localparam UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY = 4'd5; + localparam UsbOhciAxi4_txShared_frame_enumDef_SYNC = 4'd6; + localparam UsbOhciAxi4_txShared_frame_enumDef_DATA = 4'd7; + localparam UsbOhciAxi4_txShared_frame_enumDef_EOP_0 = 4'd8; + localparam UsbOhciAxi4_txShared_frame_enumDef_EOP_1 = 4'd9; + localparam UsbOhciAxi4_txShared_frame_enumDef_EOP_2 = 4'd10; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_BOOT = 4'd0; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF = 4'd1; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED = 4'd2; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED = 4'd3; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING = 4'd4; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY = 4'd5; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC = 4'd6; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED = 4'd7; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED = 4'd8; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING = 4'd9; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 = 4'd10; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 = 4'd11; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S = 4'd12; + localparam UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E = 4'd13; + localparam UsbOhciAxi4_upstreamRx_enumDef_BOOT = 2'd0; + localparam UsbOhciAxi4_upstreamRx_enumDef_IDLE = 2'd1; + localparam UsbOhciAxi4_upstreamRx_enumDef_SUSPEND = 2'd2; + localparam UsbOhciAxi4_ports_0_rx_packet_enumDef_BOOT = 2'd0; + localparam UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE = 2'd1; + localparam UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET = 2'd2; + localparam UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED = 2'd3; + + wire ports_0_filter_io_filtred_dp; + wire ports_0_filter_io_filtred_dm; + wire ports_0_filter_io_filtred_d; + wire ports_0_filter_io_filtred_se0; + wire ports_0_filter_io_filtred_sample; + wire [1:0] _zz_tickTimer_counter_valueNext; + wire [0:0] _zz_tickTimer_counter_valueNext_1; + wire [9:0] _zz_txShared_timer_oneCycle; + wire [4:0] _zz_txShared_timer_oneCycle_1; + wire [9:0] _zz_txShared_timer_twoCycle; + wire [5:0] _zz_txShared_timer_twoCycle_1; + wire [9:0] _zz_txShared_timer_fourCycle; + wire [7:0] _zz_txShared_timer_fourCycle_1; + wire [8:0] _zz_txShared_rxToTxDelay_twoCycle; + wire [6:0] _zz_txShared_rxToTxDelay_twoCycle_1; + wire [1:0] _zz_txShared_lowSpeedSof_state; + wire [0:0] _zz_txShared_lowSpeedSof_state_1; + wire [6:0] _zz_when_UsbHubPhy_l501; + wire [11:0] _zz_ports_0_rx_packet_errorTimeout_trigger; + wire [9:0] _zz_ports_0_rx_packet_errorTimeout_trigger_1; + wire [6:0] _zz_ports_0_rx_disconnect_counter; + wire [0:0] _zz_ports_0_rx_disconnect_counter_1; + wire [23:0] _zz_ports_0_fsm_timer_ONE_BIT; + wire [4:0] _zz_ports_0_fsm_timer_ONE_BIT_1; + wire [23:0] _zz_ports_0_fsm_timer_TWO_BIT; + wire [5:0] _zz_ports_0_fsm_timer_TWO_BIT_1; + wire tickTimer_counter_willIncrement; + wire tickTimer_counter_willClear; + reg [1:0] tickTimer_counter_valueNext; + reg [1:0] tickTimer_counter_value; + wire tickTimer_counter_willOverflowIfInc; + wire tickTimer_counter_willOverflow; + wire tickTimer_tick; + reg txShared_timer_lowSpeed; + reg [9:0] txShared_timer_counter; + reg txShared_timer_clear; + wire txShared_timer_inc; + wire txShared_timer_oneCycle; + wire txShared_timer_twoCycle; + wire txShared_timer_fourCycle; + reg txShared_rxToTxDelay_lowSpeed; + reg [8:0] txShared_rxToTxDelay_counter; + reg txShared_rxToTxDelay_clear; + wire txShared_rxToTxDelay_inc; + wire txShared_rxToTxDelay_twoCycle; + reg txShared_rxToTxDelay_active; + reg txShared_encoder_input_valid; + reg txShared_encoder_input_ready; + reg txShared_encoder_input_data; + reg txShared_encoder_input_lowSpeed; + reg txShared_encoder_output_valid; + reg txShared_encoder_output_se0; + reg txShared_encoder_output_lowSpeed; + reg txShared_encoder_output_data; + reg [2:0] txShared_encoder_counter; + reg txShared_encoder_state; + wire when_UsbHubPhy_l189; + wire when_UsbHubPhy_l194; + wire when_UsbHubPhy_l208; + reg txShared_serialiser_input_valid; + reg txShared_serialiser_input_ready; + reg [7:0] txShared_serialiser_input_data; + reg txShared_serialiser_input_lowSpeed; + reg [2:0] txShared_serialiser_bitCounter; + wire when_UsbHubPhy_l234; + wire when_UsbHubPhy_l240; + reg [4:0] txShared_lowSpeedSof_timer; + reg [1:0] txShared_lowSpeedSof_state; + reg txShared_lowSpeedSof_increment; + reg txShared_lowSpeedSof_overrideEncoder; + reg txShared_encoder_output_valid_regNext; + wire when_UsbHubPhy_l249; + wire when_UsbHubPhy_l251; + wire io_ctrl_tx_fire; + reg io_ctrl_tx_payload_first; + wire when_UsbHubPhy_l252; + wire when_UsbHubPhy_l259; + wire txShared_lowSpeedSof_valid; + wire txShared_lowSpeedSof_data; + wire txShared_lowSpeedSof_se0; + wire txShared_frame_wantExit; + reg txShared_frame_wantStart; + wire txShared_frame_wantKill; + wire txShared_frame_busy; + reg txShared_frame_wasLowSpeed; + wire upstreamRx_wantExit; + reg upstreamRx_wantStart; + wire upstreamRx_wantKill; + wire upstreamRx_timer_lowSpeed; + reg [19:0] upstreamRx_timer_counter; + reg upstreamRx_timer_clear; + wire upstreamRx_timer_inc; + wire upstreamRx_timer_IDLE_EOI; + wire Rx_Suspend; + reg resumeFromPort; + reg ports_0_portLowSpeed; + reg ports_0_rx_enablePackets; + wire ports_0_rx_j; + wire ports_0_rx_k; + reg ports_0_rx_stuffingError; + reg ports_0_rx_waitSync; + reg ports_0_rx_decoder_state; + reg ports_0_rx_decoder_output_valid; + reg ports_0_rx_decoder_output_payload; + wire when_UsbHubPhy_l445; + reg [2:0] ports_0_rx_destuffer_counter; + wire ports_0_rx_destuffer_unstuffNext; + wire ports_0_rx_destuffer_output_valid; + wire ports_0_rx_destuffer_output_payload; + wire when_UsbHubPhy_l466; + wire ports_0_rx_history_updated; + wire _zz_ports_0_rx_history_value; + reg _zz_ports_0_rx_history_value_1; + reg _zz_ports_0_rx_history_value_2; + reg _zz_ports_0_rx_history_value_3; + reg _zz_ports_0_rx_history_value_4; + reg _zz_ports_0_rx_history_value_5; + reg _zz_ports_0_rx_history_value_6; + reg _zz_ports_0_rx_history_value_7; + wire [7:0] ports_0_rx_history_value; + wire ports_0_rx_history_sync_hit; + wire [6:0] ports_0_rx_eop_maxThreshold; + wire [5:0] ports_0_rx_eop_minThreshold; + reg [6:0] ports_0_rx_eop_counter; + wire ports_0_rx_eop_maxHit; + reg ports_0_rx_eop_hit; + wire when_UsbHubPhy_l493; + wire when_UsbHubPhy_l494; + wire when_UsbHubPhy_l501; + wire ports_0_rx_packet_wantExit; + reg ports_0_rx_packet_wantStart; + wire ports_0_rx_packet_wantKill; + reg [2:0] ports_0_rx_packet_counter; + wire ports_0_rx_packet_errorTimeout_lowSpeed; + reg [11:0] ports_0_rx_packet_errorTimeout_counter; + reg ports_0_rx_packet_errorTimeout_clear; + wire ports_0_rx_packet_errorTimeout_inc; + wire ports_0_rx_packet_errorTimeout_trigger; + reg ports_0_rx_packet_errorTimeout_p; + reg ports_0_rx_packet_errorTimeout_n; + reg [6:0] ports_0_rx_disconnect_counter; + reg ports_0_rx_disconnect_clear; + wire ports_0_rx_disconnect_hit; + reg ports_0_rx_disconnect_hitLast; + wire ports_0_rx_disconnect_event; + wire when_UsbHubPhy_l573; + wire ports_0_fsm_wantExit; + reg ports_0_fsm_wantStart; + wire ports_0_fsm_wantKill; + reg ports_0_fsm_timer_lowSpeed; + reg [23:0] ports_0_fsm_timer_counter; + reg ports_0_fsm_timer_clear; + wire ports_0_fsm_timer_inc; + wire ports_0_fsm_timer_DISCONNECTED_EOI; + wire ports_0_fsm_timer_RESET_DELAY; + wire ports_0_fsm_timer_RESET_EOI; + wire ports_0_fsm_timer_RESUME_EOI; + wire ports_0_fsm_timer_RESTART_EOI; + wire ports_0_fsm_timer_ONE_BIT; + wire ports_0_fsm_timer_TWO_BIT; + reg ports_0_fsm_resetInProgress; + reg ports_0_fsm_lowSpeedEop; + wire ports_0_fsm_forceJ; + wire when_UsbHubPhy_l767; + reg [3:0] txShared_frame_stateReg; + reg [3:0] txShared_frame_stateNext; + wire when_UsbHubPhy_l289; + reg [1:0] upstreamRx_stateReg; + reg [1:0] upstreamRx_stateNext; + reg [1:0] ports_0_rx_packet_stateReg; + reg [1:0] ports_0_rx_packet_stateNext; + wire when_UsbHubPhy_l527; + wire when_UsbHubPhy_l549; + wire when_StateMachine_l253; + wire when_StateMachine_l253_1; + reg [3:0] ports_0_fsm_stateReg; + reg [3:0] ports_0_fsm_stateNext; + wire when_UsbHubPhy_l638; + wire when_UsbHubPhy_l675; + wire when_UsbHubPhy_l688; + wire when_UsbHubPhy_l697; + wire when_UsbHubPhy_l705; + wire when_UsbHubPhy_l707; + wire when_UsbHubPhy_l748; + wire when_UsbHubPhy_l758; + wire when_StateMachine_l253_2; + wire when_StateMachine_l253_3; + wire when_StateMachine_l253_4; + wire when_StateMachine_l253_5; + wire when_StateMachine_l253_6; + wire when_StateMachine_l253_7; + wire when_StateMachine_l253_8; + wire when_StateMachine_l253_9; + wire when_UsbHubPhy_l610; + wire when_UsbHubPhy_l617; + wire when_UsbHubPhy_l618; + `ifndef SYNTHESIS + reg [111:0] txShared_frame_stateReg_string; + reg [111:0] txShared_frame_stateNext_string; + reg [55:0] upstreamRx_stateReg_string; + reg [55:0] upstreamRx_stateNext_string; + reg [55:0] ports_0_rx_packet_stateReg_string; + reg [55:0] ports_0_rx_packet_stateNext_string; + reg [119:0] ports_0_fsm_stateReg_string; + reg [119:0] ports_0_fsm_stateNext_string; + `endif + + + assign _zz_tickTimer_counter_valueNext_1 = tickTimer_counter_willIncrement; + assign _zz_tickTimer_counter_valueNext = {1'd0, _zz_tickTimer_counter_valueNext_1}; + assign _zz_txShared_timer_oneCycle_1 = (txShared_timer_lowSpeed ? 5'h1f : 5'h03); + assign _zz_txShared_timer_oneCycle = {5'd0, _zz_txShared_timer_oneCycle_1}; + assign _zz_txShared_timer_twoCycle_1 = (txShared_timer_lowSpeed ? 6'h3f : 6'h07); + assign _zz_txShared_timer_twoCycle = {4'd0, _zz_txShared_timer_twoCycle_1}; + assign _zz_txShared_timer_fourCycle_1 = (txShared_timer_lowSpeed ? 8'h9f : 8'h13); + assign _zz_txShared_timer_fourCycle = {2'd0, _zz_txShared_timer_fourCycle_1}; + assign _zz_txShared_rxToTxDelay_twoCycle_1 = (txShared_rxToTxDelay_lowSpeed ? 7'h7f : 7'h0f); + assign _zz_txShared_rxToTxDelay_twoCycle = {2'd0, _zz_txShared_rxToTxDelay_twoCycle_1}; + assign _zz_txShared_lowSpeedSof_state_1 = txShared_lowSpeedSof_increment; + assign _zz_txShared_lowSpeedSof_state = {1'd0, _zz_txShared_lowSpeedSof_state_1}; + assign _zz_when_UsbHubPhy_l501 = {1'd0, ports_0_rx_eop_minThreshold}; + assign _zz_ports_0_rx_packet_errorTimeout_trigger_1 = (ports_0_rx_packet_errorTimeout_lowSpeed ? 10'h27f : 10'h04f); + assign _zz_ports_0_rx_packet_errorTimeout_trigger = {2'd0, _zz_ports_0_rx_packet_errorTimeout_trigger_1}; + assign _zz_ports_0_rx_disconnect_counter_1 = (! ports_0_rx_disconnect_hit); + assign _zz_ports_0_rx_disconnect_counter = {6'd0, _zz_ports_0_rx_disconnect_counter_1}; + assign _zz_ports_0_fsm_timer_ONE_BIT_1 = (ports_0_fsm_timer_lowSpeed ? 5'h1f : 5'h03); + assign _zz_ports_0_fsm_timer_ONE_BIT = {19'd0, _zz_ports_0_fsm_timer_ONE_BIT_1}; + assign _zz_ports_0_fsm_timer_TWO_BIT_1 = (ports_0_fsm_timer_lowSpeed ? 6'h3f : 6'h07); + assign _zz_ports_0_fsm_timer_TWO_BIT = {18'd0, _zz_ports_0_fsm_timer_TWO_BIT_1}; + UsbOhciAxi4_UsbLsFsPhyFilter ports_0_filter ( + .io_lowSpeed (io_ctrl_lowSpeed ), //i + .io_usb_dp (io_usb_0_rx_dp ), //i + .io_usb_dm (io_usb_0_rx_dm ), //i + .io_filtred_dp (ports_0_filter_io_filtred_dp ), //o + .io_filtred_dm (ports_0_filter_io_filtred_dm ), //o + .io_filtred_d (ports_0_filter_io_filtred_d ), //o + .io_filtred_se0 (ports_0_filter_io_filtred_se0 ), //o + .io_filtred_sample (ports_0_filter_io_filtred_sample), //o + .phy_clk (phy_clk ), //i + .phy_reset (phy_reset ) //i + ); + `ifndef SYNTHESIS + always @(*) begin + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_BOOT : txShared_frame_stateReg_string = "BOOT "; + UsbOhciAxi4_txShared_frame_enumDef_IDLE : txShared_frame_stateReg_string = "IDLE "; + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : txShared_frame_stateReg_string = "TAKE_LINE "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : txShared_frame_stateReg_string = "PREAMBLE_SYNC "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : txShared_frame_stateReg_string = "PREAMBLE_PID "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : txShared_frame_stateReg_string = "PREAMBLE_DELAY"; + UsbOhciAxi4_txShared_frame_enumDef_SYNC : txShared_frame_stateReg_string = "SYNC "; + UsbOhciAxi4_txShared_frame_enumDef_DATA : txShared_frame_stateReg_string = "DATA "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : txShared_frame_stateReg_string = "EOP_0 "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : txShared_frame_stateReg_string = "EOP_1 "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : txShared_frame_stateReg_string = "EOP_2 "; + default : txShared_frame_stateReg_string = "??????????????"; + endcase + end + always @(*) begin + case(txShared_frame_stateNext) + UsbOhciAxi4_txShared_frame_enumDef_BOOT : txShared_frame_stateNext_string = "BOOT "; + UsbOhciAxi4_txShared_frame_enumDef_IDLE : txShared_frame_stateNext_string = "IDLE "; + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : txShared_frame_stateNext_string = "TAKE_LINE "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : txShared_frame_stateNext_string = "PREAMBLE_SYNC "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : txShared_frame_stateNext_string = "PREAMBLE_PID "; + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : txShared_frame_stateNext_string = "PREAMBLE_DELAY"; + UsbOhciAxi4_txShared_frame_enumDef_SYNC : txShared_frame_stateNext_string = "SYNC "; + UsbOhciAxi4_txShared_frame_enumDef_DATA : txShared_frame_stateNext_string = "DATA "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : txShared_frame_stateNext_string = "EOP_0 "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : txShared_frame_stateNext_string = "EOP_1 "; + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : txShared_frame_stateNext_string = "EOP_2 "; + default : txShared_frame_stateNext_string = "??????????????"; + endcase + end + always @(*) begin + case(upstreamRx_stateReg) + UsbOhciAxi4_upstreamRx_enumDef_BOOT : upstreamRx_stateReg_string = "BOOT "; + UsbOhciAxi4_upstreamRx_enumDef_IDLE : upstreamRx_stateReg_string = "IDLE "; + UsbOhciAxi4_upstreamRx_enumDef_SUSPEND : upstreamRx_stateReg_string = "SUSPEND"; + default : upstreamRx_stateReg_string = "???????"; + endcase + end + always @(*) begin + case(upstreamRx_stateNext) + UsbOhciAxi4_upstreamRx_enumDef_BOOT : upstreamRx_stateNext_string = "BOOT "; + UsbOhciAxi4_upstreamRx_enumDef_IDLE : upstreamRx_stateNext_string = "IDLE "; + UsbOhciAxi4_upstreamRx_enumDef_SUSPEND : upstreamRx_stateNext_string = "SUSPEND"; + default : upstreamRx_stateNext_string = "???????"; + endcase + end + always @(*) begin + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_BOOT : ports_0_rx_packet_stateReg_string = "BOOT "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : ports_0_rx_packet_stateReg_string = "IDLE "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : ports_0_rx_packet_stateReg_string = "PACKET "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : ports_0_rx_packet_stateReg_string = "ERRORED"; + default : ports_0_rx_packet_stateReg_string = "???????"; + endcase + end + always @(*) begin + case(ports_0_rx_packet_stateNext) + UsbOhciAxi4_ports_0_rx_packet_enumDef_BOOT : ports_0_rx_packet_stateNext_string = "BOOT "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : ports_0_rx_packet_stateNext_string = "IDLE "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : ports_0_rx_packet_stateNext_string = "PACKET "; + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : ports_0_rx_packet_stateNext_string = "ERRORED"; + default : ports_0_rx_packet_stateNext_string = "???????"; + endcase + end + always @(*) begin + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_BOOT : ports_0_fsm_stateReg_string = "BOOT "; + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : ports_0_fsm_stateReg_string = "POWER_OFF "; + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : ports_0_fsm_stateReg_string = "DISCONNECTED "; + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : ports_0_fsm_stateReg_string = "DISABLED "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : ports_0_fsm_stateReg_string = "RESETTING "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : ports_0_fsm_stateReg_string = "RESETTING_DELAY"; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : ports_0_fsm_stateReg_string = "RESETTING_SYNC "; + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : ports_0_fsm_stateReg_string = "ENABLED "; + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : ports_0_fsm_stateReg_string = "SUSPENDED "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : ports_0_fsm_stateReg_string = "RESUMING "; + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : ports_0_fsm_stateReg_string = "SEND_EOP_0 "; + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : ports_0_fsm_stateReg_string = "SEND_EOP_1 "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : ports_0_fsm_stateReg_string = "RESTART_S "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : ports_0_fsm_stateReg_string = "RESTART_E "; + default : ports_0_fsm_stateReg_string = "???????????????"; + endcase + end + always @(*) begin + case(ports_0_fsm_stateNext) + UsbOhciAxi4_ports_0_fsm_enumDef_BOOT : ports_0_fsm_stateNext_string = "BOOT "; + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : ports_0_fsm_stateNext_string = "POWER_OFF "; + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : ports_0_fsm_stateNext_string = "DISCONNECTED "; + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : ports_0_fsm_stateNext_string = "DISABLED "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : ports_0_fsm_stateNext_string = "RESETTING "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : ports_0_fsm_stateNext_string = "RESETTING_DELAY"; + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : ports_0_fsm_stateNext_string = "RESETTING_SYNC "; + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : ports_0_fsm_stateNext_string = "ENABLED "; + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : ports_0_fsm_stateNext_string = "SUSPENDED "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : ports_0_fsm_stateNext_string = "RESUMING "; + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : ports_0_fsm_stateNext_string = "SEND_EOP_0 "; + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : ports_0_fsm_stateNext_string = "SEND_EOP_1 "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : ports_0_fsm_stateNext_string = "RESTART_S "; + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : ports_0_fsm_stateNext_string = "RESTART_E "; + default : ports_0_fsm_stateNext_string = "???????????????"; + endcase + end + `endif + + assign tickTimer_counter_willClear = 1'b0; + assign tickTimer_counter_willOverflowIfInc = (tickTimer_counter_value == 2'b11); + assign tickTimer_counter_willOverflow = (tickTimer_counter_willOverflowIfInc && tickTimer_counter_willIncrement); + always @(*) begin + tickTimer_counter_valueNext = (tickTimer_counter_value + _zz_tickTimer_counter_valueNext); + if(tickTimer_counter_willClear) begin + tickTimer_counter_valueNext = 2'b00; + end + end + + assign tickTimer_counter_willIncrement = 1'b1; + assign tickTimer_tick = (tickTimer_counter_willOverflow == 1'b1); + assign io_ctrl_tick = tickTimer_tick; + always @(*) begin + txShared_timer_clear = 1'b0; + if(txShared_encoder_input_valid) begin + if(txShared_encoder_input_data) begin + if(txShared_timer_oneCycle) begin + if(when_UsbHubPhy_l189) begin + txShared_timer_clear = 1'b1; + end + end + end + end + if(txShared_encoder_input_ready) begin + txShared_timer_clear = 1'b1; + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + txShared_timer_clear = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + if(txShared_timer_oneCycle) begin + txShared_timer_clear = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + if(txShared_timer_fourCycle) begin + txShared_timer_clear = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + if(txShared_timer_twoCycle) begin + txShared_timer_clear = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + if(txShared_timer_oneCycle) begin + txShared_timer_clear = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + if(txShared_timer_twoCycle) begin + txShared_timer_clear = 1'b1; + end + end + default : begin + end + endcase + end + + assign txShared_timer_inc = 1'b1; + assign txShared_timer_oneCycle = (txShared_timer_counter == _zz_txShared_timer_oneCycle); + assign txShared_timer_twoCycle = (txShared_timer_counter == _zz_txShared_timer_twoCycle); + assign txShared_timer_fourCycle = (txShared_timer_counter == _zz_txShared_timer_fourCycle); + always @(*) begin + txShared_timer_lowSpeed = 1'b0; + if(txShared_encoder_input_valid) begin + txShared_timer_lowSpeed = txShared_encoder_input_lowSpeed; + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + txShared_timer_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + txShared_timer_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + txShared_timer_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + txShared_timer_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + txShared_timer_lowSpeed = txShared_frame_wasLowSpeed; + end + default : begin + end + endcase + end + + always @(*) begin + txShared_rxToTxDelay_clear = 1'b0; + if(ports_0_rx_eop_hit) begin + txShared_rxToTxDelay_clear = 1'b1; + end + end + + assign txShared_rxToTxDelay_inc = 1'b1; + assign txShared_rxToTxDelay_twoCycle = (txShared_rxToTxDelay_counter == _zz_txShared_rxToTxDelay_twoCycle); + always @(*) begin + txShared_encoder_input_valid = 1'b0; + if(txShared_serialiser_input_valid) begin + txShared_encoder_input_valid = 1'b1; + end + end + + always @(*) begin + txShared_encoder_input_ready = 1'b0; + if(txShared_encoder_input_valid) begin + if(txShared_encoder_input_data) begin + if(txShared_timer_oneCycle) begin + txShared_encoder_input_ready = 1'b1; + if(when_UsbHubPhy_l189) begin + txShared_encoder_input_ready = 1'b0; + end + end + end else begin + if(txShared_timer_oneCycle) begin + txShared_encoder_input_ready = 1'b1; + end + end + end + end + + always @(*) begin + txShared_encoder_input_data = 1'bx; + if(txShared_serialiser_input_valid) begin + txShared_encoder_input_data = txShared_serialiser_input_data[txShared_serialiser_bitCounter]; + end + end + + always @(*) begin + txShared_encoder_input_lowSpeed = 1'bx; + if(txShared_serialiser_input_valid) begin + txShared_encoder_input_lowSpeed = txShared_serialiser_input_lowSpeed; + end + end + + always @(*) begin + txShared_encoder_output_valid = 1'b0; + if(txShared_encoder_input_valid) begin + txShared_encoder_output_valid = txShared_encoder_input_valid; + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + txShared_encoder_output_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + txShared_encoder_output_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + txShared_encoder_output_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + txShared_encoder_output_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + txShared_encoder_output_se0 = 1'b0; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + txShared_encoder_output_se0 = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + txShared_encoder_output_lowSpeed = 1'bx; + if(txShared_encoder_input_valid) begin + txShared_encoder_output_lowSpeed = txShared_encoder_input_lowSpeed; + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + txShared_encoder_output_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + txShared_encoder_output_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + txShared_encoder_output_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + txShared_encoder_output_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + txShared_encoder_output_data = 1'bx; + if(txShared_encoder_input_valid) begin + if(txShared_encoder_input_data) begin + txShared_encoder_output_data = txShared_encoder_state; + end else begin + txShared_encoder_output_data = (! txShared_encoder_state); + end + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + txShared_encoder_output_data = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + txShared_encoder_output_data = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + txShared_encoder_output_data = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + assign when_UsbHubPhy_l189 = (txShared_encoder_counter == 3'b101); + assign when_UsbHubPhy_l194 = (txShared_encoder_counter == 3'b110); + assign when_UsbHubPhy_l208 = (! txShared_encoder_input_valid); + always @(*) begin + txShared_serialiser_input_valid = 1'b0; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + txShared_serialiser_input_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + txShared_serialiser_input_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + txShared_serialiser_input_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + txShared_serialiser_input_valid = 1'b1; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + txShared_serialiser_input_ready = 1'b0; + if(txShared_serialiser_input_valid) begin + if(txShared_encoder_input_ready) begin + if(when_UsbHubPhy_l234) begin + txShared_serialiser_input_ready = 1'b1; + end + end + end + end + + always @(*) begin + txShared_serialiser_input_data = 8'bxxxxxxxx; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + txShared_serialiser_input_data = 8'h80; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + txShared_serialiser_input_data = 8'h3c; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + txShared_serialiser_input_data = 8'h80; + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + txShared_serialiser_input_data = io_ctrl_tx_payload_fragment; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + txShared_serialiser_input_lowSpeed = 1'bx; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + txShared_serialiser_input_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + txShared_serialiser_input_lowSpeed = 1'b0; + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + txShared_serialiser_input_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + txShared_serialiser_input_lowSpeed = txShared_frame_wasLowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + assign when_UsbHubPhy_l234 = (txShared_serialiser_bitCounter == 3'b111); + assign when_UsbHubPhy_l240 = ((! txShared_serialiser_input_valid) || txShared_serialiser_input_ready); + always @(*) begin + txShared_lowSpeedSof_increment = 1'b0; + if(when_UsbHubPhy_l251) begin + if(when_UsbHubPhy_l252) begin + txShared_lowSpeedSof_increment = 1'b1; + end + end + end + + assign when_UsbHubPhy_l249 = ((! txShared_encoder_output_valid) && txShared_encoder_output_valid_regNext); + assign when_UsbHubPhy_l251 = (txShared_lowSpeedSof_state == 2'b00); + assign io_ctrl_tx_fire = (io_ctrl_tx_valid && io_ctrl_tx_ready); + assign when_UsbHubPhy_l252 = ((io_ctrl_tx_valid && io_ctrl_tx_payload_first) && (io_ctrl_tx_payload_fragment == 8'ha5)); + assign when_UsbHubPhy_l259 = (txShared_lowSpeedSof_timer == 5'h1f); + assign txShared_lowSpeedSof_valid = (txShared_lowSpeedSof_state != 2'b00); + assign txShared_lowSpeedSof_data = 1'b0; + assign txShared_lowSpeedSof_se0 = (txShared_lowSpeedSof_state != 2'b11); + assign txShared_frame_wantExit = 1'b0; + always @(*) begin + txShared_frame_wantStart = 1'b0; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + txShared_frame_wantStart = 1'b1; + end + endcase + end + + assign txShared_frame_wantKill = 1'b0; + assign txShared_frame_busy = (! (txShared_frame_stateReg == UsbOhciAxi4_txShared_frame_enumDef_BOOT)); + always @(*) begin + io_ctrl_tx_ready = 1'b0; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + if(txShared_serialiser_input_ready) begin + io_ctrl_tx_ready = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_ctrl_txEop = 1'b0; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + if(txShared_timer_twoCycle) begin + io_ctrl_txEop = 1'b1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + end + + assign upstreamRx_wantExit = 1'b0; + always @(*) begin + upstreamRx_wantStart = 1'b0; + case(upstreamRx_stateReg) + UsbOhciAxi4_upstreamRx_enumDef_IDLE : begin + end + UsbOhciAxi4_upstreamRx_enumDef_SUSPEND : begin + end + default : begin + upstreamRx_wantStart = 1'b1; + end + endcase + end + + assign upstreamRx_wantKill = 1'b0; + always @(*) begin + upstreamRx_timer_clear = 1'b0; + if(txShared_encoder_output_valid) begin + upstreamRx_timer_clear = 1'b1; + end + end + + assign upstreamRx_timer_inc = 1'b1; + assign upstreamRx_timer_IDLE_EOI = (upstreamRx_timer_counter == 20'h2327f); + assign io_ctrl_overcurrent = 1'b0; + always @(*) begin + io_ctrl_rx_flow_valid = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + if(ports_0_rx_destuffer_output_valid) begin + if(when_UsbHubPhy_l527) begin + io_ctrl_rx_flow_valid = ports_0_rx_enablePackets; + end + end + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_ctrl_rx_active = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + io_ctrl_rx_active = 1'b1; + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + io_ctrl_rx_active = 1'b1; + end + default : begin + end + endcase + end + + always @(*) begin + io_ctrl_rx_flow_payload_stuffingError = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + io_ctrl_rx_flow_payload_stuffingError = ports_0_rx_stuffingError; + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_ctrl_rx_flow_payload_data = 8'bxxxxxxxx; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + io_ctrl_rx_flow_payload_data = ports_0_rx_history_value; + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + end + default : begin + end + endcase + end + + always @(*) begin + resumeFromPort = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + if(when_UsbHubPhy_l748) begin + resumeFromPort = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + if(when_UsbHubPhy_l758) begin + resumeFromPort = 1'b1; + end + end + default : begin + end + endcase + end + + assign io_ctrl_ports_0_lowSpeed = ports_0_portLowSpeed; + assign io_ctrl_ports_0_remoteResume = 1'b0; + always @(*) begin + ports_0_rx_enablePackets = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + ports_0_rx_enablePackets = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + assign ports_0_rx_j = ((ports_0_filter_io_filtred_dp == (! ports_0_portLowSpeed)) && (ports_0_filter_io_filtred_dm == ports_0_portLowSpeed)); + assign ports_0_rx_k = ((ports_0_filter_io_filtred_dp == ports_0_portLowSpeed) && (ports_0_filter_io_filtred_dm == (! ports_0_portLowSpeed))); + assign io_management_0_power = io_ctrl_ports_0_power; + assign io_ctrl_ports_0_overcurrent = io_management_0_overcurrent; + always @(*) begin + ports_0_rx_waitSync = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + ports_0_rx_waitSync = 1'b1; + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + end + default : begin + end + endcase + if(when_StateMachine_l253) begin + ports_0_rx_waitSync = 1'b1; + end + end + + always @(*) begin + ports_0_rx_decoder_output_valid = 1'b0; + if(ports_0_filter_io_filtred_sample) begin + ports_0_rx_decoder_output_valid = 1'b1; + end + end + + always @(*) begin + ports_0_rx_decoder_output_payload = 1'bx; + if(ports_0_filter_io_filtred_sample) begin + if(when_UsbHubPhy_l445) begin + ports_0_rx_decoder_output_payload = 1'b0; + end else begin + ports_0_rx_decoder_output_payload = 1'b1; + end + end + end + + assign when_UsbHubPhy_l445 = ((ports_0_rx_decoder_state ^ ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed); + assign ports_0_rx_destuffer_unstuffNext = (ports_0_rx_destuffer_counter == 3'b110); + assign ports_0_rx_destuffer_output_valid = (ports_0_rx_decoder_output_valid && (! ports_0_rx_destuffer_unstuffNext)); + assign ports_0_rx_destuffer_output_payload = ports_0_rx_decoder_output_payload; + assign when_UsbHubPhy_l466 = ((! ports_0_rx_decoder_output_payload) || ports_0_rx_destuffer_unstuffNext); + assign ports_0_rx_history_updated = ports_0_rx_destuffer_output_valid; + assign _zz_ports_0_rx_history_value = ports_0_rx_destuffer_output_payload; + assign ports_0_rx_history_value = {_zz_ports_0_rx_history_value,{_zz_ports_0_rx_history_value_1,{_zz_ports_0_rx_history_value_2,{_zz_ports_0_rx_history_value_3,{_zz_ports_0_rx_history_value_4,{_zz_ports_0_rx_history_value_5,{_zz_ports_0_rx_history_value_6,_zz_ports_0_rx_history_value_7}}}}}}}; + assign ports_0_rx_history_sync_hit = (ports_0_rx_history_updated && (ports_0_rx_history_value == 8'hd5)); + assign ports_0_rx_eop_maxThreshold = (io_ctrl_lowSpeed ? 7'h60 : 7'h0c); + assign ports_0_rx_eop_minThreshold = (io_ctrl_lowSpeed ? 6'h2a : 6'h05); + assign ports_0_rx_eop_maxHit = (ports_0_rx_eop_counter == ports_0_rx_eop_maxThreshold); + always @(*) begin + ports_0_rx_eop_hit = 1'b0; + if(ports_0_rx_j) begin + if(when_UsbHubPhy_l501) begin + ports_0_rx_eop_hit = 1'b1; + end + end + end + + assign when_UsbHubPhy_l493 = ((! ports_0_filter_io_filtred_dp) && (! ports_0_filter_io_filtred_dm)); + assign when_UsbHubPhy_l494 = (! ports_0_rx_eop_maxHit); + assign when_UsbHubPhy_l501 = ((_zz_when_UsbHubPhy_l501 <= ports_0_rx_eop_counter) && (! ports_0_rx_eop_maxHit)); + assign ports_0_rx_packet_wantExit = 1'b0; + always @(*) begin + ports_0_rx_packet_wantStart = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + end + default : begin + ports_0_rx_packet_wantStart = 1'b1; + end + endcase + end + + assign ports_0_rx_packet_wantKill = 1'b0; + always @(*) begin + ports_0_rx_packet_errorTimeout_clear = 1'b0; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + if(when_UsbHubPhy_l549) begin + ports_0_rx_packet_errorTimeout_clear = 1'b1; + end + end + default : begin + end + endcase + if(when_StateMachine_l253_1) begin + ports_0_rx_packet_errorTimeout_clear = 1'b1; + end + end + + assign ports_0_rx_packet_errorTimeout_inc = 1'b1; + assign ports_0_rx_packet_errorTimeout_lowSpeed = io_ctrl_lowSpeed; + assign ports_0_rx_packet_errorTimeout_trigger = (ports_0_rx_packet_errorTimeout_counter == _zz_ports_0_rx_packet_errorTimeout_trigger); + always @(*) begin + ports_0_rx_disconnect_clear = 1'b0; + if(when_UsbHubPhy_l573) begin + ports_0_rx_disconnect_clear = 1'b1; + end + if(when_UsbHubPhy_l767) begin + ports_0_rx_disconnect_clear = 1'b1; + end + end + + assign ports_0_rx_disconnect_hit = (ports_0_rx_disconnect_counter == 7'h68); + assign ports_0_rx_disconnect_event = (ports_0_rx_disconnect_hit && (! ports_0_rx_disconnect_hitLast)); + assign when_UsbHubPhy_l573 = ((! ports_0_filter_io_filtred_se0) || io_usb_0_tx_enable); + assign io_ctrl_ports_0_disconnect = ports_0_rx_disconnect_event; + assign ports_0_fsm_wantExit = 1'b0; + always @(*) begin + ports_0_fsm_wantStart = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + ports_0_fsm_wantStart = 1'b1; + end + endcase + end + + assign ports_0_fsm_wantKill = 1'b0; + always @(*) begin + ports_0_fsm_timer_clear = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + if(when_UsbHubPhy_l638) begin + ports_0_fsm_timer_clear = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + if(when_StateMachine_l253_2) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_3) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_4) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_5) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_6) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_7) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_8) begin + ports_0_fsm_timer_clear = 1'b1; + end + if(when_StateMachine_l253_9) begin + ports_0_fsm_timer_clear = 1'b1; + end + end + + assign ports_0_fsm_timer_inc = 1'b1; + assign ports_0_fsm_timer_DISCONNECTED_EOI = (ports_0_fsm_timer_counter == 24'h005dbf); + assign ports_0_fsm_timer_RESET_DELAY = (ports_0_fsm_timer_counter == 24'h00095f); + assign ports_0_fsm_timer_RESET_EOI = (ports_0_fsm_timer_counter == 24'h249eff); + assign ports_0_fsm_timer_RESUME_EOI = (ports_0_fsm_timer_counter == 24'h0f617f); + assign ports_0_fsm_timer_RESTART_EOI = (ports_0_fsm_timer_counter == 24'h0012bf); + assign ports_0_fsm_timer_ONE_BIT = (ports_0_fsm_timer_counter == _zz_ports_0_fsm_timer_ONE_BIT); + assign ports_0_fsm_timer_TWO_BIT = (ports_0_fsm_timer_counter == _zz_ports_0_fsm_timer_TWO_BIT); + always @(*) begin + ports_0_fsm_timer_lowSpeed = ports_0_portLowSpeed; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + if(ports_0_fsm_lowSpeedEop) begin + ports_0_fsm_timer_lowSpeed = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + if(ports_0_fsm_lowSpeedEop) begin + ports_0_fsm_timer_lowSpeed = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + assign io_ctrl_ports_0_disable_ready = 1'b1; + always @(*) begin + io_ctrl_ports_0_reset_ready = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + if(when_UsbHubPhy_l675) begin + io_ctrl_ports_0_reset_ready = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + assign io_ctrl_ports_0_resume_ready = 1'b1; + assign io_ctrl_ports_0_suspend_ready = 1'b1; + always @(*) begin + io_ctrl_ports_0_connect = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + if(ports_0_fsm_timer_DISCONNECTED_EOI) begin + io_ctrl_ports_0_connect = 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_usb_0_tx_enable = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + io_usb_0_tx_enable = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + io_usb_0_tx_enable = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + io_usb_0_tx_enable = txShared_encoder_output_valid; + if(when_UsbHubPhy_l688) begin + io_usb_0_tx_enable = txShared_lowSpeedSof_valid; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + io_usb_0_tx_enable = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + io_usb_0_tx_enable = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + io_usb_0_tx_enable = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_usb_0_tx_data = 1'bx; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + io_usb_0_tx_data = ((txShared_encoder_output_data || ports_0_fsm_forceJ) ^ ports_0_portLowSpeed); + if(when_UsbHubPhy_l688) begin + io_usb_0_tx_data = txShared_lowSpeedSof_data; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + io_usb_0_tx_data = ports_0_portLowSpeed; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + io_usb_0_tx_data = (! ports_0_portLowSpeed); + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_usb_0_tx_se0 = 1'bx; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + io_usb_0_tx_se0 = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + io_usb_0_tx_se0 = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + io_usb_0_tx_se0 = (txShared_encoder_output_se0 && (! ports_0_fsm_forceJ)); + if(when_UsbHubPhy_l688) begin + io_usb_0_tx_se0 = txShared_lowSpeedSof_se0; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + io_usb_0_tx_se0 = 1'b0; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + io_usb_0_tx_se0 = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + io_usb_0_tx_se0 = 1'b0; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + always @(*) begin + ports_0_fsm_resetInProgress = 1'b0; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + ports_0_fsm_resetInProgress = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + ports_0_fsm_resetInProgress = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + ports_0_fsm_resetInProgress = 1'b1; + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + end + + assign ports_0_fsm_forceJ = (ports_0_portLowSpeed && (! txShared_encoder_output_lowSpeed)); + assign when_UsbHubPhy_l767 = (((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED)) && (! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED))) && (! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED))); + always @(*) begin + txShared_frame_stateNext = txShared_frame_stateReg; + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + if(when_UsbHubPhy_l289) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE; + end + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + if(txShared_timer_oneCycle) begin + if(io_ctrl_lowSpeed) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC; + end else begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_SYNC; + end + end + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + if(txShared_serialiser_input_ready) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID; + end + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + if(txShared_serialiser_input_ready) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY; + end + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + if(txShared_timer_fourCycle) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_SYNC; + end + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + if(txShared_serialiser_input_ready) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_DATA; + end + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + if(txShared_serialiser_input_ready) begin + if(io_ctrl_tx_payload_last) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_EOP_0; + end + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + if(txShared_timer_twoCycle) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_EOP_1; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + if(txShared_timer_oneCycle) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_EOP_2; + end + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + if(txShared_timer_twoCycle) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_IDLE; + end + end + default : begin + end + endcase + if(txShared_frame_wantStart) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_IDLE; + end + if(txShared_frame_wantKill) begin + txShared_frame_stateNext = UsbOhciAxi4_txShared_frame_enumDef_BOOT; + end + end + + assign when_UsbHubPhy_l289 = (io_ctrl_tx_valid && (! txShared_rxToTxDelay_active)); + always @(*) begin + upstreamRx_stateNext = upstreamRx_stateReg; + case(upstreamRx_stateReg) + UsbOhciAxi4_upstreamRx_enumDef_IDLE : begin + if(upstreamRx_timer_IDLE_EOI) begin + upstreamRx_stateNext = UsbOhciAxi4_upstreamRx_enumDef_SUSPEND; + end + end + UsbOhciAxi4_upstreamRx_enumDef_SUSPEND : begin + if(txShared_encoder_output_valid) begin + upstreamRx_stateNext = UsbOhciAxi4_upstreamRx_enumDef_IDLE; + end + end + default : begin + end + endcase + if(upstreamRx_wantStart) begin + upstreamRx_stateNext = UsbOhciAxi4_upstreamRx_enumDef_IDLE; + end + if(upstreamRx_wantKill) begin + upstreamRx_stateNext = UsbOhciAxi4_upstreamRx_enumDef_BOOT; + end + end + + assign Rx_Suspend = (upstreamRx_stateReg == UsbOhciAxi4_upstreamRx_enumDef_SUSPEND); + always @(*) begin + ports_0_rx_packet_stateNext = ports_0_rx_packet_stateReg; + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + if(ports_0_rx_history_sync_hit) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET; + end + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + if(ports_0_rx_destuffer_output_valid) begin + if(when_UsbHubPhy_l527) begin + if(ports_0_rx_stuffingError) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED; + end + end + end + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + if(ports_0_rx_packet_errorTimeout_trigger) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE; + end + end + default : begin + end + endcase + if(ports_0_rx_eop_hit) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE; + end + if(txShared_encoder_output_valid) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE; + end + if(ports_0_rx_packet_wantStart) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE; + end + if(ports_0_rx_packet_wantKill) begin + ports_0_rx_packet_stateNext = UsbOhciAxi4_ports_0_rx_packet_enumDef_BOOT; + end + end + + assign when_UsbHubPhy_l527 = (ports_0_rx_packet_counter == 3'b111); + assign when_UsbHubPhy_l549 = ((ports_0_rx_packet_errorTimeout_p != ports_0_filter_io_filtred_dp) || (ports_0_rx_packet_errorTimeout_n != ports_0_filter_io_filtred_dm)); + assign when_StateMachine_l253 = ((! (ports_0_rx_packet_stateReg == UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE)) && (ports_0_rx_packet_stateNext == UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE)); + assign when_StateMachine_l253_1 = ((! (ports_0_rx_packet_stateReg == UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED)) && (ports_0_rx_packet_stateNext == UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED)); + always @(*) begin + ports_0_fsm_stateNext = ports_0_fsm_stateReg; + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + if(io_ctrl_ports_0_power) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + if(ports_0_fsm_timer_DISCONNECTED_EOI) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + if(ports_0_fsm_timer_RESET_EOI) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + if(ports_0_fsm_timer_RESET_DELAY) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + if(when_UsbHubPhy_l675) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + if(io_ctrl_ports_0_suspend_valid) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED; + end else begin + if(when_UsbHubPhy_l697) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E; + end else begin + if(io_ctrl_usbResume) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING; + end + end + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + if(when_UsbHubPhy_l705) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING; + end else begin + if(when_UsbHubPhy_l707) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S; + end + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + if(ports_0_fsm_timer_RESUME_EOI) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + if(ports_0_fsm_timer_TWO_BIT) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + if(ports_0_fsm_timer_ONE_BIT) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + if(when_UsbHubPhy_l748) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING; + end + if(ports_0_fsm_timer_RESTART_EOI) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + if(when_UsbHubPhy_l758) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING; + end + if(ports_0_fsm_timer_RESTART_EOI) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED; + end + end + default : begin + end + endcase + if(when_UsbHubPhy_l610) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF; + end else begin + if(ports_0_rx_disconnect_event) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED; + end else begin + if(io_ctrl_ports_0_disable_valid) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED; + end else begin + if(io_ctrl_ports_0_reset_valid) begin + if(when_UsbHubPhy_l617) begin + if(when_UsbHubPhy_l618) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING; + end + end + end + end + end + end + if(ports_0_fsm_wantStart) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF; + end + if(ports_0_fsm_wantKill) begin + ports_0_fsm_stateNext = UsbOhciAxi4_ports_0_fsm_enumDef_BOOT; + end + end + + assign when_UsbHubPhy_l638 = ((! ports_0_filter_io_filtred_dp) && (! ports_0_filter_io_filtred_dm)); + assign when_UsbHubPhy_l675 = (! txShared_encoder_output_valid); + assign when_UsbHubPhy_l688 = (ports_0_portLowSpeed && txShared_lowSpeedSof_overrideEncoder); + assign when_UsbHubPhy_l697 = (Rx_Suspend && (ports_0_filter_io_filtred_se0 || ((! ports_0_filter_io_filtred_se0) && ((! ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed)))); + assign when_UsbHubPhy_l705 = (io_ctrl_ports_0_resume_valid || ((! Rx_Suspend) && ((! ports_0_filter_io_filtred_se0) && ((! ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed)))); + assign when_UsbHubPhy_l707 = (Rx_Suspend && (ports_0_filter_io_filtred_se0 || ((! ports_0_filter_io_filtred_se0) && ((! ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed)))); + assign when_UsbHubPhy_l748 = ((! ports_0_filter_io_filtred_se0) && ((! ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed)); + assign when_UsbHubPhy_l758 = ((! ports_0_filter_io_filtred_se0) && ((! ports_0_filter_io_filtred_d) ^ ports_0_portLowSpeed)); + assign when_StateMachine_l253_2 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED)); + assign when_StateMachine_l253_3 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING)); + assign when_StateMachine_l253_4 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY)); + assign when_StateMachine_l253_5 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING)); + assign when_StateMachine_l253_6 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0)); + assign when_StateMachine_l253_7 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1)); + assign when_StateMachine_l253_8 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S)); + assign when_StateMachine_l253_9 = ((! (ports_0_fsm_stateReg == UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E)) && (ports_0_fsm_stateNext == UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E)); + assign when_UsbHubPhy_l610 = ((! io_ctrl_ports_0_power) || io_ctrl_usbReset); + assign when_UsbHubPhy_l617 = (! ports_0_fsm_resetInProgress); + assign when_UsbHubPhy_l618 = (ports_0_filter_io_filtred_dm != ports_0_filter_io_filtred_dp); + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + tickTimer_counter_value <= 2'b00; + txShared_rxToTxDelay_active <= 1'b0; + txShared_lowSpeedSof_state <= 2'b00; + txShared_lowSpeedSof_overrideEncoder <= 1'b0; + ports_0_rx_eop_counter <= 7'h00; + ports_0_rx_disconnect_counter <= 7'h00; + txShared_frame_stateReg <= UsbOhciAxi4_txShared_frame_enumDef_BOOT; + upstreamRx_stateReg <= UsbOhciAxi4_upstreamRx_enumDef_BOOT; + ports_0_rx_packet_stateReg <= UsbOhciAxi4_ports_0_rx_packet_enumDef_BOOT; + ports_0_fsm_stateReg <= UsbOhciAxi4_ports_0_fsm_enumDef_BOOT; + end else begin + tickTimer_counter_value <= tickTimer_counter_valueNext; + if(txShared_rxToTxDelay_twoCycle) begin + txShared_rxToTxDelay_active <= 1'b0; + end + if(when_UsbHubPhy_l249) begin + txShared_lowSpeedSof_overrideEncoder <= 1'b0; + end + txShared_lowSpeedSof_state <= (txShared_lowSpeedSof_state + _zz_txShared_lowSpeedSof_state); + if(when_UsbHubPhy_l251) begin + if(when_UsbHubPhy_l252) begin + txShared_lowSpeedSof_overrideEncoder <= 1'b1; + end + end else begin + if(when_UsbHubPhy_l259) begin + txShared_lowSpeedSof_state <= (txShared_lowSpeedSof_state + 2'b01); + end + end + if(when_UsbHubPhy_l493) begin + if(when_UsbHubPhy_l494) begin + ports_0_rx_eop_counter <= (ports_0_rx_eop_counter + 7'h01); + end + end else begin + ports_0_rx_eop_counter <= 7'h00; + end + ports_0_rx_disconnect_counter <= (ports_0_rx_disconnect_counter + _zz_ports_0_rx_disconnect_counter); + if(ports_0_rx_disconnect_clear) begin + ports_0_rx_disconnect_counter <= 7'h00; + end + txShared_frame_stateReg <= txShared_frame_stateNext; + upstreamRx_stateReg <= upstreamRx_stateNext; + ports_0_rx_packet_stateReg <= ports_0_rx_packet_stateNext; + if(ports_0_rx_eop_hit) begin + txShared_rxToTxDelay_active <= 1'b1; + end + ports_0_fsm_stateReg <= ports_0_fsm_stateNext; + end + end + + always @(posedge phy_clk) begin + if(txShared_timer_inc) begin + txShared_timer_counter <= (txShared_timer_counter + 10'h001); + end + if(txShared_timer_clear) begin + txShared_timer_counter <= 10'h000; + end + if(txShared_rxToTxDelay_inc) begin + txShared_rxToTxDelay_counter <= (txShared_rxToTxDelay_counter + 9'h001); + end + if(txShared_rxToTxDelay_clear) begin + txShared_rxToTxDelay_counter <= 9'h000; + end + if(txShared_encoder_input_valid) begin + if(txShared_encoder_input_data) begin + if(txShared_timer_oneCycle) begin + txShared_encoder_counter <= (txShared_encoder_counter + 3'b001); + if(when_UsbHubPhy_l189) begin + txShared_encoder_state <= (! txShared_encoder_state); + end + if(when_UsbHubPhy_l194) begin + txShared_encoder_counter <= 3'b000; + end + end + end else begin + if(txShared_timer_oneCycle) begin + txShared_encoder_counter <= 3'b000; + txShared_encoder_state <= (! txShared_encoder_state); + end + end + end + if(when_UsbHubPhy_l208) begin + txShared_encoder_counter <= 3'b000; + txShared_encoder_state <= 1'b1; + end + if(txShared_serialiser_input_valid) begin + if(txShared_encoder_input_ready) begin + txShared_serialiser_bitCounter <= (txShared_serialiser_bitCounter + 3'b001); + end + end + if(when_UsbHubPhy_l240) begin + txShared_serialiser_bitCounter <= 3'b000; + end + txShared_encoder_output_valid_regNext <= txShared_encoder_output_valid; + if(when_UsbHubPhy_l251) begin + if(when_UsbHubPhy_l252) begin + txShared_lowSpeedSof_timer <= 5'h00; + end + end else begin + txShared_lowSpeedSof_timer <= (txShared_lowSpeedSof_timer + 5'h01); + end + if(upstreamRx_timer_inc) begin + upstreamRx_timer_counter <= (upstreamRx_timer_counter + 20'h00001); + end + if(upstreamRx_timer_clear) begin + upstreamRx_timer_counter <= 20'h00000; + end + if(ports_0_filter_io_filtred_sample) begin + if(when_UsbHubPhy_l445) begin + ports_0_rx_decoder_state <= (! ports_0_rx_decoder_state); + end + end + if(ports_0_rx_waitSync) begin + ports_0_rx_decoder_state <= 1'b0; + end + if(ports_0_rx_decoder_output_valid) begin + ports_0_rx_destuffer_counter <= (ports_0_rx_destuffer_counter + 3'b001); + if(when_UsbHubPhy_l466) begin + ports_0_rx_destuffer_counter <= 3'b000; + if(ports_0_rx_decoder_output_payload) begin + ports_0_rx_stuffingError <= 1'b1; + end + end + end + if(ports_0_rx_waitSync) begin + ports_0_rx_destuffer_counter <= 3'b000; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_1 <= _zz_ports_0_rx_history_value; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_2 <= _zz_ports_0_rx_history_value_1; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_3 <= _zz_ports_0_rx_history_value_2; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_4 <= _zz_ports_0_rx_history_value_3; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_5 <= _zz_ports_0_rx_history_value_4; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_6 <= _zz_ports_0_rx_history_value_5; + end + if(ports_0_rx_history_updated) begin + _zz_ports_0_rx_history_value_7 <= _zz_ports_0_rx_history_value_6; + end + if(ports_0_rx_packet_errorTimeout_inc) begin + ports_0_rx_packet_errorTimeout_counter <= (ports_0_rx_packet_errorTimeout_counter + 12'h001); + end + if(ports_0_rx_packet_errorTimeout_clear) begin + ports_0_rx_packet_errorTimeout_counter <= 12'h000; + end + ports_0_rx_disconnect_hitLast <= ports_0_rx_disconnect_hit; + if(ports_0_fsm_timer_inc) begin + ports_0_fsm_timer_counter <= (ports_0_fsm_timer_counter + 24'h000001); + end + if(ports_0_fsm_timer_clear) begin + ports_0_fsm_timer_counter <= 24'h000000; + end + case(txShared_frame_stateReg) + UsbOhciAxi4_txShared_frame_enumDef_IDLE : begin + txShared_frame_wasLowSpeed <= io_ctrl_lowSpeed; + end + UsbOhciAxi4_txShared_frame_enumDef_TAKE_LINE : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_PID : begin + end + UsbOhciAxi4_txShared_frame_enumDef_PREAMBLE_DELAY : begin + end + UsbOhciAxi4_txShared_frame_enumDef_SYNC : begin + end + UsbOhciAxi4_txShared_frame_enumDef_DATA : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_0 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_1 : begin + end + UsbOhciAxi4_txShared_frame_enumDef_EOP_2 : begin + end + default : begin + end + endcase + case(ports_0_rx_packet_stateReg) + UsbOhciAxi4_ports_0_rx_packet_enumDef_IDLE : begin + ports_0_rx_packet_counter <= 3'b000; + ports_0_rx_stuffingError <= 1'b0; + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_PACKET : begin + if(ports_0_rx_destuffer_output_valid) begin + ports_0_rx_packet_counter <= (ports_0_rx_packet_counter + 3'b001); + end + end + UsbOhciAxi4_ports_0_rx_packet_enumDef_ERRORED : begin + ports_0_rx_packet_errorTimeout_p <= ports_0_filter_io_filtred_dp; + ports_0_rx_packet_errorTimeout_n <= ports_0_filter_io_filtred_dm; + end + default : begin + end + endcase + if(ports_0_rx_eop_hit) begin + txShared_rxToTxDelay_lowSpeed <= io_ctrl_lowSpeed; + end + case(ports_0_fsm_stateReg) + UsbOhciAxi4_ports_0_fsm_enumDef_POWER_OFF : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISCONNECTED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_DISABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_DELAY : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESETTING_SYNC : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_ENABLED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SUSPENDED : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESUMING : begin + if(ports_0_fsm_timer_RESUME_EOI) begin + ports_0_fsm_lowSpeedEop <= 1'b1; + end + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_0 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_SEND_EOP_1 : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_S : begin + end + UsbOhciAxi4_ports_0_fsm_enumDef_RESTART_E : begin + end + default : begin + end + endcase + if(!when_UsbHubPhy_l610) begin + if(!ports_0_rx_disconnect_event) begin + if(!io_ctrl_ports_0_disable_valid) begin + if(io_ctrl_ports_0_reset_valid) begin + if(when_UsbHubPhy_l617) begin + if(when_UsbHubPhy_l618) begin + ports_0_portLowSpeed <= (! ports_0_filter_io_filtred_d); + end + end + end + end + end + end + end + + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + io_ctrl_tx_payload_first <= 1'b1; + end else begin + if(io_ctrl_tx_fire) begin + io_ctrl_tx_payload_first <= io_ctrl_tx_payload_last; + end + end + end + + +endmodule + +module UsbOhciAxi4_UsbOhci ( + input io_ctrl_cmd_valid, + output io_ctrl_cmd_ready, + input io_ctrl_cmd_payload_last, + input [8:0] io_ctrl_cmd_payload_fragment_source, + input [0:0] io_ctrl_cmd_payload_fragment_opcode, + input [11:0] io_ctrl_cmd_payload_fragment_address, + input [9:0] io_ctrl_cmd_payload_fragment_length, + input [31:0] io_ctrl_cmd_payload_fragment_data, + input [3:0] io_ctrl_cmd_payload_fragment_mask, + output io_ctrl_rsp_valid, + input io_ctrl_rsp_ready, + output io_ctrl_rsp_payload_last, + output [8:0] io_ctrl_rsp_payload_fragment_source, + output [0:0] io_ctrl_rsp_payload_fragment_opcode, + output [31:0] io_ctrl_rsp_payload_fragment_data, + output reg io_phy_lowSpeed, + output reg io_phy_tx_valid, + input io_phy_tx_ready, + output reg io_phy_tx_payload_last, + output reg [7:0] io_phy_tx_payload_fragment, + input io_phy_txEop, + input io_phy_rx_flow_valid, + input io_phy_rx_flow_payload_stuffingError, + input [7:0] io_phy_rx_flow_payload_data, + input io_phy_rx_active, + output io_phy_usbReset, + output io_phy_usbResume, + input io_phy_overcurrent, + input io_phy_tick, + output io_phy_ports_0_disable_valid, + input io_phy_ports_0_disable_ready, + output io_phy_ports_0_removable, + output io_phy_ports_0_power, + output io_phy_ports_0_reset_valid, + input io_phy_ports_0_reset_ready, + output io_phy_ports_0_suspend_valid, + input io_phy_ports_0_suspend_ready, + output io_phy_ports_0_resume_valid, + input io_phy_ports_0_resume_ready, + input io_phy_ports_0_connect, + input io_phy_ports_0_disconnect, + input io_phy_ports_0_overcurrent, + input io_phy_ports_0_remoteResume, + input io_phy_ports_0_lowSpeed, + output io_dma_cmd_valid, + input io_dma_cmd_ready, + output io_dma_cmd_payload_last, + output [0:0] io_dma_cmd_payload_fragment_opcode, + output [31:0] io_dma_cmd_payload_fragment_address, + output [5:0] io_dma_cmd_payload_fragment_length, + output [31:0] io_dma_cmd_payload_fragment_data, + output [3:0] io_dma_cmd_payload_fragment_mask, + input io_dma_rsp_valid, + output io_dma_rsp_ready, + input io_dma_rsp_payload_last, + input [0:0] io_dma_rsp_payload_fragment_opcode, + input [31:0] io_dma_rsp_payload_fragment_data, + output io_interrupt, + output io_interruptBios, + input ctrl_clk, + input ctrl_reset +); + localparam UsbOhciAxi4_MainState_RESET = 2'd0; + localparam UsbOhciAxi4_MainState_RESUME = 2'd1; + localparam UsbOhciAxi4_MainState_OPERATIONAL = 2'd2; + localparam UsbOhciAxi4_MainState_SUSPEND = 2'd3; + localparam UsbOhciAxi4_FlowType_BULK = 2'd0; + localparam UsbOhciAxi4_FlowType_CONTROL = 2'd1; + localparam UsbOhciAxi4_FlowType_PERIODIC = 2'd2; + localparam UsbOhciAxi4_endpoint_Status_OK = 1'd0; + localparam UsbOhciAxi4_endpoint_Status_FRAME_TIME = 1'd1; + localparam UsbOhciAxi4_endpoint_enumDef_BOOT = 5'd0; + localparam UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD = 5'd1; + localparam UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP = 5'd2; + localparam UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE = 5'd3; + localparam UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD = 5'd4; + localparam UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP = 5'd5; + localparam UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY = 5'd6; + localparam UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE = 5'd7; + localparam UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME = 5'd8; + localparam UsbOhciAxi4_endpoint_enumDef_BUFFER_READ = 5'd9; + localparam UsbOhciAxi4_endpoint_enumDef_TOKEN = 5'd10; + localparam UsbOhciAxi4_endpoint_enumDef_DATA_TX = 5'd11; + localparam UsbOhciAxi4_endpoint_enumDef_DATA_RX = 5'd12; + localparam UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE = 5'd13; + localparam UsbOhciAxi4_endpoint_enumDef_ACK_RX = 5'd14; + localparam UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 = 5'd15; + localparam UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 = 5'd16; + localparam UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP = 5'd17; + localparam UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA = 5'd18; + localparam UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS = 5'd19; + localparam UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD = 5'd20; + localparam UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD = 5'd21; + localparam UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC = 5'd22; + localparam UsbOhciAxi4_endpoint_enumDef_ABORD = 5'd23; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT = 3'd0; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT = 3'd1; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB = 3'd2; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB = 3'd3; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION = 3'd4; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD = 3'd5; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD = 3'd6; + localparam UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD = 3'd7; + localparam UsbOhciAxi4_token_enumDef_BOOT = 3'd0; + localparam UsbOhciAxi4_token_enumDef_INIT = 3'd1; + localparam UsbOhciAxi4_token_enumDef_PID = 3'd2; + localparam UsbOhciAxi4_token_enumDef_B1 = 3'd3; + localparam UsbOhciAxi4_token_enumDef_B2 = 3'd4; + localparam UsbOhciAxi4_token_enumDef_EOP = 3'd5; + localparam UsbOhciAxi4_dataTx_enumDef_BOOT = 3'd0; + localparam UsbOhciAxi4_dataTx_enumDef_PID = 3'd1; + localparam UsbOhciAxi4_dataTx_enumDef_DATA = 3'd2; + localparam UsbOhciAxi4_dataTx_enumDef_CRC_0 = 3'd3; + localparam UsbOhciAxi4_dataTx_enumDef_CRC_1 = 3'd4; + localparam UsbOhciAxi4_dataTx_enumDef_EOP = 3'd5; + localparam UsbOhciAxi4_dataRx_enumDef_BOOT = 2'd0; + localparam UsbOhciAxi4_dataRx_enumDef_IDLE = 2'd1; + localparam UsbOhciAxi4_dataRx_enumDef_PID = 2'd2; + localparam UsbOhciAxi4_dataRx_enumDef_DATA = 2'd3; + localparam UsbOhciAxi4_sof_enumDef_BOOT = 2'd0; + localparam UsbOhciAxi4_sof_enumDef_FRAME_TX = 2'd1; + localparam UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD = 2'd2; + localparam UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP = 2'd3; + localparam UsbOhciAxi4_operational_enumDef_BOOT = 3'd0; + localparam UsbOhciAxi4_operational_enumDef_SOF = 3'd1; + localparam UsbOhciAxi4_operational_enumDef_ARBITER = 3'd2; + localparam UsbOhciAxi4_operational_enumDef_END_POINT = 3'd3; + localparam UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD = 3'd4; + localparam UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP = 3'd5; + localparam UsbOhciAxi4_operational_enumDef_WAIT_SOF = 3'd6; + localparam UsbOhciAxi4_hc_enumDef_BOOT = 3'd0; + localparam UsbOhciAxi4_hc_enumDef_RESET = 3'd1; + localparam UsbOhciAxi4_hc_enumDef_RESUME = 3'd2; + localparam UsbOhciAxi4_hc_enumDef_OPERATIONAL = 3'd3; + localparam UsbOhciAxi4_hc_enumDef_SUSPEND = 3'd4; + localparam UsbOhciAxi4_hc_enumDef_ANY_TO_RESET = 3'd5; + localparam UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND = 3'd6; + + reg fifo_io_push_valid; + reg [31:0] fifo_io_push_payload; + reg fifo_io_pop_ready; + reg fifo_io_flush; + reg token_crc5_io_flush; + reg token_crc5_io_input_valid; + reg dataTx_crc16_io_flush; + reg dataRx_crc16_io_flush; + reg dataRx_crc16_io_input_valid; + wire fifo_io_push_ready; + wire fifo_io_pop_valid; + wire [31:0] fifo_io_pop_payload; + wire [9:0] fifo_io_occupancy; + wire [9:0] fifo_io_availability; + wire [4:0] token_crc5_io_result; + wire [4:0] token_crc5_io_resultNext; + wire [15:0] dataTx_crc16_io_result; + wire [15:0] dataTx_crc16_io_resultNext; + wire [15:0] dataRx_crc16_io_result; + wire [15:0] dataRx_crc16_io_resultNext; + wire [3:0] _zz_dmaCtx_pendingCounter; + wire [3:0] _zz_dmaCtx_pendingCounter_1; + wire [0:0] _zz_dmaCtx_pendingCounter_2; + wire [3:0] _zz_dmaCtx_pendingCounter_3; + wire [0:0] _zz_dmaCtx_pendingCounter_4; + wire [0:0] _zz_reg_hcCommandStatus_startSoftReset; + wire [0:0] _zz_reg_hcCommandStatus_CLF; + wire [0:0] _zz_reg_hcCommandStatus_BLF; + wire [0:0] _zz_reg_hcCommandStatus_OCR; + wire [0:0] _zz_reg_hcInterrupt_MIE; + wire [0:0] _zz_reg_hcInterrupt_MIE_1; + wire [0:0] _zz_reg_hcInterrupt_SO_status; + wire [0:0] _zz_reg_hcInterrupt_SO_enable; + wire [0:0] _zz_reg_hcInterrupt_SO_enable_1; + wire [0:0] _zz_reg_hcInterrupt_WDH_status; + wire [0:0] _zz_reg_hcInterrupt_WDH_enable; + wire [0:0] _zz_reg_hcInterrupt_WDH_enable_1; + wire [0:0] _zz_reg_hcInterrupt_SF_status; + wire [0:0] _zz_reg_hcInterrupt_SF_enable; + wire [0:0] _zz_reg_hcInterrupt_SF_enable_1; + wire [0:0] _zz_reg_hcInterrupt_RD_status; + wire [0:0] _zz_reg_hcInterrupt_RD_enable; + wire [0:0] _zz_reg_hcInterrupt_RD_enable_1; + wire [0:0] _zz_reg_hcInterrupt_UE_status; + wire [0:0] _zz_reg_hcInterrupt_UE_enable; + wire [0:0] _zz_reg_hcInterrupt_UE_enable_1; + wire [0:0] _zz_reg_hcInterrupt_FNO_status; + wire [0:0] _zz_reg_hcInterrupt_FNO_enable; + wire [0:0] _zz_reg_hcInterrupt_FNO_enable_1; + wire [0:0] _zz_reg_hcInterrupt_RHSC_status; + wire [0:0] _zz_reg_hcInterrupt_RHSC_enable; + wire [0:0] _zz_reg_hcInterrupt_RHSC_enable_1; + wire [0:0] _zz_reg_hcInterrupt_OC_status; + wire [0:0] _zz_reg_hcInterrupt_OC_enable; + wire [0:0] _zz_reg_hcInterrupt_OC_enable_1; + wire [13:0] _zz_reg_hcLSThreshold_hit; + wire [0:0] _zz_reg_hcRhStatus_CCIC; + wire [0:0] _zz_reg_hcRhStatus_clearGlobalPower; + wire [0:0] _zz_reg_hcRhStatus_setRemoteWakeupEnable; + wire [0:0] _zz_reg_hcRhStatus_setGlobalPower; + wire [0:0] _zz_reg_hcRhStatus_clearRemoteWakeupEnable; + wire [0:0] _zz_reg_hcRhPortStatus_0_clearPortEnable; + wire [0:0] _zz_reg_hcRhPortStatus_0_setPortEnable; + wire [0:0] _zz_reg_hcRhPortStatus_0_setPortSuspend; + wire [0:0] _zz_reg_hcRhPortStatus_0_clearSuspendStatus; + wire [0:0] _zz_reg_hcRhPortStatus_0_setPortReset; + wire [0:0] _zz_reg_hcRhPortStatus_0_setPortPower; + wire [0:0] _zz_reg_hcRhPortStatus_0_clearPortPower; + wire [0:0] _zz_reg_hcRhPortStatus_0_CSC_clear; + wire [0:0] _zz_reg_hcRhPortStatus_0_PESC_clear; + wire [0:0] _zz_reg_hcRhPortStatus_0_PSSC_clear; + wire [0:0] _zz_reg_hcRhPortStatus_0_OCIC_clear; + wire [0:0] _zz_reg_hcRhPortStatus_0_PRSC_clear; + wire [7:0] _zz_rxTimer_ackTx; + wire [3:0] _zz_rxTimer_ackTx_1; + wire [15:0] _zz_endpoint_TD_isoOverrun; + wire [12:0] _zz_endpoint_TD_firstOffset; + wire [11:0] _zz_endpoint_TD_firstOffset_1; + wire [12:0] _zz_endpoint_TD_lastOffset; + wire [12:0] _zz_endpoint_TD_lastOffset_1; + wire [0:0] _zz_endpoint_TD_lastOffset_2; + wire [13:0] _zz_endpoint_transactionSizeMinusOne; + wire [13:0] _zz_endpoint_dataDone; + wire [5:0] _zz_endpoint_dmaLogic_lengthMax; + wire [13:0] _zz_endpoint_dmaLogic_lengthCalc; + wire [13:0] _zz_endpoint_dmaLogic_lengthCalc_1; + wire [13:0] _zz_endpoint_dmaLogic_lengthCalc_2; + wire [6:0] _zz_endpoint_dmaLogic_beatCount; + wire [6:0] _zz_endpoint_dmaLogic_beatCount_1; + wire [1:0] _zz_endpoint_dmaLogic_beatCount_2; + wire [6:0] _zz_endpoint_dmaLogic_lengthBmb; + wire [13:0] _zz_endpoint_dmaLogic_lastMask; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_1; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_2; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_3; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_4; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_5; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_6; + wire [13:0] _zz_endpoint_dmaLogic_lastMask_7; + wire [5:0] _zz_endpoint_dmaLogic_beatLast; + wire [13:0] _zz_endpoint_byteCountCalc; + wire [13:0] _zz_endpoint_byteCountCalc_1; + wire [16:0] _zz_endpoint_fsTimeCheck; + wire [16:0] _zz_endpoint_fsTimeCheck_1; + wire [15:0] _zz_token_data; + wire [4:0] _zz_ioDma_cmd_payload_fragment_length; + wire [13:0] _zz__zz_endpoint_lastAddress; + wire [13:0] _zz__zz_endpoint_lastAddress_1; + wire [11:0] _zz__zz_endpoint_lastAddress_2; + wire [13:0] _zz_endpoint_lastAddress_1; + wire [13:0] _zz_endpoint_lastAddress_2; + wire [13:0] _zz_endpoint_lastAddress_3; + wire [13:0] _zz_endpoint_lastAddress_4; + wire [13:0] _zz_when_UsbOhci_l1331; + wire [1:0] _zz_endpoint_TD_words_0; + wire [4:0] _zz_ioDma_cmd_payload_fragment_length_1; + wire [3:0] _zz_ioDma_cmd_payload_last; + wire [2:0] _zz_ioDma_cmd_payload_last_1; + wire [11:0] _zz__zz_ioDma_cmd_payload_fragment_data; + wire [13:0] _zz__zz_ioDma_cmd_payload_fragment_data_1; + wire [13:0] _zz__zz_ioDma_cmd_payload_fragment_data_2; + wire [13:0] _zz__zz_ioDma_cmd_payload_fragment_data_3; + reg [7:0] _zz_dataTx_data_payload_fragment; + wire [13:0] _zz_when_UsbOhci_l1054; + wire [13:0] _zz_endpoint_dmaLogic_overflow; + wire [13:0] _zz_endpoint_lastAddress_5; + wire [13:0] _zz_endpoint_lastAddress_6; + wire [13:0] _zz_endpoint_lastAddress_7; + wire [10:0] _zz_endpoint_dmaLogic_fromUsbCounter; + wire [0:0] _zz_endpoint_dmaLogic_fromUsbCounter_1; + wire [13:0] _zz_endpoint_currentAddress; + wire [13:0] _zz_endpoint_currentAddress_1; + wire [13:0] _zz_endpoint_currentAddress_2; + wire [13:0] _zz_endpoint_currentAddress_3; + wire [31:0] _zz_ioDma_cmd_payload_fragment_address; + wire [6:0] _zz_ioDma_cmd_payload_fragment_address_1; + reg unscheduleAll_valid; + reg unscheduleAll_ready; + reg ioDma_cmd_valid; + wire ioDma_cmd_ready; + reg ioDma_cmd_payload_last; + reg [0:0] ioDma_cmd_payload_fragment_opcode; + reg [31:0] ioDma_cmd_payload_fragment_address; + reg [5:0] ioDma_cmd_payload_fragment_length; + reg [31:0] ioDma_cmd_payload_fragment_data; + reg [3:0] ioDma_cmd_payload_fragment_mask; + wire ioDma_rsp_valid; + wire ioDma_rsp_ready; + wire ioDma_rsp_payload_last; + wire [0:0] ioDma_rsp_payload_fragment_opcode; + wire [31:0] ioDma_rsp_payload_fragment_data; + reg [3:0] dmaCtx_pendingCounter; + wire ioDma_cmd_fire; + wire ioDma_rsp_fire; + wire dmaCtx_pendingFull; + wire dmaCtx_pendingEmpty; + reg [5:0] dmaCtx_beatCounter; + wire when_UsbOhci_l157; + wire io_dma_cmd_fire; + reg io_dma_cmd_payload_first; + wire _zz_io_dma_cmd_valid; + wire [31:0] dmaRspMux_vec_0; + wire [31:0] dmaRspMux_data; + reg [3:0] dmaReadCtx_counter; + reg [3:0] dmaWriteCtx_counter; + reg ctrlHalt; + wire ctrl_readErrorFlag; + wire ctrl_writeErrorFlag; + wire ctrl_readHaltTrigger; + reg ctrl_writeHaltTrigger; + wire ctrl_rsp_valid; + wire ctrl_rsp_ready; + wire ctrl_rsp_payload_last; + wire [8:0] ctrl_rsp_payload_fragment_source; + reg [0:0] ctrl_rsp_payload_fragment_opcode; + reg [31:0] ctrl_rsp_payload_fragment_data; + wire _zz_ctrl_rsp_ready; + reg _zz_ctrl_rsp_ready_1; + wire _zz_io_ctrl_rsp_valid; + reg _zz_io_ctrl_rsp_valid_1; + reg _zz_io_ctrl_rsp_payload_last; + reg [8:0] _zz_io_ctrl_rsp_payload_fragment_source; + reg [0:0] _zz_io_ctrl_rsp_payload_fragment_opcode; + reg [31:0] _zz_io_ctrl_rsp_payload_fragment_data; + wire when_Stream_l369; + wire ctrl_askWrite; + wire ctrl_askRead; + wire io_ctrl_cmd_fire; + wire ctrl_doWrite; + wire ctrl_doRead; + wire when_BmbSlaveFactory_l33; + wire when_BmbSlaveFactory_l35; + reg doUnschedule; + reg doSoftReset; + wire when_UsbOhci_l236; + wire [4:0] reg_hcRevision_REV; + reg [1:0] reg_hcControl_CBSR; + reg reg_hcControl_PLE; + reg reg_hcControl_IE; + reg reg_hcControl_CLE; + reg reg_hcControl_BLE; + reg [1:0] reg_hcControl_HCFS; + reg reg_hcControl_IR; + reg reg_hcControl_RWC; + reg reg_hcControl_RWE; + reg reg_hcControl_HCFSWrite_valid; + wire [1:0] reg_hcControl_HCFSWrite_payload; + reg reg_hcCommandStatus_startSoftReset; + reg when_BusSlaveFactory_l377; + wire when_BusSlaveFactory_l379; + reg reg_hcCommandStatus_CLF; + reg when_BusSlaveFactory_l377_1; + wire when_BusSlaveFactory_l379_1; + reg reg_hcCommandStatus_BLF; + reg when_BusSlaveFactory_l377_2; + wire when_BusSlaveFactory_l379_2; + reg reg_hcCommandStatus_OCR; + reg when_BusSlaveFactory_l377_3; + wire when_BusSlaveFactory_l379_3; + reg [1:0] reg_hcCommandStatus_SOC; + reg reg_hcInterrupt_unmaskedPending; + reg reg_hcInterrupt_MIE; + reg when_BusSlaveFactory_l377_4; + wire when_BusSlaveFactory_l379_4; + reg when_BusSlaveFactory_l341; + wire when_BusSlaveFactory_l347; + reg reg_hcInterrupt_SO_status; + reg when_BusSlaveFactory_l341_1; + wire when_BusSlaveFactory_l347_1; + reg reg_hcInterrupt_SO_enable; + reg when_BusSlaveFactory_l377_5; + wire when_BusSlaveFactory_l379_5; + reg when_BusSlaveFactory_l341_2; + wire when_BusSlaveFactory_l347_2; + wire when_UsbOhci_l302; + reg reg_hcInterrupt_WDH_status; + reg when_BusSlaveFactory_l341_3; + wire when_BusSlaveFactory_l347_3; + reg reg_hcInterrupt_WDH_enable; + reg when_BusSlaveFactory_l377_6; + wire when_BusSlaveFactory_l379_6; + reg when_BusSlaveFactory_l341_4; + wire when_BusSlaveFactory_l347_4; + wire when_UsbOhci_l302_1; + reg reg_hcInterrupt_SF_status; + reg when_BusSlaveFactory_l341_5; + wire when_BusSlaveFactory_l347_5; + reg reg_hcInterrupt_SF_enable; + reg when_BusSlaveFactory_l377_7; + wire when_BusSlaveFactory_l379_7; + reg when_BusSlaveFactory_l341_6; + wire when_BusSlaveFactory_l347_6; + wire when_UsbOhci_l302_2; + reg reg_hcInterrupt_RD_status; + reg when_BusSlaveFactory_l341_7; + wire when_BusSlaveFactory_l347_7; + reg reg_hcInterrupt_RD_enable; + reg when_BusSlaveFactory_l377_8; + wire when_BusSlaveFactory_l379_8; + reg when_BusSlaveFactory_l341_8; + wire when_BusSlaveFactory_l347_8; + wire when_UsbOhci_l302_3; + reg reg_hcInterrupt_UE_status; + reg when_BusSlaveFactory_l341_9; + wire when_BusSlaveFactory_l347_9; + reg reg_hcInterrupt_UE_enable; + reg when_BusSlaveFactory_l377_9; + wire when_BusSlaveFactory_l379_9; + reg when_BusSlaveFactory_l341_10; + wire when_BusSlaveFactory_l347_10; + wire when_UsbOhci_l302_4; + reg reg_hcInterrupt_FNO_status; + reg when_BusSlaveFactory_l341_11; + wire when_BusSlaveFactory_l347_11; + reg reg_hcInterrupt_FNO_enable; + reg when_BusSlaveFactory_l377_10; + wire when_BusSlaveFactory_l379_10; + reg when_BusSlaveFactory_l341_12; + wire when_BusSlaveFactory_l347_12; + wire when_UsbOhci_l302_5; + reg reg_hcInterrupt_RHSC_status; + reg when_BusSlaveFactory_l341_13; + wire when_BusSlaveFactory_l347_13; + reg reg_hcInterrupt_RHSC_enable; + reg when_BusSlaveFactory_l377_11; + wire when_BusSlaveFactory_l379_11; + reg when_BusSlaveFactory_l341_14; + wire when_BusSlaveFactory_l347_14; + wire when_UsbOhci_l302_6; + reg reg_hcInterrupt_OC_status; + reg when_BusSlaveFactory_l341_15; + wire when_BusSlaveFactory_l347_15; + reg reg_hcInterrupt_OC_enable; + reg when_BusSlaveFactory_l377_12; + wire when_BusSlaveFactory_l379_12; + reg when_BusSlaveFactory_l341_16; + wire when_BusSlaveFactory_l347_16; + wire reg_hcInterrupt_doIrq; + wire [31:0] reg_hcHCCA_HCCA_address; + reg [23:0] reg_hcHCCA_HCCA_reg; + wire [31:0] reg_hcPeriodCurrentED_PCED_address; + reg [27:0] reg_hcPeriodCurrentED_PCED_reg; + wire reg_hcPeriodCurrentED_isZero; + wire [31:0] reg_hcControlHeadED_CHED_address; + reg [27:0] reg_hcControlHeadED_CHED_reg; + wire [31:0] reg_hcControlCurrentED_CCED_address; + reg [27:0] reg_hcControlCurrentED_CCED_reg; + wire reg_hcControlCurrentED_isZero; + wire [31:0] reg_hcBulkHeadED_BHED_address; + reg [27:0] reg_hcBulkHeadED_BHED_reg; + wire [31:0] reg_hcBulkCurrentED_BCED_address; + reg [27:0] reg_hcBulkCurrentED_BCED_reg; + wire reg_hcBulkCurrentED_isZero; + wire [31:0] reg_hcDoneHead_DH_address; + reg [27:0] reg_hcDoneHead_DH_reg; + reg [13:0] reg_hcFmInterval_FI; + reg [14:0] reg_hcFmInterval_FSMPS; + reg reg_hcFmInterval_FIT; + reg [13:0] reg_hcFmRemaining_FR; + reg reg_hcFmRemaining_FRT; + reg [15:0] reg_hcFmNumber_FN; + reg reg_hcFmNumber_overflow; + wire [15:0] reg_hcFmNumber_FNp1; + reg [13:0] reg_hcPeriodicStart_PS; + reg [11:0] reg_hcLSThreshold_LST; + wire reg_hcLSThreshold_hit; + wire [7:0] reg_hcRhDescriptorA_NDP; + reg reg_hcRhDescriptorA_PSM; + reg reg_hcRhDescriptorA_NPS; + reg reg_hcRhDescriptorA_OCPM; + reg reg_hcRhDescriptorA_NOCP; + reg [7:0] reg_hcRhDescriptorA_POTPGT; + reg [0:0] reg_hcRhDescriptorB_DR; + reg [0:0] reg_hcRhDescriptorB_PPCM; + reg reg_hcRhStatus_DRWE; + reg reg_hcRhStatus_CCIC; + reg when_BusSlaveFactory_l341_17; + wire when_BusSlaveFactory_l347_17; + reg io_phy_overcurrent_regNext; + wire when_UsbOhci_l409; + reg reg_hcRhStatus_clearGlobalPower; + reg when_BusSlaveFactory_l377_13; + wire when_BusSlaveFactory_l379_13; + reg reg_hcRhStatus_setRemoteWakeupEnable; + reg when_BusSlaveFactory_l377_14; + wire when_BusSlaveFactory_l379_14; + reg reg_hcRhStatus_setGlobalPower; + reg when_BusSlaveFactory_l377_15; + wire when_BusSlaveFactory_l379_15; + reg reg_hcRhStatus_clearRemoteWakeupEnable; + reg when_BusSlaveFactory_l377_16; + wire when_BusSlaveFactory_l379_16; + reg reg_hcRhPortStatus_0_clearPortEnable; + reg when_BusSlaveFactory_l377_17; + wire when_BusSlaveFactory_l379_17; + reg reg_hcRhPortStatus_0_setPortEnable; + reg when_BusSlaveFactory_l377_18; + wire when_BusSlaveFactory_l379_18; + reg reg_hcRhPortStatus_0_setPortSuspend; + reg when_BusSlaveFactory_l377_19; + wire when_BusSlaveFactory_l379_19; + reg reg_hcRhPortStatus_0_clearSuspendStatus; + reg when_BusSlaveFactory_l377_20; + wire when_BusSlaveFactory_l379_20; + reg reg_hcRhPortStatus_0_setPortReset; + reg when_BusSlaveFactory_l377_21; + wire when_BusSlaveFactory_l379_21; + reg reg_hcRhPortStatus_0_setPortPower; + reg when_BusSlaveFactory_l377_22; + wire when_BusSlaveFactory_l379_22; + reg reg_hcRhPortStatus_0_clearPortPower; + reg when_BusSlaveFactory_l377_23; + wire when_BusSlaveFactory_l379_23; + reg reg_hcRhPortStatus_0_resume; + reg reg_hcRhPortStatus_0_reset; + reg reg_hcRhPortStatus_0_suspend; + reg reg_hcRhPortStatus_0_connected; + reg reg_hcRhPortStatus_0_PSS; + reg reg_hcRhPortStatus_0_PPS; + wire reg_hcRhPortStatus_0_CCS; + reg reg_hcRhPortStatus_0_PES; + wire reg_hcRhPortStatus_0_CSC_set; + reg reg_hcRhPortStatus_0_CSC_clear; + reg reg_hcRhPortStatus_0_CSC_reg; + reg when_BusSlaveFactory_l377_24; + wire when_BusSlaveFactory_l379_24; + wire reg_hcRhPortStatus_0_PESC_set; + reg reg_hcRhPortStatus_0_PESC_clear; + reg reg_hcRhPortStatus_0_PESC_reg; + reg when_BusSlaveFactory_l377_25; + wire when_BusSlaveFactory_l379_25; + wire reg_hcRhPortStatus_0_PSSC_set; + reg reg_hcRhPortStatus_0_PSSC_clear; + reg reg_hcRhPortStatus_0_PSSC_reg; + reg when_BusSlaveFactory_l377_26; + wire when_BusSlaveFactory_l379_26; + wire reg_hcRhPortStatus_0_OCIC_set; + reg reg_hcRhPortStatus_0_OCIC_clear; + reg reg_hcRhPortStatus_0_OCIC_reg; + reg when_BusSlaveFactory_l377_27; + wire when_BusSlaveFactory_l379_27; + wire reg_hcRhPortStatus_0_PRSC_set; + reg reg_hcRhPortStatus_0_PRSC_clear; + reg reg_hcRhPortStatus_0_PRSC_reg; + reg when_BusSlaveFactory_l377_28; + wire when_BusSlaveFactory_l379_28; + wire when_UsbOhci_l460; + wire when_UsbOhci_l460_1; + wire when_UsbOhci_l460_2; + wire when_UsbOhci_l461; + wire when_UsbOhci_l461_1; + wire when_UsbOhci_l462; + wire when_UsbOhci_l463; + wire when_UsbOhci_l464; + wire when_UsbOhci_l470; + reg reg_hcRhPortStatus_0_CCS_regNext; + wire io_phy_ports_0_suspend_fire; + wire io_phy_ports_0_reset_fire; + wire io_phy_ports_0_resume_fire; + reg frame_run; + reg frame_reload; + wire frame_overflow; + reg frame_tick; + wire frame_section1; + reg [14:0] frame_limitCounter; + wire frame_limitHit; + reg [2:0] frame_decrementTimer; + wire frame_decrementTimerOverflow; + wire when_UsbOhci_l526; + wire when_UsbOhci_l528; + wire when_UsbOhci_l540; + reg token_wantExit; + reg token_wantStart; + reg token_wantKill; + reg [3:0] token_pid; + reg [10:0] token_data; + reg dataTx_wantExit; + reg dataTx_wantStart; + reg dataTx_wantKill; + reg [3:0] dataTx_pid; + reg dataTx_data_valid; + reg dataTx_data_ready; + reg dataTx_data_payload_last; + reg [7:0] dataTx_data_payload_fragment; + wire dataTx_data_fire; + wire rxTimer_lowSpeed; + reg [7:0] rxTimer_counter; + reg rxTimer_clear; + wire rxTimer_rxTimeout; + wire rxTimer_ackTx; + wire rxPidOk; + wire _zz_1; + wire [7:0] _zz_dataRx_pid; + wire when_Misc_l87; + reg dataRx_wantExit; + reg dataRx_wantStart; + reg dataRx_wantKill; + reg [3:0] dataRx_pid; + reg dataRx_data_valid; + wire [7:0] dataRx_data_payload; + wire [7:0] dataRx_history_0; + wire [7:0] dataRx_history_1; + reg [7:0] _zz_dataRx_history_0; + reg [7:0] _zz_dataRx_history_1; + reg [1:0] dataRx_valids; + reg dataRx_notResponding; + reg dataRx_stuffingError; + reg dataRx_pidError; + reg dataRx_crcError; + wire dataRx_hasError; + reg sof_wantExit; + reg sof_wantStart; + reg sof_wantKill; + reg sof_doInterruptDelay; + reg priority_bulk; + reg [1:0] priority_counter; + reg priority_tick; + reg priority_skip; + wire when_UsbOhci_l663; + reg [2:0] interruptDelay_counter; + reg interruptDelay_tick; + wire interruptDelay_done; + wire interruptDelay_disabled; + reg interruptDelay_disable; + reg interruptDelay_load_valid; + reg [2:0] interruptDelay_load_payload; + wire when_UsbOhci_l685; + wire when_UsbOhci_l689; + reg endpoint_wantExit; + reg endpoint_wantStart; + reg endpoint_wantKill; + reg [1:0] endpoint_flowType; + reg [0:0] endpoint_status_1; + reg endpoint_dataPhase; + reg [31:0] endpoint_ED_address; + reg [31:0] endpoint_ED_words_0; + reg [31:0] endpoint_ED_words_1; + reg [31:0] endpoint_ED_words_2; + reg [31:0] endpoint_ED_words_3; + wire [6:0] endpoint_ED_FA; + wire [3:0] endpoint_ED_EN; + wire [1:0] endpoint_ED_D; + wire endpoint_ED_S; + wire endpoint_ED_K; + wire endpoint_ED_F; + wire [10:0] endpoint_ED_MPS; + wire [27:0] endpoint_ED_tailP; + wire endpoint_ED_H; + wire endpoint_ED_C; + wire [27:0] endpoint_ED_headP; + wire [27:0] endpoint_ED_nextED; + wire endpoint_ED_tdEmpty; + wire endpoint_ED_isFs; + wire endpoint_ED_isoOut; + wire when_UsbOhci_l750; + wire [31:0] endpoint_TD_address; + reg [31:0] endpoint_TD_words_0; + reg [31:0] endpoint_TD_words_1; + reg [31:0] endpoint_TD_words_2; + reg [31:0] endpoint_TD_words_3; + wire [3:0] endpoint_TD_CC; + wire [1:0] endpoint_TD_EC; + wire [1:0] endpoint_TD_T; + wire [2:0] endpoint_TD_DI; + wire [1:0] endpoint_TD_DP; + wire endpoint_TD_R; + wire [31:0] endpoint_TD_CBP; + wire [27:0] endpoint_TD_nextTD; + wire [31:0] endpoint_TD_BE; + wire [2:0] endpoint_TD_FC; + wire [15:0] endpoint_TD_SF; + wire [15:0] endpoint_TD_isoRelativeFrameNumber; + wire endpoint_TD_tooEarly; + wire [2:0] endpoint_TD_isoFrameNumber; + wire endpoint_TD_isoOverrun; + reg endpoint_TD_isoOverrunReg; + wire endpoint_TD_isoLast; + reg [12:0] endpoint_TD_isoBase; + reg [12:0] endpoint_TD_isoBaseNext; + reg endpoint_TD_isoZero; + reg endpoint_TD_isoLastReg; + reg endpoint_TD_tooEarlyReg; + wire endpoint_TD_isSinglePage; + wire [12:0] endpoint_TD_firstOffset; + reg [12:0] endpoint_TD_lastOffset; + wire endpoint_TD_allowRounding; + reg endpoint_TD_retire; + reg endpoint_TD_upateCBP; + reg endpoint_TD_noUpdate; + reg endpoint_TD_dataPhaseUpdate; + wire [1:0] endpoint_TD_TNext; + wire endpoint_TD_dataPhaseNext; + wire [3:0] endpoint_TD_dataPid; + wire [3:0] endpoint_TD_dataPidWrong; + reg endpoint_TD_clear; + wire [1:0] endpoint_tockenType; + wire endpoint_isIn; + reg endpoint_applyNextED; + reg [13:0] endpoint_currentAddress; + wire [31:0] endpoint_currentAddressFull; + reg [31:0] _zz_endpoint_currentAddressBmb; + wire [31:0] endpoint_currentAddressBmb; + reg [12:0] endpoint_lastAddress; + wire [13:0] endpoint_transactionSizeMinusOne; + wire [13:0] endpoint_transactionSize; + reg endpoint_zeroLength; + wire endpoint_dataDone; + reg endpoint_dmaLogic_wantExit; + reg endpoint_dmaLogic_wantStart; + reg endpoint_dmaLogic_wantKill; + reg endpoint_dmaLogic_validated; + reg [5:0] endpoint_dmaLogic_length; + wire [5:0] endpoint_dmaLogic_lengthMax; + wire [5:0] endpoint_dmaLogic_lengthCalc; + wire [4:0] endpoint_dmaLogic_beatCount; + wire [5:0] endpoint_dmaLogic_lengthBmb; + reg [10:0] endpoint_dmaLogic_fromUsbCounter; + reg endpoint_dmaLogic_overflow; + reg endpoint_dmaLogic_underflow; + wire endpoint_dmaLogic_underflowError; + wire when_UsbOhci_l938; + reg [12:0] endpoint_dmaLogic_byteCtx_counter; + wire endpoint_dmaLogic_byteCtx_last; + wire [1:0] endpoint_dmaLogic_byteCtx_sel; + reg endpoint_dmaLogic_byteCtx_increment; + wire [3:0] endpoint_dmaLogic_headMask; + wire [3:0] endpoint_dmaLogic_lastMask; + wire [3:0] endpoint_dmaLogic_fullMask; + wire endpoint_dmaLogic_beatLast; + reg [31:0] endpoint_dmaLogic_buffer; + reg endpoint_dmaLogic_push; + wire endpoint_dmaLogic_fsmStopped; + wire [13:0] endpoint_byteCountCalc; + wire endpoint_fsTimeCheck; + wire endpoint_timeCheck; + reg endpoint_ackRxFired; + reg endpoint_ackRxActivated; + reg endpoint_ackRxPidFailure; + reg endpoint_ackRxStuffing; + reg [3:0] endpoint_ackRxPid; + wire [31:0] endpoint_tdUpdateAddress; + reg operational_wantExit; + reg operational_wantStart; + reg operational_wantKill; + reg operational_periodicHeadFetched; + reg operational_periodicDone; + reg operational_allowBulk; + reg operational_allowControl; + reg operational_allowPeriodic; + reg operational_allowIsochronous; + reg operational_askExit; + wire hc_wantExit; + reg hc_wantStart; + wire hc_wantKill; + reg hc_error; + wire hc_operationalIsDone; + wire [1:0] _zz_reg_hcControl_HCFSWrite_payload; + wire when_BusSlaveFactory_l968; + wire when_BusSlaveFactory_l968_1; + wire when_BusSlaveFactory_l968_2; + wire when_BusSlaveFactory_l968_3; + wire when_BusSlaveFactory_l968_4; + wire when_BusSlaveFactory_l968_5; + wire when_BusSlaveFactory_l968_6; + wire when_BusSlaveFactory_l968_7; + wire when_BusSlaveFactory_l968_8; + wire when_BusSlaveFactory_l968_9; + wire when_BusSlaveFactory_l968_10; + wire when_BusSlaveFactory_l968_11; + wire when_BusSlaveFactory_l968_12; + wire when_BusSlaveFactory_l968_13; + wire when_BusSlaveFactory_l968_14; + wire when_BusSlaveFactory_l968_15; + wire when_BusSlaveFactory_l968_16; + wire when_BusSlaveFactory_l968_17; + wire when_BusSlaveFactory_l968_18; + wire when_BusSlaveFactory_l968_19; + wire when_BusSlaveFactory_l968_20; + wire when_BusSlaveFactory_l968_21; + wire when_BusSlaveFactory_l968_22; + wire when_BusSlaveFactory_l968_23; + wire when_BusSlaveFactory_l968_24; + wire when_BusSlaveFactory_l968_25; + wire when_BusSlaveFactory_l968_26; + wire when_BusSlaveFactory_l968_27; + wire when_BusSlaveFactory_l968_28; + wire when_BusSlaveFactory_l968_29; + wire when_BusSlaveFactory_l968_30; + wire when_BusSlaveFactory_l968_31; + wire when_BusSlaveFactory_l968_32; + wire when_BusSlaveFactory_l968_33; + wire when_BusSlaveFactory_l968_34; + wire when_BusSlaveFactory_l968_35; + wire when_BusSlaveFactory_l968_36; + wire when_BusSlaveFactory_l968_37; + wire when_BusSlaveFactory_l968_38; + wire when_BusSlaveFactory_l968_39; + wire when_BusSlaveFactory_l968_40; + wire when_BusSlaveFactory_l968_41; + wire when_BusSlaveFactory_l968_42; + wire when_BusSlaveFactory_l968_43; + wire when_BusSlaveFactory_l968_44; + wire when_BusSlaveFactory_l968_45; + wire when_BusSlaveFactory_l968_46; + reg _zz_when_UsbOhci_l253; + wire when_UsbOhci_l253; + reg [2:0] token_stateReg; + reg [2:0] token_stateNext; + wire when_StateMachine_l237; + wire unscheduleAll_fire; + reg [2:0] dataTx_stateReg; + reg [2:0] dataTx_stateNext; + reg [1:0] dataRx_stateReg; + reg [1:0] dataRx_stateNext; + wire when_Misc_l64; + wire when_Misc_l70; + wire when_Misc_l71; + wire when_Misc_l78; + wire when_StateMachine_l253; + wire when_Misc_l85; + reg [1:0] sof_stateReg; + reg [1:0] sof_stateNext; + wire when_UsbOhci_l206; + wire when_UsbOhci_l206_1; + wire when_UsbOhci_l626; + wire when_StateMachine_l237_1; + reg [4:0] endpoint_stateReg; + reg [4:0] endpoint_stateNext; + wire when_UsbOhci_l1128; + wire when_UsbOhci_l1311; + wire when_UsbOhci_l188; + wire when_UsbOhci_l188_1; + wire when_UsbOhci_l188_2; + wire when_UsbOhci_l188_3; + wire when_UsbOhci_l855; + wire when_UsbOhci_l861; + wire when_UsbOhci_l188_4; + wire when_UsbOhci_l188_5; + wire when_UsbOhci_l188_6; + wire when_UsbOhci_l188_7; + wire when_UsbOhci_l891; + wire when_UsbOhci_l188_8; + wire when_UsbOhci_l188_9; + wire when_UsbOhci_l891_1; + wire when_UsbOhci_l188_10; + wire when_UsbOhci_l188_11; + wire when_UsbOhci_l891_2; + wire when_UsbOhci_l188_12; + wire when_UsbOhci_l188_13; + wire when_UsbOhci_l891_3; + wire when_UsbOhci_l188_14; + wire when_UsbOhci_l188_15; + wire when_UsbOhci_l891_4; + wire when_UsbOhci_l188_16; + wire when_UsbOhci_l188_17; + wire when_UsbOhci_l891_5; + wire when_UsbOhci_l188_18; + wire when_UsbOhci_l188_19; + wire when_UsbOhci_l891_6; + wire when_UsbOhci_l188_20; + wire when_UsbOhci_l188_21; + wire when_UsbOhci_l891_7; + wire when_UsbOhci_l188_22; + wire when_UsbOhci_l898; + wire [13:0] _zz_endpoint_lastAddress; + wire when_UsbOhci_l1118; + reg when_UsbOhci_l1274; + wire when_UsbOhci_l1263; + wire when_UsbOhci_l1283; + wire when_UsbOhci_l1200; + wire when_UsbOhci_l1205; + wire when_UsbOhci_l1207; + wire when_UsbOhci_l1331; + wire when_UsbOhci_l1346; + wire when_UsbOhci_l206_2; + wire when_UsbOhci_l206_3; + wire [15:0] _zz_ioDma_cmd_payload_fragment_data; + wire when_UsbOhci_l1378; + wire when_UsbOhci_l206_4; + wire when_UsbOhci_l1378_1; + wire when_UsbOhci_l206_5; + wire when_UsbOhci_l1378_2; + wire when_UsbOhci_l206_6; + wire when_UsbOhci_l1378_3; + wire when_UsbOhci_l206_7; + wire when_UsbOhci_l1378_4; + wire when_UsbOhci_l206_8; + wire when_UsbOhci_l1378_5; + wire when_UsbOhci_l206_9; + wire when_UsbOhci_l1378_6; + wire when_UsbOhci_l206_10; + wire when_UsbOhci_l1378_7; + wire when_UsbOhci_l206_11; + wire when_UsbOhci_l206_12; + wire when_UsbOhci_l206_13; + wire when_UsbOhci_l206_14; + wire when_UsbOhci_l1393; + wire when_UsbOhci_l206_15; + wire when_UsbOhci_l1408; + wire when_UsbOhci_l1415; + wire when_UsbOhci_l1418; + wire when_StateMachine_l237_2; + wire when_StateMachine_l253_1; + wire when_StateMachine_l253_2; + wire when_StateMachine_l253_3; + wire when_StateMachine_l253_4; + reg [2:0] endpoint_dmaLogic_stateReg; + reg [2:0] endpoint_dmaLogic_stateNext; + wire when_UsbOhci_l1025; + wire when_UsbOhci_l1054; + wire [3:0] _zz_2; + wire when_UsbOhci_l1063; + wire when_UsbOhci_l1068; + reg ioDma_cmd_payload_first; + wire when_StateMachine_l253_5; + reg [2:0] operational_stateReg; + reg [2:0] operational_stateNext; + wire when_UsbOhci_l1461; + wire when_UsbOhci_l1488; + wire when_UsbOhci_l1487; + wire when_StateMachine_l237_3; + wire when_StateMachine_l253_6; + reg [2:0] hc_stateReg; + reg [2:0] hc_stateNext; + wire when_UsbOhci_l1616; + wire when_UsbOhci_l1625; + wire when_UsbOhci_l1628; + wire when_UsbOhci_l1639; + wire when_UsbOhci_l1652; + wire when_StateMachine_l253_7; + wire when_StateMachine_l253_8; + wire when_StateMachine_l253_9; + wire when_UsbOhci_l1659; + `ifndef SYNTHESIS + reg [87:0] reg_hcControl_HCFS_string; + reg [87:0] reg_hcControl_HCFSWrite_payload_string; + reg [63:0] endpoint_flowType_string; + reg [79:0] endpoint_status_1_string; + reg [87:0] _zz_reg_hcControl_HCFSWrite_payload_string; + reg [31:0] token_stateReg_string; + reg [31:0] token_stateNext_string; + reg [39:0] dataTx_stateReg_string; + reg [39:0] dataTx_stateNext_string; + reg [31:0] dataRx_stateReg_string; + reg [31:0] dataRx_stateNext_string; + reg [127:0] sof_stateReg_string; + reg [127:0] sof_stateNext_string; + reg [135:0] endpoint_stateReg_string; + reg [135:0] endpoint_stateNext_string; + reg [79:0] endpoint_dmaLogic_stateReg_string; + reg [79:0] endpoint_dmaLogic_stateNext_string; + reg [135:0] operational_stateReg_string; + reg [135:0] operational_stateNext_string; + reg [111:0] hc_stateReg_string; + reg [111:0] hc_stateNext_string; + `endif + + function [31:0] zz__zz_endpoint_currentAddressBmb(input dummy); + begin + zz__zz_endpoint_currentAddressBmb = 32'hffffffff; + zz__zz_endpoint_currentAddressBmb[1 : 0] = 2'b00; + end + endfunction + wire [31:0] _zz_3; + + assign _zz_dmaCtx_pendingCounter = (dmaCtx_pendingCounter + _zz_dmaCtx_pendingCounter_1); + assign _zz_dmaCtx_pendingCounter_2 = (ioDma_cmd_fire && ioDma_cmd_payload_last); + assign _zz_dmaCtx_pendingCounter_1 = {3'd0, _zz_dmaCtx_pendingCounter_2}; + assign _zz_dmaCtx_pendingCounter_4 = (ioDma_rsp_fire && ioDma_rsp_payload_last); + assign _zz_dmaCtx_pendingCounter_3 = {3'd0, _zz_dmaCtx_pendingCounter_4}; + assign _zz_reg_hcCommandStatus_startSoftReset = 1'b1; + assign _zz_reg_hcCommandStatus_CLF = 1'b1; + assign _zz_reg_hcCommandStatus_BLF = 1'b1; + assign _zz_reg_hcCommandStatus_OCR = 1'b1; + assign _zz_reg_hcInterrupt_MIE = 1'b1; + assign _zz_reg_hcInterrupt_MIE_1 = 1'b0; + assign _zz_reg_hcInterrupt_SO_status = 1'b0; + assign _zz_reg_hcInterrupt_SO_enable = 1'b1; + assign _zz_reg_hcInterrupt_SO_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_WDH_status = 1'b0; + assign _zz_reg_hcInterrupt_WDH_enable = 1'b1; + assign _zz_reg_hcInterrupt_WDH_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_SF_status = 1'b0; + assign _zz_reg_hcInterrupt_SF_enable = 1'b1; + assign _zz_reg_hcInterrupt_SF_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_RD_status = 1'b0; + assign _zz_reg_hcInterrupt_RD_enable = 1'b1; + assign _zz_reg_hcInterrupt_RD_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_UE_status = 1'b0; + assign _zz_reg_hcInterrupt_UE_enable = 1'b1; + assign _zz_reg_hcInterrupt_UE_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_FNO_status = 1'b0; + assign _zz_reg_hcInterrupt_FNO_enable = 1'b1; + assign _zz_reg_hcInterrupt_FNO_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_RHSC_status = 1'b0; + assign _zz_reg_hcInterrupt_RHSC_enable = 1'b1; + assign _zz_reg_hcInterrupt_RHSC_enable_1 = 1'b0; + assign _zz_reg_hcInterrupt_OC_status = 1'b0; + assign _zz_reg_hcInterrupt_OC_enable = 1'b1; + assign _zz_reg_hcInterrupt_OC_enable_1 = 1'b0; + assign _zz_reg_hcLSThreshold_hit = {2'd0, reg_hcLSThreshold_LST}; + assign _zz_reg_hcRhStatus_CCIC = 1'b0; + assign _zz_reg_hcRhStatus_clearGlobalPower = 1'b1; + assign _zz_reg_hcRhStatus_setRemoteWakeupEnable = 1'b1; + assign _zz_reg_hcRhStatus_setGlobalPower = 1'b1; + assign _zz_reg_hcRhStatus_clearRemoteWakeupEnable = 1'b1; + assign _zz_reg_hcRhPortStatus_0_clearPortEnable = 1'b1; + assign _zz_reg_hcRhPortStatus_0_setPortEnable = 1'b1; + assign _zz_reg_hcRhPortStatus_0_setPortSuspend = 1'b1; + assign _zz_reg_hcRhPortStatus_0_clearSuspendStatus = 1'b1; + assign _zz_reg_hcRhPortStatus_0_setPortReset = 1'b1; + assign _zz_reg_hcRhPortStatus_0_setPortPower = 1'b1; + assign _zz_reg_hcRhPortStatus_0_clearPortPower = 1'b1; + assign _zz_reg_hcRhPortStatus_0_CSC_clear = 1'b1; + assign _zz_reg_hcRhPortStatus_0_PESC_clear = 1'b1; + assign _zz_reg_hcRhPortStatus_0_PSSC_clear = 1'b1; + assign _zz_reg_hcRhPortStatus_0_OCIC_clear = 1'b1; + assign _zz_reg_hcRhPortStatus_0_PRSC_clear = 1'b1; + assign _zz_rxTimer_ackTx_1 = (rxTimer_lowSpeed ? 4'b1111 : 4'b0001); + assign _zz_rxTimer_ackTx = {4'd0, _zz_rxTimer_ackTx_1}; + assign _zz_endpoint_TD_isoOverrun = {13'd0, endpoint_TD_FC}; + assign _zz_endpoint_TD_firstOffset_1 = endpoint_TD_CBP[11 : 0]; + assign _zz_endpoint_TD_firstOffset = {1'd0, _zz_endpoint_TD_firstOffset_1}; + assign _zz_endpoint_TD_lastOffset = (endpoint_TD_isoBaseNext - _zz_endpoint_TD_lastOffset_1); + assign _zz_endpoint_TD_lastOffset_2 = (! endpoint_TD_isoLast); + assign _zz_endpoint_TD_lastOffset_1 = {12'd0, _zz_endpoint_TD_lastOffset_2}; + assign _zz_endpoint_transactionSizeMinusOne = {1'd0, endpoint_lastAddress}; + assign _zz_endpoint_dataDone = {1'd0, endpoint_lastAddress}; + assign _zz_endpoint_dmaLogic_lengthMax = endpoint_currentAddress[5:0]; + assign _zz_endpoint_dmaLogic_lengthCalc = ((endpoint_transactionSizeMinusOne < _zz_endpoint_dmaLogic_lengthCalc_1) ? endpoint_transactionSizeMinusOne : _zz_endpoint_dmaLogic_lengthCalc_2); + assign _zz_endpoint_dmaLogic_lengthCalc_1 = {8'd0, endpoint_dmaLogic_lengthMax}; + assign _zz_endpoint_dmaLogic_lengthCalc_2 = {8'd0, endpoint_dmaLogic_lengthMax}; + assign _zz_endpoint_dmaLogic_beatCount = ({1'b0,endpoint_dmaLogic_length} + _zz_endpoint_dmaLogic_beatCount_1); + assign _zz_endpoint_dmaLogic_beatCount_2 = endpoint_currentAddressFull[1 : 0]; + assign _zz_endpoint_dmaLogic_beatCount_1 = {5'd0, _zz_endpoint_dmaLogic_beatCount_2}; + assign _zz_endpoint_dmaLogic_lengthBmb = {endpoint_dmaLogic_beatCount,2'b11}; + assign _zz_endpoint_dmaLogic_lastMask = (endpoint_currentAddress + _zz_endpoint_dmaLogic_lastMask_1); + assign _zz_endpoint_dmaLogic_lastMask_1 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_endpoint_dmaLogic_lastMask_2 = (endpoint_currentAddress + _zz_endpoint_dmaLogic_lastMask_3); + assign _zz_endpoint_dmaLogic_lastMask_3 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_endpoint_dmaLogic_lastMask_4 = (endpoint_currentAddress + _zz_endpoint_dmaLogic_lastMask_5); + assign _zz_endpoint_dmaLogic_lastMask_5 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_endpoint_dmaLogic_lastMask_6 = (endpoint_currentAddress + _zz_endpoint_dmaLogic_lastMask_7); + assign _zz_endpoint_dmaLogic_lastMask_7 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_endpoint_dmaLogic_beatLast = {1'd0, endpoint_dmaLogic_beatCount}; + assign _zz_endpoint_byteCountCalc = (_zz_endpoint_byteCountCalc_1 - endpoint_currentAddress); + assign _zz_endpoint_byteCountCalc_1 = {1'd0, endpoint_lastAddress}; + assign _zz_endpoint_fsTimeCheck = {2'd0, frame_limitCounter}; + assign _zz_endpoint_fsTimeCheck_1 = ({3'd0,endpoint_byteCountCalc} <<< 2'd3); + assign _zz_token_data = reg_hcFmNumber_FN; + assign _zz_ioDma_cmd_payload_fragment_length = (endpoint_ED_F ? 5'h1f : 5'h0f); + assign _zz__zz_endpoint_lastAddress = ({1'b0,endpoint_TD_firstOffset} + _zz__zz_endpoint_lastAddress_1); + assign _zz__zz_endpoint_lastAddress_2 = {1'b0,endpoint_ED_MPS}; + assign _zz__zz_endpoint_lastAddress_1 = {2'd0, _zz__zz_endpoint_lastAddress_2}; + assign _zz_endpoint_lastAddress_1 = (endpoint_ED_F ? _zz_endpoint_lastAddress_2 : ((_zz_endpoint_lastAddress_3 < _zz_endpoint_lastAddress) ? _zz_endpoint_lastAddress_4 : _zz_endpoint_lastAddress)); + assign _zz_endpoint_lastAddress_2 = {1'd0, endpoint_TD_lastOffset}; + assign _zz_endpoint_lastAddress_3 = {1'd0, endpoint_TD_lastOffset}; + assign _zz_endpoint_lastAddress_4 = {1'd0, endpoint_TD_lastOffset}; + assign _zz_when_UsbOhci_l1331 = {1'd0, endpoint_TD_lastOffset}; + assign _zz_endpoint_TD_words_0 = (endpoint_TD_EC + 2'b01); + assign _zz_ioDma_cmd_payload_fragment_length_1 = (endpoint_ED_F ? 5'h1f : 5'h0f); + assign _zz_ioDma_cmd_payload_last_1 = (endpoint_ED_F ? 3'b111 : 3'b011); + assign _zz_ioDma_cmd_payload_last = {1'd0, _zz_ioDma_cmd_payload_last_1}; + assign _zz__zz_ioDma_cmd_payload_fragment_data_1 = (endpoint_ED_isoOut ? 14'h0000 : _zz__zz_ioDma_cmd_payload_fragment_data_2); + assign _zz__zz_ioDma_cmd_payload_fragment_data = _zz__zz_ioDma_cmd_payload_fragment_data_1[11:0]; + assign _zz__zz_ioDma_cmd_payload_fragment_data_2 = (endpoint_currentAddress - _zz__zz_ioDma_cmd_payload_fragment_data_3); + assign _zz__zz_ioDma_cmd_payload_fragment_data_3 = {1'd0, endpoint_TD_isoBase}; + assign _zz_when_UsbOhci_l1054 = {3'd0, endpoint_dmaLogic_fromUsbCounter}; + assign _zz_endpoint_dmaLogic_overflow = {3'd0, endpoint_dmaLogic_fromUsbCounter}; + assign _zz_endpoint_lastAddress_5 = (_zz_endpoint_lastAddress_6 - 14'h0001); + assign _zz_endpoint_lastAddress_6 = (endpoint_currentAddress + _zz_endpoint_lastAddress_7); + assign _zz_endpoint_lastAddress_7 = {3'd0, endpoint_dmaLogic_fromUsbCounter}; + assign _zz_endpoint_dmaLogic_fromUsbCounter_1 = (! endpoint_dmaLogic_fromUsbCounter[10]); + assign _zz_endpoint_dmaLogic_fromUsbCounter = {10'd0, _zz_endpoint_dmaLogic_fromUsbCounter_1}; + assign _zz_endpoint_currentAddress = (endpoint_currentAddress + _zz_endpoint_currentAddress_1); + assign _zz_endpoint_currentAddress_1 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_endpoint_currentAddress_2 = (endpoint_currentAddress + _zz_endpoint_currentAddress_3); + assign _zz_endpoint_currentAddress_3 = {8'd0, endpoint_dmaLogic_length}; + assign _zz_ioDma_cmd_payload_fragment_address_1 = ({2'd0,reg_hcFmNumber_FN[4 : 0]} <<< 2'd2); + assign _zz_ioDma_cmd_payload_fragment_address = {25'd0, _zz_ioDma_cmd_payload_fragment_address_1}; + UsbOhciAxi4_StreamFifo fifo ( + .io_push_valid (fifo_io_push_valid ), //i + .io_push_ready (fifo_io_push_ready ), //o + .io_push_payload (fifo_io_push_payload[31:0]), //i + .io_pop_valid (fifo_io_pop_valid ), //o + .io_pop_ready (fifo_io_pop_ready ), //i + .io_pop_payload (fifo_io_pop_payload[31:0] ), //o + .io_flush (fifo_io_flush ), //i + .io_occupancy (fifo_io_occupancy[9:0] ), //o + .io_availability (fifo_io_availability[9:0] ), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_Crc token_crc5 ( + .io_flush (token_crc5_io_flush ), //i + .io_input_valid (token_crc5_io_input_valid ), //i + .io_input_payload (token_data[10:0] ), //i + .io_result (token_crc5_io_result[4:0] ), //o + .io_resultNext (token_crc5_io_resultNext[4:0]), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_Crc_1 dataTx_crc16 ( + .io_flush (dataTx_crc16_io_flush ), //i + .io_input_valid (dataTx_data_fire ), //i + .io_input_payload (dataTx_data_payload_fragment[7:0]), //i + .io_result (dataTx_crc16_io_result[15:0] ), //o + .io_resultNext (dataTx_crc16_io_resultNext[15:0] ), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_Crc_2 dataRx_crc16 ( + .io_flush (dataRx_crc16_io_flush ), //i + .io_input_valid (dataRx_crc16_io_input_valid ), //i + .io_input_payload (_zz_dataRx_pid[7:0] ), //i + .io_result (dataRx_crc16_io_result[15:0] ), //o + .io_resultNext (dataRx_crc16_io_resultNext[15:0]), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + always @(*) begin + case(endpoint_dmaLogic_byteCtx_sel) + 2'b00 : _zz_dataTx_data_payload_fragment = fifo_io_pop_payload[7 : 0]; + 2'b01 : _zz_dataTx_data_payload_fragment = fifo_io_pop_payload[15 : 8]; + 2'b10 : _zz_dataTx_data_payload_fragment = fifo_io_pop_payload[23 : 16]; + default : _zz_dataTx_data_payload_fragment = fifo_io_pop_payload[31 : 24]; + endcase + end + + `ifndef SYNTHESIS + always @(*) begin + case(reg_hcControl_HCFS) + UsbOhciAxi4_MainState_RESET : reg_hcControl_HCFS_string = "RESET "; + UsbOhciAxi4_MainState_RESUME : reg_hcControl_HCFS_string = "RESUME "; + UsbOhciAxi4_MainState_OPERATIONAL : reg_hcControl_HCFS_string = "OPERATIONAL"; + UsbOhciAxi4_MainState_SUSPEND : reg_hcControl_HCFS_string = "SUSPEND "; + default : reg_hcControl_HCFS_string = "???????????"; + endcase + end + always @(*) begin + case(reg_hcControl_HCFSWrite_payload) + UsbOhciAxi4_MainState_RESET : reg_hcControl_HCFSWrite_payload_string = "RESET "; + UsbOhciAxi4_MainState_RESUME : reg_hcControl_HCFSWrite_payload_string = "RESUME "; + UsbOhciAxi4_MainState_OPERATIONAL : reg_hcControl_HCFSWrite_payload_string = "OPERATIONAL"; + UsbOhciAxi4_MainState_SUSPEND : reg_hcControl_HCFSWrite_payload_string = "SUSPEND "; + default : reg_hcControl_HCFSWrite_payload_string = "???????????"; + endcase + end + always @(*) begin + case(endpoint_flowType) + UsbOhciAxi4_FlowType_BULK : endpoint_flowType_string = "BULK "; + UsbOhciAxi4_FlowType_CONTROL : endpoint_flowType_string = "CONTROL "; + UsbOhciAxi4_FlowType_PERIODIC : endpoint_flowType_string = "PERIODIC"; + default : endpoint_flowType_string = "????????"; + endcase + end + always @(*) begin + case(endpoint_status_1) + UsbOhciAxi4_endpoint_Status_OK : endpoint_status_1_string = "OK "; + UsbOhciAxi4_endpoint_Status_FRAME_TIME : endpoint_status_1_string = "FRAME_TIME"; + default : endpoint_status_1_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_reg_hcControl_HCFSWrite_payload) + UsbOhciAxi4_MainState_RESET : _zz_reg_hcControl_HCFSWrite_payload_string = "RESET "; + UsbOhciAxi4_MainState_RESUME : _zz_reg_hcControl_HCFSWrite_payload_string = "RESUME "; + UsbOhciAxi4_MainState_OPERATIONAL : _zz_reg_hcControl_HCFSWrite_payload_string = "OPERATIONAL"; + UsbOhciAxi4_MainState_SUSPEND : _zz_reg_hcControl_HCFSWrite_payload_string = "SUSPEND "; + default : _zz_reg_hcControl_HCFSWrite_payload_string = "???????????"; + endcase + end + always @(*) begin + case(token_stateReg) + UsbOhciAxi4_token_enumDef_BOOT : token_stateReg_string = "BOOT"; + UsbOhciAxi4_token_enumDef_INIT : token_stateReg_string = "INIT"; + UsbOhciAxi4_token_enumDef_PID : token_stateReg_string = "PID "; + UsbOhciAxi4_token_enumDef_B1 : token_stateReg_string = "B1 "; + UsbOhciAxi4_token_enumDef_B2 : token_stateReg_string = "B2 "; + UsbOhciAxi4_token_enumDef_EOP : token_stateReg_string = "EOP "; + default : token_stateReg_string = "????"; + endcase + end + always @(*) begin + case(token_stateNext) + UsbOhciAxi4_token_enumDef_BOOT : token_stateNext_string = "BOOT"; + UsbOhciAxi4_token_enumDef_INIT : token_stateNext_string = "INIT"; + UsbOhciAxi4_token_enumDef_PID : token_stateNext_string = "PID "; + UsbOhciAxi4_token_enumDef_B1 : token_stateNext_string = "B1 "; + UsbOhciAxi4_token_enumDef_B2 : token_stateNext_string = "B2 "; + UsbOhciAxi4_token_enumDef_EOP : token_stateNext_string = "EOP "; + default : token_stateNext_string = "????"; + endcase + end + always @(*) begin + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_BOOT : dataTx_stateReg_string = "BOOT "; + UsbOhciAxi4_dataTx_enumDef_PID : dataTx_stateReg_string = "PID "; + UsbOhciAxi4_dataTx_enumDef_DATA : dataTx_stateReg_string = "DATA "; + UsbOhciAxi4_dataTx_enumDef_CRC_0 : dataTx_stateReg_string = "CRC_0"; + UsbOhciAxi4_dataTx_enumDef_CRC_1 : dataTx_stateReg_string = "CRC_1"; + UsbOhciAxi4_dataTx_enumDef_EOP : dataTx_stateReg_string = "EOP "; + default : dataTx_stateReg_string = "?????"; + endcase + end + always @(*) begin + case(dataTx_stateNext) + UsbOhciAxi4_dataTx_enumDef_BOOT : dataTx_stateNext_string = "BOOT "; + UsbOhciAxi4_dataTx_enumDef_PID : dataTx_stateNext_string = "PID "; + UsbOhciAxi4_dataTx_enumDef_DATA : dataTx_stateNext_string = "DATA "; + UsbOhciAxi4_dataTx_enumDef_CRC_0 : dataTx_stateNext_string = "CRC_0"; + UsbOhciAxi4_dataTx_enumDef_CRC_1 : dataTx_stateNext_string = "CRC_1"; + UsbOhciAxi4_dataTx_enumDef_EOP : dataTx_stateNext_string = "EOP "; + default : dataTx_stateNext_string = "?????"; + endcase + end + always @(*) begin + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_BOOT : dataRx_stateReg_string = "BOOT"; + UsbOhciAxi4_dataRx_enumDef_IDLE : dataRx_stateReg_string = "IDLE"; + UsbOhciAxi4_dataRx_enumDef_PID : dataRx_stateReg_string = "PID "; + UsbOhciAxi4_dataRx_enumDef_DATA : dataRx_stateReg_string = "DATA"; + default : dataRx_stateReg_string = "????"; + endcase + end + always @(*) begin + case(dataRx_stateNext) + UsbOhciAxi4_dataRx_enumDef_BOOT : dataRx_stateNext_string = "BOOT"; + UsbOhciAxi4_dataRx_enumDef_IDLE : dataRx_stateNext_string = "IDLE"; + UsbOhciAxi4_dataRx_enumDef_PID : dataRx_stateNext_string = "PID "; + UsbOhciAxi4_dataRx_enumDef_DATA : dataRx_stateNext_string = "DATA"; + default : dataRx_stateNext_string = "????"; + endcase + end + always @(*) begin + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_BOOT : sof_stateReg_string = "BOOT "; + UsbOhciAxi4_sof_enumDef_FRAME_TX : sof_stateReg_string = "FRAME_TX "; + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : sof_stateReg_string = "FRAME_NUMBER_CMD"; + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : sof_stateReg_string = "FRAME_NUMBER_RSP"; + default : sof_stateReg_string = "????????????????"; + endcase + end + always @(*) begin + case(sof_stateNext) + UsbOhciAxi4_sof_enumDef_BOOT : sof_stateNext_string = "BOOT "; + UsbOhciAxi4_sof_enumDef_FRAME_TX : sof_stateNext_string = "FRAME_TX "; + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : sof_stateNext_string = "FRAME_NUMBER_CMD"; + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : sof_stateNext_string = "FRAME_NUMBER_RSP"; + default : sof_stateNext_string = "????????????????"; + endcase + end + always @(*) begin + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_BOOT : endpoint_stateReg_string = "BOOT "; + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : endpoint_stateReg_string = "ED_READ_CMD "; + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : endpoint_stateReg_string = "ED_READ_RSP "; + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : endpoint_stateReg_string = "ED_ANALYSE "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : endpoint_stateReg_string = "TD_READ_CMD "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : endpoint_stateReg_string = "TD_READ_RSP "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : endpoint_stateReg_string = "TD_READ_DELAY "; + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : endpoint_stateReg_string = "TD_ANALYSE "; + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : endpoint_stateReg_string = "TD_CHECK_TIME "; + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : endpoint_stateReg_string = "BUFFER_READ "; + UsbOhciAxi4_endpoint_enumDef_TOKEN : endpoint_stateReg_string = "TOKEN "; + UsbOhciAxi4_endpoint_enumDef_DATA_TX : endpoint_stateReg_string = "DATA_TX "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX : endpoint_stateReg_string = "DATA_RX "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : endpoint_stateReg_string = "DATA_RX_VALIDATE "; + UsbOhciAxi4_endpoint_enumDef_ACK_RX : endpoint_stateReg_string = "ACK_RX "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : endpoint_stateReg_string = "ACK_TX_0 "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : endpoint_stateReg_string = "ACK_TX_1 "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : endpoint_stateReg_string = "ACK_TX_EOP "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : endpoint_stateReg_string = "DATA_RX_WAIT_DMA "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : endpoint_stateReg_string = "UPDATE_TD_PROCESS"; + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : endpoint_stateReg_string = "UPDATE_TD_CMD "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : endpoint_stateReg_string = "UPDATE_ED_CMD "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : endpoint_stateReg_string = "UPDATE_SYNC "; + UsbOhciAxi4_endpoint_enumDef_ABORD : endpoint_stateReg_string = "ABORD "; + default : endpoint_stateReg_string = "?????????????????"; + endcase + end + always @(*) begin + case(endpoint_stateNext) + UsbOhciAxi4_endpoint_enumDef_BOOT : endpoint_stateNext_string = "BOOT "; + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : endpoint_stateNext_string = "ED_READ_CMD "; + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : endpoint_stateNext_string = "ED_READ_RSP "; + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : endpoint_stateNext_string = "ED_ANALYSE "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : endpoint_stateNext_string = "TD_READ_CMD "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : endpoint_stateNext_string = "TD_READ_RSP "; + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : endpoint_stateNext_string = "TD_READ_DELAY "; + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : endpoint_stateNext_string = "TD_ANALYSE "; + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : endpoint_stateNext_string = "TD_CHECK_TIME "; + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : endpoint_stateNext_string = "BUFFER_READ "; + UsbOhciAxi4_endpoint_enumDef_TOKEN : endpoint_stateNext_string = "TOKEN "; + UsbOhciAxi4_endpoint_enumDef_DATA_TX : endpoint_stateNext_string = "DATA_TX "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX : endpoint_stateNext_string = "DATA_RX "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : endpoint_stateNext_string = "DATA_RX_VALIDATE "; + UsbOhciAxi4_endpoint_enumDef_ACK_RX : endpoint_stateNext_string = "ACK_RX "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : endpoint_stateNext_string = "ACK_TX_0 "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : endpoint_stateNext_string = "ACK_TX_1 "; + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : endpoint_stateNext_string = "ACK_TX_EOP "; + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : endpoint_stateNext_string = "DATA_RX_WAIT_DMA "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : endpoint_stateNext_string = "UPDATE_TD_PROCESS"; + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : endpoint_stateNext_string = "UPDATE_TD_CMD "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : endpoint_stateNext_string = "UPDATE_ED_CMD "; + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : endpoint_stateNext_string = "UPDATE_SYNC "; + UsbOhciAxi4_endpoint_enumDef_ABORD : endpoint_stateNext_string = "ABORD "; + default : endpoint_stateNext_string = "?????????????????"; + endcase + end + always @(*) begin + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT : endpoint_dmaLogic_stateReg_string = "BOOT "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : endpoint_dmaLogic_stateReg_string = "INIT "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : endpoint_dmaLogic_stateReg_string = "TO_USB "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : endpoint_dmaLogic_stateReg_string = "FROM_USB "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : endpoint_dmaLogic_stateReg_string = "VALIDATION"; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : endpoint_dmaLogic_stateReg_string = "CALC_CMD "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : endpoint_dmaLogic_stateReg_string = "READ_CMD "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : endpoint_dmaLogic_stateReg_string = "WRITE_CMD "; + default : endpoint_dmaLogic_stateReg_string = "??????????"; + endcase + end + always @(*) begin + case(endpoint_dmaLogic_stateNext) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT : endpoint_dmaLogic_stateNext_string = "BOOT "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : endpoint_dmaLogic_stateNext_string = "INIT "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : endpoint_dmaLogic_stateNext_string = "TO_USB "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : endpoint_dmaLogic_stateNext_string = "FROM_USB "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : endpoint_dmaLogic_stateNext_string = "VALIDATION"; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : endpoint_dmaLogic_stateNext_string = "CALC_CMD "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : endpoint_dmaLogic_stateNext_string = "READ_CMD "; + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : endpoint_dmaLogic_stateNext_string = "WRITE_CMD "; + default : endpoint_dmaLogic_stateNext_string = "??????????"; + endcase + end + always @(*) begin + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_BOOT : operational_stateReg_string = "BOOT "; + UsbOhciAxi4_operational_enumDef_SOF : operational_stateReg_string = "SOF "; + UsbOhciAxi4_operational_enumDef_ARBITER : operational_stateReg_string = "ARBITER "; + UsbOhciAxi4_operational_enumDef_END_POINT : operational_stateReg_string = "END_POINT "; + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : operational_stateReg_string = "PERIODIC_HEAD_CMD"; + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : operational_stateReg_string = "PERIODIC_HEAD_RSP"; + UsbOhciAxi4_operational_enumDef_WAIT_SOF : operational_stateReg_string = "WAIT_SOF "; + default : operational_stateReg_string = "?????????????????"; + endcase + end + always @(*) begin + case(operational_stateNext) + UsbOhciAxi4_operational_enumDef_BOOT : operational_stateNext_string = "BOOT "; + UsbOhciAxi4_operational_enumDef_SOF : operational_stateNext_string = "SOF "; + UsbOhciAxi4_operational_enumDef_ARBITER : operational_stateNext_string = "ARBITER "; + UsbOhciAxi4_operational_enumDef_END_POINT : operational_stateNext_string = "END_POINT "; + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : operational_stateNext_string = "PERIODIC_HEAD_CMD"; + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : operational_stateNext_string = "PERIODIC_HEAD_RSP"; + UsbOhciAxi4_operational_enumDef_WAIT_SOF : operational_stateNext_string = "WAIT_SOF "; + default : operational_stateNext_string = "?????????????????"; + endcase + end + always @(*) begin + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_BOOT : hc_stateReg_string = "BOOT "; + UsbOhciAxi4_hc_enumDef_RESET : hc_stateReg_string = "RESET "; + UsbOhciAxi4_hc_enumDef_RESUME : hc_stateReg_string = "RESUME "; + UsbOhciAxi4_hc_enumDef_OPERATIONAL : hc_stateReg_string = "OPERATIONAL "; + UsbOhciAxi4_hc_enumDef_SUSPEND : hc_stateReg_string = "SUSPEND "; + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : hc_stateReg_string = "ANY_TO_RESET "; + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : hc_stateReg_string = "ANY_TO_SUSPEND"; + default : hc_stateReg_string = "??????????????"; + endcase + end + always @(*) begin + case(hc_stateNext) + UsbOhciAxi4_hc_enumDef_BOOT : hc_stateNext_string = "BOOT "; + UsbOhciAxi4_hc_enumDef_RESET : hc_stateNext_string = "RESET "; + UsbOhciAxi4_hc_enumDef_RESUME : hc_stateNext_string = "RESUME "; + UsbOhciAxi4_hc_enumDef_OPERATIONAL : hc_stateNext_string = "OPERATIONAL "; + UsbOhciAxi4_hc_enumDef_SUSPEND : hc_stateNext_string = "SUSPEND "; + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : hc_stateNext_string = "ANY_TO_RESET "; + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : hc_stateNext_string = "ANY_TO_SUSPEND"; + default : hc_stateNext_string = "??????????????"; + endcase + end + `endif + + always @(*) begin + io_phy_lowSpeed = 1'b0; + if(when_UsbOhci_l750) begin + io_phy_lowSpeed = endpoint_ED_S; + end + end + + always @(*) begin + unscheduleAll_valid = 1'b0; + if(doUnschedule) begin + unscheduleAll_valid = 1'b1; + end + end + + always @(*) begin + unscheduleAll_ready = 1'b1; + if(when_UsbOhci_l157) begin + unscheduleAll_ready = 1'b0; + end + end + + assign ioDma_cmd_fire = (ioDma_cmd_valid && ioDma_cmd_ready); + assign ioDma_rsp_fire = (ioDma_rsp_valid && ioDma_rsp_ready); + assign dmaCtx_pendingFull = dmaCtx_pendingCounter[3]; + assign dmaCtx_pendingEmpty = (dmaCtx_pendingCounter == 4'b0000); + assign when_UsbOhci_l157 = (! dmaCtx_pendingEmpty); + assign io_dma_cmd_fire = (io_dma_cmd_valid && io_dma_cmd_ready); + assign _zz_io_dma_cmd_valid = (! (dmaCtx_pendingFull || (unscheduleAll_valid && io_dma_cmd_payload_first))); + assign ioDma_cmd_ready = (io_dma_cmd_ready && _zz_io_dma_cmd_valid); + assign io_dma_cmd_valid = (ioDma_cmd_valid && _zz_io_dma_cmd_valid); + assign io_dma_cmd_payload_last = ioDma_cmd_payload_last; + assign io_dma_cmd_payload_fragment_opcode = ioDma_cmd_payload_fragment_opcode; + assign io_dma_cmd_payload_fragment_address = ioDma_cmd_payload_fragment_address; + assign io_dma_cmd_payload_fragment_length = ioDma_cmd_payload_fragment_length; + assign io_dma_cmd_payload_fragment_data = ioDma_cmd_payload_fragment_data; + assign io_dma_cmd_payload_fragment_mask = ioDma_cmd_payload_fragment_mask; + assign ioDma_rsp_valid = io_dma_rsp_valid; + assign io_dma_rsp_ready = ioDma_rsp_ready; + assign ioDma_rsp_payload_last = io_dma_rsp_payload_last; + assign ioDma_rsp_payload_fragment_opcode = io_dma_rsp_payload_fragment_opcode; + assign ioDma_rsp_payload_fragment_data = io_dma_rsp_payload_fragment_data; + always @(*) begin + ioDma_cmd_valid = 1'b0; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_valid = 1'b1; + end + default : begin + end + endcase + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + ioDma_cmd_valid = 1'b1; + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_last = 1'bx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + ioDma_cmd_payload_last = (dmaWriteCtx_counter == 4'b0001); + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + ioDma_cmd_payload_last = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + ioDma_cmd_payload_last = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + ioDma_cmd_payload_last = (dmaWriteCtx_counter == _zz_ioDma_cmd_payload_last); + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + ioDma_cmd_payload_last = (dmaWriteCtx_counter == 4'b0011); + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + ioDma_cmd_payload_last = 1'b1; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_last = endpoint_dmaLogic_beatLast; + end + default : begin + end + endcase + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + ioDma_cmd_payload_last = 1'b1; + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_fragment_opcode = 1'bx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b1; + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b0; + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b0; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b0; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b1; + end + default : begin + end + endcase + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + ioDma_cmd_payload_fragment_opcode = 1'b0; + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_fragment_address = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + ioDma_cmd_payload_fragment_address = (reg_hcHCCA_HCCA_address | 32'h00000080); + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_ED_address; + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_TD_address; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_TD_address; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_ED_address; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_currentAddressBmb; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_fragment_address = endpoint_currentAddressBmb; + end + default : begin + end + endcase + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + ioDma_cmd_payload_fragment_address = (reg_hcHCCA_HCCA_address | _zz_ioDma_cmd_payload_fragment_address); + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_fragment_length = 6'bxxxxxx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + ioDma_cmd_payload_fragment_length = 6'h07; + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + ioDma_cmd_payload_fragment_length = 6'h0f; + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + ioDma_cmd_payload_fragment_length = {1'd0, _zz_ioDma_cmd_payload_fragment_length}; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + ioDma_cmd_payload_fragment_length = {1'd0, _zz_ioDma_cmd_payload_fragment_length_1}; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + ioDma_cmd_payload_fragment_length = 6'h0f; + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + ioDma_cmd_payload_fragment_length = endpoint_dmaLogic_lengthBmb; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_fragment_length = endpoint_dmaLogic_lengthBmb; + end + default : begin + end + endcase + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + ioDma_cmd_payload_fragment_length = 6'h03; + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_fragment_data = 32'h00000000; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + if(when_UsbOhci_l206) begin + ioDma_cmd_payload_fragment_data[31 : 0] = {16'h0000,reg_hcFmNumber_FN}; + end + if(sof_doInterruptDelay) begin + if(when_UsbOhci_l206_1) begin + ioDma_cmd_payload_fragment_data[31 : 0] = {reg_hcDoneHead_DH_address[31 : 1],reg_hcInterrupt_unmaskedPending}; + end + end + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + if(endpoint_ED_F) begin + if(endpoint_TD_isoOverrunReg) begin + if(when_UsbOhci_l206_2) begin + ioDma_cmd_payload_fragment_data[31 : 24] = {{4'b1000,endpoint_TD_words_0[27]},endpoint_TD_FC}; + end + end else begin + if(endpoint_TD_isoLastReg) begin + if(when_UsbOhci_l206_3) begin + ioDma_cmd_payload_fragment_data[31 : 24] = {{4'b0000,endpoint_TD_words_0[27]},endpoint_TD_FC}; + end + end + if(when_UsbOhci_l1378) begin + if(when_UsbOhci_l206_4) begin + ioDma_cmd_payload_fragment_data[15 : 0] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_1) begin + if(when_UsbOhci_l206_5) begin + ioDma_cmd_payload_fragment_data[31 : 16] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_2) begin + if(when_UsbOhci_l206_6) begin + ioDma_cmd_payload_fragment_data[15 : 0] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_3) begin + if(when_UsbOhci_l206_7) begin + ioDma_cmd_payload_fragment_data[31 : 16] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_4) begin + if(when_UsbOhci_l206_8) begin + ioDma_cmd_payload_fragment_data[15 : 0] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_5) begin + if(when_UsbOhci_l206_9) begin + ioDma_cmd_payload_fragment_data[31 : 16] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_6) begin + if(when_UsbOhci_l206_10) begin + ioDma_cmd_payload_fragment_data[15 : 0] = _zz_ioDma_cmd_payload_fragment_data; + end + end + if(when_UsbOhci_l1378_7) begin + if(when_UsbOhci_l206_11) begin + ioDma_cmd_payload_fragment_data[31 : 16] = _zz_ioDma_cmd_payload_fragment_data; + end + end + end + end else begin + if(when_UsbOhci_l206_12) begin + ioDma_cmd_payload_fragment_data[31 : 24] = {{endpoint_TD_CC,endpoint_TD_EC},endpoint_TD_TNext}; + end + if(endpoint_TD_upateCBP) begin + if(when_UsbOhci_l206_13) begin + ioDma_cmd_payload_fragment_data[31 : 0] = endpoint_tdUpdateAddress; + end + end + end + if(endpoint_TD_retire) begin + if(when_UsbOhci_l206_14) begin + ioDma_cmd_payload_fragment_data[31 : 0] = reg_hcDoneHead_DH_address; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + if(endpoint_TD_retire) begin + if(when_UsbOhci_l206_15) begin + ioDma_cmd_payload_fragment_data[31 : 0] = {{{endpoint_TD_nextTD,2'b00},endpoint_TD_dataPhaseNext},endpoint_ED_H}; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_fragment_data = fifo_io_pop_payload; + end + default : begin + end + endcase + end + + always @(*) begin + ioDma_cmd_payload_fragment_mask = 4'b0000; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + if(when_UsbOhci_l206) begin + ioDma_cmd_payload_fragment_mask[3 : 0] = 4'b1111; + end + if(sof_doInterruptDelay) begin + if(when_UsbOhci_l206_1) begin + ioDma_cmd_payload_fragment_mask[3 : 0] = 4'b1111; + end + end + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + if(endpoint_ED_F) begin + if(endpoint_TD_isoOverrunReg) begin + if(when_UsbOhci_l206_2) begin + ioDma_cmd_payload_fragment_mask[3 : 3] = 1'b1; + end + end else begin + if(endpoint_TD_isoLastReg) begin + if(when_UsbOhci_l206_3) begin + ioDma_cmd_payload_fragment_mask[3 : 3] = 1'b1; + end + end + if(when_UsbOhci_l1378) begin + if(when_UsbOhci_l206_4) begin + ioDma_cmd_payload_fragment_mask[1 : 0] = 2'b11; + end + end + if(when_UsbOhci_l1378_1) begin + if(when_UsbOhci_l206_5) begin + ioDma_cmd_payload_fragment_mask[3 : 2] = 2'b11; + end + end + if(when_UsbOhci_l1378_2) begin + if(when_UsbOhci_l206_6) begin + ioDma_cmd_payload_fragment_mask[1 : 0] = 2'b11; + end + end + if(when_UsbOhci_l1378_3) begin + if(when_UsbOhci_l206_7) begin + ioDma_cmd_payload_fragment_mask[3 : 2] = 2'b11; + end + end + if(when_UsbOhci_l1378_4) begin + if(when_UsbOhci_l206_8) begin + ioDma_cmd_payload_fragment_mask[1 : 0] = 2'b11; + end + end + if(when_UsbOhci_l1378_5) begin + if(when_UsbOhci_l206_9) begin + ioDma_cmd_payload_fragment_mask[3 : 2] = 2'b11; + end + end + if(when_UsbOhci_l1378_6) begin + if(when_UsbOhci_l206_10) begin + ioDma_cmd_payload_fragment_mask[1 : 0] = 2'b11; + end + end + if(when_UsbOhci_l1378_7) begin + if(when_UsbOhci_l206_11) begin + ioDma_cmd_payload_fragment_mask[3 : 2] = 2'b11; + end + end + end + end else begin + if(when_UsbOhci_l206_12) begin + ioDma_cmd_payload_fragment_mask[3 : 3] = 1'b1; + end + if(endpoint_TD_upateCBP) begin + if(when_UsbOhci_l206_13) begin + ioDma_cmd_payload_fragment_mask[3 : 0] = 4'b1111; + end + end + end + if(endpoint_TD_retire) begin + if(when_UsbOhci_l206_14) begin + ioDma_cmd_payload_fragment_mask[3 : 0] = 4'b1111; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + if(endpoint_TD_retire) begin + if(when_UsbOhci_l206_15) begin + ioDma_cmd_payload_fragment_mask[3 : 0] = 4'b1111; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + ioDma_cmd_payload_fragment_mask = ((endpoint_dmaLogic_fullMask & (ioDma_cmd_payload_first ? endpoint_dmaLogic_headMask : endpoint_dmaLogic_fullMask)) & (ioDma_cmd_payload_last ? endpoint_dmaLogic_lastMask : endpoint_dmaLogic_fullMask)); + end + default : begin + end + endcase + end + + assign ioDma_rsp_ready = 1'b1; + assign dmaRspMux_vec_0 = ioDma_rsp_payload_fragment_data[31 : 0]; + assign dmaRspMux_data = dmaRspMux_vec_0; + always @(*) begin + fifo_io_push_valid = 1'b0; + if(when_UsbOhci_l938) begin + fifo_io_push_valid = 1'b1; + end + if(endpoint_dmaLogic_push) begin + fifo_io_push_valid = 1'b1; + end + end + + always @(*) begin + fifo_io_push_payload = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; + if(when_UsbOhci_l938) begin + fifo_io_push_payload = ioDma_rsp_payload_fragment_data; + end + if(endpoint_dmaLogic_push) begin + fifo_io_push_payload = endpoint_dmaLogic_buffer; + end + end + + always @(*) begin + fifo_io_pop_ready = 1'b0; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + if(dataTx_data_ready) begin + if(when_UsbOhci_l1025) begin + fifo_io_pop_ready = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + if(ioDma_cmd_ready) begin + fifo_io_pop_ready = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + fifo_io_flush = 1'b0; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + fifo_io_flush = 1'b1; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_phy_tx_valid = 1'b0; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + end + UsbOhciAxi4_token_enumDef_PID : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_token_enumDef_B1 : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_token_enumDef_B2 : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_token_enumDef_EOP : begin + end + default : begin + end + endcase + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + io_phy_tx_valid = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_phy_tx_payload_fragment = 8'bxxxxxxxx; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + end + UsbOhciAxi4_token_enumDef_PID : begin + io_phy_tx_payload_fragment = {(~ token_pid),token_pid}; + end + UsbOhciAxi4_token_enumDef_B1 : begin + io_phy_tx_payload_fragment = token_data[7 : 0]; + end + UsbOhciAxi4_token_enumDef_B2 : begin + io_phy_tx_payload_fragment = {token_crc5_io_result,token_data[10 : 8]}; + end + UsbOhciAxi4_token_enumDef_EOP : begin + end + default : begin + end + endcase + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + io_phy_tx_payload_fragment = {(~ dataTx_pid),dataTx_pid}; + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + io_phy_tx_payload_fragment = dataTx_data_payload_fragment; + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + io_phy_tx_payload_fragment = dataTx_crc16_io_result[7 : 0]; + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + io_phy_tx_payload_fragment = dataTx_crc16_io_result[15 : 8]; + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + io_phy_tx_payload_fragment = 8'hd2; + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + io_phy_tx_payload_last = 1'bx; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + end + UsbOhciAxi4_token_enumDef_PID : begin + io_phy_tx_payload_last = 1'b0; + end + UsbOhciAxi4_token_enumDef_B1 : begin + io_phy_tx_payload_last = 1'b0; + end + UsbOhciAxi4_token_enumDef_B2 : begin + io_phy_tx_payload_last = 1'b1; + end + UsbOhciAxi4_token_enumDef_EOP : begin + end + default : begin + end + endcase + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + io_phy_tx_payload_last = 1'b0; + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + io_phy_tx_payload_last = 1'b0; + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + io_phy_tx_payload_last = 1'b0; + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + io_phy_tx_payload_last = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + io_phy_tx_payload_last = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + ctrlHalt = 1'b0; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + ctrlHalt = 1'b1; + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + ctrlHalt = 1'b1; + end + default : begin + end + endcase + end + + assign ctrl_readErrorFlag = 1'b0; + assign ctrl_writeErrorFlag = 1'b0; + assign ctrl_readHaltTrigger = 1'b0; + always @(*) begin + ctrl_writeHaltTrigger = 1'b0; + if(ctrlHalt) begin + ctrl_writeHaltTrigger = 1'b1; + end + end + + assign _zz_ctrl_rsp_ready = (! (ctrl_readHaltTrigger || ctrl_writeHaltTrigger)); + assign ctrl_rsp_ready = (_zz_ctrl_rsp_ready_1 && _zz_ctrl_rsp_ready); + always @(*) begin + _zz_ctrl_rsp_ready_1 = io_ctrl_rsp_ready; + if(when_Stream_l369) begin + _zz_ctrl_rsp_ready_1 = 1'b1; + end + end + + assign when_Stream_l369 = (! _zz_io_ctrl_rsp_valid); + assign _zz_io_ctrl_rsp_valid = _zz_io_ctrl_rsp_valid_1; + assign io_ctrl_rsp_valid = _zz_io_ctrl_rsp_valid; + assign io_ctrl_rsp_payload_last = _zz_io_ctrl_rsp_payload_last; + assign io_ctrl_rsp_payload_fragment_source = _zz_io_ctrl_rsp_payload_fragment_source; + assign io_ctrl_rsp_payload_fragment_opcode = _zz_io_ctrl_rsp_payload_fragment_opcode; + assign io_ctrl_rsp_payload_fragment_data = _zz_io_ctrl_rsp_payload_fragment_data; + assign ctrl_askWrite = (io_ctrl_cmd_valid && (io_ctrl_cmd_payload_fragment_opcode == 1'b1)); + assign ctrl_askRead = (io_ctrl_cmd_valid && (io_ctrl_cmd_payload_fragment_opcode == 1'b0)); + assign io_ctrl_cmd_fire = (io_ctrl_cmd_valid && io_ctrl_cmd_ready); + assign ctrl_doWrite = (io_ctrl_cmd_fire && (io_ctrl_cmd_payload_fragment_opcode == 1'b1)); + assign ctrl_doRead = (io_ctrl_cmd_fire && (io_ctrl_cmd_payload_fragment_opcode == 1'b0)); + assign ctrl_rsp_valid = io_ctrl_cmd_valid; + assign io_ctrl_cmd_ready = ctrl_rsp_ready; + assign ctrl_rsp_payload_last = 1'b1; + assign when_BmbSlaveFactory_l33 = (ctrl_doWrite && ctrl_writeErrorFlag); + always @(*) begin + if(when_BmbSlaveFactory_l33) begin + ctrl_rsp_payload_fragment_opcode = 1'b1; + end else begin + if(when_BmbSlaveFactory_l35) begin + ctrl_rsp_payload_fragment_opcode = 1'b1; + end else begin + ctrl_rsp_payload_fragment_opcode = 1'b0; + end + end + end + + assign when_BmbSlaveFactory_l35 = (ctrl_doRead && ctrl_readErrorFlag); + always @(*) begin + ctrl_rsp_payload_fragment_data = 32'h00000000; + case(io_ctrl_cmd_payload_fragment_address) + 12'h000 : begin + ctrl_rsp_payload_fragment_data[4 : 0] = reg_hcRevision_REV; + end + 12'h004 : begin + ctrl_rsp_payload_fragment_data[1 : 0] = reg_hcControl_CBSR; + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcControl_PLE; + ctrl_rsp_payload_fragment_data[3 : 3] = reg_hcControl_IE; + ctrl_rsp_payload_fragment_data[4 : 4] = reg_hcControl_CLE; + ctrl_rsp_payload_fragment_data[5 : 5] = reg_hcControl_BLE; + ctrl_rsp_payload_fragment_data[7 : 6] = reg_hcControl_HCFS; + ctrl_rsp_payload_fragment_data[8 : 8] = reg_hcControl_IR; + ctrl_rsp_payload_fragment_data[9 : 9] = reg_hcControl_RWC; + ctrl_rsp_payload_fragment_data[10 : 10] = reg_hcControl_RWE; + end + 12'h008 : begin + ctrl_rsp_payload_fragment_data[0 : 0] = doSoftReset; + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcCommandStatus_CLF; + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcCommandStatus_BLF; + ctrl_rsp_payload_fragment_data[3 : 3] = reg_hcCommandStatus_OCR; + ctrl_rsp_payload_fragment_data[17 : 16] = reg_hcCommandStatus_SOC; + end + 12'h010 : begin + ctrl_rsp_payload_fragment_data[31 : 31] = reg_hcInterrupt_MIE; + ctrl_rsp_payload_fragment_data[0 : 0] = reg_hcInterrupt_SO_enable; + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcInterrupt_WDH_enable; + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcInterrupt_SF_enable; + ctrl_rsp_payload_fragment_data[3 : 3] = reg_hcInterrupt_RD_enable; + ctrl_rsp_payload_fragment_data[4 : 4] = reg_hcInterrupt_UE_enable; + ctrl_rsp_payload_fragment_data[5 : 5] = reg_hcInterrupt_FNO_enable; + ctrl_rsp_payload_fragment_data[6 : 6] = reg_hcInterrupt_RHSC_enable; + ctrl_rsp_payload_fragment_data[30 : 30] = reg_hcInterrupt_OC_enable; + end + 12'h014 : begin + ctrl_rsp_payload_fragment_data[31 : 31] = reg_hcInterrupt_MIE; + ctrl_rsp_payload_fragment_data[0 : 0] = reg_hcInterrupt_SO_enable; + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcInterrupt_WDH_enable; + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcInterrupt_SF_enable; + ctrl_rsp_payload_fragment_data[3 : 3] = reg_hcInterrupt_RD_enable; + ctrl_rsp_payload_fragment_data[4 : 4] = reg_hcInterrupt_UE_enable; + ctrl_rsp_payload_fragment_data[5 : 5] = reg_hcInterrupt_FNO_enable; + ctrl_rsp_payload_fragment_data[6 : 6] = reg_hcInterrupt_RHSC_enable; + ctrl_rsp_payload_fragment_data[30 : 30] = reg_hcInterrupt_OC_enable; + end + 12'h00c : begin + ctrl_rsp_payload_fragment_data[0 : 0] = reg_hcInterrupt_SO_status; + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcInterrupt_WDH_status; + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcInterrupt_SF_status; + ctrl_rsp_payload_fragment_data[3 : 3] = reg_hcInterrupt_RD_status; + ctrl_rsp_payload_fragment_data[4 : 4] = reg_hcInterrupt_UE_status; + ctrl_rsp_payload_fragment_data[5 : 5] = reg_hcInterrupt_FNO_status; + ctrl_rsp_payload_fragment_data[6 : 6] = reg_hcInterrupt_RHSC_status; + ctrl_rsp_payload_fragment_data[30 : 30] = reg_hcInterrupt_OC_status; + end + 12'h018 : begin + ctrl_rsp_payload_fragment_data[31 : 8] = reg_hcHCCA_HCCA_reg; + end + 12'h01c : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcPeriodCurrentED_PCED_reg; + end + 12'h020 : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcControlHeadED_CHED_reg; + end + 12'h024 : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcControlCurrentED_CCED_reg; + end + 12'h028 : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcBulkHeadED_BHED_reg; + end + 12'h02c : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcBulkCurrentED_BCED_reg; + end + 12'h030 : begin + ctrl_rsp_payload_fragment_data[31 : 4] = reg_hcDoneHead_DH_reg; + end + 12'h034 : begin + ctrl_rsp_payload_fragment_data[13 : 0] = reg_hcFmInterval_FI; + ctrl_rsp_payload_fragment_data[30 : 16] = reg_hcFmInterval_FSMPS; + ctrl_rsp_payload_fragment_data[31 : 31] = reg_hcFmInterval_FIT; + end + 12'h038 : begin + ctrl_rsp_payload_fragment_data[13 : 0] = reg_hcFmRemaining_FR; + ctrl_rsp_payload_fragment_data[31 : 31] = reg_hcFmRemaining_FRT; + end + 12'h03c : begin + ctrl_rsp_payload_fragment_data[15 : 0] = reg_hcFmNumber_FN; + end + 12'h040 : begin + ctrl_rsp_payload_fragment_data[13 : 0] = reg_hcPeriodicStart_PS; + end + 12'h044 : begin + ctrl_rsp_payload_fragment_data[11 : 0] = reg_hcLSThreshold_LST; + end + 12'h048 : begin + ctrl_rsp_payload_fragment_data[7 : 0] = reg_hcRhDescriptorA_NDP; + ctrl_rsp_payload_fragment_data[8 : 8] = reg_hcRhDescriptorA_PSM; + ctrl_rsp_payload_fragment_data[9 : 9] = reg_hcRhDescriptorA_NPS; + ctrl_rsp_payload_fragment_data[11 : 11] = reg_hcRhDescriptorA_OCPM; + ctrl_rsp_payload_fragment_data[12 : 12] = reg_hcRhDescriptorA_NOCP; + ctrl_rsp_payload_fragment_data[31 : 24] = reg_hcRhDescriptorA_POTPGT; + end + 12'h04c : begin + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcRhDescriptorB_DR; + ctrl_rsp_payload_fragment_data[17 : 17] = reg_hcRhDescriptorB_PPCM; + end + 12'h050 : begin + ctrl_rsp_payload_fragment_data[1 : 1] = io_phy_overcurrent; + ctrl_rsp_payload_fragment_data[15 : 15] = reg_hcRhStatus_DRWE; + ctrl_rsp_payload_fragment_data[17 : 17] = reg_hcRhStatus_CCIC; + end + 12'h054 : begin + ctrl_rsp_payload_fragment_data[2 : 2] = reg_hcRhPortStatus_0_PSS; + ctrl_rsp_payload_fragment_data[8 : 8] = reg_hcRhPortStatus_0_PPS; + ctrl_rsp_payload_fragment_data[0 : 0] = reg_hcRhPortStatus_0_CCS; + ctrl_rsp_payload_fragment_data[1 : 1] = reg_hcRhPortStatus_0_PES; + ctrl_rsp_payload_fragment_data[3 : 3] = io_phy_ports_0_overcurrent; + ctrl_rsp_payload_fragment_data[4 : 4] = reg_hcRhPortStatus_0_reset; + ctrl_rsp_payload_fragment_data[9 : 9] = io_phy_ports_0_lowSpeed; + ctrl_rsp_payload_fragment_data[16 : 16] = reg_hcRhPortStatus_0_CSC_reg; + ctrl_rsp_payload_fragment_data[17 : 17] = reg_hcRhPortStatus_0_PESC_reg; + ctrl_rsp_payload_fragment_data[18 : 18] = reg_hcRhPortStatus_0_PSSC_reg; + ctrl_rsp_payload_fragment_data[19 : 19] = reg_hcRhPortStatus_0_OCIC_reg; + ctrl_rsp_payload_fragment_data[20 : 20] = reg_hcRhPortStatus_0_PRSC_reg; + end + default : begin + end + endcase + end + + assign ctrl_rsp_payload_fragment_source = io_ctrl_cmd_payload_fragment_source; + assign when_UsbOhci_l236 = (! doUnschedule); + assign reg_hcRevision_REV = 5'h10; + always @(*) begin + reg_hcControl_HCFSWrite_valid = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h004 : begin + if(ctrl_doWrite) begin + reg_hcControl_HCFSWrite_valid = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + reg_hcCommandStatus_startSoftReset = 1'b0; + if(when_BusSlaveFactory_l377) begin + if(when_BusSlaveFactory_l379) begin + reg_hcCommandStatus_startSoftReset = _zz_reg_hcCommandStatus_startSoftReset[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h008 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379 = io_ctrl_cmd_payload_fragment_data[0]; + always @(*) begin + when_BusSlaveFactory_l377_1 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h008 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_1 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_1 = io_ctrl_cmd_payload_fragment_data[1]; + always @(*) begin + when_BusSlaveFactory_l377_2 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h008 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_2 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_2 = io_ctrl_cmd_payload_fragment_data[2]; + always @(*) begin + when_BusSlaveFactory_l377_3 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h008 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_3 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_3 = io_ctrl_cmd_payload_fragment_data[3]; + always @(*) begin + reg_hcInterrupt_unmaskedPending = 1'b0; + if(when_UsbOhci_l302) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_1) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_2) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_3) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_4) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_5) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + if(when_UsbOhci_l302_6) begin + reg_hcInterrupt_unmaskedPending = 1'b1; + end + end + + always @(*) begin + when_BusSlaveFactory_l377_4 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_4 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_4 = io_ctrl_cmd_payload_fragment_data[31]; + always @(*) begin + when_BusSlaveFactory_l341 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347 = io_ctrl_cmd_payload_fragment_data[31]; + always @(*) begin + when_BusSlaveFactory_l341_1 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_1 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_1 = io_ctrl_cmd_payload_fragment_data[0]; + always @(*) begin + when_BusSlaveFactory_l377_5 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_5 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_5 = io_ctrl_cmd_payload_fragment_data[0]; + always @(*) begin + when_BusSlaveFactory_l341_2 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_2 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_2 = io_ctrl_cmd_payload_fragment_data[0]; + assign when_UsbOhci_l302 = (reg_hcInterrupt_SO_status && reg_hcInterrupt_SO_enable); + always @(*) begin + when_BusSlaveFactory_l341_3 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_3 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_3 = io_ctrl_cmd_payload_fragment_data[1]; + always @(*) begin + when_BusSlaveFactory_l377_6 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_6 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_6 = io_ctrl_cmd_payload_fragment_data[1]; + always @(*) begin + when_BusSlaveFactory_l341_4 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_4 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_4 = io_ctrl_cmd_payload_fragment_data[1]; + assign when_UsbOhci_l302_1 = (reg_hcInterrupt_WDH_status && reg_hcInterrupt_WDH_enable); + always @(*) begin + when_BusSlaveFactory_l341_5 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_5 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_5 = io_ctrl_cmd_payload_fragment_data[2]; + always @(*) begin + when_BusSlaveFactory_l377_7 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_7 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_7 = io_ctrl_cmd_payload_fragment_data[2]; + always @(*) begin + when_BusSlaveFactory_l341_6 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_6 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_6 = io_ctrl_cmd_payload_fragment_data[2]; + assign when_UsbOhci_l302_2 = (reg_hcInterrupt_SF_status && reg_hcInterrupt_SF_enable); + always @(*) begin + when_BusSlaveFactory_l341_7 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_7 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_7 = io_ctrl_cmd_payload_fragment_data[3]; + always @(*) begin + when_BusSlaveFactory_l377_8 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_8 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_8 = io_ctrl_cmd_payload_fragment_data[3]; + always @(*) begin + when_BusSlaveFactory_l341_8 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_8 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_8 = io_ctrl_cmd_payload_fragment_data[3]; + assign when_UsbOhci_l302_3 = (reg_hcInterrupt_RD_status && reg_hcInterrupt_RD_enable); + always @(*) begin + when_BusSlaveFactory_l341_9 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_9 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_9 = io_ctrl_cmd_payload_fragment_data[4]; + always @(*) begin + when_BusSlaveFactory_l377_9 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_9 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_9 = io_ctrl_cmd_payload_fragment_data[4]; + always @(*) begin + when_BusSlaveFactory_l341_10 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_10 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_10 = io_ctrl_cmd_payload_fragment_data[4]; + assign when_UsbOhci_l302_4 = (reg_hcInterrupt_UE_status && reg_hcInterrupt_UE_enable); + always @(*) begin + when_BusSlaveFactory_l341_11 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_11 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_11 = io_ctrl_cmd_payload_fragment_data[5]; + always @(*) begin + when_BusSlaveFactory_l377_10 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_10 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_10 = io_ctrl_cmd_payload_fragment_data[5]; + always @(*) begin + when_BusSlaveFactory_l341_12 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_12 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_12 = io_ctrl_cmd_payload_fragment_data[5]; + assign when_UsbOhci_l302_5 = (reg_hcInterrupt_FNO_status && reg_hcInterrupt_FNO_enable); + always @(*) begin + when_BusSlaveFactory_l341_13 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_13 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_13 = io_ctrl_cmd_payload_fragment_data[6]; + always @(*) begin + when_BusSlaveFactory_l377_11 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_11 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_11 = io_ctrl_cmd_payload_fragment_data[6]; + always @(*) begin + when_BusSlaveFactory_l341_14 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_14 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_14 = io_ctrl_cmd_payload_fragment_data[6]; + assign when_UsbOhci_l302_6 = (reg_hcInterrupt_RHSC_status && reg_hcInterrupt_RHSC_enable); + always @(*) begin + when_BusSlaveFactory_l341_15 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h00c : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_15 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_15 = io_ctrl_cmd_payload_fragment_data[30]; + always @(*) begin + when_BusSlaveFactory_l377_12 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h010 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_12 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_12 = io_ctrl_cmd_payload_fragment_data[30]; + always @(*) begin + when_BusSlaveFactory_l341_16 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h014 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_16 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_16 = io_ctrl_cmd_payload_fragment_data[30]; + assign reg_hcInterrupt_doIrq = (reg_hcInterrupt_unmaskedPending && reg_hcInterrupt_MIE); + assign io_interrupt = (reg_hcInterrupt_doIrq && (! reg_hcControl_IR)); + assign io_interruptBios = ((reg_hcInterrupt_doIrq && reg_hcControl_IR) || (reg_hcInterrupt_OC_status && reg_hcInterrupt_OC_enable)); + assign reg_hcHCCA_HCCA_address = {reg_hcHCCA_HCCA_reg,8'h00}; + assign reg_hcPeriodCurrentED_PCED_address = {reg_hcPeriodCurrentED_PCED_reg,4'b0000}; + assign reg_hcPeriodCurrentED_isZero = (reg_hcPeriodCurrentED_PCED_reg == 28'h0000000); + assign reg_hcControlHeadED_CHED_address = {reg_hcControlHeadED_CHED_reg,4'b0000}; + assign reg_hcControlCurrentED_CCED_address = {reg_hcControlCurrentED_CCED_reg,4'b0000}; + assign reg_hcControlCurrentED_isZero = (reg_hcControlCurrentED_CCED_reg == 28'h0000000); + assign reg_hcBulkHeadED_BHED_address = {reg_hcBulkHeadED_BHED_reg,4'b0000}; + assign reg_hcBulkCurrentED_BCED_address = {reg_hcBulkCurrentED_BCED_reg,4'b0000}; + assign reg_hcBulkCurrentED_isZero = (reg_hcBulkCurrentED_BCED_reg == 28'h0000000); + assign reg_hcDoneHead_DH_address = {reg_hcDoneHead_DH_reg,4'b0000}; + assign reg_hcFmNumber_FNp1 = (reg_hcFmNumber_FN + 16'h0001); + assign reg_hcLSThreshold_hit = (reg_hcFmRemaining_FR < _zz_reg_hcLSThreshold_hit); + assign reg_hcRhDescriptorA_NDP = 8'h01; + always @(*) begin + when_BusSlaveFactory_l341_17 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h050 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l341_17 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l347_17 = io_ctrl_cmd_payload_fragment_data[17]; + assign when_UsbOhci_l409 = (io_phy_overcurrent ^ io_phy_overcurrent_regNext); + always @(*) begin + reg_hcRhStatus_clearGlobalPower = 1'b0; + if(when_BusSlaveFactory_l377_13) begin + if(when_BusSlaveFactory_l379_13) begin + reg_hcRhStatus_clearGlobalPower = _zz_reg_hcRhStatus_clearGlobalPower[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_13 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h050 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_13 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_13 = io_ctrl_cmd_payload_fragment_data[0]; + always @(*) begin + reg_hcRhStatus_setRemoteWakeupEnable = 1'b0; + if(when_BusSlaveFactory_l377_14) begin + if(when_BusSlaveFactory_l379_14) begin + reg_hcRhStatus_setRemoteWakeupEnable = _zz_reg_hcRhStatus_setRemoteWakeupEnable[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_14 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h050 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_14 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_14 = io_ctrl_cmd_payload_fragment_data[15]; + always @(*) begin + reg_hcRhStatus_setGlobalPower = 1'b0; + if(when_BusSlaveFactory_l377_15) begin + if(when_BusSlaveFactory_l379_15) begin + reg_hcRhStatus_setGlobalPower = _zz_reg_hcRhStatus_setGlobalPower[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_15 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h050 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_15 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_15 = io_ctrl_cmd_payload_fragment_data[16]; + always @(*) begin + reg_hcRhStatus_clearRemoteWakeupEnable = 1'b0; + if(when_BusSlaveFactory_l377_16) begin + if(when_BusSlaveFactory_l379_16) begin + reg_hcRhStatus_clearRemoteWakeupEnable = _zz_reg_hcRhStatus_clearRemoteWakeupEnable[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_16 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h050 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_16 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_16 = io_ctrl_cmd_payload_fragment_data[31]; + always @(*) begin + reg_hcRhPortStatus_0_clearPortEnable = 1'b0; + if(when_BusSlaveFactory_l377_17) begin + if(when_BusSlaveFactory_l379_17) begin + reg_hcRhPortStatus_0_clearPortEnable = _zz_reg_hcRhPortStatus_0_clearPortEnable[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_17 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_17 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_17 = io_ctrl_cmd_payload_fragment_data[0]; + always @(*) begin + reg_hcRhPortStatus_0_setPortEnable = 1'b0; + if(when_BusSlaveFactory_l377_18) begin + if(when_BusSlaveFactory_l379_18) begin + reg_hcRhPortStatus_0_setPortEnable = _zz_reg_hcRhPortStatus_0_setPortEnable[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_18 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_18 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_18 = io_ctrl_cmd_payload_fragment_data[1]; + always @(*) begin + reg_hcRhPortStatus_0_setPortSuspend = 1'b0; + if(when_BusSlaveFactory_l377_19) begin + if(when_BusSlaveFactory_l379_19) begin + reg_hcRhPortStatus_0_setPortSuspend = _zz_reg_hcRhPortStatus_0_setPortSuspend[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_19 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_19 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_19 = io_ctrl_cmd_payload_fragment_data[2]; + always @(*) begin + reg_hcRhPortStatus_0_clearSuspendStatus = 1'b0; + if(when_BusSlaveFactory_l377_20) begin + if(when_BusSlaveFactory_l379_20) begin + reg_hcRhPortStatus_0_clearSuspendStatus = _zz_reg_hcRhPortStatus_0_clearSuspendStatus[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_20 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_20 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_20 = io_ctrl_cmd_payload_fragment_data[3]; + always @(*) begin + reg_hcRhPortStatus_0_setPortReset = 1'b0; + if(when_BusSlaveFactory_l377_21) begin + if(when_BusSlaveFactory_l379_21) begin + reg_hcRhPortStatus_0_setPortReset = _zz_reg_hcRhPortStatus_0_setPortReset[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_21 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_21 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_21 = io_ctrl_cmd_payload_fragment_data[4]; + always @(*) begin + reg_hcRhPortStatus_0_setPortPower = 1'b0; + if(when_BusSlaveFactory_l377_22) begin + if(when_BusSlaveFactory_l379_22) begin + reg_hcRhPortStatus_0_setPortPower = _zz_reg_hcRhPortStatus_0_setPortPower[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_22 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_22 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_22 = io_ctrl_cmd_payload_fragment_data[8]; + always @(*) begin + reg_hcRhPortStatus_0_clearPortPower = 1'b0; + if(when_BusSlaveFactory_l377_23) begin + if(when_BusSlaveFactory_l379_23) begin + reg_hcRhPortStatus_0_clearPortPower = _zz_reg_hcRhPortStatus_0_clearPortPower[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_23 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_23 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_23 = io_ctrl_cmd_payload_fragment_data[9]; + assign reg_hcRhPortStatus_0_CCS = ((reg_hcRhPortStatus_0_connected || reg_hcRhDescriptorB_DR[0]) && reg_hcRhPortStatus_0_PPS); + always @(*) begin + reg_hcRhPortStatus_0_CSC_clear = 1'b0; + if(when_BusSlaveFactory_l377_24) begin + if(when_BusSlaveFactory_l379_24) begin + reg_hcRhPortStatus_0_CSC_clear = _zz_reg_hcRhPortStatus_0_CSC_clear[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_24 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_24 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_24 = io_ctrl_cmd_payload_fragment_data[16]; + always @(*) begin + reg_hcRhPortStatus_0_PESC_clear = 1'b0; + if(when_BusSlaveFactory_l377_25) begin + if(when_BusSlaveFactory_l379_25) begin + reg_hcRhPortStatus_0_PESC_clear = _zz_reg_hcRhPortStatus_0_PESC_clear[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_25 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_25 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_25 = io_ctrl_cmd_payload_fragment_data[17]; + always @(*) begin + reg_hcRhPortStatus_0_PSSC_clear = 1'b0; + if(when_BusSlaveFactory_l377_26) begin + if(when_BusSlaveFactory_l379_26) begin + reg_hcRhPortStatus_0_PSSC_clear = _zz_reg_hcRhPortStatus_0_PSSC_clear[0]; + end + end + if(reg_hcRhPortStatus_0_PRSC_set) begin + reg_hcRhPortStatus_0_PSSC_clear = 1'b1; + end + end + + always @(*) begin + when_BusSlaveFactory_l377_26 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_26 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_26 = io_ctrl_cmd_payload_fragment_data[18]; + always @(*) begin + reg_hcRhPortStatus_0_OCIC_clear = 1'b0; + if(when_BusSlaveFactory_l377_27) begin + if(when_BusSlaveFactory_l379_27) begin + reg_hcRhPortStatus_0_OCIC_clear = _zz_reg_hcRhPortStatus_0_OCIC_clear[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_27 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_27 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_27 = io_ctrl_cmd_payload_fragment_data[19]; + always @(*) begin + reg_hcRhPortStatus_0_PRSC_clear = 1'b0; + if(when_BusSlaveFactory_l377_28) begin + if(when_BusSlaveFactory_l379_28) begin + reg_hcRhPortStatus_0_PRSC_clear = _zz_reg_hcRhPortStatus_0_PRSC_clear[0]; + end + end + end + + always @(*) begin + when_BusSlaveFactory_l377_28 = 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h054 : begin + if(ctrl_doWrite) begin + when_BusSlaveFactory_l377_28 = 1'b1; + end + end + default : begin + end + endcase + end + + assign when_BusSlaveFactory_l379_28 = io_ctrl_cmd_payload_fragment_data[20]; + assign when_UsbOhci_l460 = ((reg_hcRhPortStatus_0_clearPortEnable || reg_hcRhPortStatus_0_PESC_set) || (! reg_hcRhPortStatus_0_PPS)); + assign when_UsbOhci_l460_1 = (reg_hcRhPortStatus_0_PRSC_set || reg_hcRhPortStatus_0_PSSC_set); + assign when_UsbOhci_l460_2 = (reg_hcRhPortStatus_0_setPortEnable && reg_hcRhPortStatus_0_CCS); + assign when_UsbOhci_l461 = (((reg_hcRhPortStatus_0_PSSC_set || reg_hcRhPortStatus_0_PRSC_set) || (! reg_hcRhPortStatus_0_PPS)) || (reg_hcControl_HCFS == UsbOhciAxi4_MainState_RESUME)); + assign when_UsbOhci_l461_1 = (reg_hcRhPortStatus_0_setPortSuspend && reg_hcRhPortStatus_0_CCS); + assign when_UsbOhci_l462 = (reg_hcRhPortStatus_0_setPortSuspend && reg_hcRhPortStatus_0_CCS); + assign when_UsbOhci_l463 = (reg_hcRhPortStatus_0_clearSuspendStatus && reg_hcRhPortStatus_0_PSS); + assign when_UsbOhci_l464 = (reg_hcRhPortStatus_0_setPortReset && reg_hcRhPortStatus_0_CCS); + assign when_UsbOhci_l470 = reg_hcRhDescriptorB_PPCM[0]; + assign reg_hcRhPortStatus_0_CSC_set = ((((reg_hcRhPortStatus_0_CCS ^ reg_hcRhPortStatus_0_CCS_regNext) || (reg_hcRhPortStatus_0_setPortEnable && (! reg_hcRhPortStatus_0_CCS))) || (reg_hcRhPortStatus_0_setPortSuspend && (! reg_hcRhPortStatus_0_CCS))) || (reg_hcRhPortStatus_0_setPortReset && (! reg_hcRhPortStatus_0_CCS))); + assign reg_hcRhPortStatus_0_PESC_set = io_phy_ports_0_overcurrent; + assign io_phy_ports_0_suspend_fire = (io_phy_ports_0_suspend_valid && io_phy_ports_0_suspend_ready); + assign reg_hcRhPortStatus_0_PSSC_set = (io_phy_ports_0_suspend_fire || io_phy_ports_0_remoteResume); + assign reg_hcRhPortStatus_0_OCIC_set = io_phy_ports_0_overcurrent; + assign io_phy_ports_0_reset_fire = (io_phy_ports_0_reset_valid && io_phy_ports_0_reset_ready); + assign reg_hcRhPortStatus_0_PRSC_set = io_phy_ports_0_reset_fire; + assign io_phy_ports_0_disable_valid = reg_hcRhPortStatus_0_clearPortEnable; + assign io_phy_ports_0_removable = reg_hcRhDescriptorB_DR[0]; + assign io_phy_ports_0_power = reg_hcRhPortStatus_0_PPS; + assign io_phy_ports_0_resume_valid = reg_hcRhPortStatus_0_resume; + assign io_phy_ports_0_resume_fire = (io_phy_ports_0_resume_valid && io_phy_ports_0_resume_ready); + assign io_phy_ports_0_reset_valid = reg_hcRhPortStatus_0_reset; + assign io_phy_ports_0_suspend_valid = reg_hcRhPortStatus_0_suspend; + always @(*) begin + frame_run = 1'b0; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + frame_run = 1'b1; + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + end + default : begin + end + endcase + end + + always @(*) begin + frame_reload = 1'b0; + if(when_UsbOhci_l526) begin + if(frame_overflow) begin + frame_reload = 1'b1; + end + end + if(when_StateMachine_l253_7) begin + frame_reload = 1'b1; + end + end + + assign frame_overflow = (reg_hcFmRemaining_FR == 14'h0000); + always @(*) begin + frame_tick = 1'b0; + if(when_UsbOhci_l526) begin + if(frame_overflow) begin + frame_tick = 1'b1; + end + end + end + + assign frame_section1 = (reg_hcPeriodicStart_PS < reg_hcFmRemaining_FR); + assign frame_limitHit = (frame_limitCounter == 15'h0000); + assign frame_decrementTimerOverflow = (frame_decrementTimer == 3'b110); + assign when_UsbOhci_l526 = (frame_run && io_phy_tick); + assign when_UsbOhci_l528 = ((! frame_limitHit) && (! frame_decrementTimerOverflow)); + assign when_UsbOhci_l540 = (reg_hcFmNumber_FNp1[15] ^ reg_hcFmNumber_FN[15]); + always @(*) begin + token_wantExit = 1'b0; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + end + UsbOhciAxi4_token_enumDef_PID : begin + end + UsbOhciAxi4_token_enumDef_B1 : begin + end + UsbOhciAxi4_token_enumDef_B2 : begin + end + UsbOhciAxi4_token_enumDef_EOP : begin + if(io_phy_txEop) begin + token_wantExit = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + token_wantStart = 1'b0; + if(when_StateMachine_l237_1) begin + token_wantStart = 1'b1; + end + if(when_StateMachine_l253_1) begin + token_wantStart = 1'b1; + end + end + + always @(*) begin + token_wantKill = 1'b0; + if(unscheduleAll_fire) begin + token_wantKill = 1'b1; + end + end + + always @(*) begin + token_pid = 4'bxxxx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + token_pid = 4'b0101; + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + case(endpoint_tockenType) + 2'b00 : begin + token_pid = 4'b1101; + end + 2'b01 : begin + token_pid = 4'b0001; + end + 2'b10 : begin + token_pid = 4'b1001; + end + default : begin + end + endcase + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + token_data = 11'bxxxxxxxxxxx; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + token_data = _zz_token_data[10:0]; + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + token_data = {endpoint_ED_EN,endpoint_ED_FA}; + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + token_crc5_io_flush = 1'b0; + if(when_StateMachine_l237) begin + token_crc5_io_flush = 1'b1; + end + end + + always @(*) begin + token_crc5_io_input_valid = 1'b0; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + token_crc5_io_input_valid = 1'b1; + end + UsbOhciAxi4_token_enumDef_PID : begin + end + UsbOhciAxi4_token_enumDef_B1 : begin + end + UsbOhciAxi4_token_enumDef_B2 : begin + end + UsbOhciAxi4_token_enumDef_EOP : begin + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_wantExit = 1'b0; + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + if(io_phy_txEop) begin + dataTx_wantExit = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_wantStart = 1'b0; + if(when_StateMachine_l253_2) begin + dataTx_wantStart = 1'b1; + end + end + + always @(*) begin + dataTx_wantKill = 1'b0; + if(unscheduleAll_fire) begin + dataTx_wantKill = 1'b1; + end + end + + always @(*) begin + dataTx_pid = 4'bxxxx; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + dataTx_pid = {endpoint_dataPhase,3'b011}; + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_data_valid = 1'b0; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + dataTx_data_valid = 1'b1; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_data_payload_last = 1'bx; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + dataTx_data_payload_last = endpoint_dmaLogic_byteCtx_last; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_data_payload_fragment = 8'bxxxxxxxx; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + dataTx_data_payload_fragment = _zz_dataTx_data_payload_fragment; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + always @(*) begin + dataTx_data_ready = 1'b0; + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + if(io_phy_tx_ready) begin + dataTx_data_ready = 1'b1; + end + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + end + default : begin + end + endcase + end + + assign dataTx_data_fire = (dataTx_data_valid && dataTx_data_ready); + always @(*) begin + dataTx_crc16_io_flush = 1'b0; + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + dataTx_crc16_io_flush = 1'b1; + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + end + default : begin + end + endcase + end + + always @(*) begin + rxTimer_clear = 1'b0; + if(io_phy_rx_active) begin + rxTimer_clear = 1'b1; + end + if(when_StateMachine_l253) begin + rxTimer_clear = 1'b1; + end + if(when_StateMachine_l253_4) begin + rxTimer_clear = 1'b1; + end + end + + assign rxTimer_rxTimeout = (rxTimer_counter == (rxTimer_lowSpeed ? 8'hbf : 8'h17)); + assign rxTimer_ackTx = (rxTimer_counter == _zz_rxTimer_ackTx); + assign rxPidOk = (io_phy_rx_flow_payload_data[3 : 0] == (~ io_phy_rx_flow_payload_data[7 : 4])); + assign _zz_1 = io_phy_rx_flow_valid; + assign _zz_dataRx_pid = io_phy_rx_flow_payload_data; + assign when_Misc_l87 = (io_phy_rx_flow_valid && io_phy_rx_flow_payload_stuffingError); + always @(*) begin + dataRx_wantExit = 1'b0; + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + if(!io_phy_rx_active) begin + if(rxTimer_rxTimeout) begin + dataRx_wantExit = 1'b1; + end + end + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + if(!_zz_1) begin + if(when_Misc_l64) begin + dataRx_wantExit = 1'b1; + end + end + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + if(when_Misc_l70) begin + dataRx_wantExit = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + dataRx_wantStart = 1'b0; + if(when_StateMachine_l253_3) begin + dataRx_wantStart = 1'b1; + end + end + + always @(*) begin + dataRx_wantKill = 1'b0; + if(unscheduleAll_fire) begin + dataRx_wantKill = 1'b1; + end + end + + assign dataRx_history_0 = _zz_dataRx_history_0; + assign dataRx_history_1 = _zz_dataRx_history_1; + assign dataRx_hasError = ({dataRx_crcError,{dataRx_pidError,{dataRx_stuffingError,dataRx_notResponding}}} != 4'b0000); + always @(*) begin + dataRx_data_valid = 1'b0; + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + if(!when_Misc_l70) begin + if(_zz_1) begin + if(when_Misc_l78) begin + dataRx_data_valid = 1'b1; + end + end + end + end + default : begin + end + endcase + end + + assign dataRx_data_payload = dataRx_history_1; + always @(*) begin + dataRx_crc16_io_input_valid = 1'b0; + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + if(!when_Misc_l70) begin + if(_zz_1) begin + dataRx_crc16_io_input_valid = 1'b1; + end + end + end + default : begin + end + endcase + end + + always @(*) begin + dataRx_crc16_io_flush = 1'b0; + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + dataRx_crc16_io_flush = 1'b1; + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + end + default : begin + end + endcase + end + + always @(*) begin + sof_wantExit = 1'b0; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + sof_wantExit = 1'b1; + end + end + default : begin + end + endcase + end + + always @(*) begin + sof_wantStart = 1'b0; + if(when_StateMachine_l253_6) begin + sof_wantStart = 1'b1; + end + end + + always @(*) begin + sof_wantKill = 1'b0; + if(unscheduleAll_fire) begin + sof_wantKill = 1'b1; + end + end + + always @(*) begin + priority_tick = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + if(when_UsbOhci_l1418) begin + priority_tick = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + priority_skip = 1'b0; + if(priority_tick) begin + if(when_UsbOhci_l663) begin + priority_skip = 1'b1; + end + end + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + if(!operational_askExit) begin + if(!frame_limitHit) begin + if(!when_UsbOhci_l1487) begin + priority_skip = 1'b1; + if(priority_bulk) begin + if(operational_allowBulk) begin + if(reg_hcBulkCurrentED_isZero) begin + if(reg_hcCommandStatus_BLF) begin + priority_skip = 1'b0; + end + end else begin + priority_skip = 1'b0; + end + end + end else begin + if(operational_allowControl) begin + if(reg_hcControlCurrentED_isZero) begin + if(reg_hcCommandStatus_CLF) begin + priority_skip = 1'b0; + end + end else begin + priority_skip = 1'b0; + end + end + end + end + end + end + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + assign when_UsbOhci_l663 = (priority_bulk || (priority_counter == reg_hcControl_CBSR)); + always @(*) begin + interruptDelay_tick = 1'b0; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + interruptDelay_tick = 1'b1; + end + end + default : begin + end + endcase + end + + assign interruptDelay_done = (interruptDelay_counter == 3'b000); + assign interruptDelay_disabled = (interruptDelay_counter == 3'b111); + always @(*) begin + interruptDelay_disable = 1'b0; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + if(sof_doInterruptDelay) begin + interruptDelay_disable = 1'b1; + end + end + end + default : begin + end + endcase + if(when_StateMachine_l237_3) begin + interruptDelay_disable = 1'b1; + end + end + + always @(*) begin + interruptDelay_load_valid = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + if(endpoint_TD_retire) begin + interruptDelay_load_valid = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + always @(*) begin + interruptDelay_load_payload = 3'bxxx; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + if(endpoint_TD_retire) begin + interruptDelay_load_payload = endpoint_TD_DI; + end + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + assign when_UsbOhci_l685 = ((interruptDelay_tick && (! interruptDelay_done)) && (! interruptDelay_disabled)); + assign when_UsbOhci_l689 = (interruptDelay_load_valid && (interruptDelay_load_payload < interruptDelay_counter)); + always @(*) begin + endpoint_wantExit = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + if(when_UsbOhci_l861) begin + endpoint_wantExit = 1'b1; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + endpoint_wantExit = 1'b1; + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + endpoint_wantExit = 1'b1; + end + default : begin + end + endcase + end + + always @(*) begin + endpoint_wantStart = 1'b0; + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + if(!operational_askExit) begin + if(!frame_limitHit) begin + if(when_UsbOhci_l1487) begin + if(!when_UsbOhci_l1488) begin + if(!reg_hcPeriodCurrentED_isZero) begin + endpoint_wantStart = 1'b1; + end + end + end else begin + if(priority_bulk) begin + if(operational_allowBulk) begin + if(!reg_hcBulkCurrentED_isZero) begin + endpoint_wantStart = 1'b1; + end + end + end else begin + if(operational_allowControl) begin + if(!reg_hcControlCurrentED_isZero) begin + endpoint_wantStart = 1'b1; + end + end + end + end + end + end + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + endpoint_wantKill = 1'b0; + if(unscheduleAll_fire) begin + endpoint_wantKill = 1'b1; + end + end + + assign endpoint_ED_FA = endpoint_ED_words_0[6 : 0]; + assign endpoint_ED_EN = endpoint_ED_words_0[10 : 7]; + assign endpoint_ED_D = endpoint_ED_words_0[12 : 11]; + assign endpoint_ED_S = endpoint_ED_words_0[13]; + assign endpoint_ED_K = endpoint_ED_words_0[14]; + assign endpoint_ED_F = endpoint_ED_words_0[15]; + assign endpoint_ED_MPS = endpoint_ED_words_0[26 : 16]; + assign endpoint_ED_tailP = endpoint_ED_words_1[31 : 4]; + assign endpoint_ED_H = endpoint_ED_words_2[0]; + assign endpoint_ED_C = endpoint_ED_words_2[1]; + assign endpoint_ED_headP = endpoint_ED_words_2[31 : 4]; + assign endpoint_ED_nextED = endpoint_ED_words_3[31 : 4]; + assign endpoint_ED_tdEmpty = (endpoint_ED_tailP == endpoint_ED_headP); + assign endpoint_ED_isFs = (! endpoint_ED_S); + assign endpoint_ED_isoOut = endpoint_ED_D[0]; + assign when_UsbOhci_l750 = (! (endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_BOOT)); + assign rxTimer_lowSpeed = endpoint_ED_S; + assign endpoint_TD_address = ({4'd0,endpoint_ED_headP} <<< 3'd4); + assign endpoint_TD_CC = endpoint_TD_words_0[31 : 28]; + assign endpoint_TD_EC = endpoint_TD_words_0[27 : 26]; + assign endpoint_TD_T = endpoint_TD_words_0[25 : 24]; + assign endpoint_TD_DI = endpoint_TD_words_0[23 : 21]; + assign endpoint_TD_DP = endpoint_TD_words_0[20 : 19]; + assign endpoint_TD_R = endpoint_TD_words_0[18]; + assign endpoint_TD_CBP = endpoint_TD_words_1[31 : 0]; + assign endpoint_TD_nextTD = endpoint_TD_words_2[31 : 4]; + assign endpoint_TD_BE = endpoint_TD_words_3[31 : 0]; + assign endpoint_TD_FC = endpoint_TD_words_0[26 : 24]; + assign endpoint_TD_SF = endpoint_TD_words_0[15 : 0]; + assign endpoint_TD_isoRelativeFrameNumber = (reg_hcFmNumber_FN - endpoint_TD_SF); + assign endpoint_TD_tooEarly = endpoint_TD_isoRelativeFrameNumber[15]; + assign endpoint_TD_isoFrameNumber = endpoint_TD_isoRelativeFrameNumber[2 : 0]; + assign endpoint_TD_isoOverrun = ((! endpoint_TD_tooEarly) && (_zz_endpoint_TD_isoOverrun < endpoint_TD_isoRelativeFrameNumber)); + assign endpoint_TD_isoLast = (((! endpoint_TD_isoOverrun) && (! endpoint_TD_tooEarly)) && (endpoint_TD_isoFrameNumber == endpoint_TD_FC)); + assign endpoint_TD_isSinglePage = (endpoint_TD_CBP[31 : 12] == endpoint_TD_BE[31 : 12]); + assign endpoint_TD_firstOffset = (endpoint_ED_F ? endpoint_TD_isoBase : _zz_endpoint_TD_firstOffset); + assign endpoint_TD_allowRounding = ((! endpoint_ED_F) && endpoint_TD_R); + assign endpoint_TD_TNext = (endpoint_TD_dataPhaseUpdate ? {1'b1,(! endpoint_dataPhase)} : endpoint_TD_T); + assign endpoint_TD_dataPhaseNext = (endpoint_dataPhase ^ endpoint_TD_dataPhaseUpdate); + assign endpoint_TD_dataPid = (endpoint_dataPhase ? 4'b1011 : 4'b0011); + assign endpoint_TD_dataPidWrong = (endpoint_dataPhase ? 4'b0011 : 4'b1011); + always @(*) begin + endpoint_TD_clear = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + endpoint_TD_clear = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + assign endpoint_tockenType = ((endpoint_ED_D[0] != endpoint_ED_D[1]) ? endpoint_ED_D : endpoint_TD_DP); + assign endpoint_isIn = (endpoint_tockenType == 2'b10); + always @(*) begin + endpoint_applyNextED = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + if(when_UsbOhci_l861) begin + endpoint_applyNextED = 1'b1; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + if(when_UsbOhci_l1415) begin + endpoint_applyNextED = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + assign endpoint_currentAddressFull = {(endpoint_currentAddress[12] ? endpoint_TD_BE[31 : 12] : endpoint_TD_CBP[31 : 12]),endpoint_currentAddress[11 : 0]}; + assign _zz_3 = zz__zz_endpoint_currentAddressBmb(1'b0); + always @(*) _zz_endpoint_currentAddressBmb = _zz_3; + assign endpoint_currentAddressBmb = (endpoint_currentAddressFull & _zz_endpoint_currentAddressBmb); + assign endpoint_transactionSizeMinusOne = (_zz_endpoint_transactionSizeMinusOne - endpoint_currentAddress); + assign endpoint_transactionSize = (endpoint_transactionSizeMinusOne + 14'h0001); + assign endpoint_dataDone = (endpoint_zeroLength || (_zz_endpoint_dataDone < endpoint_currentAddress)); + always @(*) begin + endpoint_dmaLogic_wantExit = 1'b0; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + if(dataTx_data_ready) begin + if(endpoint_dmaLogic_byteCtx_last) begin + endpoint_dmaLogic_wantExit = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + if(when_UsbOhci_l1068) begin + endpoint_dmaLogic_wantExit = 1'b1; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + if(endpoint_dataDone) begin + if(endpoint_isIn) begin + endpoint_dmaLogic_wantExit = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + always @(*) begin + endpoint_dmaLogic_wantStart = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + if(!endpoint_timeCheck) begin + if(!when_UsbOhci_l1118) begin + endpoint_dmaLogic_wantStart = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + if(when_StateMachine_l253_3) begin + endpoint_dmaLogic_wantStart = 1'b1; + end + end + + always @(*) begin + endpoint_dmaLogic_wantKill = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + if(when_UsbOhci_l1128) begin + if(endpoint_timeCheck) begin + endpoint_dmaLogic_wantKill = 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + if(unscheduleAll_fire) begin + endpoint_dmaLogic_wantKill = 1'b1; + end + end + + always @(*) begin + endpoint_dmaLogic_validated = 1'b0; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + endpoint_dmaLogic_validated = 1'b1; + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + end + + assign endpoint_dmaLogic_lengthMax = (~ _zz_endpoint_dmaLogic_lengthMax); + assign endpoint_dmaLogic_lengthCalc = _zz_endpoint_dmaLogic_lengthCalc[5:0]; + assign endpoint_dmaLogic_beatCount = _zz_endpoint_dmaLogic_beatCount[6 : 2]; + assign endpoint_dmaLogic_lengthBmb = _zz_endpoint_dmaLogic_lengthBmb[5:0]; + assign endpoint_dmaLogic_underflowError = (endpoint_dmaLogic_underflow && (! endpoint_TD_allowRounding)); + assign when_UsbOhci_l938 = (((! (endpoint_dmaLogic_stateReg == UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT)) && (! endpoint_isIn)) && ioDma_rsp_valid); + assign endpoint_dmaLogic_byteCtx_last = (endpoint_dmaLogic_byteCtx_counter == endpoint_lastAddress); + assign endpoint_dmaLogic_byteCtx_sel = endpoint_dmaLogic_byteCtx_counter[1:0]; + always @(*) begin + endpoint_dmaLogic_byteCtx_increment = 1'b0; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + if(dataTx_data_ready) begin + endpoint_dmaLogic_byteCtx_increment = 1'b1; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + if(dataRx_data_valid) begin + endpoint_dmaLogic_byteCtx_increment = 1'b1; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + end + + assign endpoint_dmaLogic_headMask = {(endpoint_currentAddress[1 : 0] <= 2'b11),{(endpoint_currentAddress[1 : 0] <= 2'b10),{(endpoint_currentAddress[1 : 0] <= 2'b01),(endpoint_currentAddress[1 : 0] <= 2'b00)}}}; + assign endpoint_dmaLogic_lastMask = {(2'b11 <= _zz_endpoint_dmaLogic_lastMask[1 : 0]),{(2'b10 <= _zz_endpoint_dmaLogic_lastMask_2[1 : 0]),{(2'b01 <= _zz_endpoint_dmaLogic_lastMask_4[1 : 0]),(2'b00 <= _zz_endpoint_dmaLogic_lastMask_6[1 : 0])}}}; + assign endpoint_dmaLogic_fullMask = 4'b1111; + assign endpoint_dmaLogic_beatLast = (dmaCtx_beatCounter == _zz_endpoint_dmaLogic_beatLast); + assign endpoint_byteCountCalc = (_zz_endpoint_byteCountCalc + 14'h0001); + assign endpoint_fsTimeCheck = (endpoint_zeroLength ? (frame_limitCounter == 15'h0000) : (_zz_endpoint_fsTimeCheck <= _zz_endpoint_fsTimeCheck_1)); + assign endpoint_timeCheck = ((endpoint_ED_isFs && endpoint_fsTimeCheck) || (endpoint_ED_S && reg_hcLSThreshold_hit)); + assign endpoint_tdUpdateAddress = ((endpoint_TD_retire && (! ((endpoint_isIn && ((endpoint_TD_CC == 4'b0000) || (endpoint_TD_CC == 4'b1001))) && endpoint_dmaLogic_underflow))) ? 32'h00000000 : endpoint_currentAddressFull); + always @(*) begin + operational_wantExit = 1'b0; + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + if(operational_askExit) begin + operational_wantExit = 1'b1; + end + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + end + + always @(*) begin + operational_wantStart = 1'b0; + if(when_StateMachine_l253_7) begin + operational_wantStart = 1'b1; + end + end + + always @(*) begin + operational_wantKill = 1'b0; + if(unscheduleAll_fire) begin + operational_wantKill = 1'b1; + end + end + + always @(*) begin + operational_askExit = 1'b0; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + operational_askExit = 1'b1; + end + default : begin + end + endcase + end + + assign hc_wantExit = 1'b0; + always @(*) begin + hc_wantStart = 1'b0; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + end + default : begin + hc_wantStart = 1'b1; + end + endcase + end + + assign hc_wantKill = 1'b0; + always @(*) begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_RESET; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_RESUME; + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_OPERATIONAL; + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_SUSPEND; + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_RESET; + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + reg_hcControl_HCFS = UsbOhciAxi4_MainState_SUSPEND; + end + default : begin + end + endcase + end + + assign io_phy_usbReset = (reg_hcControl_HCFS == UsbOhciAxi4_MainState_RESET); + assign io_phy_usbResume = (reg_hcControl_HCFS == UsbOhciAxi4_MainState_RESUME); + always @(*) begin + hc_error = 1'b0; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + if(reg_hcControl_HCFSWrite_valid) begin + case(reg_hcControl_HCFSWrite_payload) + UsbOhciAxi4_MainState_OPERATIONAL : begin + end + default : begin + hc_error = 1'b1; + end + endcase + end + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + end + default : begin + end + endcase + end + + assign _zz_reg_hcControl_HCFSWrite_payload = io_ctrl_cmd_payload_fragment_data[7 : 6]; + assign reg_hcControl_HCFSWrite_payload = _zz_reg_hcControl_HCFSWrite_payload; + assign when_BusSlaveFactory_l968 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_1 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_2 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_3 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_4 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_5 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_6 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_7 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_8 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_9 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_10 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_11 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_12 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_13 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_14 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_15 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_16 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_17 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_18 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_19 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_20 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_21 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_22 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_23 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_24 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_25 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_26 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_27 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_28 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_29 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_30 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_31 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_32 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_33 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_BusSlaveFactory_l968_34 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_35 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_36 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_37 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_38 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_39 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_40 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_41 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_42 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_43 = io_ctrl_cmd_payload_fragment_mask[1]; + assign when_BusSlaveFactory_l968_44 = io_ctrl_cmd_payload_fragment_mask[3]; + assign when_BusSlaveFactory_l968_45 = io_ctrl_cmd_payload_fragment_mask[0]; + assign when_BusSlaveFactory_l968_46 = io_ctrl_cmd_payload_fragment_mask[2]; + assign when_UsbOhci_l253 = (doSoftReset || _zz_when_UsbOhci_l253); + always @(*) begin + token_stateNext = token_stateReg; + case(token_stateReg) + UsbOhciAxi4_token_enumDef_INIT : begin + token_stateNext = UsbOhciAxi4_token_enumDef_PID; + end + UsbOhciAxi4_token_enumDef_PID : begin + if(io_phy_tx_ready) begin + token_stateNext = UsbOhciAxi4_token_enumDef_B1; + end + end + UsbOhciAxi4_token_enumDef_B1 : begin + if(io_phy_tx_ready) begin + token_stateNext = UsbOhciAxi4_token_enumDef_B2; + end + end + UsbOhciAxi4_token_enumDef_B2 : begin + if(io_phy_tx_ready) begin + token_stateNext = UsbOhciAxi4_token_enumDef_EOP; + end + end + UsbOhciAxi4_token_enumDef_EOP : begin + if(io_phy_txEop) begin + token_stateNext = UsbOhciAxi4_token_enumDef_BOOT; + end + end + default : begin + end + endcase + if(token_wantStart) begin + token_stateNext = UsbOhciAxi4_token_enumDef_INIT; + end + if(token_wantKill) begin + token_stateNext = UsbOhciAxi4_token_enumDef_BOOT; + end + end + + assign when_StateMachine_l237 = ((token_stateReg == UsbOhciAxi4_token_enumDef_BOOT) && (! (token_stateNext == UsbOhciAxi4_token_enumDef_BOOT))); + assign unscheduleAll_fire = (unscheduleAll_valid && unscheduleAll_ready); + always @(*) begin + dataTx_stateNext = dataTx_stateReg; + case(dataTx_stateReg) + UsbOhciAxi4_dataTx_enumDef_PID : begin + if(io_phy_tx_ready) begin + if(dataTx_data_valid) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_DATA; + end else begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_CRC_0; + end + end + end + UsbOhciAxi4_dataTx_enumDef_DATA : begin + if(io_phy_tx_ready) begin + if(dataTx_data_payload_last) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_CRC_0; + end + end + end + UsbOhciAxi4_dataTx_enumDef_CRC_0 : begin + if(io_phy_tx_ready) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_CRC_1; + end + end + UsbOhciAxi4_dataTx_enumDef_CRC_1 : begin + if(io_phy_tx_ready) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_EOP; + end + end + UsbOhciAxi4_dataTx_enumDef_EOP : begin + if(io_phy_txEop) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_BOOT; + end + end + default : begin + end + endcase + if(dataTx_wantStart) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_PID; + end + if(dataTx_wantKill) begin + dataTx_stateNext = UsbOhciAxi4_dataTx_enumDef_BOOT; + end + end + + always @(*) begin + dataRx_stateNext = dataRx_stateReg; + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + if(io_phy_rx_active) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_PID; + end else begin + if(rxTimer_rxTimeout) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_BOOT; + end + end + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + if(_zz_1) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_DATA; + end else begin + if(when_Misc_l64) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_BOOT; + end + end + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + if(when_Misc_l70) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_BOOT; + end + end + default : begin + end + endcase + if(dataRx_wantStart) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_IDLE; + end + if(dataRx_wantKill) begin + dataRx_stateNext = UsbOhciAxi4_dataRx_enumDef_BOOT; + end + end + + assign when_Misc_l64 = (! io_phy_rx_active); + assign when_Misc_l70 = (! io_phy_rx_active); + assign when_Misc_l71 = ((! (&dataRx_valids)) || (dataRx_crc16_io_result != 16'h800d)); + assign when_Misc_l78 = (&dataRx_valids); + assign when_StateMachine_l253 = ((! (dataRx_stateReg == UsbOhciAxi4_dataRx_enumDef_IDLE)) && (dataRx_stateNext == UsbOhciAxi4_dataRx_enumDef_IDLE)); + assign when_Misc_l85 = (! (dataRx_stateReg == UsbOhciAxi4_dataRx_enumDef_BOOT)); + always @(*) begin + sof_stateNext = sof_stateReg; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + if(token_wantExit) begin + sof_stateNext = UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD; + end + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + if(when_UsbOhci_l626) begin + sof_stateNext = UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP; + end + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + sof_stateNext = UsbOhciAxi4_sof_enumDef_BOOT; + end + end + default : begin + end + endcase + if(sof_wantStart) begin + sof_stateNext = UsbOhciAxi4_sof_enumDef_FRAME_TX; + end + if(sof_wantKill) begin + sof_stateNext = UsbOhciAxi4_sof_enumDef_BOOT; + end + end + + assign when_UsbOhci_l206 = (dmaWriteCtx_counter == 4'b0000); + assign when_UsbOhci_l206_1 = (dmaWriteCtx_counter == 4'b0001); + assign when_UsbOhci_l626 = (ioDma_cmd_ready && ioDma_cmd_payload_last); + assign when_StateMachine_l237_1 = ((sof_stateReg == UsbOhciAxi4_sof_enumDef_BOOT) && (! (sof_stateNext == UsbOhciAxi4_sof_enumDef_BOOT))); + always @(*) begin + endpoint_stateNext = endpoint_stateReg; + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + if(ioDma_cmd_ready) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP; + end + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + if(when_UsbOhci_l855) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE; + end + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + if(when_UsbOhci_l861) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_BOOT; + end else begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + if(ioDma_cmd_ready) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + if(when_UsbOhci_l898) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE; + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME; + if(endpoint_ED_F) begin + if(endpoint_TD_tooEarlyReg) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC; + end + if(endpoint_TD_isoOverrunReg) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD; + end + end + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + if(endpoint_timeCheck) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ABORD; + end else begin + if(when_UsbOhci_l1118) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TOKEN; + end else begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_BUFFER_READ; + end + end + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + if(when_UsbOhci_l1128) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_TOKEN; + if(endpoint_timeCheck) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ABORD; + end + end + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + if(token_wantExit) begin + if(endpoint_isIn) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_DATA_RX; + end else begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_DATA_TX; + end + end + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + if(dataTx_wantExit) begin + if(endpoint_ED_F) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS; + end else begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ACK_RX; + end + end + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + if(dataRx_wantExit) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE; + end + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA; + if(!dataRx_notResponding) begin + if(!dataRx_stuffingError) begin + if(!dataRx_pidError) begin + if(!endpoint_ED_F) begin + case(dataRx_pid) + 4'b1010 : begin + end + 4'b1110 : begin + end + 4'b0011, 4'b1011 : begin + if(when_UsbOhci_l1263) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ACK_TX_0; + end + end + default : begin + end + endcase + end + if(when_UsbOhci_l1274) begin + if(!dataRx_crcError) begin + if(when_UsbOhci_l1283) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ACK_TX_0; + end + end + end + end + end + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + if(when_UsbOhci_l1205) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS; + if(!when_UsbOhci_l1207) begin + if(!endpoint_ackRxStuffing) begin + if(!endpoint_ackRxPidFailure) begin + case(endpoint_ackRxPid) + 4'b0010 : begin + end + 4'b1010 : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC; + end + 4'b1110 : begin + end + default : begin + end + endcase + end + end + end + end + if(rxTimer_rxTimeout) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS; + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + if(rxTimer_ackTx) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ACK_TX_1; + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + if(io_phy_tx_ready) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP; + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + if(io_phy_txEop) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA; + end + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + if(when_UsbOhci_l1311) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS; + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD; + if(!endpoint_ED_F) begin + if(endpoint_TD_noUpdate) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + if(when_UsbOhci_l1393) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD; + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + if(when_UsbOhci_l1408) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC; + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_BOOT; + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_BOOT; + end + default : begin + end + endcase + if(endpoint_wantStart) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD; + end + if(endpoint_wantKill) begin + endpoint_stateNext = UsbOhciAxi4_endpoint_enumDef_BOOT; + end + end + + assign when_UsbOhci_l188 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0000)); + assign when_UsbOhci_l188_1 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0001)); + assign when_UsbOhci_l188_2 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0010)); + assign when_UsbOhci_l188_3 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0011)); + assign when_UsbOhci_l855 = (ioDma_rsp_valid && ioDma_rsp_payload_last); + assign when_UsbOhci_l861 = ((endpoint_ED_H || endpoint_ED_K) || endpoint_ED_tdEmpty); + assign when_UsbOhci_l188_4 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0000)); + assign when_UsbOhci_l188_5 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0001)); + assign when_UsbOhci_l188_6 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0010)); + assign when_UsbOhci_l188_7 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0011)); + assign when_UsbOhci_l891 = (endpoint_TD_isoFrameNumber == 3'b000); + assign when_UsbOhci_l188_8 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0100)); + assign when_UsbOhci_l188_9 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0100)); + assign when_UsbOhci_l891_1 = (endpoint_TD_isoFrameNumber == 3'b001); + assign when_UsbOhci_l188_10 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0100)); + assign when_UsbOhci_l188_11 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0101)); + assign when_UsbOhci_l891_2 = (endpoint_TD_isoFrameNumber == 3'b010); + assign when_UsbOhci_l188_12 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0101)); + assign when_UsbOhci_l188_13 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0101)); + assign when_UsbOhci_l891_3 = (endpoint_TD_isoFrameNumber == 3'b011); + assign when_UsbOhci_l188_14 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0101)); + assign when_UsbOhci_l188_15 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0110)); + assign when_UsbOhci_l891_4 = (endpoint_TD_isoFrameNumber == 3'b100); + assign when_UsbOhci_l188_16 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0110)); + assign when_UsbOhci_l188_17 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0110)); + assign when_UsbOhci_l891_5 = (endpoint_TD_isoFrameNumber == 3'b101); + assign when_UsbOhci_l188_18 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0110)); + assign when_UsbOhci_l188_19 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0111)); + assign when_UsbOhci_l891_6 = (endpoint_TD_isoFrameNumber == 3'b110); + assign when_UsbOhci_l188_20 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0111)); + assign when_UsbOhci_l188_21 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0111)); + assign when_UsbOhci_l891_7 = (endpoint_TD_isoFrameNumber == 3'b111); + assign when_UsbOhci_l188_22 = (ioDma_rsp_valid && (dmaReadCtx_counter == 4'b0111)); + assign when_UsbOhci_l898 = (ioDma_rsp_fire && ioDma_rsp_payload_last); + assign _zz_endpoint_lastAddress = (_zz__zz_endpoint_lastAddress - 14'h0001); + assign when_UsbOhci_l1118 = (endpoint_isIn || endpoint_zeroLength); + always @(*) begin + when_UsbOhci_l1274 = 1'b0; + if(endpoint_ED_F) begin + case(dataRx_pid) + 4'b1110, 4'b1010 : begin + end + 4'b0011, 4'b1011 : begin + when_UsbOhci_l1274 = 1'b1; + end + default : begin + end + endcase + end else begin + case(dataRx_pid) + 4'b1010 : begin + end + 4'b1110 : begin + end + 4'b0011, 4'b1011 : begin + if(!when_UsbOhci_l1263) begin + when_UsbOhci_l1274 = 1'b1; + end + end + default : begin + end + endcase + end + end + + assign when_UsbOhci_l1263 = (dataRx_pid == endpoint_TD_dataPidWrong); + assign when_UsbOhci_l1283 = (! endpoint_ED_F); + assign when_UsbOhci_l1200 = ((! rxPidOk) || endpoint_ackRxFired); + assign when_UsbOhci_l1205 = ((! io_phy_rx_active) && endpoint_ackRxActivated); + assign when_UsbOhci_l1207 = (! endpoint_ackRxFired); + assign when_UsbOhci_l1331 = ((endpoint_dmaLogic_underflow || (_zz_when_UsbOhci_l1331 < endpoint_currentAddress)) || endpoint_zeroLength); + assign when_UsbOhci_l1346 = (endpoint_TD_EC != 2'b10); + assign when_UsbOhci_l206_2 = (dmaWriteCtx_counter == 4'b0000); + assign when_UsbOhci_l206_3 = (dmaWriteCtx_counter == 4'b0000); + assign _zz_ioDma_cmd_payload_fragment_data = {endpoint_TD_CC,_zz__zz_ioDma_cmd_payload_fragment_data}; + assign when_UsbOhci_l1378 = (endpoint_TD_isoFrameNumber == 3'b000); + assign when_UsbOhci_l206_4 = (dmaWriteCtx_counter == 4'b0100); + assign when_UsbOhci_l1378_1 = (endpoint_TD_isoFrameNumber == 3'b001); + assign when_UsbOhci_l206_5 = (dmaWriteCtx_counter == 4'b0100); + assign when_UsbOhci_l1378_2 = (endpoint_TD_isoFrameNumber == 3'b010); + assign when_UsbOhci_l206_6 = (dmaWriteCtx_counter == 4'b0101); + assign when_UsbOhci_l1378_3 = (endpoint_TD_isoFrameNumber == 3'b011); + assign when_UsbOhci_l206_7 = (dmaWriteCtx_counter == 4'b0101); + assign when_UsbOhci_l1378_4 = (endpoint_TD_isoFrameNumber == 3'b100); + assign when_UsbOhci_l206_8 = (dmaWriteCtx_counter == 4'b0110); + assign when_UsbOhci_l1378_5 = (endpoint_TD_isoFrameNumber == 3'b101); + assign when_UsbOhci_l206_9 = (dmaWriteCtx_counter == 4'b0110); + assign when_UsbOhci_l1378_6 = (endpoint_TD_isoFrameNumber == 3'b110); + assign when_UsbOhci_l206_10 = (dmaWriteCtx_counter == 4'b0111); + assign when_UsbOhci_l1378_7 = (endpoint_TD_isoFrameNumber == 3'b111); + assign when_UsbOhci_l206_11 = (dmaWriteCtx_counter == 4'b0111); + assign when_UsbOhci_l206_12 = (dmaWriteCtx_counter == 4'b0000); + assign when_UsbOhci_l206_13 = (dmaWriteCtx_counter == 4'b0001); + assign when_UsbOhci_l206_14 = (dmaWriteCtx_counter == 4'b0010); + assign when_UsbOhci_l1393 = (ioDma_cmd_ready && ioDma_cmd_payload_last); + assign when_UsbOhci_l206_15 = (dmaWriteCtx_counter == 4'b0010); + assign when_UsbOhci_l1408 = (ioDma_cmd_ready && ioDma_cmd_payload_last); + assign when_UsbOhci_l1415 = (! (endpoint_ED_F && endpoint_TD_isoOverrunReg)); + assign when_UsbOhci_l1418 = (endpoint_flowType != UsbOhciAxi4_FlowType_PERIODIC); + assign when_StateMachine_l237_2 = ((endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_BOOT) && (! (endpoint_stateNext == UsbOhciAxi4_endpoint_enumDef_BOOT))); + assign when_StateMachine_l253_1 = ((! (endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_TOKEN)) && (endpoint_stateNext == UsbOhciAxi4_endpoint_enumDef_TOKEN)); + assign when_StateMachine_l253_2 = ((! (endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_DATA_TX)) && (endpoint_stateNext == UsbOhciAxi4_endpoint_enumDef_DATA_TX)); + assign when_StateMachine_l253_3 = ((! (endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_DATA_RX)) && (endpoint_stateNext == UsbOhciAxi4_endpoint_enumDef_DATA_RX)); + assign when_StateMachine_l253_4 = ((! (endpoint_stateReg == UsbOhciAxi4_endpoint_enumDef_ACK_RX)) && (endpoint_stateNext == UsbOhciAxi4_endpoint_enumDef_ACK_RX)); + always @(*) begin + endpoint_dmaLogic_stateNext = endpoint_dmaLogic_stateReg; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + if(endpoint_isIn) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB; + end else begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + if(dataTx_data_ready) begin + if(endpoint_dmaLogic_byteCtx_last) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + if(dataRx_wantExit) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + if(when_UsbOhci_l1068) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT; + end else begin + if(endpoint_dmaLogic_validated) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + if(endpoint_dataDone) begin + if(endpoint_isIn) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT; + end else begin + if(dmaCtx_pendingEmpty) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB; + end + end + end else begin + if(endpoint_isIn) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD; + end else begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + if(ioDma_cmd_ready) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD; + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + if(ioDma_cmd_ready) begin + if(endpoint_dmaLogic_beatLast) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD; + end + end + end + default : begin + end + endcase + if(endpoint_dmaLogic_wantStart) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT; + end + if(endpoint_dmaLogic_wantKill) begin + endpoint_dmaLogic_stateNext = UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT; + end + end + + assign when_UsbOhci_l1025 = (&endpoint_dmaLogic_byteCtx_sel); + assign when_UsbOhci_l1054 = (_zz_when_UsbOhci_l1054 < endpoint_transactionSize); + assign _zz_2 = ({3'd0,1'b1} <<< endpoint_dmaLogic_byteCtx_sel); + assign when_UsbOhci_l1063 = (&endpoint_dmaLogic_byteCtx_sel); + assign when_UsbOhci_l1068 = (endpoint_dmaLogic_fromUsbCounter == 11'h000); + assign when_StateMachine_l253_5 = ((! (endpoint_dmaLogic_stateReg == UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB)) && (endpoint_dmaLogic_stateNext == UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB)); + assign endpoint_dmaLogic_fsmStopped = (endpoint_dmaLogic_stateReg == UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT); + assign when_UsbOhci_l1128 = (endpoint_dmaLogic_stateReg == UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB); + assign when_UsbOhci_l1311 = (endpoint_dmaLogic_stateReg == UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT); + always @(*) begin + operational_stateNext = operational_stateReg; + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + if(sof_wantExit) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_ARBITER; + end + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + if(operational_askExit) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_BOOT; + end else begin + if(frame_limitHit) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_WAIT_SOF; + end else begin + if(when_UsbOhci_l1487) begin + if(when_UsbOhci_l1488) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD; + end else begin + if(!reg_hcPeriodCurrentED_isZero) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_END_POINT; + end + end + end else begin + if(priority_bulk) begin + if(operational_allowBulk) begin + if(!reg_hcBulkCurrentED_isZero) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_END_POINT; + end + end + end else begin + if(operational_allowControl) begin + if(!reg_hcControlCurrentED_isZero) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_END_POINT; + end + end + end + end + end + end + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + if(endpoint_wantExit) begin + case(endpoint_status_1) + UsbOhciAxi4_endpoint_Status_OK : begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_ARBITER; + end + default : begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_WAIT_SOF; + end + endcase + end + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + if(ioDma_cmd_ready) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP; + end + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + if(ioDma_rsp_valid) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_ARBITER; + end + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + if(frame_tick) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_SOF; + end + end + default : begin + end + endcase + if(operational_wantStart) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_WAIT_SOF; + end + if(operational_wantKill) begin + operational_stateNext = UsbOhciAxi4_operational_enumDef_BOOT; + end + end + + assign when_UsbOhci_l1461 = (operational_allowPeriodic && (! operational_periodicDone)); + assign when_UsbOhci_l1488 = (! operational_periodicHeadFetched); + assign when_UsbOhci_l1487 = ((operational_allowPeriodic && (! operational_periodicDone)) && (! frame_section1)); + assign when_StateMachine_l237_3 = ((operational_stateReg == UsbOhciAxi4_operational_enumDef_BOOT) && (! (operational_stateNext == UsbOhciAxi4_operational_enumDef_BOOT))); + assign when_StateMachine_l253_6 = ((! (operational_stateReg == UsbOhciAxi4_operational_enumDef_SOF)) && (operational_stateNext == UsbOhciAxi4_operational_enumDef_SOF)); + assign hc_operationalIsDone = (operational_stateReg == UsbOhciAxi4_operational_enumDef_BOOT); + always @(*) begin + hc_stateNext = hc_stateReg; + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + if(reg_hcControl_HCFSWrite_valid) begin + case(reg_hcControl_HCFSWrite_payload) + UsbOhciAxi4_MainState_OPERATIONAL : begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_OPERATIONAL; + end + default : begin + end + endcase + end + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + if(when_UsbOhci_l1616) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_OPERATIONAL; + end + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + if(when_UsbOhci_l1625) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_RESUME; + end else begin + if(when_UsbOhci_l1628) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_OPERATIONAL; + end + end + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + if(when_UsbOhci_l1639) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_RESET; + end + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + if(when_UsbOhci_l1652) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_SUSPEND; + end + end + default : begin + end + endcase + if(when_UsbOhci_l1659) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_ANY_TO_RESET; + end + if(reg_hcCommandStatus_startSoftReset) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND; + end + if(hc_wantStart) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_RESET; + end + if(hc_wantKill) begin + hc_stateNext = UsbOhciAxi4_hc_enumDef_BOOT; + end + end + + assign when_UsbOhci_l1616 = (reg_hcControl_HCFSWrite_valid && (reg_hcControl_HCFSWrite_payload == UsbOhciAxi4_MainState_OPERATIONAL)); + assign when_UsbOhci_l1625 = (reg_hcRhStatus_DRWE && (reg_hcRhPortStatus_0_CSC_reg != 1'b0)); + assign when_UsbOhci_l1628 = (reg_hcControl_HCFSWrite_valid && (reg_hcControl_HCFSWrite_payload == UsbOhciAxi4_MainState_OPERATIONAL)); + assign when_UsbOhci_l1639 = (! doUnschedule); + assign when_UsbOhci_l1652 = (((! doUnschedule) && (! doSoftReset)) && hc_operationalIsDone); + assign when_StateMachine_l253_7 = ((! (hc_stateReg == UsbOhciAxi4_hc_enumDef_OPERATIONAL)) && (hc_stateNext == UsbOhciAxi4_hc_enumDef_OPERATIONAL)); + assign when_StateMachine_l253_8 = ((! (hc_stateReg == UsbOhciAxi4_hc_enumDef_ANY_TO_RESET)) && (hc_stateNext == UsbOhciAxi4_hc_enumDef_ANY_TO_RESET)); + assign when_StateMachine_l253_9 = ((! (hc_stateReg == UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND)) && (hc_stateNext == UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND)); + assign when_UsbOhci_l1659 = (reg_hcControl_HCFSWrite_valid && (reg_hcControl_HCFSWrite_payload == UsbOhciAxi4_MainState_RESET)); + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + dmaCtx_pendingCounter <= 4'b0000; + dmaCtx_beatCounter <= 6'h00; + io_dma_cmd_payload_first <= 1'b1; + dmaReadCtx_counter <= 4'b0000; + dmaWriteCtx_counter <= 4'b0000; + _zz_io_ctrl_rsp_valid_1 <= 1'b0; + doUnschedule <= 1'b0; + doSoftReset <= 1'b0; + reg_hcControl_IR <= 1'b0; + reg_hcControl_RWC <= 1'b0; + reg_hcFmNumber_overflow <= 1'b0; + reg_hcPeriodicStart_PS <= 14'h0000; + io_phy_overcurrent_regNext <= 1'b0; + reg_hcRhPortStatus_0_connected <= 1'b0; + reg_hcRhPortStatus_0_CCS_regNext <= 1'b0; + interruptDelay_counter <= 3'b111; + endpoint_dmaLogic_push <= 1'b0; + _zz_when_UsbOhci_l253 <= 1'b1; + token_stateReg <= UsbOhciAxi4_token_enumDef_BOOT; + dataTx_stateReg <= UsbOhciAxi4_dataTx_enumDef_BOOT; + dataRx_stateReg <= UsbOhciAxi4_dataRx_enumDef_BOOT; + sof_stateReg <= UsbOhciAxi4_sof_enumDef_BOOT; + endpoint_stateReg <= UsbOhciAxi4_endpoint_enumDef_BOOT; + endpoint_dmaLogic_stateReg <= UsbOhciAxi4_endpoint_dmaLogic_enumDef_BOOT; + operational_stateReg <= UsbOhciAxi4_operational_enumDef_BOOT; + hc_stateReg <= UsbOhciAxi4_hc_enumDef_BOOT; + end else begin + dmaCtx_pendingCounter <= (_zz_dmaCtx_pendingCounter - _zz_dmaCtx_pendingCounter_3); + if(ioDma_cmd_fire) begin + dmaCtx_beatCounter <= (dmaCtx_beatCounter + 6'h01); + if(io_dma_cmd_payload_last) begin + dmaCtx_beatCounter <= 6'h00; + end + end + if(io_dma_cmd_fire) begin + io_dma_cmd_payload_first <= io_dma_cmd_payload_last; + end + if(ioDma_rsp_fire) begin + dmaReadCtx_counter <= (dmaReadCtx_counter + 4'b0001); + if(ioDma_rsp_payload_last) begin + dmaReadCtx_counter <= 4'b0000; + end + end + if(ioDma_cmd_fire) begin + dmaWriteCtx_counter <= (dmaWriteCtx_counter + 4'b0001); + if(ioDma_cmd_payload_last) begin + dmaWriteCtx_counter <= 4'b0000; + end + end + if(_zz_ctrl_rsp_ready_1) begin + _zz_io_ctrl_rsp_valid_1 <= (ctrl_rsp_valid && _zz_ctrl_rsp_ready); + end + if(unscheduleAll_ready) begin + doUnschedule <= 1'b0; + end + if(when_UsbOhci_l236) begin + doSoftReset <= 1'b0; + end + io_phy_overcurrent_regNext <= io_phy_overcurrent; + if(io_phy_ports_0_connect) begin + reg_hcRhPortStatus_0_connected <= 1'b1; + end + if(io_phy_ports_0_disconnect) begin + reg_hcRhPortStatus_0_connected <= 1'b0; + end + reg_hcRhPortStatus_0_CCS_regNext <= reg_hcRhPortStatus_0_CCS; + if(frame_reload) begin + if(when_UsbOhci_l540) begin + reg_hcFmNumber_overflow <= 1'b1; + end + end + if(when_UsbOhci_l685) begin + interruptDelay_counter <= (interruptDelay_counter - 3'b001); + end + if(when_UsbOhci_l689) begin + interruptDelay_counter <= interruptDelay_load_payload; + end + if(interruptDelay_disable) begin + interruptDelay_counter <= 3'b111; + end + endpoint_dmaLogic_push <= 1'b0; + case(io_ctrl_cmd_payload_fragment_address) + 12'h004 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_5) begin + reg_hcControl_IR <= io_ctrl_cmd_payload_fragment_data[8]; + end + if(when_BusSlaveFactory_l968_6) begin + reg_hcControl_RWC <= io_ctrl_cmd_payload_fragment_data[9]; + end + end + end + 12'h040 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_36) begin + reg_hcPeriodicStart_PS[7 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 0]; + end + if(when_BusSlaveFactory_l968_37) begin + reg_hcPeriodicStart_PS[13 : 8] <= io_ctrl_cmd_payload_fragment_data[13 : 8]; + end + end + end + default : begin + end + endcase + _zz_when_UsbOhci_l253 <= 1'b0; + token_stateReg <= token_stateNext; + dataTx_stateReg <= dataTx_stateNext; + dataRx_stateReg <= dataRx_stateNext; + sof_stateReg <= sof_stateNext; + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + reg_hcFmNumber_overflow <= 1'b0; + end + end + default : begin + end + endcase + endpoint_stateReg <= endpoint_stateNext; + endpoint_dmaLogic_stateReg <= endpoint_dmaLogic_stateNext; + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + if(dataRx_wantExit) begin + endpoint_dmaLogic_push <= (|endpoint_dmaLogic_byteCtx_sel); + end + if(dataRx_data_valid) begin + if(when_UsbOhci_l1063) begin + endpoint_dmaLogic_push <= 1'b1; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + end + default : begin + end + endcase + operational_stateReg <= operational_stateNext; + hc_stateReg <= hc_stateNext; + if(when_StateMachine_l253_8) begin + doUnschedule <= 1'b1; + end + if(when_StateMachine_l253_9) begin + doUnschedule <= 1'b1; + end + if(reg_hcCommandStatus_startSoftReset) begin + doSoftReset <= 1'b1; + end + end + end + + always @(posedge ctrl_clk) begin + if(_zz_ctrl_rsp_ready_1) begin + _zz_io_ctrl_rsp_payload_last <= ctrl_rsp_payload_last; + _zz_io_ctrl_rsp_payload_fragment_source <= ctrl_rsp_payload_fragment_source; + _zz_io_ctrl_rsp_payload_fragment_opcode <= ctrl_rsp_payload_fragment_opcode; + _zz_io_ctrl_rsp_payload_fragment_data <= ctrl_rsp_payload_fragment_data; + end + if(when_BusSlaveFactory_l377_1) begin + if(when_BusSlaveFactory_l379_1) begin + reg_hcCommandStatus_CLF <= _zz_reg_hcCommandStatus_CLF[0]; + end + end + if(when_BusSlaveFactory_l377_2) begin + if(when_BusSlaveFactory_l379_2) begin + reg_hcCommandStatus_BLF <= _zz_reg_hcCommandStatus_BLF[0]; + end + end + if(when_BusSlaveFactory_l377_3) begin + if(when_BusSlaveFactory_l379_3) begin + reg_hcCommandStatus_OCR <= _zz_reg_hcCommandStatus_OCR[0]; + end + end + if(when_BusSlaveFactory_l377_4) begin + if(when_BusSlaveFactory_l379_4) begin + reg_hcInterrupt_MIE <= _zz_reg_hcInterrupt_MIE[0]; + end + end + if(when_BusSlaveFactory_l341) begin + if(when_BusSlaveFactory_l347) begin + reg_hcInterrupt_MIE <= _zz_reg_hcInterrupt_MIE_1[0]; + end + end + if(when_BusSlaveFactory_l341_1) begin + if(when_BusSlaveFactory_l347_1) begin + reg_hcInterrupt_SO_status <= _zz_reg_hcInterrupt_SO_status[0]; + end + end + if(when_BusSlaveFactory_l377_5) begin + if(when_BusSlaveFactory_l379_5) begin + reg_hcInterrupt_SO_enable <= _zz_reg_hcInterrupt_SO_enable[0]; + end + end + if(when_BusSlaveFactory_l341_2) begin + if(when_BusSlaveFactory_l347_2) begin + reg_hcInterrupt_SO_enable <= _zz_reg_hcInterrupt_SO_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_3) begin + if(when_BusSlaveFactory_l347_3) begin + reg_hcInterrupt_WDH_status <= _zz_reg_hcInterrupt_WDH_status[0]; + end + end + if(when_BusSlaveFactory_l377_6) begin + if(when_BusSlaveFactory_l379_6) begin + reg_hcInterrupt_WDH_enable <= _zz_reg_hcInterrupt_WDH_enable[0]; + end + end + if(when_BusSlaveFactory_l341_4) begin + if(when_BusSlaveFactory_l347_4) begin + reg_hcInterrupt_WDH_enable <= _zz_reg_hcInterrupt_WDH_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_5) begin + if(when_BusSlaveFactory_l347_5) begin + reg_hcInterrupt_SF_status <= _zz_reg_hcInterrupt_SF_status[0]; + end + end + if(when_BusSlaveFactory_l377_7) begin + if(when_BusSlaveFactory_l379_7) begin + reg_hcInterrupt_SF_enable <= _zz_reg_hcInterrupt_SF_enable[0]; + end + end + if(when_BusSlaveFactory_l341_6) begin + if(when_BusSlaveFactory_l347_6) begin + reg_hcInterrupt_SF_enable <= _zz_reg_hcInterrupt_SF_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_7) begin + if(when_BusSlaveFactory_l347_7) begin + reg_hcInterrupt_RD_status <= _zz_reg_hcInterrupt_RD_status[0]; + end + end + if(when_BusSlaveFactory_l377_8) begin + if(when_BusSlaveFactory_l379_8) begin + reg_hcInterrupt_RD_enable <= _zz_reg_hcInterrupt_RD_enable[0]; + end + end + if(when_BusSlaveFactory_l341_8) begin + if(when_BusSlaveFactory_l347_8) begin + reg_hcInterrupt_RD_enable <= _zz_reg_hcInterrupt_RD_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_9) begin + if(when_BusSlaveFactory_l347_9) begin + reg_hcInterrupt_UE_status <= _zz_reg_hcInterrupt_UE_status[0]; + end + end + if(when_BusSlaveFactory_l377_9) begin + if(when_BusSlaveFactory_l379_9) begin + reg_hcInterrupt_UE_enable <= _zz_reg_hcInterrupt_UE_enable[0]; + end + end + if(when_BusSlaveFactory_l341_10) begin + if(when_BusSlaveFactory_l347_10) begin + reg_hcInterrupt_UE_enable <= _zz_reg_hcInterrupt_UE_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_11) begin + if(when_BusSlaveFactory_l347_11) begin + reg_hcInterrupt_FNO_status <= _zz_reg_hcInterrupt_FNO_status[0]; + end + end + if(when_BusSlaveFactory_l377_10) begin + if(when_BusSlaveFactory_l379_10) begin + reg_hcInterrupt_FNO_enable <= _zz_reg_hcInterrupt_FNO_enable[0]; + end + end + if(when_BusSlaveFactory_l341_12) begin + if(when_BusSlaveFactory_l347_12) begin + reg_hcInterrupt_FNO_enable <= _zz_reg_hcInterrupt_FNO_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_13) begin + if(when_BusSlaveFactory_l347_13) begin + reg_hcInterrupt_RHSC_status <= _zz_reg_hcInterrupt_RHSC_status[0]; + end + end + if(when_BusSlaveFactory_l377_11) begin + if(when_BusSlaveFactory_l379_11) begin + reg_hcInterrupt_RHSC_enable <= _zz_reg_hcInterrupt_RHSC_enable[0]; + end + end + if(when_BusSlaveFactory_l341_14) begin + if(when_BusSlaveFactory_l347_14) begin + reg_hcInterrupt_RHSC_enable <= _zz_reg_hcInterrupt_RHSC_enable_1[0]; + end + end + if(when_BusSlaveFactory_l341_15) begin + if(when_BusSlaveFactory_l347_15) begin + reg_hcInterrupt_OC_status <= _zz_reg_hcInterrupt_OC_status[0]; + end + end + if(when_BusSlaveFactory_l377_12) begin + if(when_BusSlaveFactory_l379_12) begin + reg_hcInterrupt_OC_enable <= _zz_reg_hcInterrupt_OC_enable[0]; + end + end + if(when_BusSlaveFactory_l341_16) begin + if(when_BusSlaveFactory_l347_16) begin + reg_hcInterrupt_OC_enable <= _zz_reg_hcInterrupt_OC_enable_1[0]; + end + end + if(reg_hcCommandStatus_OCR) begin + reg_hcInterrupt_OC_status <= 1'b1; + end + if(when_BusSlaveFactory_l341_17) begin + if(when_BusSlaveFactory_l347_17) begin + reg_hcRhStatus_CCIC <= _zz_reg_hcRhStatus_CCIC[0]; + end + end + if(when_UsbOhci_l409) begin + reg_hcRhStatus_CCIC <= 1'b1; + end + if(reg_hcRhStatus_setRemoteWakeupEnable) begin + reg_hcRhStatus_DRWE <= 1'b1; + end + if(reg_hcRhStatus_clearRemoteWakeupEnable) begin + reg_hcRhStatus_DRWE <= 1'b0; + end + if(reg_hcRhPortStatus_0_CSC_clear) begin + reg_hcRhPortStatus_0_CSC_reg <= 1'b0; + end + if(reg_hcRhPortStatus_0_CSC_set) begin + reg_hcRhPortStatus_0_CSC_reg <= 1'b1; + end + if(reg_hcRhPortStatus_0_CSC_set) begin + reg_hcInterrupt_RHSC_status <= 1'b1; + end + if(reg_hcRhPortStatus_0_PESC_clear) begin + reg_hcRhPortStatus_0_PESC_reg <= 1'b0; + end + if(reg_hcRhPortStatus_0_PESC_set) begin + reg_hcRhPortStatus_0_PESC_reg <= 1'b1; + end + if(reg_hcRhPortStatus_0_PESC_set) begin + reg_hcInterrupt_RHSC_status <= 1'b1; + end + if(reg_hcRhPortStatus_0_PSSC_clear) begin + reg_hcRhPortStatus_0_PSSC_reg <= 1'b0; + end + if(reg_hcRhPortStatus_0_PSSC_set) begin + reg_hcRhPortStatus_0_PSSC_reg <= 1'b1; + end + if(reg_hcRhPortStatus_0_PSSC_set) begin + reg_hcInterrupt_RHSC_status <= 1'b1; + end + if(reg_hcRhPortStatus_0_OCIC_clear) begin + reg_hcRhPortStatus_0_OCIC_reg <= 1'b0; + end + if(reg_hcRhPortStatus_0_OCIC_set) begin + reg_hcRhPortStatus_0_OCIC_reg <= 1'b1; + end + if(reg_hcRhPortStatus_0_OCIC_set) begin + reg_hcInterrupt_RHSC_status <= 1'b1; + end + if(reg_hcRhPortStatus_0_PRSC_clear) begin + reg_hcRhPortStatus_0_PRSC_reg <= 1'b0; + end + if(reg_hcRhPortStatus_0_PRSC_set) begin + reg_hcRhPortStatus_0_PRSC_reg <= 1'b1; + end + if(reg_hcRhPortStatus_0_PRSC_set) begin + reg_hcInterrupt_RHSC_status <= 1'b1; + end + if(when_UsbOhci_l460) begin + reg_hcRhPortStatus_0_PES <= 1'b0; + end + if(when_UsbOhci_l460_1) begin + reg_hcRhPortStatus_0_PES <= 1'b1; + end + if(when_UsbOhci_l460_2) begin + reg_hcRhPortStatus_0_PES <= 1'b1; + end + if(when_UsbOhci_l461) begin + reg_hcRhPortStatus_0_PSS <= 1'b0; + end + if(when_UsbOhci_l461_1) begin + reg_hcRhPortStatus_0_PSS <= 1'b1; + end + if(when_UsbOhci_l462) begin + reg_hcRhPortStatus_0_suspend <= 1'b1; + end + if(when_UsbOhci_l463) begin + reg_hcRhPortStatus_0_resume <= 1'b1; + end + if(when_UsbOhci_l464) begin + reg_hcRhPortStatus_0_reset <= 1'b1; + end + if(reg_hcRhDescriptorA_NPS) begin + reg_hcRhPortStatus_0_PPS <= 1'b1; + end else begin + if(reg_hcRhDescriptorA_PSM) begin + if(when_UsbOhci_l470) begin + if(reg_hcRhPortStatus_0_clearPortPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b0; + end + if(reg_hcRhPortStatus_0_setPortPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b1; + end + end else begin + if(reg_hcRhStatus_clearGlobalPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b0; + end + if(reg_hcRhStatus_setGlobalPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b1; + end + end + end else begin + if(reg_hcRhStatus_clearGlobalPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b0; + end + if(reg_hcRhStatus_setGlobalPower) begin + reg_hcRhPortStatus_0_PPS <= 1'b1; + end + end + end + if(io_phy_overcurrent) begin + reg_hcRhPortStatus_0_PPS <= 1'b0; + end + if(io_phy_ports_0_resume_fire) begin + reg_hcRhPortStatus_0_resume <= 1'b0; + end + if(io_phy_ports_0_reset_fire) begin + reg_hcRhPortStatus_0_reset <= 1'b0; + end + if(io_phy_ports_0_suspend_fire) begin + reg_hcRhPortStatus_0_suspend <= 1'b0; + end + frame_decrementTimer <= (frame_decrementTimer + 3'b001); + if(frame_decrementTimerOverflow) begin + frame_decrementTimer <= 3'b000; + end + if(when_UsbOhci_l526) begin + reg_hcFmRemaining_FR <= (reg_hcFmRemaining_FR - 14'h0001); + if(when_UsbOhci_l528) begin + frame_limitCounter <= (frame_limitCounter - 15'h0001); + end + end + if(frame_reload) begin + reg_hcFmRemaining_FR <= reg_hcFmInterval_FI; + reg_hcFmRemaining_FRT <= reg_hcFmInterval_FIT; + reg_hcFmNumber_FN <= reg_hcFmNumber_FNp1; + frame_limitCounter <= reg_hcFmInterval_FSMPS; + frame_decrementTimer <= 3'b000; + end + if(io_phy_tick) begin + rxTimer_counter <= (rxTimer_counter + 8'h01); + end + if(rxTimer_clear) begin + rxTimer_counter <= 8'h00; + end + if(_zz_1) begin + _zz_dataRx_history_0 <= _zz_dataRx_pid; + end + if(_zz_1) begin + _zz_dataRx_history_1 <= _zz_dataRx_history_0; + end + if(priority_tick) begin + priority_counter <= (priority_counter + 2'b01); + end + if(priority_skip) begin + priority_bulk <= (! priority_bulk); + priority_counter <= 2'b00; + end + endpoint_TD_isoOverrunReg <= endpoint_TD_isoOverrun; + endpoint_TD_isoZero <= (endpoint_TD_isoLast ? (endpoint_TD_isoBaseNext < endpoint_TD_isoBase) : (endpoint_TD_isoBase == endpoint_TD_isoBaseNext)); + endpoint_TD_isoLastReg <= endpoint_TD_isoLast; + endpoint_TD_tooEarlyReg <= endpoint_TD_tooEarly; + endpoint_TD_lastOffset <= (endpoint_ED_F ? _zz_endpoint_TD_lastOffset : {(! endpoint_TD_isSinglePage),endpoint_TD_BE[11 : 0]}); + if(endpoint_TD_clear) begin + endpoint_TD_retire <= 1'b0; + endpoint_TD_dataPhaseUpdate <= 1'b0; + endpoint_TD_upateCBP <= 1'b0; + endpoint_TD_noUpdate <= 1'b0; + end + if(endpoint_applyNextED) begin + case(endpoint_flowType) + UsbOhciAxi4_FlowType_BULK : begin + reg_hcBulkCurrentED_BCED_reg <= endpoint_ED_nextED; + end + UsbOhciAxi4_FlowType_CONTROL : begin + reg_hcControlCurrentED_CCED_reg <= endpoint_ED_nextED; + end + default : begin + reg_hcPeriodCurrentED_PCED_reg <= endpoint_ED_nextED; + end + endcase + end + if(endpoint_dmaLogic_byteCtx_increment) begin + endpoint_dmaLogic_byteCtx_counter <= (endpoint_dmaLogic_byteCtx_counter + 13'h0001); + end + case(io_ctrl_cmd_payload_fragment_address) + 12'h004 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968) begin + reg_hcControl_CBSR[1 : 0] <= io_ctrl_cmd_payload_fragment_data[1 : 0]; + end + if(when_BusSlaveFactory_l968_1) begin + reg_hcControl_PLE <= io_ctrl_cmd_payload_fragment_data[2]; + end + if(when_BusSlaveFactory_l968_2) begin + reg_hcControl_IE <= io_ctrl_cmd_payload_fragment_data[3]; + end + if(when_BusSlaveFactory_l968_3) begin + reg_hcControl_CLE <= io_ctrl_cmd_payload_fragment_data[4]; + end + if(when_BusSlaveFactory_l968_4) begin + reg_hcControl_BLE <= io_ctrl_cmd_payload_fragment_data[5]; + end + if(when_BusSlaveFactory_l968_7) begin + reg_hcControl_RWE <= io_ctrl_cmd_payload_fragment_data[10]; + end + end + end + 12'h018 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_8) begin + reg_hcHCCA_HCCA_reg[7 : 0] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_9) begin + reg_hcHCCA_HCCA_reg[15 : 8] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_10) begin + reg_hcHCCA_HCCA_reg[23 : 16] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h020 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_11) begin + reg_hcControlHeadED_CHED_reg[3 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 4]; + end + if(when_BusSlaveFactory_l968_12) begin + reg_hcControlHeadED_CHED_reg[11 : 4] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_13) begin + reg_hcControlHeadED_CHED_reg[19 : 12] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_14) begin + reg_hcControlHeadED_CHED_reg[27 : 20] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h024 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_15) begin + reg_hcControlCurrentED_CCED_reg[3 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 4]; + end + if(when_BusSlaveFactory_l968_16) begin + reg_hcControlCurrentED_CCED_reg[11 : 4] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_17) begin + reg_hcControlCurrentED_CCED_reg[19 : 12] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_18) begin + reg_hcControlCurrentED_CCED_reg[27 : 20] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h028 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_19) begin + reg_hcBulkHeadED_BHED_reg[3 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 4]; + end + if(when_BusSlaveFactory_l968_20) begin + reg_hcBulkHeadED_BHED_reg[11 : 4] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_21) begin + reg_hcBulkHeadED_BHED_reg[19 : 12] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_22) begin + reg_hcBulkHeadED_BHED_reg[27 : 20] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h02c : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_23) begin + reg_hcBulkCurrentED_BCED_reg[3 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 4]; + end + if(when_BusSlaveFactory_l968_24) begin + reg_hcBulkCurrentED_BCED_reg[11 : 4] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_25) begin + reg_hcBulkCurrentED_BCED_reg[19 : 12] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_26) begin + reg_hcBulkCurrentED_BCED_reg[27 : 20] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h030 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_27) begin + reg_hcDoneHead_DH_reg[3 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 4]; + end + if(when_BusSlaveFactory_l968_28) begin + reg_hcDoneHead_DH_reg[11 : 4] <= io_ctrl_cmd_payload_fragment_data[15 : 8]; + end + if(when_BusSlaveFactory_l968_29) begin + reg_hcDoneHead_DH_reg[19 : 12] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_30) begin + reg_hcDoneHead_DH_reg[27 : 20] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h034 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_31) begin + reg_hcFmInterval_FI[7 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 0]; + end + if(when_BusSlaveFactory_l968_32) begin + reg_hcFmInterval_FI[13 : 8] <= io_ctrl_cmd_payload_fragment_data[13 : 8]; + end + if(when_BusSlaveFactory_l968_33) begin + reg_hcFmInterval_FSMPS[7 : 0] <= io_ctrl_cmd_payload_fragment_data[23 : 16]; + end + if(when_BusSlaveFactory_l968_34) begin + reg_hcFmInterval_FSMPS[14 : 8] <= io_ctrl_cmd_payload_fragment_data[30 : 24]; + end + if(when_BusSlaveFactory_l968_35) begin + reg_hcFmInterval_FIT <= io_ctrl_cmd_payload_fragment_data[31]; + end + end + end + 12'h044 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_38) begin + reg_hcLSThreshold_LST[7 : 0] <= io_ctrl_cmd_payload_fragment_data[7 : 0]; + end + if(when_BusSlaveFactory_l968_39) begin + reg_hcLSThreshold_LST[11 : 8] <= io_ctrl_cmd_payload_fragment_data[11 : 8]; + end + end + end + 12'h048 : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_40) begin + reg_hcRhDescriptorA_PSM <= io_ctrl_cmd_payload_fragment_data[8]; + end + if(when_BusSlaveFactory_l968_41) begin + reg_hcRhDescriptorA_NPS <= io_ctrl_cmd_payload_fragment_data[9]; + end + if(when_BusSlaveFactory_l968_42) begin + reg_hcRhDescriptorA_OCPM <= io_ctrl_cmd_payload_fragment_data[11]; + end + if(when_BusSlaveFactory_l968_43) begin + reg_hcRhDescriptorA_NOCP <= io_ctrl_cmd_payload_fragment_data[12]; + end + if(when_BusSlaveFactory_l968_44) begin + reg_hcRhDescriptorA_POTPGT[7 : 0] <= io_ctrl_cmd_payload_fragment_data[31 : 24]; + end + end + end + 12'h04c : begin + if(ctrl_doWrite) begin + if(when_BusSlaveFactory_l968_45) begin + reg_hcRhDescriptorB_DR[0 : 0] <= io_ctrl_cmd_payload_fragment_data[1 : 1]; + end + if(when_BusSlaveFactory_l968_46) begin + reg_hcRhDescriptorB_PPCM[0 : 0] <= io_ctrl_cmd_payload_fragment_data[17 : 17]; + end + end + end + default : begin + end + endcase + if(when_UsbOhci_l253) begin + reg_hcControl_CBSR <= 2'b00; + reg_hcControl_PLE <= 1'b0; + reg_hcControl_IE <= 1'b0; + reg_hcControl_CLE <= 1'b0; + reg_hcControl_BLE <= 1'b0; + reg_hcControl_RWE <= 1'b0; + reg_hcCommandStatus_CLF <= 1'b0; + reg_hcCommandStatus_BLF <= 1'b0; + reg_hcCommandStatus_OCR <= 1'b0; + reg_hcCommandStatus_SOC <= 2'b00; + reg_hcInterrupt_MIE <= 1'b0; + reg_hcInterrupt_SO_status <= 1'b0; + reg_hcInterrupt_SO_enable <= 1'b0; + reg_hcInterrupt_WDH_status <= 1'b0; + reg_hcInterrupt_WDH_enable <= 1'b0; + reg_hcInterrupt_SF_status <= 1'b0; + reg_hcInterrupt_SF_enable <= 1'b0; + reg_hcInterrupt_RD_status <= 1'b0; + reg_hcInterrupt_RD_enable <= 1'b0; + reg_hcInterrupt_UE_status <= 1'b0; + reg_hcInterrupt_UE_enable <= 1'b0; + reg_hcInterrupt_FNO_status <= 1'b0; + reg_hcInterrupt_FNO_enable <= 1'b0; + reg_hcInterrupt_RHSC_status <= 1'b0; + reg_hcInterrupt_RHSC_enable <= 1'b0; + reg_hcInterrupt_OC_status <= 1'b0; + reg_hcInterrupt_OC_enable <= 1'b0; + reg_hcHCCA_HCCA_reg <= 24'h000000; + reg_hcPeriodCurrentED_PCED_reg <= 28'h0000000; + reg_hcControlHeadED_CHED_reg <= 28'h0000000; + reg_hcControlCurrentED_CCED_reg <= 28'h0000000; + reg_hcBulkHeadED_BHED_reg <= 28'h0000000; + reg_hcBulkCurrentED_BCED_reg <= 28'h0000000; + reg_hcDoneHead_DH_reg <= 28'h0000000; + reg_hcFmInterval_FI <= 14'h2edf; + reg_hcFmInterval_FIT <= 1'b0; + reg_hcFmRemaining_FR <= 14'h0000; + reg_hcFmRemaining_FRT <= 1'b0; + reg_hcFmNumber_FN <= 16'h0000; + reg_hcLSThreshold_LST <= 12'h628; + reg_hcRhDescriptorA_PSM <= 1'b0; + reg_hcRhDescriptorA_NPS <= 1'b0; + reg_hcRhDescriptorA_OCPM <= 1'b0; + reg_hcRhDescriptorA_NOCP <= 1'b0; + reg_hcRhDescriptorA_POTPGT <= 8'h0a; + reg_hcRhDescriptorB_DR <= 1'b0; + reg_hcRhDescriptorB_PPCM <= 1'b1; + reg_hcRhStatus_DRWE <= 1'b0; + reg_hcRhStatus_CCIC <= 1'b0; + reg_hcRhPortStatus_0_resume <= 1'b0; + reg_hcRhPortStatus_0_reset <= 1'b0; + reg_hcRhPortStatus_0_suspend <= 1'b0; + reg_hcRhPortStatus_0_PSS <= 1'b0; + reg_hcRhPortStatus_0_PPS <= 1'b0; + reg_hcRhPortStatus_0_PES <= 1'b0; + reg_hcRhPortStatus_0_CSC_reg <= 1'b0; + reg_hcRhPortStatus_0_PESC_reg <= 1'b0; + reg_hcRhPortStatus_0_PSSC_reg <= 1'b0; + reg_hcRhPortStatus_0_OCIC_reg <= 1'b0; + reg_hcRhPortStatus_0_PRSC_reg <= 1'b0; + end + case(dataRx_stateReg) + UsbOhciAxi4_dataRx_enumDef_IDLE : begin + if(!io_phy_rx_active) begin + if(rxTimer_rxTimeout) begin + dataRx_notResponding <= 1'b1; + end + end + end + UsbOhciAxi4_dataRx_enumDef_PID : begin + dataRx_valids <= 2'b00; + dataRx_pidError <= 1'b1; + if(_zz_1) begin + dataRx_pid <= _zz_dataRx_pid[3 : 0]; + dataRx_pidError <= (_zz_dataRx_pid[3 : 0] != (~ _zz_dataRx_pid[7 : 4])); + end + end + UsbOhciAxi4_dataRx_enumDef_DATA : begin + if(when_Misc_l70) begin + if(when_Misc_l71) begin + dataRx_crcError <= 1'b1; + end + end else begin + if(_zz_1) begin + dataRx_valids <= {dataRx_valids[0],1'b1}; + end + end + end + default : begin + end + endcase + if(when_StateMachine_l253) begin + dataRx_notResponding <= 1'b0; + dataRx_stuffingError <= 1'b0; + dataRx_pidError <= 1'b0; + dataRx_crcError <= 1'b0; + end + if(when_Misc_l85) begin + if(_zz_1) begin + if(when_Misc_l87) begin + dataRx_stuffingError <= 1'b1; + end + end + end + case(sof_stateReg) + UsbOhciAxi4_sof_enumDef_FRAME_TX : begin + sof_doInterruptDelay <= (interruptDelay_done && (! reg_hcInterrupt_WDH_status)); + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_CMD : begin + end + UsbOhciAxi4_sof_enumDef_FRAME_NUMBER_RSP : begin + if(ioDma_rsp_valid) begin + reg_hcInterrupt_SF_status <= 1'b1; + if(reg_hcFmNumber_overflow) begin + reg_hcInterrupt_FNO_status <= 1'b1; + end + if(sof_doInterruptDelay) begin + reg_hcInterrupt_WDH_status <= 1'b1; + reg_hcDoneHead_DH_reg <= 28'h0000000; + end + end + end + default : begin + end + endcase + case(endpoint_stateReg) + UsbOhciAxi4_endpoint_enumDef_ED_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_ED_READ_RSP : begin + if(when_UsbOhci_l188) begin + endpoint_ED_words_0 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_1) begin + endpoint_ED_words_1 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_2) begin + endpoint_ED_words_2 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_3) begin + endpoint_ED_words_3 <= dmaRspMux_vec_0[31 : 0]; + end + end + UsbOhciAxi4_endpoint_enumDef_ED_ANALYSE : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_RSP : begin + if(when_UsbOhci_l188_4) begin + endpoint_TD_words_0 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_5) begin + endpoint_TD_words_1 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_6) begin + endpoint_TD_words_2 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l188_7) begin + endpoint_TD_words_3 <= dmaRspMux_vec_0[31 : 0]; + end + if(when_UsbOhci_l891) begin + if(when_UsbOhci_l188_8) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[12 : 0]; + end + if(when_UsbOhci_l188_9) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[28 : 16]; + end + end + if(when_UsbOhci_l891_1) begin + if(when_UsbOhci_l188_10) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[28 : 16]; + end + if(when_UsbOhci_l188_11) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[12 : 0]; + end + end + if(when_UsbOhci_l891_2) begin + if(when_UsbOhci_l188_12) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[12 : 0]; + end + if(when_UsbOhci_l188_13) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[28 : 16]; + end + end + if(when_UsbOhci_l891_3) begin + if(when_UsbOhci_l188_14) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[28 : 16]; + end + if(when_UsbOhci_l188_15) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[12 : 0]; + end + end + if(when_UsbOhci_l891_4) begin + if(when_UsbOhci_l188_16) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[12 : 0]; + end + if(when_UsbOhci_l188_17) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[28 : 16]; + end + end + if(when_UsbOhci_l891_5) begin + if(when_UsbOhci_l188_18) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[28 : 16]; + end + if(when_UsbOhci_l188_19) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[12 : 0]; + end + end + if(when_UsbOhci_l891_6) begin + if(when_UsbOhci_l188_20) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[12 : 0]; + end + if(when_UsbOhci_l188_21) begin + endpoint_TD_isoBaseNext <= dmaRspMux_vec_0[28 : 16]; + end + end + if(when_UsbOhci_l891_7) begin + if(when_UsbOhci_l188_22) begin + endpoint_TD_isoBase <= dmaRspMux_vec_0[28 : 16]; + end + end + if(endpoint_TD_isoLast) begin + endpoint_TD_isoBaseNext <= {(! endpoint_TD_isSinglePage),endpoint_TD_BE[11 : 0]}; + end + end + UsbOhciAxi4_endpoint_enumDef_TD_READ_DELAY : begin + end + UsbOhciAxi4_endpoint_enumDef_TD_ANALYSE : begin + case(endpoint_flowType) + UsbOhciAxi4_FlowType_CONTROL : begin + reg_hcCommandStatus_CLF <= 1'b1; + end + UsbOhciAxi4_FlowType_BULK : begin + reg_hcCommandStatus_BLF <= 1'b1; + end + default : begin + end + endcase + endpoint_dmaLogic_byteCtx_counter <= endpoint_TD_firstOffset; + endpoint_currentAddress <= {1'd0, endpoint_TD_firstOffset}; + endpoint_lastAddress <= _zz_endpoint_lastAddress_1[12:0]; + endpoint_zeroLength <= (endpoint_ED_F ? endpoint_TD_isoZero : (endpoint_TD_CBP == 32'h00000000)); + endpoint_dataPhase <= (endpoint_ED_F ? 1'b0 : (endpoint_TD_T[1] ? endpoint_TD_T[0] : endpoint_ED_C)); + if(endpoint_ED_F) begin + if(endpoint_TD_isoOverrunReg) begin + endpoint_TD_retire <= 1'b1; + end + end + end + UsbOhciAxi4_endpoint_enumDef_TD_CHECK_TIME : begin + if(endpoint_timeCheck) begin + endpoint_status_1 <= UsbOhciAxi4_endpoint_Status_FRAME_TIME; + end + end + UsbOhciAxi4_endpoint_enumDef_BUFFER_READ : begin + if(when_UsbOhci_l1128) begin + if(endpoint_timeCheck) begin + endpoint_status_1 <= UsbOhciAxi4_endpoint_Status_FRAME_TIME; + end + end + end + UsbOhciAxi4_endpoint_enumDef_TOKEN : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_TX : begin + if(dataTx_wantExit) begin + if(endpoint_ED_F) begin + endpoint_TD_words_0[31 : 28] <= 4'b0000; + end + end + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_VALIDATE : begin + endpoint_TD_words_0[31 : 28] <= 4'b0000; + if(dataRx_notResponding) begin + endpoint_TD_words_0[31 : 28] <= 4'b0101; + end else begin + if(dataRx_stuffingError) begin + endpoint_TD_words_0[31 : 28] <= 4'b0010; + end else begin + if(dataRx_pidError) begin + endpoint_TD_words_0[31 : 28] <= 4'b0110; + end else begin + if(endpoint_ED_F) begin + case(dataRx_pid) + 4'b1110, 4'b1010 : begin + endpoint_TD_words_0[31 : 28] <= 4'b0100; + end + 4'b0011, 4'b1011 : begin + end + default : begin + endpoint_TD_words_0[31 : 28] <= 4'b0111; + end + endcase + end else begin + case(dataRx_pid) + 4'b1010 : begin + endpoint_TD_noUpdate <= 1'b1; + end + 4'b1110 : begin + endpoint_TD_words_0[31 : 28] <= 4'b0100; + end + 4'b0011, 4'b1011 : begin + if(when_UsbOhci_l1263) begin + endpoint_TD_words_0[31 : 28] <= 4'b0011; + end + end + default : begin + endpoint_TD_words_0[31 : 28] <= 4'b0111; + end + endcase + end + if(when_UsbOhci_l1274) begin + if(dataRx_crcError) begin + endpoint_TD_words_0[31 : 28] <= 4'b0001; + end else begin + if(endpoint_dmaLogic_underflowError) begin + endpoint_TD_words_0[31 : 28] <= 4'b1001; + end else begin + if(endpoint_dmaLogic_overflow) begin + endpoint_TD_words_0[31 : 28] <= 4'b1000; + end + end + end + end + end + end + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_RX : begin + if(io_phy_rx_flow_valid) begin + endpoint_ackRxFired <= 1'b1; + endpoint_ackRxPid <= io_phy_rx_flow_payload_data[3 : 0]; + if(io_phy_rx_flow_payload_stuffingError) begin + endpoint_ackRxStuffing <= 1'b1; + end + if(when_UsbOhci_l1200) begin + endpoint_ackRxPidFailure <= 1'b1; + end + end + if(io_phy_rx_active) begin + endpoint_ackRxActivated <= 1'b1; + end + if(when_UsbOhci_l1205) begin + if(when_UsbOhci_l1207) begin + endpoint_TD_words_0[31 : 28] <= 4'b0110; + end else begin + if(endpoint_ackRxStuffing) begin + endpoint_TD_words_0[31 : 28] <= 4'b0010; + end else begin + if(endpoint_ackRxPidFailure) begin + endpoint_TD_words_0[31 : 28] <= 4'b0110; + end else begin + case(endpoint_ackRxPid) + 4'b0010 : begin + endpoint_TD_words_0[31 : 28] <= 4'b0000; + end + 4'b1010 : begin + end + 4'b1110 : begin + endpoint_TD_words_0[31 : 28] <= 4'b0100; + end + default : begin + endpoint_TD_words_0[31 : 28] <= 4'b0111; + end + endcase + end + end + end + end + if(rxTimer_rxTimeout) begin + endpoint_TD_words_0[31 : 28] <= 4'b0101; + end + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_0 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_1 : begin + end + UsbOhciAxi4_endpoint_enumDef_ACK_TX_EOP : begin + end + UsbOhciAxi4_endpoint_enumDef_DATA_RX_WAIT_DMA : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_PROCESS : begin + if(endpoint_ED_F) begin + if(endpoint_TD_isoLastReg) begin + endpoint_TD_retire <= 1'b1; + end + end else begin + endpoint_TD_words_0[27 : 26] <= 2'b00; + case(endpoint_TD_CC) + 4'b0000 : begin + if(when_UsbOhci_l1331) begin + endpoint_TD_retire <= 1'b1; + end + endpoint_TD_dataPhaseUpdate <= 1'b1; + endpoint_TD_upateCBP <= 1'b1; + end + 4'b1001 : begin + endpoint_TD_retire <= 1'b1; + endpoint_TD_dataPhaseUpdate <= 1'b1; + endpoint_TD_upateCBP <= 1'b1; + end + 4'b1000 : begin + endpoint_TD_retire <= 1'b1; + endpoint_TD_dataPhaseUpdate <= 1'b1; + end + 4'b0010, 4'b0001, 4'b0110, 4'b0101, 4'b0111, 4'b0011 : begin + endpoint_TD_words_0[27 : 26] <= _zz_endpoint_TD_words_0; + if(when_UsbOhci_l1346) begin + endpoint_TD_words_0[31 : 28] <= 4'b0000; + end else begin + endpoint_TD_retire <= 1'b1; + end + end + default : begin + endpoint_TD_retire <= 1'b1; + end + endcase + if(endpoint_TD_noUpdate) begin + endpoint_TD_retire <= 1'b0; + end + end + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_TD_CMD : begin + endpoint_ED_words_2[0] <= ((! endpoint_ED_F) && (endpoint_TD_CC != 4'b0000)); + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_ED_CMD : begin + end + UsbOhciAxi4_endpoint_enumDef_UPDATE_SYNC : begin + if(dmaCtx_pendingEmpty) begin + if(endpoint_TD_retire) begin + reg_hcDoneHead_DH_reg <= endpoint_ED_headP; + end + end + end + UsbOhciAxi4_endpoint_enumDef_ABORD : begin + end + default : begin + end + endcase + if(when_StateMachine_l237_2) begin + endpoint_status_1 <= UsbOhciAxi4_endpoint_Status_OK; + end + if(when_StateMachine_l253_4) begin + endpoint_ackRxFired <= 1'b0; + endpoint_ackRxActivated <= 1'b0; + endpoint_ackRxPidFailure <= 1'b0; + endpoint_ackRxStuffing <= 1'b0; + end + case(endpoint_dmaLogic_stateReg) + UsbOhciAxi4_endpoint_dmaLogic_enumDef_INIT : begin + endpoint_dmaLogic_underflow <= 1'b0; + endpoint_dmaLogic_overflow <= 1'b0; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_TO_USB : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_FROM_USB : begin + if(dataRx_wantExit) begin + endpoint_dmaLogic_underflow <= when_UsbOhci_l1054; + endpoint_dmaLogic_overflow <= ((! when_UsbOhci_l1054) && (_zz_endpoint_dmaLogic_overflow != endpoint_transactionSize)); + if(endpoint_zeroLength) begin + endpoint_dmaLogic_underflow <= 1'b0; + endpoint_dmaLogic_overflow <= (endpoint_dmaLogic_fromUsbCounter != 11'h000); + end + if(when_UsbOhci_l1054) begin + endpoint_lastAddress <= _zz_endpoint_lastAddress_5[12:0]; + end + end + if(dataRx_data_valid) begin + endpoint_dmaLogic_fromUsbCounter <= (endpoint_dmaLogic_fromUsbCounter + _zz_endpoint_dmaLogic_fromUsbCounter); + if(_zz_2[0]) begin + endpoint_dmaLogic_buffer[7 : 0] <= dataRx_data_payload; + end + if(_zz_2[1]) begin + endpoint_dmaLogic_buffer[15 : 8] <= dataRx_data_payload; + end + if(_zz_2[2]) begin + endpoint_dmaLogic_buffer[23 : 16] <= dataRx_data_payload; + end + if(_zz_2[3]) begin + endpoint_dmaLogic_buffer[31 : 24] <= dataRx_data_payload; + end + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_VALIDATION : begin + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_CALC_CMD : begin + endpoint_dmaLogic_length <= endpoint_dmaLogic_lengthCalc; + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_READ_CMD : begin + if(ioDma_cmd_ready) begin + endpoint_currentAddress <= (_zz_endpoint_currentAddress + 14'h0001); + end + end + UsbOhciAxi4_endpoint_dmaLogic_enumDef_WRITE_CMD : begin + if(ioDma_cmd_ready) begin + if(endpoint_dmaLogic_beatLast) begin + endpoint_currentAddress <= (_zz_endpoint_currentAddress_2 + 14'h0001); + end + end + end + default : begin + end + endcase + if(when_StateMachine_l253_5) begin + endpoint_dmaLogic_fromUsbCounter <= 11'h000; + end + case(operational_stateReg) + UsbOhciAxi4_operational_enumDef_SOF : begin + if(sof_wantExit) begin + if(when_UsbOhci_l1461) begin + reg_hcInterrupt_SO_status <= 1'b1; + reg_hcCommandStatus_SOC <= (reg_hcCommandStatus_SOC + 2'b01); + end + operational_allowBulk <= reg_hcControl_BLE; + operational_allowControl <= reg_hcControl_CLE; + operational_allowPeriodic <= reg_hcControl_PLE; + operational_allowIsochronous <= reg_hcControl_IE; + operational_periodicDone <= 1'b0; + operational_periodicHeadFetched <= 1'b0; + priority_bulk <= 1'b0; + priority_counter <= 2'b00; + end + end + UsbOhciAxi4_operational_enumDef_ARBITER : begin + if(reg_hcControl_BLE) begin + operational_allowBulk <= 1'b1; + end + if(reg_hcControl_CLE) begin + operational_allowControl <= 1'b1; + end + if(!operational_askExit) begin + if(!frame_limitHit) begin + if(when_UsbOhci_l1487) begin + if(!when_UsbOhci_l1488) begin + if(reg_hcPeriodCurrentED_isZero) begin + operational_periodicDone <= 1'b1; + end else begin + endpoint_flowType <= UsbOhciAxi4_FlowType_PERIODIC; + endpoint_ED_address <= reg_hcPeriodCurrentED_PCED_address; + end + end + end else begin + if(priority_bulk) begin + if(operational_allowBulk) begin + if(reg_hcBulkCurrentED_isZero) begin + if(reg_hcCommandStatus_BLF) begin + reg_hcBulkCurrentED_BCED_reg <= reg_hcBulkHeadED_BHED_reg; + reg_hcCommandStatus_BLF <= 1'b0; + end + end else begin + endpoint_flowType <= UsbOhciAxi4_FlowType_BULK; + endpoint_ED_address <= reg_hcBulkCurrentED_BCED_address; + end + end + end else begin + if(operational_allowControl) begin + if(reg_hcControlCurrentED_isZero) begin + if(reg_hcCommandStatus_CLF) begin + reg_hcControlCurrentED_CCED_reg <= reg_hcControlHeadED_CHED_reg; + reg_hcCommandStatus_CLF <= 1'b0; + end + end else begin + endpoint_flowType <= UsbOhciAxi4_FlowType_CONTROL; + endpoint_ED_address <= reg_hcControlCurrentED_CCED_address; + end + end + end + end + end + end + end + UsbOhciAxi4_operational_enumDef_END_POINT : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_CMD : begin + end + UsbOhciAxi4_operational_enumDef_PERIODIC_HEAD_RSP : begin + if(ioDma_rsp_valid) begin + operational_periodicHeadFetched <= 1'b1; + reg_hcPeriodCurrentED_PCED_reg <= dmaRspMux_data[31 : 4]; + end + end + UsbOhciAxi4_operational_enumDef_WAIT_SOF : begin + end + default : begin + end + endcase + if(when_StateMachine_l237_3) begin + operational_allowPeriodic <= 1'b0; + end + case(hc_stateReg) + UsbOhciAxi4_hc_enumDef_RESET : begin + end + UsbOhciAxi4_hc_enumDef_RESUME : begin + end + UsbOhciAxi4_hc_enumDef_OPERATIONAL : begin + end + UsbOhciAxi4_hc_enumDef_SUSPEND : begin + if(when_UsbOhci_l1625) begin + reg_hcInterrupt_RD_status <= 1'b1; + end + end + UsbOhciAxi4_hc_enumDef_ANY_TO_RESET : begin + end + UsbOhciAxi4_hc_enumDef_ANY_TO_SUSPEND : begin + end + default : begin + end + endcase + end + + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + ioDma_cmd_payload_first <= 1'b1; + end else begin + if(ioDma_cmd_fire) begin + ioDma_cmd_payload_first <= ioDma_cmd_payload_last; + end + end + end + + +endmodule + +module UsbOhciAxi4_StreamArbiter ( + input io_inputs_0_valid, + output io_inputs_0_ready, + input [11:0] io_inputs_0_payload_addr, + input [7:0] io_inputs_0_payload_id, + input [3:0] io_inputs_0_payload_region, + input [7:0] io_inputs_0_payload_len, + input [2:0] io_inputs_0_payload_size, + input [1:0] io_inputs_0_payload_burst, + input [0:0] io_inputs_0_payload_lock, + input [3:0] io_inputs_0_payload_cache, + input [3:0] io_inputs_0_payload_qos, + input [2:0] io_inputs_0_payload_prot, + input io_inputs_1_valid, + output io_inputs_1_ready, + input [11:0] io_inputs_1_payload_addr, + input [7:0] io_inputs_1_payload_id, + input [3:0] io_inputs_1_payload_region, + input [7:0] io_inputs_1_payload_len, + input [2:0] io_inputs_1_payload_size, + input [1:0] io_inputs_1_payload_burst, + input [0:0] io_inputs_1_payload_lock, + input [3:0] io_inputs_1_payload_cache, + input [3:0] io_inputs_1_payload_qos, + input [2:0] io_inputs_1_payload_prot, + output io_output_valid, + input io_output_ready, + output [11:0] io_output_payload_addr, + output [7:0] io_output_payload_id, + output [3:0] io_output_payload_region, + output [7:0] io_output_payload_len, + output [2:0] io_output_payload_size, + output [1:0] io_output_payload_burst, + output [0:0] io_output_payload_lock, + output [3:0] io_output_payload_cache, + output [3:0] io_output_payload_qos, + output [2:0] io_output_payload_prot, + output [0:0] io_chosen, + output [1:0] io_chosenOH, + input ctrl_clk, + input ctrl_reset +); + + wire [3:0] _zz__zz_maskProposal_0_2; + wire [3:0] _zz__zz_maskProposal_0_2_1; + wire [1:0] _zz__zz_maskProposal_0_2_2; + reg locked; + wire maskProposal_0; + wire maskProposal_1; + reg maskLocked_0; + reg maskLocked_1; + wire maskRouted_0; + wire maskRouted_1; + wire [1:0] _zz_maskProposal_0; + wire [3:0] _zz_maskProposal_0_1; + wire [3:0] _zz_maskProposal_0_2; + wire [1:0] _zz_maskProposal_0_3; + wire io_output_fire; + wire _zz_io_chosen; + + assign _zz__zz_maskProposal_0_2 = (_zz_maskProposal_0_1 - _zz__zz_maskProposal_0_2_1); + assign _zz__zz_maskProposal_0_2_2 = {maskLocked_0,maskLocked_1}; + assign _zz__zz_maskProposal_0_2_1 = {2'd0, _zz__zz_maskProposal_0_2_2}; + assign maskRouted_0 = (locked ? maskLocked_0 : maskProposal_0); + assign maskRouted_1 = (locked ? maskLocked_1 : maskProposal_1); + assign _zz_maskProposal_0 = {io_inputs_1_valid,io_inputs_0_valid}; + assign _zz_maskProposal_0_1 = {_zz_maskProposal_0,_zz_maskProposal_0}; + assign _zz_maskProposal_0_2 = (_zz_maskProposal_0_1 & (~ _zz__zz_maskProposal_0_2)); + assign _zz_maskProposal_0_3 = (_zz_maskProposal_0_2[3 : 2] | _zz_maskProposal_0_2[1 : 0]); + assign maskProposal_0 = _zz_maskProposal_0_3[0]; + assign maskProposal_1 = _zz_maskProposal_0_3[1]; + assign io_output_fire = (io_output_valid && io_output_ready); + assign io_output_valid = ((io_inputs_0_valid && maskRouted_0) || (io_inputs_1_valid && maskRouted_1)); + assign io_output_payload_addr = (maskRouted_0 ? io_inputs_0_payload_addr : io_inputs_1_payload_addr); + assign io_output_payload_id = (maskRouted_0 ? io_inputs_0_payload_id : io_inputs_1_payload_id); + assign io_output_payload_region = (maskRouted_0 ? io_inputs_0_payload_region : io_inputs_1_payload_region); + assign io_output_payload_len = (maskRouted_0 ? io_inputs_0_payload_len : io_inputs_1_payload_len); + assign io_output_payload_size = (maskRouted_0 ? io_inputs_0_payload_size : io_inputs_1_payload_size); + assign io_output_payload_burst = (maskRouted_0 ? io_inputs_0_payload_burst : io_inputs_1_payload_burst); + assign io_output_payload_lock = (maskRouted_0 ? io_inputs_0_payload_lock : io_inputs_1_payload_lock); + assign io_output_payload_cache = (maskRouted_0 ? io_inputs_0_payload_cache : io_inputs_1_payload_cache); + assign io_output_payload_qos = (maskRouted_0 ? io_inputs_0_payload_qos : io_inputs_1_payload_qos); + assign io_output_payload_prot = (maskRouted_0 ? io_inputs_0_payload_prot : io_inputs_1_payload_prot); + assign io_inputs_0_ready = (maskRouted_0 && io_output_ready); + assign io_inputs_1_ready = (maskRouted_1 && io_output_ready); + assign io_chosenOH = {maskRouted_1,maskRouted_0}; + assign _zz_io_chosen = io_chosenOH[1]; + assign io_chosen = _zz_io_chosen; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + locked <= 1'b0; + maskLocked_0 <= 1'b0; + maskLocked_1 <= 1'b1; + end else begin + if(io_output_valid) begin + maskLocked_0 <= maskRouted_0; + maskLocked_1 <= maskRouted_1; + end + if(io_output_valid) begin + locked <= 1'b1; + end + if(io_output_fire) begin + locked <= 1'b0; + end + end + end + + +endmodule + +module UsbOhciAxi4_Axi4SharedToBmb ( + input io_axi_arw_valid, + output io_axi_arw_ready, + input [11:0] io_axi_arw_payload_addr, + input [7:0] io_axi_arw_payload_id, + input [3:0] io_axi_arw_payload_region, + input [7:0] io_axi_arw_payload_len, + input [2:0] io_axi_arw_payload_size, + input [1:0] io_axi_arw_payload_burst, + input [0:0] io_axi_arw_payload_lock, + input [3:0] io_axi_arw_payload_cache, + input [3:0] io_axi_arw_payload_qos, + input [2:0] io_axi_arw_payload_prot, + input io_axi_arw_payload_write, + input io_axi_w_valid, + output io_axi_w_ready, + input [31:0] io_axi_w_payload_data, + input [3:0] io_axi_w_payload_strb, + input io_axi_w_payload_last, + output io_axi_b_valid, + input io_axi_b_ready, + output [7:0] io_axi_b_payload_id, + output reg [1:0] io_axi_b_payload_resp, + output io_axi_r_valid, + input io_axi_r_ready, + output [31:0] io_axi_r_payload_data, + output [7:0] io_axi_r_payload_id, + output reg [1:0] io_axi_r_payload_resp, + output io_axi_r_payload_last, + output io_bmb_cmd_valid, + input io_bmb_cmd_ready, + output io_bmb_cmd_payload_last, + output [8:0] io_bmb_cmd_payload_fragment_source, + output [0:0] io_bmb_cmd_payload_fragment_opcode, + output [11:0] io_bmb_cmd_payload_fragment_address, + output [9:0] io_bmb_cmd_payload_fragment_length, + output [31:0] io_bmb_cmd_payload_fragment_data, + output [3:0] io_bmb_cmd_payload_fragment_mask, + input io_bmb_rsp_valid, + output io_bmb_rsp_ready, + input io_bmb_rsp_payload_last, + input [8:0] io_bmb_rsp_payload_fragment_source, + input [0:0] io_bmb_rsp_payload_fragment_opcode, + input [31:0] io_bmb_rsp_payload_fragment_data +); + + wire [9:0] _zz_io_bmb_cmd_payload_fragment_length; + wire hazard; + wire io_bmb_cmd_fire; + wire rspIsWrite; + wire when_Axi4SharedToBmb_l42; + wire when_Axi4SharedToBmb_l49; + + assign _zz_io_bmb_cmd_payload_fragment_length = ({2'd0,io_axi_arw_payload_len} <<< 2'd2); + assign hazard = (io_axi_arw_payload_write && (! io_axi_w_valid)); + assign io_bmb_cmd_valid = (io_axi_arw_valid && (! hazard)); + assign io_bmb_cmd_payload_fragment_source = {io_axi_arw_payload_write,io_axi_arw_payload_id}; + assign io_bmb_cmd_payload_fragment_opcode = io_axi_arw_payload_write; + assign io_bmb_cmd_payload_fragment_address = io_axi_arw_payload_addr; + assign io_bmb_cmd_payload_fragment_length = (_zz_io_bmb_cmd_payload_fragment_length | 10'h003); + assign io_bmb_cmd_payload_fragment_data = io_axi_w_payload_data; + assign io_bmb_cmd_payload_fragment_mask = io_axi_w_payload_strb; + assign io_bmb_cmd_payload_last = ((! io_axi_arw_payload_write) || io_axi_w_payload_last); + assign io_bmb_cmd_fire = (io_bmb_cmd_valid && io_bmb_cmd_ready); + assign io_axi_arw_ready = (io_bmb_cmd_fire && io_bmb_cmd_payload_last); + assign io_axi_w_ready = (io_bmb_cmd_fire && (io_bmb_cmd_payload_fragment_opcode == 1'b1)); + assign rspIsWrite = io_bmb_rsp_payload_fragment_source[8]; + assign io_axi_b_valid = (io_bmb_rsp_valid && rspIsWrite); + assign io_axi_b_payload_id = io_bmb_rsp_payload_fragment_source[7:0]; + always @(*) begin + io_axi_b_payload_resp = 2'b00; + if(when_Axi4SharedToBmb_l42) begin + io_axi_b_payload_resp = 2'b11; + end + end + + assign when_Axi4SharedToBmb_l42 = (io_bmb_rsp_payload_fragment_opcode == 1'b1); + assign io_axi_r_valid = (io_bmb_rsp_valid && (! rspIsWrite)); + assign io_axi_r_payload_data = io_bmb_rsp_payload_fragment_data; + assign io_axi_r_payload_id = io_bmb_rsp_payload_fragment_source[7:0]; + assign io_axi_r_payload_last = io_bmb_rsp_payload_last; + always @(*) begin + io_axi_r_payload_resp = 2'b00; + if(when_Axi4SharedToBmb_l49) begin + io_axi_r_payload_resp = 2'b11; + end + end + + assign when_Axi4SharedToBmb_l49 = (io_bmb_rsp_payload_fragment_opcode == 1'b1); + assign io_bmb_rsp_ready = (rspIsWrite ? io_axi_b_ready : io_axi_r_ready); + +endmodule + +module UsbOhciAxi4_BmbToAxi4SharedBridge ( + input io_input_cmd_valid, + output io_input_cmd_ready, + input io_input_cmd_payload_last, + input [0:0] io_input_cmd_payload_fragment_opcode, + input [31:0] io_input_cmd_payload_fragment_address, + input [5:0] io_input_cmd_payload_fragment_length, + input [31:0] io_input_cmd_payload_fragment_data, + input [3:0] io_input_cmd_payload_fragment_mask, + output reg io_input_rsp_valid, + input io_input_rsp_ready, + output reg io_input_rsp_payload_last, + output reg [0:0] io_input_rsp_payload_fragment_opcode, + output [31:0] io_input_rsp_payload_fragment_data, + output io_output_arw_valid, + input io_output_arw_ready, + output [31:0] io_output_arw_payload_addr, + output [7:0] io_output_arw_payload_len, + output [2:0] io_output_arw_payload_size, + output [3:0] io_output_arw_payload_cache, + output [2:0] io_output_arw_payload_prot, + output io_output_arw_payload_write, + output io_output_w_valid, + input io_output_w_ready, + output [31:0] io_output_w_payload_data, + output [3:0] io_output_w_payload_strb, + output io_output_w_payload_last, + input io_output_b_valid, + output io_output_b_ready, + input [1:0] io_output_b_payload_resp, + input io_output_r_valid, + output io_output_r_ready, + input [31:0] io_output_r_payload_data, + input [1:0] io_output_r_payload_resp, + input io_output_r_payload_last, + input ctrl_clk, + input ctrl_reset +); + + wire writeCmdInfo_fifo_io_pop_ready; + wire writeCmdInfo_fifo_io_flush; + wire readCmdInfo_fifo_io_pop_ready; + wire readCmdInfo_fifo_io_flush; + wire writeCmdInfo_fifo_io_push_ready; + wire writeCmdInfo_fifo_io_pop_valid; + wire [5:0] writeCmdInfo_fifo_io_occupancy; + wire [5:0] writeCmdInfo_fifo_io_availability; + wire readCmdInfo_fifo_io_push_ready; + wire readCmdInfo_fifo_io_pop_valid; + wire [5:0] readCmdInfo_fifo_io_occupancy; + wire [5:0] readCmdInfo_fifo_io_availability; + wire [3:0] _zz_io_output_arw_payload_len; + reg pendingWrite; + reg [4:0] pendingCounter; + wire io_input_cmd_fire; + wire when_Utils_l688; + wire io_input_rsp_fire; + wire when_Utils_l691; + reg states_0_counter_incrementIt; + reg states_0_counter_decrementIt; + wire [4:0] states_0_counter_valueNext; + reg [4:0] states_0_counter_value; + wire states_0_counter_mayOverflow; + wire states_0_counter_willOverflowIfInc; + wire states_0_counter_willOverflow; + reg [4:0] states_0_counter_finalIncrement; + wire when_Utils_l717; + wire when_Utils_l719; + wire when_BmbToAxi4Bridge_l45; + reg states_0_write; + wire when_BmbToAxi4Bridge_l47; + wire hazard; + wire _zz_io_input_cmd_ready; + wire _zz_cmdFork_valid; + reg _zz_io_input_cmd_ready_1; + wire _zz_cmdFork_payload_last; + wire [0:0] _zz_cmdFork_payload_fragment_opcode; + wire [31:0] _zz_cmdFork_payload_fragment_address; + wire [5:0] _zz_cmdFork_payload_fragment_length; + wire [31:0] _zz_cmdFork_payload_fragment_data; + wire [3:0] _zz_cmdFork_payload_fragment_mask; + wire cmdFork_valid; + reg cmdFork_ready; + wire cmdFork_payload_last; + wire [0:0] cmdFork_payload_fragment_opcode; + wire [31:0] cmdFork_payload_fragment_address; + wire [5:0] cmdFork_payload_fragment_length; + wire [31:0] cmdFork_payload_fragment_data; + wire [3:0] cmdFork_payload_fragment_mask; + wire dataFork_valid; + reg dataFork_ready; + wire dataFork_payload_last; + wire [0:0] dataFork_payload_fragment_opcode; + wire [31:0] dataFork_payload_fragment_address; + wire [5:0] dataFork_payload_fragment_length; + wire [31:0] dataFork_payload_fragment_data; + wire [3:0] dataFork_payload_fragment_mask; + reg _zz_cmdFork_valid_1; + reg _zz_dataFork_valid; + wire when_Stream_l1020; + wire when_Stream_l1020_1; + wire cmdFork_fire; + wire dataFork_fire; + reg io_input_cmd_payload_first; + wire when_Stream_l439; + reg cmdStage_valid; + wire cmdStage_ready; + wire cmdStage_payload_last; + wire [0:0] cmdStage_payload_fragment_opcode; + wire [31:0] cmdStage_payload_fragment_address; + wire [5:0] cmdStage_payload_fragment_length; + wire [31:0] cmdStage_payload_fragment_data; + wire [3:0] cmdStage_payload_fragment_mask; + wire when_Stream_l439_1; + reg dataStage_valid; + wire dataStage_ready; + wire dataStage_payload_last; + wire [0:0] dataStage_payload_fragment_opcode; + wire [31:0] dataStage_payload_fragment_address; + wire [5:0] dataStage_payload_fragment_length; + wire [31:0] dataStage_payload_fragment_data; + wire [3:0] dataStage_payload_fragment_mask; + wire writeCmdInfo_valid; + wire writeCmdInfo_ready; + wire readCmdInfo_valid; + wire readCmdInfo_ready; + wire cmdStage_fire; + wire writeRspInfo_valid; + wire writeRspInfo_ready; + reg front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid; + wire writeRspInfo_fire; + wire readRspInfo_valid; + wire readRspInfo_ready; + reg front_dmaBridge_readCmdInfo_fifo_io_pop_rValid; + wire readRspInfo_fire; + wire _zz_io_output_arw_valid; + reg rspSelLock; + wire when_BmbToAxi4Bridge_l87; + wire io_output_r_fire; + wire io_output_b_fire; + wire when_BmbToAxi4Bridge_l87_1; + wire when_BmbToAxi4Bridge_l88; + reg rspSelReadLast; + wire rspSelRead; + wire when_BmbToAxi4Bridge_l108; + + assign _zz_io_output_arw_payload_len = io_input_cmd_payload_fragment_length[5 : 2]; + UsbOhciAxi4_StreamFifo_1 writeCmdInfo_fifo ( + .io_push_valid (writeCmdInfo_valid ), //i + .io_push_ready (writeCmdInfo_fifo_io_push_ready ), //o + .io_pop_valid (writeCmdInfo_fifo_io_pop_valid ), //o + .io_pop_ready (writeCmdInfo_fifo_io_pop_ready ), //i + .io_flush (writeCmdInfo_fifo_io_flush ), //i + .io_occupancy (writeCmdInfo_fifo_io_occupancy[5:0] ), //o + .io_availability (writeCmdInfo_fifo_io_availability[5:0]), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_StreamFifo_1 readCmdInfo_fifo ( + .io_push_valid (readCmdInfo_valid ), //i + .io_push_ready (readCmdInfo_fifo_io_push_ready ), //o + .io_pop_valid (readCmdInfo_fifo_io_pop_valid ), //o + .io_pop_ready (readCmdInfo_fifo_io_pop_ready ), //i + .io_flush (readCmdInfo_fifo_io_flush ), //i + .io_occupancy (readCmdInfo_fifo_io_occupancy[5:0] ), //o + .io_availability (readCmdInfo_fifo_io_availability[5:0]), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + always @(*) begin + pendingWrite = 1'bx; + if(when_BmbToAxi4Bridge_l47) begin + pendingWrite = states_0_write; + end + end + + always @(*) begin + pendingCounter = 5'bxxxxx; + if(when_BmbToAxi4Bridge_l47) begin + pendingCounter = states_0_counter_value; + end + end + + assign io_input_cmd_fire = (io_input_cmd_valid && io_input_cmd_ready); + assign when_Utils_l688 = ((1'b1 && io_input_cmd_fire) && io_input_cmd_payload_last); + assign io_input_rsp_fire = (io_input_rsp_valid && io_input_rsp_ready); + assign when_Utils_l691 = ((1'b1 && io_input_rsp_fire) && io_input_rsp_payload_last); + always @(*) begin + states_0_counter_incrementIt = 1'b0; + if(when_Utils_l688) begin + states_0_counter_incrementIt = 1'b1; + end + end + + always @(*) begin + states_0_counter_decrementIt = 1'b0; + if(when_Utils_l691) begin + states_0_counter_decrementIt = 1'b1; + end + end + + assign states_0_counter_mayOverflow = (states_0_counter_value == 5'h1f); + assign states_0_counter_willOverflowIfInc = (states_0_counter_mayOverflow && (! states_0_counter_decrementIt)); + assign states_0_counter_willOverflow = (states_0_counter_willOverflowIfInc && states_0_counter_incrementIt); + assign when_Utils_l717 = (states_0_counter_incrementIt && (! states_0_counter_decrementIt)); + always @(*) begin + if(when_Utils_l717) begin + states_0_counter_finalIncrement = 5'h01; + end else begin + if(when_Utils_l719) begin + states_0_counter_finalIncrement = 5'h1f; + end else begin + states_0_counter_finalIncrement = 5'h00; + end + end + end + + assign when_Utils_l719 = ((! states_0_counter_incrementIt) && states_0_counter_decrementIt); + assign states_0_counter_valueNext = (states_0_counter_value + states_0_counter_finalIncrement); + assign when_BmbToAxi4Bridge_l45 = (1'b1 && io_input_cmd_fire); + assign when_BmbToAxi4Bridge_l47 = 1'b1; + assign hazard = ((((io_input_cmd_payload_fragment_opcode == 1'b1) != pendingWrite) && (pendingCounter != 5'h00)) || (pendingCounter == 5'h1f)); + assign _zz_io_input_cmd_ready = (! hazard); + assign _zz_cmdFork_valid = (io_input_cmd_valid && _zz_io_input_cmd_ready); + assign io_input_cmd_ready = (_zz_io_input_cmd_ready_1 && _zz_io_input_cmd_ready); + assign _zz_cmdFork_payload_last = io_input_cmd_payload_last; + assign _zz_cmdFork_payload_fragment_opcode = io_input_cmd_payload_fragment_opcode; + assign _zz_cmdFork_payload_fragment_address = io_input_cmd_payload_fragment_address; + assign _zz_cmdFork_payload_fragment_length = io_input_cmd_payload_fragment_length; + assign _zz_cmdFork_payload_fragment_data = io_input_cmd_payload_fragment_data; + assign _zz_cmdFork_payload_fragment_mask = io_input_cmd_payload_fragment_mask; + always @(*) begin + _zz_io_input_cmd_ready_1 = 1'b1; + if(when_Stream_l1020) begin + _zz_io_input_cmd_ready_1 = 1'b0; + end + if(when_Stream_l1020_1) begin + _zz_io_input_cmd_ready_1 = 1'b0; + end + end + + assign when_Stream_l1020 = ((! cmdFork_ready) && _zz_cmdFork_valid_1); + assign when_Stream_l1020_1 = ((! dataFork_ready) && _zz_dataFork_valid); + assign cmdFork_valid = (_zz_cmdFork_valid && _zz_cmdFork_valid_1); + assign cmdFork_payload_last = _zz_cmdFork_payload_last; + assign cmdFork_payload_fragment_opcode = _zz_cmdFork_payload_fragment_opcode; + assign cmdFork_payload_fragment_address = _zz_cmdFork_payload_fragment_address; + assign cmdFork_payload_fragment_length = _zz_cmdFork_payload_fragment_length; + assign cmdFork_payload_fragment_data = _zz_cmdFork_payload_fragment_data; + assign cmdFork_payload_fragment_mask = _zz_cmdFork_payload_fragment_mask; + assign cmdFork_fire = (cmdFork_valid && cmdFork_ready); + assign dataFork_valid = (_zz_cmdFork_valid && _zz_dataFork_valid); + assign dataFork_payload_last = _zz_cmdFork_payload_last; + assign dataFork_payload_fragment_opcode = _zz_cmdFork_payload_fragment_opcode; + assign dataFork_payload_fragment_address = _zz_cmdFork_payload_fragment_address; + assign dataFork_payload_fragment_length = _zz_cmdFork_payload_fragment_length; + assign dataFork_payload_fragment_data = _zz_cmdFork_payload_fragment_data; + assign dataFork_payload_fragment_mask = _zz_cmdFork_payload_fragment_mask; + assign dataFork_fire = (dataFork_valid && dataFork_ready); + assign when_Stream_l439 = (! io_input_cmd_payload_first); + always @(*) begin + cmdStage_valid = cmdFork_valid; + if(when_Stream_l439) begin + cmdStage_valid = 1'b0; + end + end + + always @(*) begin + cmdFork_ready = cmdStage_ready; + if(when_Stream_l439) begin + cmdFork_ready = 1'b1; + end + end + + assign cmdStage_payload_last = cmdFork_payload_last; + assign cmdStage_payload_fragment_opcode = cmdFork_payload_fragment_opcode; + assign cmdStage_payload_fragment_address = cmdFork_payload_fragment_address; + assign cmdStage_payload_fragment_length = cmdFork_payload_fragment_length; + assign cmdStage_payload_fragment_data = cmdFork_payload_fragment_data; + assign cmdStage_payload_fragment_mask = cmdFork_payload_fragment_mask; + assign when_Stream_l439_1 = (! (dataFork_payload_fragment_opcode == 1'b1)); + always @(*) begin + dataStage_valid = dataFork_valid; + if(when_Stream_l439_1) begin + dataStage_valid = 1'b0; + end + end + + always @(*) begin + dataFork_ready = dataStage_ready; + if(when_Stream_l439_1) begin + dataFork_ready = 1'b1; + end + end + + assign dataStage_payload_last = dataFork_payload_last; + assign dataStage_payload_fragment_opcode = dataFork_payload_fragment_opcode; + assign dataStage_payload_fragment_address = dataFork_payload_fragment_address; + assign dataStage_payload_fragment_length = dataFork_payload_fragment_length; + assign dataStage_payload_fragment_data = dataFork_payload_fragment_data; + assign dataStage_payload_fragment_mask = dataFork_payload_fragment_mask; + assign cmdStage_fire = (cmdStage_valid && cmdStage_ready); + assign writeCmdInfo_valid = (cmdStage_fire && (cmdStage_payload_fragment_opcode == 1'b1)); + assign readCmdInfo_valid = (cmdStage_fire && (cmdStage_payload_fragment_opcode == 1'b0)); + assign writeCmdInfo_ready = writeCmdInfo_fifo_io_push_ready; + assign writeRspInfo_fire = (writeRspInfo_valid && writeRspInfo_ready); + assign writeCmdInfo_fifo_io_pop_ready = (! front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid); + assign writeRspInfo_valid = front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid; + assign readCmdInfo_ready = readCmdInfo_fifo_io_push_ready; + assign readRspInfo_fire = (readRspInfo_valid && readRspInfo_ready); + assign readCmdInfo_fifo_io_pop_ready = (! front_dmaBridge_readCmdInfo_fifo_io_pop_rValid); + assign readRspInfo_valid = front_dmaBridge_readCmdInfo_fifo_io_pop_rValid; + assign _zz_io_output_arw_valid = (! ((! writeCmdInfo_ready) || (! readCmdInfo_ready))); + assign cmdStage_ready = (io_output_arw_ready && _zz_io_output_arw_valid); + assign io_output_arw_valid = (cmdStage_valid && _zz_io_output_arw_valid); + assign io_output_arw_payload_write = (io_input_cmd_payload_fragment_opcode == 1'b1); + assign io_output_arw_payload_addr = io_input_cmd_payload_fragment_address; + assign io_output_arw_payload_len = {4'd0, _zz_io_output_arw_payload_len}; + assign io_output_arw_payload_size = 3'b010; + assign io_output_arw_payload_prot = 3'b010; + assign io_output_arw_payload_cache = 4'b1111; + assign io_output_w_valid = dataStage_valid; + assign dataStage_ready = io_output_w_ready; + assign io_output_w_payload_data = dataStage_payload_fragment_data; + assign io_output_w_payload_strb = dataStage_payload_fragment_mask; + assign io_output_w_payload_last = dataStage_payload_last; + assign when_BmbToAxi4Bridge_l87 = (io_output_r_valid || io_output_b_valid); + assign io_output_r_fire = (io_output_r_valid && io_output_r_ready); + assign io_output_b_fire = (io_output_b_valid && io_output_b_ready); + assign when_BmbToAxi4Bridge_l87_1 = ((io_output_r_fire && io_output_r_payload_last) || io_output_b_fire); + assign when_BmbToAxi4Bridge_l88 = (! rspSelLock); + assign rspSelRead = (rspSelLock ? rspSelReadLast : io_output_r_valid); + assign io_output_b_ready = ((io_input_rsp_ready && (! rspSelRead)) && writeRspInfo_valid); + assign io_output_r_ready = ((io_input_rsp_ready && rspSelRead) && readRspInfo_valid); + assign writeRspInfo_ready = ((io_input_rsp_fire && io_input_rsp_payload_last) && (! rspSelRead)); + assign readRspInfo_ready = ((io_input_rsp_fire && io_input_rsp_payload_last) && rspSelRead); + assign io_input_rsp_payload_fragment_data = io_output_r_payload_data; + always @(*) begin + if(rspSelRead) begin + io_input_rsp_valid = (io_output_r_valid && readRspInfo_valid); + end else begin + io_input_rsp_valid = (io_output_b_valid && writeRspInfo_valid); + end + end + + always @(*) begin + if(rspSelRead) begin + io_input_rsp_payload_last = io_output_r_payload_last; + end else begin + io_input_rsp_payload_last = 1'b1; + end + end + + assign when_BmbToAxi4Bridge_l108 = (rspSelRead ? (io_output_r_payload_resp == 2'b00) : (io_output_b_payload_resp == 2'b00)); + always @(*) begin + if(when_BmbToAxi4Bridge_l108) begin + io_input_rsp_payload_fragment_opcode = 1'b0; + end else begin + io_input_rsp_payload_fragment_opcode = 1'b1; + end + end + + assign writeCmdInfo_fifo_io_flush = 1'b0; + assign readCmdInfo_fifo_io_flush = 1'b0; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + states_0_counter_value <= 5'h00; + _zz_cmdFork_valid_1 <= 1'b1; + _zz_dataFork_valid <= 1'b1; + io_input_cmd_payload_first <= 1'b1; + front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid <= 1'b0; + front_dmaBridge_readCmdInfo_fifo_io_pop_rValid <= 1'b0; + rspSelLock <= 1'b0; + end else begin + states_0_counter_value <= states_0_counter_valueNext; + if(cmdFork_fire) begin + _zz_cmdFork_valid_1 <= 1'b0; + end + if(dataFork_fire) begin + _zz_dataFork_valid <= 1'b0; + end + if(_zz_io_input_cmd_ready_1) begin + _zz_cmdFork_valid_1 <= 1'b1; + _zz_dataFork_valid <= 1'b1; + end + if(io_input_cmd_fire) begin + io_input_cmd_payload_first <= io_input_cmd_payload_last; + end + if(writeCmdInfo_fifo_io_pop_valid) begin + front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid <= 1'b1; + end + if(writeRspInfo_fire) begin + front_dmaBridge_writeCmdInfo_fifo_io_pop_rValid <= 1'b0; + end + if(readCmdInfo_fifo_io_pop_valid) begin + front_dmaBridge_readCmdInfo_fifo_io_pop_rValid <= 1'b1; + end + if(readRspInfo_fire) begin + front_dmaBridge_readCmdInfo_fifo_io_pop_rValid <= 1'b0; + end + if(when_BmbToAxi4Bridge_l87) begin + rspSelLock <= 1'b1; + end + if(when_BmbToAxi4Bridge_l87_1) begin + rspSelLock <= 1'b0; + end + end + end + + always @(posedge ctrl_clk) begin + if(when_BmbToAxi4Bridge_l45) begin + states_0_write <= (io_input_cmd_payload_fragment_opcode == 1'b1); + end + if(when_BmbToAxi4Bridge_l88) begin + rspSelReadLast <= io_output_r_valid; + end + end + + +endmodule + +//UsbOhciAxi4_StreamCCByToggle_4 replaced by UsbOhciAxi4_StreamCCByToggle_1 + +//UsbOhciAxi4_StreamCCByToggle_3 replaced by UsbOhciAxi4_StreamCCByToggle_1 + +//UsbOhciAxi4_StreamCCByToggle_2 replaced by UsbOhciAxi4_StreamCCByToggle_1 + +module UsbOhciAxi4_StreamCCByToggle_1 ( + input io_input_valid, + output io_input_ready, + output io_output_valid, + input io_output_ready, + input ctrl_clk, + input ctrl_reset, + input phy_clk, + input ctrl_reset_syncronized +); + + wire outHitSignal_buffercc_io_dataOut; + wire pushArea_target_buffercc_io_dataOut; + wire outHitSignal; + wire pushArea_hit; + wire pushArea_accept; + reg pushArea_target; + reg _zz_io_input_ready; + wire popArea_stream_valid; + wire popArea_stream_ready; + wire popArea_target; + wire popArea_stream_fire; + reg popArea_hit; + + UsbOhciAxi4_BufferCC_24 outHitSignal_buffercc ( + .io_dataIn (outHitSignal ), //i + .io_dataOut (outHitSignal_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_BufferCC_26 pushArea_target_buffercc ( + .io_dataIn (pushArea_target ), //i + .io_dataOut (pushArea_target_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (ctrl_reset_syncronized ) //i + ); + assign pushArea_hit = outHitSignal_buffercc_io_dataOut; + assign pushArea_accept = ((! _zz_io_input_ready) && io_input_valid); + assign io_input_ready = (_zz_io_input_ready && (pushArea_hit == pushArea_target)); + assign popArea_target = pushArea_target_buffercc_io_dataOut; + assign popArea_stream_fire = (popArea_stream_valid && popArea_stream_ready); + assign outHitSignal = popArea_hit; + assign popArea_stream_valid = (popArea_target != popArea_hit); + assign io_output_valid = popArea_stream_valid; + assign popArea_stream_ready = io_output_ready; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + pushArea_target <= 1'b0; + _zz_io_input_ready <= 1'b0; + end else begin + if(pushArea_accept) begin + pushArea_target <= (! pushArea_target); + end + if(pushArea_accept) begin + _zz_io_input_ready <= 1'b1; + end + if(io_input_ready) begin + _zz_io_input_ready <= 1'b0; + end + end + end + + always @(posedge phy_clk or posedge ctrl_reset_syncronized) begin + if(ctrl_reset_syncronized) begin + popArea_hit <= 1'b0; + end else begin + if(popArea_stream_fire) begin + popArea_hit <= popArea_target; + end + end + end + + +endmodule + +//UsbOhciAxi4_PulseCCByToggle_4 replaced by UsbOhciAxi4_PulseCCByToggle_1 + +//UsbOhciAxi4_PulseCCByToggle_3 replaced by UsbOhciAxi4_PulseCCByToggle_1 + +//UsbOhciAxi4_PulseCCByToggle_2 replaced by UsbOhciAxi4_PulseCCByToggle_1 + +//UsbOhciAxi4_BufferCC_8 replaced by UsbOhciAxi4_BufferCC_3 + +//UsbOhciAxi4_BufferCC_7 replaced by UsbOhciAxi4_BufferCC_3 + +//UsbOhciAxi4_BufferCC_6 replaced by UsbOhciAxi4_BufferCC + +//UsbOhciAxi4_BufferCC_5 replaced by UsbOhciAxi4_BufferCC + +module UsbOhciAxi4_PulseCCByToggle_1 ( + input io_pulseIn, + output io_pulseOut, + input phy_clk, + input phy_reset, + input ctrl_clk, + input phy_reset_syncronized +); + + wire inArea_target_buffercc_io_dataOut; + reg inArea_target; + wire outArea_target; + reg outArea_target_regNext; + + UsbOhciAxi4_BufferCC_23 inArea_target_buffercc ( + .io_dataIn (inArea_target ), //i + .io_dataOut (inArea_target_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (phy_reset_syncronized ) //i + ); + assign outArea_target = inArea_target_buffercc_io_dataOut; + assign io_pulseOut = (outArea_target ^ outArea_target_regNext); + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + inArea_target <= 1'b0; + end else begin + if(io_pulseIn) begin + inArea_target <= (! inArea_target); + end + end + end + + always @(posedge ctrl_clk or posedge phy_reset_syncronized) begin + if(phy_reset_syncronized) begin + outArea_target_regNext <= 1'b0; + end else begin + outArea_target_regNext <= outArea_target; + end + end + + +endmodule + +//UsbOhciAxi4_BufferCC_4 replaced by UsbOhciAxi4_BufferCC_3 + +module UsbOhciAxi4_FlowCCByToggle ( + input io_input_valid, + input io_input_payload_stuffingError, + input [7:0] io_input_payload_data, + output io_output_valid, + output io_output_payload_stuffingError, + output [7:0] io_output_payload_data, + input phy_clk, + input phy_reset, + input ctrl_clk, + input phy_reset_syncronized +); + + wire inputArea_target_buffercc_io_dataOut; + reg inputArea_target; + reg inputArea_data_stuffingError; + reg [7:0] inputArea_data_data; + wire outputArea_target; + reg outputArea_hit; + wire outputArea_flow_valid; + wire outputArea_flow_payload_stuffingError; + wire [7:0] outputArea_flow_payload_data; + reg outputArea_flow_m2sPipe_valid; + (* async_reg = "true" *) reg outputArea_flow_m2sPipe_payload_stuffingError; + (* async_reg = "true" *) reg [7:0] outputArea_flow_m2sPipe_payload_data; + + UsbOhciAxi4_BufferCC_23 inputArea_target_buffercc ( + .io_dataIn (inputArea_target ), //i + .io_dataOut (inputArea_target_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (phy_reset_syncronized ) //i + ); + assign outputArea_target = inputArea_target_buffercc_io_dataOut; + assign outputArea_flow_valid = (outputArea_target != outputArea_hit); + assign outputArea_flow_payload_stuffingError = inputArea_data_stuffingError; + assign outputArea_flow_payload_data = inputArea_data_data; + assign io_output_valid = outputArea_flow_m2sPipe_valid; + assign io_output_payload_stuffingError = outputArea_flow_m2sPipe_payload_stuffingError; + assign io_output_payload_data = outputArea_flow_m2sPipe_payload_data; + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + inputArea_target <= 1'b0; + end else begin + if(io_input_valid) begin + inputArea_target <= (! inputArea_target); + end + end + end + + always @(posedge phy_clk) begin + if(io_input_valid) begin + inputArea_data_stuffingError <= io_input_payload_stuffingError; + inputArea_data_data <= io_input_payload_data; + end + end + + always @(posedge ctrl_clk or posedge phy_reset_syncronized) begin + if(phy_reset_syncronized) begin + outputArea_flow_m2sPipe_valid <= 1'b0; + outputArea_hit <= 1'b0; + end else begin + outputArea_hit <= outputArea_target; + outputArea_flow_m2sPipe_valid <= outputArea_flow_valid; + end + end + + always @(posedge ctrl_clk) begin + if(outputArea_flow_valid) begin + outputArea_flow_m2sPipe_payload_stuffingError <= outputArea_flow_payload_stuffingError; + outputArea_flow_m2sPipe_payload_data <= outputArea_flow_payload_data; + end + end + + +endmodule + +module UsbOhciAxi4_PulseCCByToggle ( + input io_pulseIn, + output io_pulseOut, + input phy_clk, + input phy_reset, + input ctrl_clk, + output phy_reset_syncronized_1 +); + + wire bufferCC_io_dataIn; + wire bufferCC_io_dataOut; + wire inArea_target_buffercc_io_dataOut; + reg inArea_target; + wire phy_reset_syncronized; + wire outArea_target; + reg outArea_target_regNext; + + UsbOhciAxi4_BufferCC_22 bufferCC ( + .io_dataIn (bufferCC_io_dataIn ), //i + .io_dataOut (bufferCC_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .phy_reset (phy_reset ) //i + ); + UsbOhciAxi4_BufferCC_23 inArea_target_buffercc ( + .io_dataIn (inArea_target ), //i + .io_dataOut (inArea_target_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .phy_reset_syncronized (phy_reset_syncronized ) //i + ); + assign bufferCC_io_dataIn = (1'b0 ^ 1'b0); + assign phy_reset_syncronized = bufferCC_io_dataOut; + assign outArea_target = inArea_target_buffercc_io_dataOut; + assign io_pulseOut = (outArea_target ^ outArea_target_regNext); + assign phy_reset_syncronized_1 = phy_reset_syncronized; + always @(posedge phy_clk or posedge phy_reset) begin + if(phy_reset) begin + inArea_target <= 1'b0; + end else begin + if(io_pulseIn) begin + inArea_target <= (! inArea_target); + end + end + end + + always @(posedge ctrl_clk or posedge phy_reset_syncronized) begin + if(phy_reset_syncronized) begin + outArea_target_regNext <= 1'b0; + end else begin + outArea_target_regNext <= outArea_target; + end + end + + +endmodule + +module UsbOhciAxi4_StreamCCByToggle ( + input io_input_valid, + output io_input_ready, + input io_input_payload_last, + input [7:0] io_input_payload_fragment, + output io_output_valid, + input io_output_ready, + output io_output_payload_last, + output [7:0] io_output_payload_fragment, + input ctrl_clk, + input ctrl_reset, + input phy_clk, + output ctrl_reset_syncronized_1 +); + + wire bufferCC_io_dataIn; + wire outHitSignal_buffercc_io_dataOut; + wire bufferCC_io_dataOut; + wire pushArea_target_buffercc_io_dataOut; + wire outHitSignal; + wire pushArea_hit; + wire pushArea_accept; + reg pushArea_target; + reg pushArea_data_last; + reg [7:0] pushArea_data_fragment; + wire io_input_fire; + wire ctrl_reset_syncronized; + wire popArea_stream_valid; + reg popArea_stream_ready; + wire popArea_stream_payload_last; + wire [7:0] popArea_stream_payload_fragment; + wire popArea_target; + wire popArea_stream_fire; + reg popArea_hit; + wire popArea_stream_m2sPipe_valid; + wire popArea_stream_m2sPipe_ready; + wire popArea_stream_m2sPipe_payload_last; + wire [7:0] popArea_stream_m2sPipe_payload_fragment; + reg popArea_stream_rValid; + (* async_reg = "true" *) reg popArea_stream_rData_last; + (* async_reg = "true" *) reg [7:0] popArea_stream_rData_fragment; + wire when_Stream_l369; + + UsbOhciAxi4_BufferCC_24 outHitSignal_buffercc ( + .io_dataIn (outHitSignal ), //i + .io_dataOut (outHitSignal_buffercc_io_dataOut), //o + .ctrl_clk (ctrl_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_BufferCC_25 bufferCC ( + .io_dataIn (bufferCC_io_dataIn ), //i + .io_dataOut (bufferCC_io_dataOut), //o + .phy_clk (phy_clk ), //i + .ctrl_reset (ctrl_reset ) //i + ); + UsbOhciAxi4_BufferCC_26 pushArea_target_buffercc ( + .io_dataIn (pushArea_target ), //i + .io_dataOut (pushArea_target_buffercc_io_dataOut), //o + .phy_clk (phy_clk ), //i + .ctrl_reset_syncronized (ctrl_reset_syncronized ) //i + ); + assign pushArea_hit = outHitSignal_buffercc_io_dataOut; + assign io_input_fire = (io_input_valid && io_input_ready); + assign pushArea_accept = io_input_fire; + assign io_input_ready = (pushArea_hit == pushArea_target); + assign bufferCC_io_dataIn = (1'b0 ^ 1'b0); + assign ctrl_reset_syncronized = bufferCC_io_dataOut; + assign popArea_target = pushArea_target_buffercc_io_dataOut; + assign popArea_stream_fire = (popArea_stream_valid && popArea_stream_ready); + assign outHitSignal = popArea_hit; + assign popArea_stream_valid = (popArea_target != popArea_hit); + assign popArea_stream_payload_last = pushArea_data_last; + assign popArea_stream_payload_fragment = pushArea_data_fragment; + always @(*) begin + popArea_stream_ready = popArea_stream_m2sPipe_ready; + if(when_Stream_l369) begin + popArea_stream_ready = 1'b1; + end + end + + assign when_Stream_l369 = (! popArea_stream_m2sPipe_valid); + assign popArea_stream_m2sPipe_valid = popArea_stream_rValid; + assign popArea_stream_m2sPipe_payload_last = popArea_stream_rData_last; + assign popArea_stream_m2sPipe_payload_fragment = popArea_stream_rData_fragment; + assign io_output_valid = popArea_stream_m2sPipe_valid; + assign popArea_stream_m2sPipe_ready = io_output_ready; + assign io_output_payload_last = popArea_stream_m2sPipe_payload_last; + assign io_output_payload_fragment = popArea_stream_m2sPipe_payload_fragment; + assign ctrl_reset_syncronized_1 = ctrl_reset_syncronized; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + pushArea_target <= 1'b0; + end else begin + if(pushArea_accept) begin + pushArea_target <= (! pushArea_target); + end + end + end + + always @(posedge ctrl_clk) begin + if(pushArea_accept) begin + pushArea_data_last <= io_input_payload_last; + pushArea_data_fragment <= io_input_payload_fragment; + end + end + + always @(posedge phy_clk or posedge ctrl_reset_syncronized) begin + if(ctrl_reset_syncronized) begin + popArea_hit <= 1'b0; + popArea_stream_rValid <= 1'b0; + end else begin + if(popArea_stream_fire) begin + popArea_hit <= popArea_target; + end + if(popArea_stream_ready) begin + popArea_stream_rValid <= popArea_stream_valid; + end + end + end + + always @(posedge phy_clk) begin + if(popArea_stream_fire) begin + popArea_stream_rData_last <= popArea_stream_payload_last; + popArea_stream_rData_fragment <= popArea_stream_payload_fragment; + end + end + + +endmodule + +module UsbOhciAxi4_BufferCC_3 ( + input io_dataIn, + output io_dataOut, + input ctrl_clk, + input ctrl_reset +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge ctrl_clk) begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + + +endmodule + +//UsbOhciAxi4_BufferCC_2 replaced by UsbOhciAxi4_BufferCC + +//UsbOhciAxi4_BufferCC_1 replaced by UsbOhciAxi4_BufferCC + +module UsbOhciAxi4_BufferCC ( + input io_dataIn, + output io_dataOut, + input phy_clk, + input phy_reset +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge phy_clk) begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + + +endmodule + +module UsbOhciAxi4_UsbLsFsPhyFilter ( + input io_lowSpeed, + input io_usb_dp, + input io_usb_dm, + output io_filtred_dp, + output io_filtred_dm, + output io_filtred_d, + output io_filtred_se0, + output io_filtred_sample, + input phy_clk, + input phy_reset +); + + wire [4:0] _zz_timer_sampleDo; + reg timer_clear; + reg [4:0] timer_counter; + wire [4:0] timer_counterLimit; + wire when_UsbHubPhy_l93; + wire [3:0] timer_sampleAt; + wire timer_sampleDo; + reg io_usb_dp_regNext; + reg io_usb_dm_regNext; + wire when_UsbHubPhy_l100; + + assign _zz_timer_sampleDo = {1'd0, timer_sampleAt}; + always @(*) begin + timer_clear = 1'b0; + if(when_UsbHubPhy_l100) begin + timer_clear = 1'b1; + end + end + + assign timer_counterLimit = (io_lowSpeed ? 5'h1f : 5'h03); + assign when_UsbHubPhy_l93 = ((timer_counter == timer_counterLimit) || timer_clear); + assign timer_sampleAt = (io_lowSpeed ? 4'b1110 : 4'b0000); + assign timer_sampleDo = ((timer_counter == _zz_timer_sampleDo) && (! timer_clear)); + assign when_UsbHubPhy_l100 = ((io_usb_dp ^ io_usb_dp_regNext) || (io_usb_dm ^ io_usb_dm_regNext)); + assign io_filtred_dp = io_usb_dp; + assign io_filtred_dm = io_usb_dm; + assign io_filtred_d = io_usb_dp; + assign io_filtred_sample = timer_sampleDo; + assign io_filtred_se0 = ((! io_usb_dp) && (! io_usb_dm)); + always @(posedge phy_clk) begin + timer_counter <= (timer_counter + 5'h01); + if(when_UsbHubPhy_l93) begin + timer_counter <= 5'h00; + end + io_usb_dp_regNext <= io_usb_dp; + io_usb_dm_regNext <= io_usb_dm; + end + + +endmodule + +module UsbOhciAxi4_Crc_2 ( + input io_flush, + input io_input_valid, + input [7:0] io_input_payload, + output [15:0] io_result, + output [15:0] io_resultNext, + input ctrl_clk, + input ctrl_reset +); + + wire [15:0] _zz_state_1; + wire [15:0] _zz_state_2; + wire [15:0] _zz_state_3; + wire [15:0] _zz_state_4; + wire [15:0] _zz_state_5; + wire [15:0] _zz_state_6; + wire [15:0] _zz_state_7; + wire [15:0] _zz_state_8; + reg [15:0] state_8; + reg [15:0] state_7; + reg [15:0] state_6; + reg [15:0] state_5; + reg [15:0] state_4; + reg [15:0] state_3; + reg [15:0] state_2; + reg [15:0] state_1; + reg [15:0] state; + wire [15:0] stateXor; + wire [15:0] accXor; + + assign _zz_state_1 = (state <<< 1); + assign _zz_state_2 = (state_1 <<< 1); + assign _zz_state_3 = (state_2 <<< 1); + assign _zz_state_4 = (state_3 <<< 1); + assign _zz_state_5 = (state_4 <<< 1); + assign _zz_state_6 = (state_5 <<< 1); + assign _zz_state_7 = (state_6 <<< 1); + assign _zz_state_8 = (state_7 <<< 1); + always @(*) begin + state_8 = state_7; + state_8 = (_zz_state_8 ^ ((io_input_payload[7] ^ state_7[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_7 = state_6; + state_7 = (_zz_state_7 ^ ((io_input_payload[6] ^ state_6[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_6 = state_5; + state_6 = (_zz_state_6 ^ ((io_input_payload[5] ^ state_5[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_5 = state_4; + state_5 = (_zz_state_5 ^ ((io_input_payload[4] ^ state_4[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_4 = state_3; + state_4 = (_zz_state_4 ^ ((io_input_payload[3] ^ state_3[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_3 = state_2; + state_3 = (_zz_state_3 ^ ((io_input_payload[2] ^ state_2[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_2 = state_1; + state_2 = (_zz_state_2 ^ ((io_input_payload[1] ^ state_1[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_1 = state; + state_1 = (_zz_state_1 ^ ((io_input_payload[0] ^ state[15]) ? 16'h8005 : 16'h0000)); + end + + assign stateXor = (state ^ 16'h0000); + assign accXor = (state_8 ^ 16'h0000); + assign io_result = stateXor; + assign io_resultNext = accXor; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + state <= 16'hffff; + end else begin + if(io_input_valid) begin + state <= state_8; + end + if(io_flush) begin + state <= 16'hffff; + end + end + end + + +endmodule + +module UsbOhciAxi4_Crc_1 ( + input io_flush, + input io_input_valid, + input [7:0] io_input_payload, + output [15:0] io_result, + output [15:0] io_resultNext, + input ctrl_clk, + input ctrl_reset +); + + wire [15:0] _zz_state_1; + wire [15:0] _zz_state_2; + wire [15:0] _zz_state_3; + wire [15:0] _zz_state_4; + wire [15:0] _zz_state_5; + wire [15:0] _zz_state_6; + wire [15:0] _zz_state_7; + wire [15:0] _zz_state_8; + wire _zz_io_result; + wire [0:0] _zz_io_result_1; + wire [4:0] _zz_io_result_2; + wire _zz_io_resultNext; + wire [0:0] _zz_io_resultNext_1; + wire [4:0] _zz_io_resultNext_2; + reg [15:0] state_8; + reg [15:0] state_7; + reg [15:0] state_6; + reg [15:0] state_5; + reg [15:0] state_4; + reg [15:0] state_3; + reg [15:0] state_2; + reg [15:0] state_1; + reg [15:0] state; + wire [15:0] stateXor; + wire [15:0] accXor; + + assign _zz_state_1 = (state <<< 1); + assign _zz_state_2 = (state_1 <<< 1); + assign _zz_state_3 = (state_2 <<< 1); + assign _zz_state_4 = (state_3 <<< 1); + assign _zz_state_5 = (state_4 <<< 1); + assign _zz_state_6 = (state_5 <<< 1); + assign _zz_state_7 = (state_6 <<< 1); + assign _zz_state_8 = (state_7 <<< 1); + assign _zz_io_result = stateXor[9]; + assign _zz_io_result_1 = stateXor[10]; + assign _zz_io_result_2 = {stateXor[11],{stateXor[12],{stateXor[13],{stateXor[14],stateXor[15]}}}}; + assign _zz_io_resultNext = accXor[9]; + assign _zz_io_resultNext_1 = accXor[10]; + assign _zz_io_resultNext_2 = {accXor[11],{accXor[12],{accXor[13],{accXor[14],accXor[15]}}}}; + always @(*) begin + state_8 = state_7; + state_8 = (_zz_state_8 ^ ((io_input_payload[7] ^ state_7[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_7 = state_6; + state_7 = (_zz_state_7 ^ ((io_input_payload[6] ^ state_6[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_6 = state_5; + state_6 = (_zz_state_6 ^ ((io_input_payload[5] ^ state_5[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_5 = state_4; + state_5 = (_zz_state_5 ^ ((io_input_payload[4] ^ state_4[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_4 = state_3; + state_4 = (_zz_state_4 ^ ((io_input_payload[3] ^ state_3[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_3 = state_2; + state_3 = (_zz_state_3 ^ ((io_input_payload[2] ^ state_2[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_2 = state_1; + state_2 = (_zz_state_2 ^ ((io_input_payload[1] ^ state_1[15]) ? 16'h8005 : 16'h0000)); + end + + always @(*) begin + state_1 = state; + state_1 = (_zz_state_1 ^ ((io_input_payload[0] ^ state[15]) ? 16'h8005 : 16'h0000)); + end + + assign stateXor = (state ^ 16'hffff); + assign accXor = (state_8 ^ 16'hffff); + assign io_result = {stateXor[0],{stateXor[1],{stateXor[2],{stateXor[3],{stateXor[4],{stateXor[5],{stateXor[6],{stateXor[7],{stateXor[8],{_zz_io_result,{_zz_io_result_1,_zz_io_result_2}}}}}}}}}}}; + assign io_resultNext = {accXor[0],{accXor[1],{accXor[2],{accXor[3],{accXor[4],{accXor[5],{accXor[6],{accXor[7],{accXor[8],{_zz_io_resultNext,{_zz_io_resultNext_1,_zz_io_resultNext_2}}}}}}}}}}}; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + state <= 16'hffff; + end else begin + if(io_input_valid) begin + state <= state_8; + end + if(io_flush) begin + state <= 16'hffff; + end + end + end + + +endmodule + +module UsbOhciAxi4_Crc ( + input io_flush, + input io_input_valid, + input [10:0] io_input_payload, + output [4:0] io_result, + output [4:0] io_resultNext, + input ctrl_clk, + input ctrl_reset +); + + wire [4:0] _zz_state_1; + wire [4:0] _zz_state_2; + wire [4:0] _zz_state_3; + wire [4:0] _zz_state_4; + wire [4:0] _zz_state_5; + wire [4:0] _zz_state_6; + wire [4:0] _zz_state_7; + wire [4:0] _zz_state_8; + wire [4:0] _zz_state_9; + wire [4:0] _zz_state_10; + wire [4:0] _zz_state_11; + reg [4:0] state_11; + reg [4:0] state_10; + reg [4:0] state_9; + reg [4:0] state_8; + reg [4:0] state_7; + reg [4:0] state_6; + reg [4:0] state_5; + reg [4:0] state_4; + reg [4:0] state_3; + reg [4:0] state_2; + reg [4:0] state_1; + reg [4:0] state; + wire [4:0] stateXor; + wire [4:0] accXor; + + assign _zz_state_1 = (state <<< 1); + assign _zz_state_2 = (state_1 <<< 1); + assign _zz_state_3 = (state_2 <<< 1); + assign _zz_state_4 = (state_3 <<< 1); + assign _zz_state_5 = (state_4 <<< 1); + assign _zz_state_6 = (state_5 <<< 1); + assign _zz_state_7 = (state_6 <<< 1); + assign _zz_state_8 = (state_7 <<< 1); + assign _zz_state_9 = (state_8 <<< 1); + assign _zz_state_10 = (state_9 <<< 1); + assign _zz_state_11 = (state_10 <<< 1); + always @(*) begin + state_11 = state_10; + state_11 = (_zz_state_11 ^ ((io_input_payload[10] ^ state_10[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_10 = state_9; + state_10 = (_zz_state_10 ^ ((io_input_payload[9] ^ state_9[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_9 = state_8; + state_9 = (_zz_state_9 ^ ((io_input_payload[8] ^ state_8[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_8 = state_7; + state_8 = (_zz_state_8 ^ ((io_input_payload[7] ^ state_7[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_7 = state_6; + state_7 = (_zz_state_7 ^ ((io_input_payload[6] ^ state_6[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_6 = state_5; + state_6 = (_zz_state_6 ^ ((io_input_payload[5] ^ state_5[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_5 = state_4; + state_5 = (_zz_state_5 ^ ((io_input_payload[4] ^ state_4[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_4 = state_3; + state_4 = (_zz_state_4 ^ ((io_input_payload[3] ^ state_3[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_3 = state_2; + state_3 = (_zz_state_3 ^ ((io_input_payload[2] ^ state_2[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_2 = state_1; + state_2 = (_zz_state_2 ^ ((io_input_payload[1] ^ state_1[4]) ? 5'h05 : 5'h00)); + end + + always @(*) begin + state_1 = state; + state_1 = (_zz_state_1 ^ ((io_input_payload[0] ^ state[4]) ? 5'h05 : 5'h00)); + end + + assign stateXor = (state ^ 5'h1f); + assign accXor = (state_11 ^ 5'h1f); + assign io_result = {stateXor[0],{stateXor[1],{stateXor[2],{stateXor[3],stateXor[4]}}}}; + assign io_resultNext = {accXor[0],{accXor[1],{accXor[2],{accXor[3],accXor[4]}}}}; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + state <= 5'h1f; + end else begin + if(io_input_valid) begin + state <= state_11; + end + if(io_flush) begin + state <= 5'h1f; + end + end + end + + +endmodule + +module UsbOhciAxi4_StreamFifo ( + input io_push_valid, + output io_push_ready, + input [31:0] io_push_payload, + output io_pop_valid, + input io_pop_ready, + output [31:0] io_pop_payload, + input io_flush, + output [9:0] io_occupancy, + output [9:0] io_availability, + input ctrl_clk, + input ctrl_reset +); + + reg [31:0] _zz_logic_ram_port1; + reg _zz_1; + wire logic_ptr_doPush; + wire logic_ptr_doPop; + wire logic_ptr_full; + wire logic_ptr_empty; + reg [9:0] logic_ptr_push; + reg [9:0] logic_ptr_pop; + wire [9:0] logic_ptr_occupancy; + wire [9:0] logic_ptr_popOnIo; + wire when_Stream_l1205; + reg logic_ptr_wentUp; + wire io_push_fire; + wire logic_push_onRam_write_valid; + wire [8:0] logic_push_onRam_write_payload_address; + wire [31:0] logic_push_onRam_write_payload_data; + wire logic_pop_addressGen_valid; + reg logic_pop_addressGen_ready; + wire [8:0] logic_pop_addressGen_payload; + wire logic_pop_addressGen_fire; + wire logic_pop_sync_readArbitation_valid; + wire logic_pop_sync_readArbitation_ready; + wire [8:0] logic_pop_sync_readArbitation_payload; + reg logic_pop_addressGen_rValid; + reg [8:0] logic_pop_addressGen_rData; + wire when_Stream_l369; + wire logic_pop_sync_readPort_cmd_valid; + wire [8:0] logic_pop_sync_readPort_cmd_payload; + wire [31:0] logic_pop_sync_readPort_rsp; + wire logic_pop_sync_readArbitation_translated_valid; + wire logic_pop_sync_readArbitation_translated_ready; + wire [31:0] logic_pop_sync_readArbitation_translated_payload; + wire logic_pop_sync_readArbitation_fire; + reg [9:0] logic_pop_sync_popReg; + reg [31:0] logic_ram [0:511]; + + always @(posedge ctrl_clk) begin + if(_zz_1) begin + logic_ram[logic_push_onRam_write_payload_address] <= logic_push_onRam_write_payload_data; + end + end + + always @(posedge ctrl_clk) begin + if(logic_pop_sync_readPort_cmd_valid) begin + _zz_logic_ram_port1 <= logic_ram[logic_pop_sync_readPort_cmd_payload]; + end + end + + always @(*) begin + _zz_1 = 1'b0; + if(logic_push_onRam_write_valid) begin + _zz_1 = 1'b1; + end + end + + assign when_Stream_l1205 = (logic_ptr_doPush != logic_ptr_doPop); + assign logic_ptr_empty = (logic_ptr_push == logic_ptr_pop); + assign logic_ptr_occupancy = (logic_ptr_push - logic_ptr_popOnIo); + assign io_push_ready = (! logic_ptr_full); + assign io_push_fire = (io_push_valid && io_push_ready); + assign logic_ptr_doPush = io_push_fire; + assign logic_push_onRam_write_valid = io_push_fire; + assign logic_push_onRam_write_payload_address = logic_ptr_push[8:0]; + assign logic_push_onRam_write_payload_data = io_push_payload; + assign logic_pop_addressGen_valid = (! logic_ptr_empty); + assign logic_pop_addressGen_payload = logic_ptr_pop[8:0]; + assign logic_pop_addressGen_fire = (logic_pop_addressGen_valid && logic_pop_addressGen_ready); + assign logic_ptr_doPop = logic_pop_addressGen_fire; + always @(*) begin + logic_pop_addressGen_ready = logic_pop_sync_readArbitation_ready; + if(when_Stream_l369) begin + logic_pop_addressGen_ready = 1'b1; + end + end + + assign when_Stream_l369 = (! logic_pop_sync_readArbitation_valid); + assign logic_pop_sync_readArbitation_valid = logic_pop_addressGen_rValid; + assign logic_pop_sync_readArbitation_payload = logic_pop_addressGen_rData; + assign logic_pop_sync_readPort_rsp = _zz_logic_ram_port1; + assign logic_pop_sync_readPort_cmd_valid = logic_pop_addressGen_fire; + assign logic_pop_sync_readPort_cmd_payload = logic_pop_addressGen_payload; + assign logic_pop_sync_readArbitation_translated_valid = logic_pop_sync_readArbitation_valid; + assign logic_pop_sync_readArbitation_ready = logic_pop_sync_readArbitation_translated_ready; + assign logic_pop_sync_readArbitation_translated_payload = logic_pop_sync_readPort_rsp; + assign io_pop_valid = logic_pop_sync_readArbitation_translated_valid; + assign logic_pop_sync_readArbitation_translated_ready = io_pop_ready; + assign io_pop_payload = logic_pop_sync_readArbitation_translated_payload; + assign logic_pop_sync_readArbitation_fire = (logic_pop_sync_readArbitation_valid && logic_pop_sync_readArbitation_ready); + assign logic_ptr_popOnIo = logic_pop_sync_popReg; + assign io_occupancy = logic_ptr_occupancy; + assign io_availability = (10'h200 - logic_ptr_occupancy); + assign logic_ptr_full = 1'b0; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + logic_ptr_push <= 10'h000; + logic_ptr_pop <= 10'h000; + logic_ptr_wentUp <= 1'b0; + logic_pop_addressGen_rValid <= 1'b0; + logic_pop_sync_popReg <= 10'h000; + end else begin + if(when_Stream_l1205) begin + logic_ptr_wentUp <= logic_ptr_doPush; + end + if(io_flush) begin + logic_ptr_wentUp <= 1'b0; + end + if(logic_ptr_doPush) begin + logic_ptr_push <= (logic_ptr_push + 10'h001); + end + if(logic_ptr_doPop) begin + logic_ptr_pop <= (logic_ptr_pop + 10'h001); + end + if(io_flush) begin + logic_ptr_push <= 10'h000; + logic_ptr_pop <= 10'h000; + end + if(logic_pop_addressGen_ready) begin + logic_pop_addressGen_rValid <= logic_pop_addressGen_valid; + end + if(io_flush) begin + logic_pop_addressGen_rValid <= 1'b0; + end + if(logic_pop_sync_readArbitation_fire) begin + logic_pop_sync_popReg <= logic_ptr_pop; + end + if(io_flush) begin + logic_pop_sync_popReg <= 10'h000; + end + end + end + + always @(posedge ctrl_clk) begin + if(logic_pop_addressGen_ready) begin + logic_pop_addressGen_rData <= logic_pop_addressGen_payload; + end + end + + +endmodule + +//UsbOhciAxi4_StreamFifo_2 replaced by UsbOhciAxi4_StreamFifo_1 + +module UsbOhciAxi4_StreamFifo_1 ( + input io_push_valid, + output io_push_ready, + output io_pop_valid, + input io_pop_ready, + input io_flush, + output [5:0] io_occupancy, + output [5:0] io_availability, + input ctrl_clk, + input ctrl_reset +); + + wire logic_ptr_doPush; + wire logic_ptr_doPop; + wire logic_ptr_full; + wire logic_ptr_empty; + reg [5:0] logic_ptr_push; + reg [5:0] logic_ptr_pop; + wire [5:0] logic_ptr_occupancy; + wire [5:0] logic_ptr_popOnIo; + wire when_Stream_l1205; + reg logic_ptr_wentUp; + wire io_push_fire; + wire logic_push_onRam_write_valid; + wire [4:0] logic_push_onRam_write_payload_address; + wire logic_pop_addressGen_valid; + reg logic_pop_addressGen_ready; + wire [4:0] logic_pop_addressGen_payload; + wire logic_pop_addressGen_fire; + wire logic_pop_sync_readArbitation_valid; + wire logic_pop_sync_readArbitation_ready; + wire [4:0] logic_pop_sync_readArbitation_payload; + reg logic_pop_addressGen_rValid; + reg [4:0] logic_pop_addressGen_rData; + wire when_Stream_l369; + wire logic_pop_sync_readPort_cmd_valid; + wire [4:0] logic_pop_sync_readPort_cmd_payload; + wire logic_pop_sync_readArbitation_translated_valid; + wire logic_pop_sync_readArbitation_translated_ready; + wire logic_pop_sync_readArbitation_fire; + reg [5:0] logic_pop_sync_popReg; + + assign when_Stream_l1205 = (logic_ptr_doPush != logic_ptr_doPop); + assign logic_ptr_full = (((logic_ptr_push ^ logic_ptr_popOnIo) ^ 6'h20) == 6'h00); + assign logic_ptr_empty = (logic_ptr_push == logic_ptr_pop); + assign logic_ptr_occupancy = (logic_ptr_push - logic_ptr_popOnIo); + assign io_push_ready = (! logic_ptr_full); + assign io_push_fire = (io_push_valid && io_push_ready); + assign logic_ptr_doPush = io_push_fire; + assign logic_push_onRam_write_valid = io_push_fire; + assign logic_push_onRam_write_payload_address = logic_ptr_push[4:0]; + assign logic_pop_addressGen_valid = (! logic_ptr_empty); + assign logic_pop_addressGen_payload = logic_ptr_pop[4:0]; + assign logic_pop_addressGen_fire = (logic_pop_addressGen_valid && logic_pop_addressGen_ready); + assign logic_ptr_doPop = logic_pop_addressGen_fire; + always @(*) begin + logic_pop_addressGen_ready = logic_pop_sync_readArbitation_ready; + if(when_Stream_l369) begin + logic_pop_addressGen_ready = 1'b1; + end + end + + assign when_Stream_l369 = (! logic_pop_sync_readArbitation_valid); + assign logic_pop_sync_readArbitation_valid = logic_pop_addressGen_rValid; + assign logic_pop_sync_readArbitation_payload = logic_pop_addressGen_rData; + assign logic_pop_sync_readPort_cmd_valid = logic_pop_addressGen_fire; + assign logic_pop_sync_readPort_cmd_payload = logic_pop_addressGen_payload; + assign logic_pop_sync_readArbitation_translated_valid = logic_pop_sync_readArbitation_valid; + assign logic_pop_sync_readArbitation_ready = logic_pop_sync_readArbitation_translated_ready; + assign io_pop_valid = logic_pop_sync_readArbitation_translated_valid; + assign logic_pop_sync_readArbitation_translated_ready = io_pop_ready; + assign logic_pop_sync_readArbitation_fire = (logic_pop_sync_readArbitation_valid && logic_pop_sync_readArbitation_ready); + assign logic_ptr_popOnIo = logic_pop_sync_popReg; + assign io_occupancy = logic_ptr_occupancy; + assign io_availability = (6'h20 - logic_ptr_occupancy); + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + logic_ptr_push <= 6'h00; + logic_ptr_pop <= 6'h00; + logic_ptr_wentUp <= 1'b0; + logic_pop_addressGen_rValid <= 1'b0; + logic_pop_sync_popReg <= 6'h00; + end else begin + if(when_Stream_l1205) begin + logic_ptr_wentUp <= logic_ptr_doPush; + end + if(io_flush) begin + logic_ptr_wentUp <= 1'b0; + end + if(logic_ptr_doPush) begin + logic_ptr_push <= (logic_ptr_push + 6'h01); + end + if(logic_ptr_doPop) begin + logic_ptr_pop <= (logic_ptr_pop + 6'h01); + end + if(io_flush) begin + logic_ptr_push <= 6'h00; + logic_ptr_pop <= 6'h00; + end + if(logic_pop_addressGen_ready) begin + logic_pop_addressGen_rValid <= logic_pop_addressGen_valid; + end + if(io_flush) begin + logic_pop_addressGen_rValid <= 1'b0; + end + if(logic_pop_sync_readArbitation_fire) begin + logic_pop_sync_popReg <= logic_ptr_pop; + end + if(io_flush) begin + logic_pop_sync_popReg <= 6'h00; + end + end + end + + always @(posedge ctrl_clk) begin + if(logic_pop_addressGen_ready) begin + logic_pop_addressGen_rData <= logic_pop_addressGen_payload; + end + end + + +endmodule + +//UsbOhciAxi4_BufferCC_10 replaced by UsbOhciAxi4_BufferCC_26 + +//UsbOhciAxi4_BufferCC_9 replaced by UsbOhciAxi4_BufferCC_24 + +//UsbOhciAxi4_BufferCC_12 replaced by UsbOhciAxi4_BufferCC_26 + +//UsbOhciAxi4_BufferCC_11 replaced by UsbOhciAxi4_BufferCC_24 + +//UsbOhciAxi4_BufferCC_14 replaced by UsbOhciAxi4_BufferCC_26 + +//UsbOhciAxi4_BufferCC_13 replaced by UsbOhciAxi4_BufferCC_24 + +//UsbOhciAxi4_BufferCC_16 replaced by UsbOhciAxi4_BufferCC_26 + +//UsbOhciAxi4_BufferCC_15 replaced by UsbOhciAxi4_BufferCC_24 + +//UsbOhciAxi4_BufferCC_17 replaced by UsbOhciAxi4_BufferCC_23 + +//UsbOhciAxi4_BufferCC_18 replaced by UsbOhciAxi4_BufferCC_23 + +//UsbOhciAxi4_BufferCC_19 replaced by UsbOhciAxi4_BufferCC_23 + +//UsbOhciAxi4_BufferCC_20 replaced by UsbOhciAxi4_BufferCC_23 + +//UsbOhciAxi4_BufferCC_21 replaced by UsbOhciAxi4_BufferCC_23 + +module UsbOhciAxi4_BufferCC_23 ( + input io_dataIn, + output io_dataOut, + input ctrl_clk, + input phy_reset_syncronized +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge ctrl_clk or posedge phy_reset_syncronized) begin + if(phy_reset_syncronized) begin + buffers_0 <= 1'b0; + buffers_1 <= 1'b0; + end else begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + end + + +endmodule + +module UsbOhciAxi4_BufferCC_22 ( + input io_dataIn, + output io_dataOut, + input ctrl_clk, + input phy_reset +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge ctrl_clk or posedge phy_reset) begin + if(phy_reset) begin + buffers_0 <= 1'b1; + buffers_1 <= 1'b1; + end else begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + end + + +endmodule + +module UsbOhciAxi4_BufferCC_26 ( + input io_dataIn, + output io_dataOut, + input phy_clk, + input ctrl_reset_syncronized +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge phy_clk or posedge ctrl_reset_syncronized) begin + if(ctrl_reset_syncronized) begin + buffers_0 <= 1'b0; + buffers_1 <= 1'b0; + end else begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + end + + +endmodule + +module UsbOhciAxi4_BufferCC_25 ( + input io_dataIn, + output io_dataOut, + input phy_clk, + input ctrl_reset +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge phy_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + buffers_0 <= 1'b1; + buffers_1 <= 1'b1; + end else begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + end + + +endmodule + +module UsbOhciAxi4_BufferCC_24 ( + input io_dataIn, + output io_dataOut, + input ctrl_clk, + input ctrl_reset +); + + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; + + assign io_dataOut = buffers_1; + always @(posedge ctrl_clk or posedge ctrl_reset) begin + if(ctrl_reset) begin + buffers_0 <= 1'b0; + buffers_1 <= 1'b0; + end else begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; + end + end + + +endmodule From 861d28918acee7a0a5642bbde99480316cad4d72 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 30 Oct 2023 10:57:11 +0100 Subject: [PATCH 02/21] Define slave and master AXI ports for USB. --- hw/cheshire_pkg.sv | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/hw/cheshire_pkg.sv b/hw/cheshire_pkg.sv index 5adf1ea4..8dd12710 100644 --- a/hw/cheshire_pkg.sv +++ b/hw/cheshire_pkg.sv @@ -128,6 +128,7 @@ package cheshire_pkg; bit I2c; bit SpiHost; bit Gpio; + bit Usb; bit Dma; bit SerialLink; bit Vga; @@ -169,6 +170,8 @@ package cheshire_pkg; doub_bt SlinkTxAddrMask; doub_bt SlinkTxAddrDomain; dw_bt SlinkUserAmoBit; + // Parameters for USB + // Parameters for DMA dw_bt DmaConfMaxReadTxns; dw_bt DmaConfMaxWriteTxns; @@ -285,6 +288,7 @@ package cheshire_pkg; typedef struct packed { aw_bt [2**MaxCoresWidth-1:0] cores; aw_bt dbg; + aw_bt usb; //Add USB as master to AXI Bar aw_bt dma; aw_bt slink; aw_bt vga; @@ -297,6 +301,7 @@ package cheshire_pkg; int unsigned i = 0; for (int j = 0; j < cfg.NumCores; j++) begin ret.cores[i] = i; i++; end ret.dbg = i; + if (cfg.Usb) begin i++; ret.usb = i; end if (cfg.Dma) begin i++; ret.dma = i; end if (cfg.SerialLink) begin i++; ret.slink = i; end if (cfg.Vga) begin i++; ret.vga = i; end @@ -319,6 +324,7 @@ package cheshire_pkg; aw_bt reg_demux; aw_bt llc; aw_bt spm; + aw_bt usb; // Add USB control port as a slave aw_bt dma; aw_bt slink; aw_bt ext_base; @@ -345,6 +351,7 @@ package cheshire_pkg; r++; ret.map[r] = '{i, AmSpm, AmSpm + SizeSpm}; r++; ret.map[r] = '{i, AmSpm + 'h0400_0000, AmSpm + 'h0400_0000 + SizeSpm}; end + if (cfg.Usb) begin i++; r++; ret.usb = i; ret.map[r] = '{i, 'h0100_1000, 'h0100_1800}; end //USB requires 2KB of 32bit aligned memory, it seems like the exact position in memory is not important if (cfg.Dma) begin i++; r++; ret.dma = i; ret.map[r] = '{i, 'h0100_0000, 'h0100_1000}; end if (cfg.SerialLink) begin i++; r++; ret.slink = i; ret.map[r] = '{i, cfg.SlinkRegionStart, cfg.SlinkRegionEnd}; end @@ -543,6 +550,7 @@ package cheshire_pkg; I2c : 1, SpiHost : 1, Gpio : 1, + Usb : 1, // Added USB as new Feature Dma : 1, SerialLink : 1, Vga : 1, @@ -584,6 +592,8 @@ package cheshire_pkg; SlinkTxAddrMask : 'hFFFF_FFFF, SlinkTxAddrDomain : 'h0000_0000, SlinkUserAmoBit : 1, // Convention: lower AMO bits for cores, MSB for serial link + // USB config + // Are there parameters which we should define here, unsure // DMA config DmaConfMaxReadTxns : 4, DmaConfMaxWriteTxns : 4, From 5402e419510d56222bde58db2be5cdc1e056917d Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 30 Oct 2023 11:55:29 +0100 Subject: [PATCH 03/21] Add USB Host Controller Verilog file to Benders sources --- Bender.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/Bender.yml b/Bender.yml index 8b2b64e9..616b9bdc 100644 --- a/Bender.yml +++ b/Bender.yml @@ -40,6 +40,7 @@ sources: - hw/regs/cheshire_reg_top.sv - hw/cheshire_pkg.sv - hw/cheshire_soc.sv + - hw/future/UsbOhciAxi4.v - target: any(simulation, test) files: From a75a770ad8ae5dfdc801d7edafc87d0bcf56b266 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 30 Oct 2023 12:51:43 +0100 Subject: [PATCH 04/21] Include initial USB block into cheshire_soc.sv. --- hw/cheshire_soc.sv | 61 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index a11cd1d6..dcd091f4 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -1360,6 +1360,67 @@ module cheshire_soc import cheshire_pkg::*; #( end + /////////// + // USB // + /////////// + + if (Cfg.Usb) begin : gen_usb + axi_slv_req_t usb_ctrl_req; // Define req and rsp ports for ctrl + axi_slv_rsp_t usb_ctrl_rsp; // ports of the controller? + axi_mst_req_t usb_dma_req; // Request port for dma? + axi_mst_rsp_t usb_dma_rsp; // Response port for dma? + + // Add AXI Atomics struct, I am not sure if this is neccessary. Purpose not fully clear + axi_riscv_atomics_structs #( + .AxiAddrWidth ( Cfg.AddrWidth ), + .AxiDataWidth ( Cfg.AxiDataWidth ), + .AxiIdWidth ( AxiSlvIdWidth ), + .AxiUserWidth ( Cfg.AxiUserWidth ), + .AxiMaxReadTxns ( Cfg.DmaConfMaxReadTxns ), + .AxiMaxWriteTxns ( Cfg.DmaConfMaxWriteTxns ), + .AxiUserAsId ( 1 ), + .AxiUserIdMsb ( Cfg.AxiUserAmoMsb ), + .AxiUserIdLsb ( Cfg.AxiUserAmoLsb ), + .RiscvWordWidth ( 64 ), + .NAxiCuts ( Cfg.DmaConfAmoNumCuts ), + .axi_req_t ( axi_slv_req_t ), + .axi_rsp_t ( axi_slv_rsp_t ) + ) i_usb_conf_atomics ( + .clk_i, + .rst_ni, + .axi_slv_req_i ( axi_out_req[AxiOut.usb] ), + .axi_slv_rsp_o ( axi_out_rsp[AxiOut.usb] ), + .axi_mst_req_o ( usb_ctrl_req ), // We connect the slave ports to the master I/O? + .axi_mst_rsp_i ( usb_ctrl_rsp ) + ); + + // These look like the correct channels. But how do I connect the ones from the Verilog? + axi_cut #( + .Bypass ( ~Cfg.DmaConfAmoPostCut ), + .aw_chan_t ( axi_slv_aw_chan_t ), + .w_chan_t ( axi_slv_w_chan_t ), + .b_chan_t ( axi_slv_b_chan_t ), + .ar_chan_t ( axi_slv_ar_chan_t ), + .r_chan_t ( axi_slv_r_chan_t ), + .axi_req_t ( axi_slv_req_t ), + .axi_resp_t ( axi_slv_rsp_t ) + ) i_usb_conf_atomics_cut ( + .clk_i, + .rst_ni, + .slv_req_i ( dma_amo_req ), + .slv_resp_o ( dma_amo_rsp ), + .mst_req_o ( dma_cut_req ), + .mst_resp_i ( dma_cut_rsp ) + ); + + always_comb begin + axi_in_req[AxiIn.usb] = usb_dma_req; + axi_in_req[AxiIn.usb].aw.user = Cfg.AxiUserDefault; + axi_in_req[AxiIn.usb].w.user = Cfg.AxiUserDefault; + axi_in_req[AxiIn.usb].ar.user = Cfg.AxiUserDefault; + end + end + /////////// // DMA // /////////// From 3688dd0a70bf0f6d62670964fc12d91b90a1c6f0 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Fri, 3 Nov 2023 11:43:58 +0100 Subject: [PATCH 05/21] Extend mapped address space for USB Host to 4K (as stated in the docs) --- hw/cheshire_pkg.sv | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/hw/cheshire_pkg.sv b/hw/cheshire_pkg.sv index 8dd12710..2a719908 100644 --- a/hw/cheshire_pkg.sv +++ b/hw/cheshire_pkg.sv @@ -171,7 +171,15 @@ package cheshire_pkg; doub_bt SlinkTxAddrDomain; dw_bt SlinkUserAmoBit; // Parameters for USB - + dw_bt UsbConfMaxReadTxns; + dw_bt UsbConfMaxWriteTxns; + aw_bt UsbConfAmoNumCuts; + bit UsbConfAmoPostCut; + bit UsbConfEnableTwoD; + dw_bt UsbNumAxInFlight; + dw_bt UsbMemSysDepth; + aw_bt UsbJobFifoDepth; + bit UsbRAWCouplingAvail; // Parameters for DMA dw_bt DmaConfMaxReadTxns; dw_bt DmaConfMaxWriteTxns; @@ -351,7 +359,8 @@ package cheshire_pkg; r++; ret.map[r] = '{i, AmSpm, AmSpm + SizeSpm}; r++; ret.map[r] = '{i, AmSpm + 'h0400_0000, AmSpm + 'h0400_0000 + SizeSpm}; end - if (cfg.Usb) begin i++; r++; ret.usb = i; ret.map[r] = '{i, 'h0100_1000, 'h0100_1800}; end //USB requires 2KB of 32bit aligned memory, it seems like the exact position in memory is not important + //USB requires 2KB of 32bit aligned memory, it seems like the exact position in memory is not important + if (cfg.Usb) begin i++; r++; ret.usb = i; ret.map[r] = '{i, 'h0100_1000, 'h0100_2000}; end // Give it a 4K window (as Paul suggested) if (cfg.Dma) begin i++; r++; ret.dma = i; ret.map[r] = '{i, 'h0100_0000, 'h0100_1000}; end if (cfg.SerialLink) begin i++; r++; ret.slink = i; ret.map[r] = '{i, cfg.SlinkRegionStart, cfg.SlinkRegionEnd}; end @@ -592,8 +601,16 @@ package cheshire_pkg; SlinkTxAddrMask : 'hFFFF_FFFF, SlinkTxAddrDomain : 'h0000_0000, SlinkUserAmoBit : 1, // Convention: lower AMO bits for cores, MSB for serial link - // USB config - // Are there parameters which we should define here, unsure + // USB config ( for now it's just a copy of the DMA config) + UsbConfMaxReadTxns : 4, + UsbConfMaxWriteTxns : 4, + UsbConfAmoNumCuts : 1, + UsbConfAmoPostCut : 1, + UsbConfEnableTwoD : 1, + UsbNumAxInFlight : 16, + UsbMemSysDepth : 8, + UsbJobFifoDepth : 2, + UsbRAWCouplingAvail : 1, // DMA config DmaConfMaxReadTxns : 4, DmaConfMaxWriteTxns : 4, From 17bb7ab3569fd6ea41b5127aeffbdb8549ad78df Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Fri, 3 Nov 2023 11:44:53 +0100 Subject: [PATCH 06/21] Instanciate and connect OHCI Controller --- hw/cheshire_soc.sv | 105 ++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 95 insertions(+), 10 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index dcd091f4..3504d33c 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -97,6 +97,11 @@ module cheshire_soc import cheshire_pkg::*; #( output logic [Cfg.VgaRedWidth -1:0] vga_red_o, output logic [Cfg.VgaGreenWidth-1:0] vga_green_o, output logic [Cfg.VgaBlueWidth -1:0] vga_blue_o + // USB interface + input logic usb_dm_read, + output logic usb_dm_write, + input logic usb_dp_read, + output logic usb_dp_write, ); `include "axi/typedef.svh" @@ -1370,19 +1375,18 @@ module cheshire_soc import cheshire_pkg::*; #( axi_mst_req_t usb_dma_req; // Request port for dma? axi_mst_rsp_t usb_dma_rsp; // Response port for dma? - // Add AXI Atomics struct, I am not sure if this is neccessary. Purpose not fully clear axi_riscv_atomics_structs #( .AxiAddrWidth ( Cfg.AddrWidth ), .AxiDataWidth ( Cfg.AxiDataWidth ), .AxiIdWidth ( AxiSlvIdWidth ), .AxiUserWidth ( Cfg.AxiUserWidth ), - .AxiMaxReadTxns ( Cfg.DmaConfMaxReadTxns ), - .AxiMaxWriteTxns ( Cfg.DmaConfMaxWriteTxns ), + .AxiMaxReadTxns ( Cfg.UsbConfMaxReadTxns ), + .AxiMaxWriteTxns ( Cfg.UsbConfMaxWriteTxns ), .AxiUserAsId ( 1 ), .AxiUserIdMsb ( Cfg.AxiUserAmoMsb ), .AxiUserIdLsb ( Cfg.AxiUserAmoLsb ), .RiscvWordWidth ( 64 ), - .NAxiCuts ( Cfg.DmaConfAmoNumCuts ), + .NAxiCuts ( Cfg.UsbConfAmoNumCuts ), .axi_req_t ( axi_slv_req_t ), .axi_rsp_t ( axi_slv_rsp_t ) ) i_usb_conf_atomics ( @@ -1394,9 +1398,8 @@ module cheshire_soc import cheshire_pkg::*; #( .axi_mst_rsp_i ( usb_ctrl_rsp ) ); - // These look like the correct channels. But how do I connect the ones from the Verilog? axi_cut #( - .Bypass ( ~Cfg.DmaConfAmoPostCut ), + .Bypass ( ~Cfg.UsbConfAmoPostCut ), .aw_chan_t ( axi_slv_aw_chan_t ), .w_chan_t ( axi_slv_w_chan_t ), .b_chan_t ( axi_slv_b_chan_t ), @@ -1407,10 +1410,10 @@ module cheshire_soc import cheshire_pkg::*; #( ) i_usb_conf_atomics_cut ( .clk_i, .rst_ni, - .slv_req_i ( dma_amo_req ), - .slv_resp_o ( dma_amo_rsp ), - .mst_req_o ( dma_cut_req ), - .mst_resp_i ( dma_cut_rsp ) + .slv_req_i ( usb_amo_req ), + .slv_resp_o ( usb_amo_rsp ), + .mst_req_o ( usb_cut_req ), + .mst_resp_i ( usb_cut_rsp ) ); always_comb begin @@ -1419,6 +1422,88 @@ module cheshire_soc import cheshire_pkg::*; #( axi_in_req[AxiIn.usb].w.user = Cfg.AxiUserDefault; axi_in_req[AxiIn.usb].ar.user = Cfg.AxiUserDefault; end + +UsbOhciAxi4 i_UsbOhciAxi4 ( + .io_dma_aw_valid ( axi_in_req[AxiIn.usb].aw_valid ), + .io_dma_aw_ready ( axi_in_rsp[AxiIn.usb].aw_ready ), + .io_dma_aw_payload_addr ( axi_in_req[AxiIn.usb].aw.addr ), + .io_dma_aw_payload_len ( axi_in_req[AxiIn.usb].aw.len ), + .io_dma_aw_payload_size ( axi_in_req[AxiIn.usb].aw.size ), + .io_dma_aw_payload_cache ( axi_in_req[AxiIn.usb].aw.cache ), + .io_dma_aw_payload_prot ( axi_in_req[AxiIn.usb].aw.prot ), + .io_dma_w_valid ( axi_in_req[AxiIn.usb].w_valid ), + .io_dma_w_ready ( axi_in_rsp[AxiIn.usb].w_ready ), + .io_dma_w_payload_data ( axi_in_req[AxiIn.usb].w.data ), + .io_dma_w_payload_strb ( axi_in_req[AxiIn.usb].w.strb ), + .io_dma_w_payload_last ( axi_in_req[AxiIn.usb].w.last ), + .io_dma_b_valid ( axi_in_rsp[AxiIn.usb].b_valid ), + .io_dma_b_ready ( axi_in_req[AxiIn.usb].b_ready ), + .io_dma_b_payload_resp ( axi_in_rsp[AxiIn.usb].b.resp ), + .io_dma_ar_valid ( axi_in_req[AxiIn.usb].ar_valid ), + .io_dma_ar_ready ( axi_in_rsp[AxiIn.usb].ar_ready ), + .io_dma_ar_payload_addr ( axi_in_req[AxiIn.usb].ar.addr ), + .io_dma_ar_payload_len ( axi_in_req[AxiIn.usb].ar.len ), + .io_dma_ar_payload_size ( axi_in_req[AxiIn.usb].ar.size ), + .io_dma_ar_payload_cache ( axi_in_req[AxiIn.usb].ar.cache ), + .io_dma_ar_payload_prot ( axi_in_req[AxiIn.usb].ar.prot ), + .io_dma_r_valid ( axi_in_rsp[AxiIn.usb].r_valid ), + .io_dma_r_ready ( axi_in_req[AxiIn.usb].r_ready ), + .io_dma_r_payload_data ( axi_in_rsp[AxiIn.usb].r.data ), + .io_dma_r_payload_resp ( axi_in_rsp[AxiIn.usb].r.resp ), + .io_dma_r_payload_last ( axi_in_rsp[AxiIn.usb].r.last ), + .io_ctrl_aw_valid ( axi_out_req[AxiOut.usb].aw_valid ), + .io_ctrl_aw_ready ( axi_out_rsp[AxiOut.usb].aw_ready ), + .io_ctrl_aw_payload_addr ( axi_out_req[AxiOut.usb].aw.addr ), + .io_ctrl_aw_payload_id ( axi_out_req[AxiOut.usb].aw.id ), + .io_ctrl_aw_payload_region( axi_out_req[AxiOut.usb].aw.region ), + .io_ctrl_aw_payload_len ( axi_out_req[AxiOut.usb].aw.len ), + .io_ctrl_aw_payload_size ( axi_out_req[AxiOut.usb].aw.size ), + .io_ctrl_aw_payload_burst ( axi_out_req[AxiOut.usb].aw.burst ), + .io_ctrl_aw_payload_lock ( axi_out_req[AxiOut.usb].aw.lock ), + .io_ctrl_aw_payload_cache ( axi_out_req[AxiOut.usb].aw.cache ), + .io_ctrl_aw_payload_qos ( axi_out_req[AxiOut.usb].aw.qos ), + .io_ctrl_aw_payload_prot ( axi_out_req[AxiOut.usb].aw.prot ), + .io_ctrl_w_valid ( axi_out_req[AxiOut.usb].w_valid ), + .io_ctrl_w_ready ( axi_out_rsp[AxiOut.usb].w_ready ), + .io_ctrl_w_payload_data ( axi_out_req[AxiOut.usb].w.data ), + .io_ctrl_w_payload_strb ( axi_out_req[AxiOut.usb].w.strb ), + .io_ctrl_w_payload_last ( axi_out_req[AxiOut.usb].w.last ), + .io_ctrl_b_valid ( axi_out_rsp[AxiOut.usb].b_valid ), + .io_ctrl_b_ready ( axi_out_req[AxiOut.usb].b_ready ), + .io_ctrl_b_payload_id ( axi_out_rsp[AxiOut.usb].b.id ), + .io_ctrl_b_payload_resp ( axi_out_rsp[AxiOut.usb].b.resp ), + .io_ctrl_ar_valid ( axi_out_req[AxiOut.usb].ar_valid ), + .io_ctrl_ar_ready ( axi_out_rsp[AxiOut.usb].ar_ready ), + .io_ctrl_ar_payload_addr ( axi_out_req[AxiOut.usb].ar.addr ), + .io_ctrl_ar_payload_id ( axi_out_req[AxiOut.usb].ar.id ), + .io_ctrl_ar_payload_region( axi_out_req[AxiOut.usb].ar.region ), + .io_ctrl_ar_payload_len ( axi_out_req[AxiOut.usb].ar.len ), + .io_ctrl_ar_payload_size ( axi_out_req[AxiOut.usb].ar.size ), + .io_ctrl_ar_payload_burst ( axi_out_req[AxiOut.usb].ar.burst ), + .io_ctrl_ar_payload_lock ( axi_out_req[AxiOut.usb].ar.lock ), + .io_ctrl_ar_payload_cache ( axi_out_req[AxiOut.usb].ar.cache ), + .io_ctrl_ar_payload_qos ( axi_out_req[AxiOut.usb].ar.qos ), + .io_ctrl_ar_payload_prot ( axi_out_req[AxiOut.usb].ar.prot ), + .io_ctrl_r_valid ( axi_out_rsp[AxiOut.usb].r_valid ), + .io_ctrl_r_ready ( axi_out_req[AxiOut.usb].r_ready ), + .io_ctrl_r_payload_data ( axi_out_rsp[AxiOut.usb].r.data ), + .io_ctrl_r_payload_id ( axi_out_rsp[AxiOut.usb].r.id ), + .io_ctrl_r_payload_resp ( axi_out_rsp[AxiOut.usb].r.resp ), + .io_ctrl_r_payload_last ( axi_out_rsp[AxiOut.usb].r.last ), + .io_interrupt (io_interrupt ), + .io_usb_0_dp_read ( usb_dp_read ), // For these we probably have to define new outputs for cheshire + .io_usb_0_dp_write ( usb_dp_write ), // Defined them in cheshire_soc.sv line 100ff + .io_usb_0_dp_writeEnable ( io_usb_0_dp_writeEnable ), // Where do we connect write enable? To a bidirectional I/O? + .io_usb_0_dm_read ( usb_dm_read ), + .io_usb_0_dm_write ( usb_dm_write ), + .io_usb_0_dm_writeEnable ( io_usb_0_dm_writeEnable ), + .phy_clk ( clk_i ), // I don't think these are the correct clock lines + .phy_reset ( rst_ni ), + .ctrl_clk ( clk_i ), + .ctrl_reset ( rst_ni ) +); + + end /////////// From 6c1b597320630164aa55e2be8250043413ac899d Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Fri, 3 Nov 2023 12:35:30 +0100 Subject: [PATCH 07/21] Fix compilation error, improve formatting --- hw/cheshire_soc.sv | 162 ++++++++++++++++++++++----------------------- 1 file changed, 81 insertions(+), 81 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index 3504d33c..9c4569a6 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -96,12 +96,12 @@ module cheshire_soc import cheshire_pkg::*; #( output logic vga_vsync_o, output logic [Cfg.VgaRedWidth -1:0] vga_red_o, output logic [Cfg.VgaGreenWidth-1:0] vga_green_o, - output logic [Cfg.VgaBlueWidth -1:0] vga_blue_o + output logic [Cfg.VgaBlueWidth -1:0] vga_blue_o, // USB interface input logic usb_dm_read, output logic usb_dm_write, input logic usb_dp_read, - output logic usb_dp_write, + output logic usb_dp_write ); `include "axi/typedef.svh" @@ -1423,85 +1423,85 @@ module cheshire_soc import cheshire_pkg::*; #( axi_in_req[AxiIn.usb].ar.user = Cfg.AxiUserDefault; end -UsbOhciAxi4 i_UsbOhciAxi4 ( - .io_dma_aw_valid ( axi_in_req[AxiIn.usb].aw_valid ), - .io_dma_aw_ready ( axi_in_rsp[AxiIn.usb].aw_ready ), - .io_dma_aw_payload_addr ( axi_in_req[AxiIn.usb].aw.addr ), - .io_dma_aw_payload_len ( axi_in_req[AxiIn.usb].aw.len ), - .io_dma_aw_payload_size ( axi_in_req[AxiIn.usb].aw.size ), - .io_dma_aw_payload_cache ( axi_in_req[AxiIn.usb].aw.cache ), - .io_dma_aw_payload_prot ( axi_in_req[AxiIn.usb].aw.prot ), - .io_dma_w_valid ( axi_in_req[AxiIn.usb].w_valid ), - .io_dma_w_ready ( axi_in_rsp[AxiIn.usb].w_ready ), - .io_dma_w_payload_data ( axi_in_req[AxiIn.usb].w.data ), - .io_dma_w_payload_strb ( axi_in_req[AxiIn.usb].w.strb ), - .io_dma_w_payload_last ( axi_in_req[AxiIn.usb].w.last ), - .io_dma_b_valid ( axi_in_rsp[AxiIn.usb].b_valid ), - .io_dma_b_ready ( axi_in_req[AxiIn.usb].b_ready ), - .io_dma_b_payload_resp ( axi_in_rsp[AxiIn.usb].b.resp ), - .io_dma_ar_valid ( axi_in_req[AxiIn.usb].ar_valid ), - .io_dma_ar_ready ( axi_in_rsp[AxiIn.usb].ar_ready ), - .io_dma_ar_payload_addr ( axi_in_req[AxiIn.usb].ar.addr ), - .io_dma_ar_payload_len ( axi_in_req[AxiIn.usb].ar.len ), - .io_dma_ar_payload_size ( axi_in_req[AxiIn.usb].ar.size ), - .io_dma_ar_payload_cache ( axi_in_req[AxiIn.usb].ar.cache ), - .io_dma_ar_payload_prot ( axi_in_req[AxiIn.usb].ar.prot ), - .io_dma_r_valid ( axi_in_rsp[AxiIn.usb].r_valid ), - .io_dma_r_ready ( axi_in_req[AxiIn.usb].r_ready ), - .io_dma_r_payload_data ( axi_in_rsp[AxiIn.usb].r.data ), - .io_dma_r_payload_resp ( axi_in_rsp[AxiIn.usb].r.resp ), - .io_dma_r_payload_last ( axi_in_rsp[AxiIn.usb].r.last ), - .io_ctrl_aw_valid ( axi_out_req[AxiOut.usb].aw_valid ), - .io_ctrl_aw_ready ( axi_out_rsp[AxiOut.usb].aw_ready ), - .io_ctrl_aw_payload_addr ( axi_out_req[AxiOut.usb].aw.addr ), - .io_ctrl_aw_payload_id ( axi_out_req[AxiOut.usb].aw.id ), - .io_ctrl_aw_payload_region( axi_out_req[AxiOut.usb].aw.region ), - .io_ctrl_aw_payload_len ( axi_out_req[AxiOut.usb].aw.len ), - .io_ctrl_aw_payload_size ( axi_out_req[AxiOut.usb].aw.size ), - .io_ctrl_aw_payload_burst ( axi_out_req[AxiOut.usb].aw.burst ), - .io_ctrl_aw_payload_lock ( axi_out_req[AxiOut.usb].aw.lock ), - .io_ctrl_aw_payload_cache ( axi_out_req[AxiOut.usb].aw.cache ), - .io_ctrl_aw_payload_qos ( axi_out_req[AxiOut.usb].aw.qos ), - .io_ctrl_aw_payload_prot ( axi_out_req[AxiOut.usb].aw.prot ), - .io_ctrl_w_valid ( axi_out_req[AxiOut.usb].w_valid ), - .io_ctrl_w_ready ( axi_out_rsp[AxiOut.usb].w_ready ), - .io_ctrl_w_payload_data ( axi_out_req[AxiOut.usb].w.data ), - .io_ctrl_w_payload_strb ( axi_out_req[AxiOut.usb].w.strb ), - .io_ctrl_w_payload_last ( axi_out_req[AxiOut.usb].w.last ), - .io_ctrl_b_valid ( axi_out_rsp[AxiOut.usb].b_valid ), - .io_ctrl_b_ready ( axi_out_req[AxiOut.usb].b_ready ), - .io_ctrl_b_payload_id ( axi_out_rsp[AxiOut.usb].b.id ), - .io_ctrl_b_payload_resp ( axi_out_rsp[AxiOut.usb].b.resp ), - .io_ctrl_ar_valid ( axi_out_req[AxiOut.usb].ar_valid ), - .io_ctrl_ar_ready ( axi_out_rsp[AxiOut.usb].ar_ready ), - .io_ctrl_ar_payload_addr ( axi_out_req[AxiOut.usb].ar.addr ), - .io_ctrl_ar_payload_id ( axi_out_req[AxiOut.usb].ar.id ), - .io_ctrl_ar_payload_region( axi_out_req[AxiOut.usb].ar.region ), - .io_ctrl_ar_payload_len ( axi_out_req[AxiOut.usb].ar.len ), - .io_ctrl_ar_payload_size ( axi_out_req[AxiOut.usb].ar.size ), - .io_ctrl_ar_payload_burst ( axi_out_req[AxiOut.usb].ar.burst ), - .io_ctrl_ar_payload_lock ( axi_out_req[AxiOut.usb].ar.lock ), - .io_ctrl_ar_payload_cache ( axi_out_req[AxiOut.usb].ar.cache ), - .io_ctrl_ar_payload_qos ( axi_out_req[AxiOut.usb].ar.qos ), - .io_ctrl_ar_payload_prot ( axi_out_req[AxiOut.usb].ar.prot ), - .io_ctrl_r_valid ( axi_out_rsp[AxiOut.usb].r_valid ), - .io_ctrl_r_ready ( axi_out_req[AxiOut.usb].r_ready ), - .io_ctrl_r_payload_data ( axi_out_rsp[AxiOut.usb].r.data ), - .io_ctrl_r_payload_id ( axi_out_rsp[AxiOut.usb].r.id ), - .io_ctrl_r_payload_resp ( axi_out_rsp[AxiOut.usb].r.resp ), - .io_ctrl_r_payload_last ( axi_out_rsp[AxiOut.usb].r.last ), - .io_interrupt (io_interrupt ), - .io_usb_0_dp_read ( usb_dp_read ), // For these we probably have to define new outputs for cheshire - .io_usb_0_dp_write ( usb_dp_write ), // Defined them in cheshire_soc.sv line 100ff - .io_usb_0_dp_writeEnable ( io_usb_0_dp_writeEnable ), // Where do we connect write enable? To a bidirectional I/O? - .io_usb_0_dm_read ( usb_dm_read ), - .io_usb_0_dm_write ( usb_dm_write ), - .io_usb_0_dm_writeEnable ( io_usb_0_dm_writeEnable ), - .phy_clk ( clk_i ), // I don't think these are the correct clock lines - .phy_reset ( rst_ni ), - .ctrl_clk ( clk_i ), - .ctrl_reset ( rst_ni ) -); + UsbOhciAxi4 i_UsbOhciAxi4 ( + .io_dma_aw_valid ( axi_in_req[AxiIn.usb].aw_valid ), + .io_dma_aw_ready ( axi_in_rsp[AxiIn.usb].aw_ready ), + .io_dma_aw_payload_addr ( axi_in_req[AxiIn.usb].aw.addr ), + .io_dma_aw_payload_len ( axi_in_req[AxiIn.usb].aw.len ), + .io_dma_aw_payload_size ( axi_in_req[AxiIn.usb].aw.size ), + .io_dma_aw_payload_cache ( axi_in_req[AxiIn.usb].aw.cache ), + .io_dma_aw_payload_prot ( axi_in_req[AxiIn.usb].aw.prot ), + .io_dma_w_valid ( axi_in_req[AxiIn.usb].w_valid ), + .io_dma_w_ready ( axi_in_rsp[AxiIn.usb].w_ready ), + .io_dma_w_payload_data ( axi_in_req[AxiIn.usb].w.data ), + .io_dma_w_payload_strb ( axi_in_req[AxiIn.usb].w.strb ), + .io_dma_w_payload_last ( axi_in_req[AxiIn.usb].w.last ), + .io_dma_b_valid ( axi_in_rsp[AxiIn.usb].b_valid ), + .io_dma_b_ready ( axi_in_req[AxiIn.usb].b_ready ), + .io_dma_b_payload_resp ( axi_in_rsp[AxiIn.usb].b.resp ), + .io_dma_ar_valid ( axi_in_req[AxiIn.usb].ar_valid ), + .io_dma_ar_ready ( axi_in_rsp[AxiIn.usb].ar_ready ), + .io_dma_ar_payload_addr ( axi_in_req[AxiIn.usb].ar.addr ), + .io_dma_ar_payload_len ( axi_in_req[AxiIn.usb].ar.len ), + .io_dma_ar_payload_size ( axi_in_req[AxiIn.usb].ar.size ), + .io_dma_ar_payload_cache ( axi_in_req[AxiIn.usb].ar.cache ), + .io_dma_ar_payload_prot ( axi_in_req[AxiIn.usb].ar.prot ), + .io_dma_r_valid ( axi_in_rsp[AxiIn.usb].r_valid ), + .io_dma_r_ready ( axi_in_req[AxiIn.usb].r_ready ), + .io_dma_r_payload_data ( axi_in_rsp[AxiIn.usb].r.data ), + .io_dma_r_payload_resp ( axi_in_rsp[AxiIn.usb].r.resp ), + .io_dma_r_payload_last ( axi_in_rsp[AxiIn.usb].r.last ), + .io_ctrl_aw_valid ( axi_out_req[AxiOut.usb].aw_valid ), + .io_ctrl_aw_ready ( axi_out_rsp[AxiOut.usb].aw_ready ), + .io_ctrl_aw_payload_addr ( axi_out_req[AxiOut.usb].aw.addr ), + .io_ctrl_aw_payload_id ( axi_out_req[AxiOut.usb].aw.id ), + .io_ctrl_aw_payload_region( axi_out_req[AxiOut.usb].aw.region ), + .io_ctrl_aw_payload_len ( axi_out_req[AxiOut.usb].aw.len ), + .io_ctrl_aw_payload_size ( axi_out_req[AxiOut.usb].aw.size ), + .io_ctrl_aw_payload_burst ( axi_out_req[AxiOut.usb].aw.burst ), + .io_ctrl_aw_payload_lock ( axi_out_req[AxiOut.usb].aw.lock ), + .io_ctrl_aw_payload_cache ( axi_out_req[AxiOut.usb].aw.cache ), + .io_ctrl_aw_payload_qos ( axi_out_req[AxiOut.usb].aw.qos ), + .io_ctrl_aw_payload_prot ( axi_out_req[AxiOut.usb].aw.prot ), + .io_ctrl_w_valid ( axi_out_req[AxiOut.usb].w_valid ), + .io_ctrl_w_ready ( axi_out_rsp[AxiOut.usb].w_ready ), + .io_ctrl_w_payload_data ( axi_out_req[AxiOut.usb].w.data ), + .io_ctrl_w_payload_strb ( axi_out_req[AxiOut.usb].w.strb ), + .io_ctrl_w_payload_last ( axi_out_req[AxiOut.usb].w.last ), + .io_ctrl_b_valid ( axi_out_rsp[AxiOut.usb].b_valid ), + .io_ctrl_b_ready ( axi_out_req[AxiOut.usb].b_ready ), + .io_ctrl_b_payload_id ( axi_out_rsp[AxiOut.usb].b.id ), + .io_ctrl_b_payload_resp ( axi_out_rsp[AxiOut.usb].b.resp ), + .io_ctrl_ar_valid ( axi_out_req[AxiOut.usb].ar_valid ), + .io_ctrl_ar_ready ( axi_out_rsp[AxiOut.usb].ar_ready ), + .io_ctrl_ar_payload_addr ( axi_out_req[AxiOut.usb].ar.addr ), + .io_ctrl_ar_payload_id ( axi_out_req[AxiOut.usb].ar.id ), + .io_ctrl_ar_payload_region( axi_out_req[AxiOut.usb].ar.region ), + .io_ctrl_ar_payload_len ( axi_out_req[AxiOut.usb].ar.len ), + .io_ctrl_ar_payload_size ( axi_out_req[AxiOut.usb].ar.size ), + .io_ctrl_ar_payload_burst ( axi_out_req[AxiOut.usb].ar.burst ), + .io_ctrl_ar_payload_lock ( axi_out_req[AxiOut.usb].ar.lock ), + .io_ctrl_ar_payload_cache ( axi_out_req[AxiOut.usb].ar.cache ), + .io_ctrl_ar_payload_qos ( axi_out_req[AxiOut.usb].ar.qos ), + .io_ctrl_ar_payload_prot ( axi_out_req[AxiOut.usb].ar.prot ), + .io_ctrl_r_valid ( axi_out_rsp[AxiOut.usb].r_valid ), + .io_ctrl_r_ready ( axi_out_req[AxiOut.usb].r_ready ), + .io_ctrl_r_payload_data ( axi_out_rsp[AxiOut.usb].r.data ), + .io_ctrl_r_payload_id ( axi_out_rsp[AxiOut.usb].r.id ), + .io_ctrl_r_payload_resp ( axi_out_rsp[AxiOut.usb].r.resp ), + .io_ctrl_r_payload_last ( axi_out_rsp[AxiOut.usb].r.last ), + .io_interrupt (io_interrupt ), // Where do we connect this one? + .io_usb_0_dp_read ( usb_dp_read ), // For these we probably have to define new outputs for cheshire + .io_usb_0_dp_write ( usb_dp_write ), // Defined them in cheshire_soc.sv line 100ff + .io_usb_0_dp_writeEnable ( io_usb_0_dp_writeEnable ), // Where do we connect write enable? To a bidirectional I/O? + .io_usb_0_dm_read ( usb_dm_read ), + .io_usb_0_dm_write ( usb_dm_write ), + .io_usb_0_dm_writeEnable ( io_usb_0_dm_writeEnable ), + .phy_clk ( clk_i ), // I don't think these are the correct clock lines + .phy_reset ( rst_ni ), + .ctrl_clk ( clk_i ), + .ctrl_reset ( rst_ni ) + ); end From 840cd711031174c756b859a0537405d6dad84c60 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 8 Nov 2023 14:19:16 +0100 Subject: [PATCH 08/21] Added AXI width conversion chains between OCHI and Crossbar --- hw/cheshire_pkg.sv | 1 + hw/cheshire_soc.sv | 341 ++++++++++++++++++++++++++++++++------------- 2 files changed, 243 insertions(+), 99 deletions(-) diff --git a/hw/cheshire_pkg.sv b/hw/cheshire_pkg.sv index 2a719908..d4ab8b11 100644 --- a/hw/cheshire_pkg.sv +++ b/hw/cheshire_pkg.sv @@ -219,6 +219,7 @@ package cheshire_pkg; // Defined interrupts typedef struct packed { cheshire_bus_err_intr_t bus_err; + logic usb; logic [31:0] gpio; logic spih_spi_event; logic spih_error; diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index 9c4569a6..0861e10c 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -98,10 +98,12 @@ module cheshire_soc import cheshire_pkg::*; #( output logic [Cfg.VgaGreenWidth-1:0] vga_green_o, output logic [Cfg.VgaBlueWidth -1:0] vga_blue_o, // USB interface - input logic usb_dm_read, - output logic usb_dm_write, - input logic usb_dp_read, - output logic usb_dp_write + output logic usb_dm_o, + input logic usb_dm_i, + output logic usb_dm_en_o, + output logic usb_dp_o, + input logic usb_dp_i, + output logic usb_dp_en_o ); `include "axi/typedef.svh" @@ -290,9 +292,6 @@ module cheshire_soc import cheshire_pkg::*; #( // Reg Demux // ///////////////// - // Define types needed - `CHESHIRE_TYPEDEF_AXI_CT(axi_d32, addr_t, axi_slv_id_t, logic [31:0], logic [3:0], axi_user_t) - // Generate indices and get maps for all ports localparam reg_out_t RegOut = gen_reg_out(Cfg); @@ -312,7 +311,6 @@ module cheshire_soc import cheshire_pkg::*; #( axi_slv_req_t axi_reg_amo_req, axi_reg_cut_req; axi_slv_rsp_t axi_reg_amo_rsp, axi_reg_cut_rsp; - reg_req_t reg_in_req; reg_rsp_t reg_in_rsp; @@ -1369,11 +1367,18 @@ module cheshire_soc import cheshire_pkg::*; #( // USB // /////////// + // Define types needed + // For the crtl converter chain + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_ctrl_ser, addr_t, logic [7:0], axi_data_t, axi_strb_t, axi_user_t) + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_ctrl_dw, addr_t, logic [7:0], logic [31:0], logic [3:0], axi_user_t) + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_ctrl, logic [11:0], logic [7:0], logic [31:0], logic [3:0], axi_user_t) + // For the dma converter chain + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma, logic [31:0], logic [AxiSlvIdWidth-1:0], logic [31:0], logic [3:0], axi_user_t) + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma_dw, logic [31:0], logic [AxiSlvIdWidth-1:0], axi_data_t, axi_strb_t, axi_user_t) + if (Cfg.Usb) begin : gen_usb - axi_slv_req_t usb_ctrl_req; // Define req and rsp ports for ctrl - axi_slv_rsp_t usb_ctrl_rsp; // ports of the controller? - axi_mst_req_t usb_dma_req; // Request port for dma? - axi_mst_rsp_t usb_dma_rsp; // Response port for dma? + axi_slv_req_t usb_amo_req, usb_cut_req; // AXI interconnect for atomics and cuts + axi_slv_rsp_t usb_amo_rsp, usb_cut_rsp; axi_riscv_atomics_structs #( .AxiAddrWidth ( Cfg.AddrWidth ), @@ -1389,13 +1394,13 @@ module cheshire_soc import cheshire_pkg::*; #( .NAxiCuts ( Cfg.UsbConfAmoNumCuts ), .axi_req_t ( axi_slv_req_t ), .axi_rsp_t ( axi_slv_rsp_t ) - ) i_usb_conf_atomics ( + ) i_usb_ctrl_atomics ( .clk_i, .rst_ni, .axi_slv_req_i ( axi_out_req[AxiOut.usb] ), .axi_slv_rsp_o ( axi_out_rsp[AxiOut.usb] ), - .axi_mst_req_o ( usb_ctrl_req ), // We connect the slave ports to the master I/O? - .axi_mst_rsp_i ( usb_ctrl_rsp ) + .axi_mst_req_o ( usb_amo_req ), + .axi_mst_rsp_i ( usb_amo_rsp ) ); axi_cut #( @@ -1407,7 +1412,7 @@ module cheshire_soc import cheshire_pkg::*; #( .r_chan_t ( axi_slv_r_chan_t ), .axi_req_t ( axi_slv_req_t ), .axi_resp_t ( axi_slv_rsp_t ) - ) i_usb_conf_atomics_cut ( + ) i_usb_ctrl_atomics_cut ( .clk_i, .rst_ni, .slv_req_i ( usb_amo_req ), @@ -1416,94 +1421,232 @@ module cheshire_soc import cheshire_pkg::*; #( .mst_resp_i ( usb_cut_rsp ) ); + axi_usb_ctrl_ser_req_t usb_ctrl_ser_req; + axi_usb_ctrl_ser_rsp_t usb_ctrl_ser_rsp; + + axi_id_serialize #( + .AxiSlvPortMaxTxns ( 1 /* TODO */ ), + .AxiMstPortMaxUniqIds ( 1 /* TODO */ ), + .AxiMstPortMaxTxnsPerId ( 1 /* TODO */ ), + .AxiSlvPortIdWidth ( AxiSlvIdWidth ), + .AxiMstPortIdWidth ( 8 ), + .AxiAddrWidth ( Cfg.AddrWidth ), + .AxiDataWidth ( Cfg.AxiDataWidth ), + .AxiUserWidth ( Cfg.AxiUserWidth ), + .AtopSupport ( 0 /* filtered above */ ), + .slv_req_t ( axi_slv_req_t ), + .slv_resp_t ( axi_slv_rsp_t ), + .mst_req_t ( axi_usb_ctrl_ser_req_t ), + .mst_resp_t ( axi_usb_ctrl_ser_rsp_t ) + ) i_usb_ctrl_id_serialize ( + .clk_i, + .rst_ni, + .slv_req_i ( usb_cut_req ), + .slv_resp_o ( usb_cut_rsp ), + .mst_req_o ( usb_ctrl_ser_req ), + .mst_resp_i ( usb_ctrl_ser_rsp ) + ); + + axi_usb_ctrl_dw_req_t usb_ctrl_dw_req; + axi_usb_ctrl_dw_rsp_t usb_ctrl_dw_rsp; + + axi_dw_converter #( + .AxiMaxReads ( 1 /* TODO */ ), + .AxiSlvPortDataWidth ( Cfg.AxiDataWidth ), + .AxiMstPortDataWidth ( 32 ), + .AxiAddrWidth ( Cfg.AddrWidth ), + .AxiIdWidth ( AxiSlvIdWidth ), + .aw_chan_t ( axi_usb_ctrl_ser_aw_chan_t ), + .ar_chan_t ( axi_usb_ctrl_ser_ar_chan_t ), + .mst_w_chan_t ( axi_usb_ctrl_dw_w_chan_t ), + .slv_w_chan_t ( axi_usb_ctrl_ser_w_chan_t ), + .b_chan_t ( axi_usb_ctrl_ser_b_chan_t ), + .mst_r_chan_t ( axi_usb_ctrl_dw_r_chan_t ), + .slv_r_chan_t ( axi_usb_ctrl_ser_r_chan_t ), + .axi_slv_req_t ( axi_usb_ctrl_ser_req_t ), + .axi_slv_resp_t ( axi_usb_ctrl_ser_rsp_t ), + .axi_mst_req_t ( axi_usb_ctrl_dw_req_t ), + .axi_mst_resp_t ( axi_usb_ctrl_dw_rsp_t ) + ) i_usb_ctrl_dw_converter ( + .clk_i, + .rst_ni, + .slv_req_i ( usb_ctrl_ser_req ), + .slv_resp_o ( usb_ctrl_ser_rsp ), + .mst_req_o ( usb_ctrl_dw_req ), + .mst_resp_i ( usb_ctrl_dw_rsp ) + ); + + axi_usb_ctrl_req_t usb_ctrl_req; + axi_usb_ctrl_rsp_t usb_ctrl_rsp; + + axi_modify_address #( + .slv_req_t ( axi_usb_ctrl_dw_req_t ), + .mst_req_t ( axi_usb_ctrl_req_t ), + .mst_addr_t ( logic [11:0] ), + .axi_resp_t ( axi_usb_ctrl_rsp_t ) + ) i_usb_ctrl_modify_address ( + .slv_req_i ( usb_ctrl_dw_req ), + .slv_resp_o ( usb_ctrl_dw_rsp ), + .mst_aw_addr_i( usb_ctrl_dw_req.aw.addr[11:0] ), // Could not be correct, leave it for now + .mst_ar_addr_i( usb_ctrl_dw_req.ar.addr[11:0] ), + .mst_req_o ( usb_ctrl_req ), + .mst_resp_i ( usb_ctrl_rsp ) + ); + + axi_usb_dma_req_t usb_dma_req; + axi_usb_dma_rsp_t usb_dma_rsp; + + axi_usb_dma_dw_req_t usb_dma_dw_req; + axi_usb_dma_dw_rsp_t usb_dma_dw_rsp; + + axi_dw_converter #( + .AxiMaxReads ( 1 /* TODO */ ), + .AxiSlvPortDataWidth ( 32 ), + .AxiMstPortDataWidth ( Cfg.AxiDataWidth ), + .AxiAddrWidth ( Cfg.AddrWidth ), + .AxiIdWidth ( AxiSlvIdWidth ), + .aw_chan_t ( axi_usb_dma_aw_chan_t ), + .ar_chan_t ( axi_usb_dma_ar_chan_t ), + .mst_w_chan_t ( axi_usb_dma_dw_w_chan_t ), + .slv_w_chan_t ( axi_usb_dma_w_chan_t ), + .b_chan_t ( axi_usb_dma_b_chan_t ), + .mst_r_chan_t ( axi_usb_dma_dw_r_chan_t ), + .slv_r_chan_t ( axi_usb_dma_r_chan_t ), + .axi_slv_req_t ( axi_usb_dma_req_t ), + .axi_slv_resp_t ( axi_usb_dma_rsp_t ), + .axi_mst_req_t ( axi_usb_dma_dw_req_t ), + .axi_mst_resp_t ( axi_usb_dma_dw_rsp_t ) + ) i_usb_dma_dw_converter ( + .clk_i, + .rst_ni, + .slv_req_i ( usb_dma_req ), + .slv_resp_o ( usb_dma_rsp ), + .mst_req_o ( usb_dma_dw_req ), + .mst_resp_i ( usb_dma_dw_rsp ) + ); + + axi_modify_address #( + .slv_req_t ( axi_usb_dma_dw_req_t ), + .mst_req_t ( axi_mst_req_t ), + .mst_addr_t ( logic [31:0] ), + .axi_resp_t ( axi_usb_dma_dw_rsp_t ) + ) i_usb_dma_modify_address ( + .slv_req_i ( usb_dma_dw_req ), + .slv_resp_o ( usb_dma_dw_rsp ), + // TODO: how to write to addresses exceeding 32 bit? Find solution. + .mst_aw_addr_i( usb_dma_dw_req.aw.addr ), + .mst_ar_addr_i( usb_dma_dw_req.ar.addr ), + .mst_req_o ( axi_in_req[AxiIn.usb] ), + .mst_resp_i ( axi_in_rsp[AxiIn.usb] ) + ); + + // Tie unconnected AXI IO always_comb begin - axi_in_req[AxiIn.usb] = usb_dma_req; - axi_in_req[AxiIn.usb].aw.user = Cfg.AxiUserDefault; - axi_in_req[AxiIn.usb].w.user = Cfg.AxiUserDefault; - axi_in_req[AxiIn.usb].ar.user = Cfg.AxiUserDefault; + // Ctrl connections + //usb_ctrl_req.aw.user = Cfg.AxiUserDefault; + //usb_ctrl_req.w.user = Cfg.AxiUserDefault; + //usb_ctrl_req.ar.user = Cfg.AxiUserDefault; + usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; + usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; + // DMA connections + usb_dma_req.aw.id = 0; + usb_dma_req.aw.burst = 0; + usb_dma_req.aw.lock = 0; + usb_dma_req.aw.qos = 0; + usb_dma_req.aw.region = 0; + usb_dma_req.aw.user = Cfg.AxiUserDefault; + usb_dma_req.w.user = Cfg.AxiUserDefault; + usb_dma_req.ar.id = 0; + usb_dma_req.ar.burst = 0; + usb_dma_req.ar.qos = 0; + usb_dma_req.ar.region = 0; + usb_dma_req.ar.user = Cfg.AxiUserDefault; + //usb_dma_rsp.r.id = 0; + //usb_dma_rsp.r.user = Cfg.AxiUserDefault; + //usb_dma_rsp.b.id = 0; + //usb_dma_rsp.b.user = Cfg.AxiUserDefault; end - UsbOhciAxi4 i_UsbOhciAxi4 ( - .io_dma_aw_valid ( axi_in_req[AxiIn.usb].aw_valid ), - .io_dma_aw_ready ( axi_in_rsp[AxiIn.usb].aw_ready ), - .io_dma_aw_payload_addr ( axi_in_req[AxiIn.usb].aw.addr ), - .io_dma_aw_payload_len ( axi_in_req[AxiIn.usb].aw.len ), - .io_dma_aw_payload_size ( axi_in_req[AxiIn.usb].aw.size ), - .io_dma_aw_payload_cache ( axi_in_req[AxiIn.usb].aw.cache ), - .io_dma_aw_payload_prot ( axi_in_req[AxiIn.usb].aw.prot ), - .io_dma_w_valid ( axi_in_req[AxiIn.usb].w_valid ), - .io_dma_w_ready ( axi_in_rsp[AxiIn.usb].w_ready ), - .io_dma_w_payload_data ( axi_in_req[AxiIn.usb].w.data ), - .io_dma_w_payload_strb ( axi_in_req[AxiIn.usb].w.strb ), - .io_dma_w_payload_last ( axi_in_req[AxiIn.usb].w.last ), - .io_dma_b_valid ( axi_in_rsp[AxiIn.usb].b_valid ), - .io_dma_b_ready ( axi_in_req[AxiIn.usb].b_ready ), - .io_dma_b_payload_resp ( axi_in_rsp[AxiIn.usb].b.resp ), - .io_dma_ar_valid ( axi_in_req[AxiIn.usb].ar_valid ), - .io_dma_ar_ready ( axi_in_rsp[AxiIn.usb].ar_ready ), - .io_dma_ar_payload_addr ( axi_in_req[AxiIn.usb].ar.addr ), - .io_dma_ar_payload_len ( axi_in_req[AxiIn.usb].ar.len ), - .io_dma_ar_payload_size ( axi_in_req[AxiIn.usb].ar.size ), - .io_dma_ar_payload_cache ( axi_in_req[AxiIn.usb].ar.cache ), - .io_dma_ar_payload_prot ( axi_in_req[AxiIn.usb].ar.prot ), - .io_dma_r_valid ( axi_in_rsp[AxiIn.usb].r_valid ), - .io_dma_r_ready ( axi_in_req[AxiIn.usb].r_ready ), - .io_dma_r_payload_data ( axi_in_rsp[AxiIn.usb].r.data ), - .io_dma_r_payload_resp ( axi_in_rsp[AxiIn.usb].r.resp ), - .io_dma_r_payload_last ( axi_in_rsp[AxiIn.usb].r.last ), - .io_ctrl_aw_valid ( axi_out_req[AxiOut.usb].aw_valid ), - .io_ctrl_aw_ready ( axi_out_rsp[AxiOut.usb].aw_ready ), - .io_ctrl_aw_payload_addr ( axi_out_req[AxiOut.usb].aw.addr ), - .io_ctrl_aw_payload_id ( axi_out_req[AxiOut.usb].aw.id ), - .io_ctrl_aw_payload_region( axi_out_req[AxiOut.usb].aw.region ), - .io_ctrl_aw_payload_len ( axi_out_req[AxiOut.usb].aw.len ), - .io_ctrl_aw_payload_size ( axi_out_req[AxiOut.usb].aw.size ), - .io_ctrl_aw_payload_burst ( axi_out_req[AxiOut.usb].aw.burst ), - .io_ctrl_aw_payload_lock ( axi_out_req[AxiOut.usb].aw.lock ), - .io_ctrl_aw_payload_cache ( axi_out_req[AxiOut.usb].aw.cache ), - .io_ctrl_aw_payload_qos ( axi_out_req[AxiOut.usb].aw.qos ), - .io_ctrl_aw_payload_prot ( axi_out_req[AxiOut.usb].aw.prot ), - .io_ctrl_w_valid ( axi_out_req[AxiOut.usb].w_valid ), - .io_ctrl_w_ready ( axi_out_rsp[AxiOut.usb].w_ready ), - .io_ctrl_w_payload_data ( axi_out_req[AxiOut.usb].w.data ), - .io_ctrl_w_payload_strb ( axi_out_req[AxiOut.usb].w.strb ), - .io_ctrl_w_payload_last ( axi_out_req[AxiOut.usb].w.last ), - .io_ctrl_b_valid ( axi_out_rsp[AxiOut.usb].b_valid ), - .io_ctrl_b_ready ( axi_out_req[AxiOut.usb].b_ready ), - .io_ctrl_b_payload_id ( axi_out_rsp[AxiOut.usb].b.id ), - .io_ctrl_b_payload_resp ( axi_out_rsp[AxiOut.usb].b.resp ), - .io_ctrl_ar_valid ( axi_out_req[AxiOut.usb].ar_valid ), - .io_ctrl_ar_ready ( axi_out_rsp[AxiOut.usb].ar_ready ), - .io_ctrl_ar_payload_addr ( axi_out_req[AxiOut.usb].ar.addr ), - .io_ctrl_ar_payload_id ( axi_out_req[AxiOut.usb].ar.id ), - .io_ctrl_ar_payload_region( axi_out_req[AxiOut.usb].ar.region ), - .io_ctrl_ar_payload_len ( axi_out_req[AxiOut.usb].ar.len ), - .io_ctrl_ar_payload_size ( axi_out_req[AxiOut.usb].ar.size ), - .io_ctrl_ar_payload_burst ( axi_out_req[AxiOut.usb].ar.burst ), - .io_ctrl_ar_payload_lock ( axi_out_req[AxiOut.usb].ar.lock ), - .io_ctrl_ar_payload_cache ( axi_out_req[AxiOut.usb].ar.cache ), - .io_ctrl_ar_payload_qos ( axi_out_req[AxiOut.usb].ar.qos ), - .io_ctrl_ar_payload_prot ( axi_out_req[AxiOut.usb].ar.prot ), - .io_ctrl_r_valid ( axi_out_rsp[AxiOut.usb].r_valid ), - .io_ctrl_r_ready ( axi_out_req[AxiOut.usb].r_ready ), - .io_ctrl_r_payload_data ( axi_out_rsp[AxiOut.usb].r.data ), - .io_ctrl_r_payload_id ( axi_out_rsp[AxiOut.usb].r.id ), - .io_ctrl_r_payload_resp ( axi_out_rsp[AxiOut.usb].r.resp ), - .io_ctrl_r_payload_last ( axi_out_rsp[AxiOut.usb].r.last ), - .io_interrupt (io_interrupt ), // Where do we connect this one? - .io_usb_0_dp_read ( usb_dp_read ), // For these we probably have to define new outputs for cheshire - .io_usb_0_dp_write ( usb_dp_write ), // Defined them in cheshire_soc.sv line 100ff - .io_usb_0_dp_writeEnable ( io_usb_0_dp_writeEnable ), // Where do we connect write enable? To a bidirectional I/O? - .io_usb_0_dm_read ( usb_dm_read ), - .io_usb_0_dm_write ( usb_dm_write ), - .io_usb_0_dm_writeEnable ( io_usb_0_dm_writeEnable ), - .phy_clk ( clk_i ), // I don't think these are the correct clock lines - .phy_reset ( rst_ni ), - .ctrl_clk ( clk_i ), - .ctrl_reset ( rst_ni ) + UsbOhciAxi4 i_usb ( + .io_dma_aw_valid ( usb_dma_req.aw_valid ), + .io_dma_aw_ready ( usb_dma_rsp.aw_ready ), + .io_dma_aw_payload_addr ( usb_dma_req.aw.addr ), + .io_dma_aw_payload_len ( usb_dma_req.aw.len ), + .io_dma_aw_payload_size ( usb_dma_req.aw.size ), + .io_dma_aw_payload_cache ( usb_dma_req.aw.cache ), + .io_dma_aw_payload_prot ( usb_dma_req.aw.prot ), + .io_dma_w_valid ( usb_dma_req.w_valid ), + .io_dma_w_ready ( usb_dma_rsp.w_ready ), + .io_dma_w_payload_data ( usb_dma_req.w.data ), + .io_dma_w_payload_strb ( usb_dma_req.w.strb ), + .io_dma_w_payload_last ( usb_dma_req.w.last ), + .io_dma_b_valid ( usb_dma_rsp.b_valid ), + .io_dma_b_ready ( usb_dma_req.b_ready ), + .io_dma_b_payload_resp ( usb_dma_rsp.b.resp ), + .io_dma_ar_valid ( usb_dma_req.ar_valid ), + .io_dma_ar_ready ( usb_dma_rsp.ar_ready ), + .io_dma_ar_payload_addr ( usb_dma_req.ar.addr ), + .io_dma_ar_payload_len ( usb_dma_req.ar.len ), + .io_dma_ar_payload_size ( usb_dma_req.ar.size ), + .io_dma_ar_payload_cache ( usb_dma_req.ar.cache ), + .io_dma_ar_payload_prot ( usb_dma_req.ar.prot ), + .io_dma_r_valid ( usb_dma_rsp.r_valid ), + .io_dma_r_ready ( usb_dma_req.r_ready ), + .io_dma_r_payload_data ( usb_dma_rsp.r.data ), + .io_dma_r_payload_resp ( usb_dma_rsp.r.resp ), + .io_dma_r_payload_last ( usb_dma_rsp.r.last ), + .io_ctrl_aw_valid ( usb_ctrl_req.aw_valid ), + .io_ctrl_aw_ready ( usb_ctrl_rsp.aw_ready ), + .io_ctrl_aw_payload_addr ( usb_ctrl_req.aw.addr ), + .io_ctrl_aw_payload_id ( usb_ctrl_req.aw.id ), + .io_ctrl_aw_payload_region( usb_ctrl_req.aw.region ), + .io_ctrl_aw_payload_len ( usb_ctrl_req.aw.len ), + .io_ctrl_aw_payload_size ( usb_ctrl_req.aw.size ), + .io_ctrl_aw_payload_burst ( usb_ctrl_req.aw.burst ), + .io_ctrl_aw_payload_lock ( usb_ctrl_req.aw.lock ), + .io_ctrl_aw_payload_cache ( usb_ctrl_req.aw.cache ), + .io_ctrl_aw_payload_qos ( usb_ctrl_req.aw.qos ), + .io_ctrl_aw_payload_prot ( usb_ctrl_req.aw.prot ), + .io_ctrl_w_valid ( usb_ctrl_req.w_valid ), + .io_ctrl_w_ready ( usb_ctrl_rsp.w_ready ), + .io_ctrl_w_payload_data ( usb_ctrl_req.w.data ), + .io_ctrl_w_payload_strb ( usb_ctrl_req.w.strb ), + .io_ctrl_w_payload_last ( usb_ctrl_req.w.last ), + .io_ctrl_b_valid ( usb_ctrl_rsp.b_valid ), + .io_ctrl_b_ready ( usb_ctrl_req.b_ready ), + .io_ctrl_b_payload_id ( usb_ctrl_rsp.b.id ), + .io_ctrl_b_payload_resp ( usb_ctrl_rsp.b.resp ), + .io_ctrl_ar_valid ( usb_ctrl_req.ar_valid ), + .io_ctrl_ar_ready ( usb_ctrl_rsp.ar_ready ), + .io_ctrl_ar_payload_addr ( usb_ctrl_req.ar.addr ), + .io_ctrl_ar_payload_id ( usb_ctrl_req.ar.id ), + .io_ctrl_ar_payload_region( usb_ctrl_req.ar.region ), + .io_ctrl_ar_payload_len ( usb_ctrl_req.ar.len ), + .io_ctrl_ar_payload_size ( usb_ctrl_req.ar.size ), + .io_ctrl_ar_payload_burst ( usb_ctrl_req.ar.burst ), + .io_ctrl_ar_payload_lock ( usb_ctrl_req.ar.lock ), + .io_ctrl_ar_payload_cache ( usb_ctrl_req.ar.cache ), + .io_ctrl_ar_payload_qos ( usb_ctrl_req.ar.qos ), + .io_ctrl_ar_payload_prot ( usb_ctrl_req.ar.prot ), + .io_ctrl_r_valid ( usb_ctrl_rsp.r_valid ), + .io_ctrl_r_ready ( usb_ctrl_req.r_ready ), + .io_ctrl_r_payload_data ( usb_ctrl_rsp.r.data ), + .io_ctrl_r_payload_id ( usb_ctrl_rsp.r.id ), + .io_ctrl_r_payload_resp ( usb_ctrl_rsp.r.resp ), + .io_ctrl_r_payload_last ( usb_ctrl_rsp.r.last ), + .io_interrupt ( intr.intn.usb ), + .io_usb_0_dp_read ( usb_dp_i ), + .io_usb_0_dp_write ( usb_dp_o ), + .io_usb_0_dp_writeEnable ( usb_dp_en_o ), + .io_usb_0_dm_read ( usb_dm_i ), + .io_usb_0_dm_write ( usb_dm_o ), + .io_usb_0_dm_writeEnable ( usb_dm_en_o ), + .phy_clk ( clk_i ), + .phy_reset ( rst_ni ), + .ctrl_clk ( clk_i ), + .ctrl_reset ( rst_ni ) ); - end /////////// From 7ae789dd38a83033ed0614c00cab6265f9b0f93f Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 8 Nov 2023 15:23:12 +0100 Subject: [PATCH 09/21] Fix address width in i_usb_dma_modify_address --- hw/cheshire_soc.sv | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index 0861e10c..bd749cc9 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -1373,8 +1373,8 @@ module cheshire_soc import cheshire_pkg::*; #( `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_ctrl_dw, addr_t, logic [7:0], logic [31:0], logic [3:0], axi_user_t) `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_ctrl, logic [11:0], logic [7:0], logic [31:0], logic [3:0], axi_user_t) // For the dma converter chain - `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma, logic [31:0], logic [AxiSlvIdWidth-1:0], logic [31:0], logic [3:0], axi_user_t) - `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma_dw, logic [31:0], logic [AxiSlvIdWidth-1:0], axi_data_t, axi_strb_t, axi_user_t) + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma, logic [31:0], logic [Cfg.AxiMstIdWidth-1:0], logic [31:0], logic [3:0], axi_user_t) + `CHESHIRE_TYPEDEF_AXI_CT(axi_usb_dma_dw, logic [31:0], logic [Cfg.AxiMstIdWidth-1:0], axi_data_t, axi_strb_t, axi_user_t) if (Cfg.Usb) begin : gen_usb axi_slv_req_t usb_amo_req, usb_cut_req; // AXI interconnect for atomics and cuts @@ -1528,14 +1528,14 @@ module cheshire_soc import cheshire_pkg::*; #( axi_modify_address #( .slv_req_t ( axi_usb_dma_dw_req_t ), .mst_req_t ( axi_mst_req_t ), - .mst_addr_t ( logic [31:0] ), - .axi_resp_t ( axi_usb_dma_dw_rsp_t ) + .mst_addr_t ( addr_t ), + .axi_resp_t ( axi_mst_rsp_t ) ) i_usb_dma_modify_address ( .slv_req_i ( usb_dma_dw_req ), .slv_resp_o ( usb_dma_dw_rsp ), // TODO: how to write to addresses exceeding 32 bit? Find solution. - .mst_aw_addr_i( usb_dma_dw_req.aw.addr ), - .mst_ar_addr_i( usb_dma_dw_req.ar.addr ), + .mst_aw_addr_i( addr_t'(usb_dma_dw_req.aw.addr) ), + .mst_ar_addr_i( addr_t'(usb_dma_dw_req.ar.addr) ), .mst_req_o ( axi_in_req[AxiIn.usb] ), .mst_resp_i ( axi_in_rsp[AxiIn.usb] ) ); @@ -1649,6 +1649,10 @@ module cheshire_soc import cheshire_pkg::*; #( end + if (!(Cfg.Usb && Cfg.BusErr)) begin : gen_usb_bus_err_tie + assign intr.intn.bus_err.usb = '0; + end + /////////// // DMA // /////////// From 439ecfa385e09bf489edf4f184e714f01d4c4569 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 8 Nov 2023 15:46:40 +0100 Subject: [PATCH 10/21] Add USB dp/dm outputs to target top levels --- target/sim/src/fixture_cheshire_soc.sv | 13 +++++++++++++ target/xilinx/src/cheshire_top_xilinx.sv | 14 ++++++++++++++ 2 files changed, 27 insertions(+) diff --git a/target/sim/src/fixture_cheshire_soc.sv b/target/sim/src/fixture_cheshire_soc.sv index 00f0c493..4626e30e 100644 --- a/target/sim/src/fixture_cheshire_soc.sv +++ b/target/sim/src/fixture_cheshire_soc.sv @@ -49,6 +49,13 @@ module fixture_cheshire_soc #( logic i2c_scl_i; logic i2c_scl_en; + logic usb_dp_i; + logic usb_dp_o; + logic usb_dp_en_o; + logic usb_dm_i; + logic usb_dm_o; + logic usb_dm_en_o; + logic spih_sck_o; logic spih_sck_en; logic [SpihNumCs-1:0] spih_csb_o; @@ -115,6 +122,12 @@ module fixture_cheshire_soc #( .i2c_scl_o ( i2c_scl_o ), .i2c_scl_i ( i2c_scl_i ), .i2c_scl_en_o ( i2c_scl_en ), + .usb_dp_i ( usb_dp_i ), + .usb_dp_o ( usb_dp_o ), + .usb_dp_en_o ( usb_dp_en_o ), + .usb_dm_i ( usb_dm_i ), + .usb_dm_o ( usb_dm_o ), + .usb_dm_en_o ( usb_dm_en_o ), .spih_sck_o ( spih_sck_o ), .spih_sck_en_o ( spih_sck_en ), .spih_csb_o ( spih_csb_o ), diff --git a/target/xilinx/src/cheshire_top_xilinx.sv b/target/xilinx/src/cheshire_top_xilinx.sv index 188e0ce3..a624d6cc 100644 --- a/target/xilinx/src/cheshire_top_xilinx.sv +++ b/target/xilinx/src/cheshire_top_xilinx.sv @@ -64,6 +64,9 @@ module cheshire_top_xilinx // VGA Sync signals output logic vga_hs, output logic vga_vs + + // USB output wires + ); // Configure cheshire for FPGA mapping @@ -101,6 +104,7 @@ module cheshire_top_xilinx I2c : 1, SpiHost : 1, Gpio : 1, + Usb : 1, Dma : 1, SerialLink : 0, Vga : 1, @@ -148,6 +152,16 @@ module cheshire_top_xilinx DmaMemSysDepth : 8, DmaJobFifoDepth : 2, DmaRAWCouplingAvail : 1, + // USB config (for now this is just a copy of the DMA config) + UsbConfMaxReadTxns : 4, + UsbConfMaxWriteTxns : 4, + UsbConfAmoNumCuts : 1, + UsbConfAmoPostCut : 1, + UsbConfEnableTwoD : 1, + UsbNumAxInFlight : 16, + UsbMemSysDepth : 8, + UsbJobFifoDepth : 2, + UsbRAWCouplingAvail : 1, // GPIOs GpioInputSyncs : 1, // All non-set values should be zero From 10e2c83c7ddca11442b82e9f2f37745c5d8574e6 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 8 Nov 2023 15:54:22 +0100 Subject: [PATCH 11/21] Remove Bus error interrupts for USB --- hw/cheshire_soc.sv | 32 ++++++++++++++------------------ 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index bd749cc9..be891e19 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -1546,21 +1546,21 @@ module cheshire_soc import cheshire_pkg::*; #( //usb_ctrl_req.aw.user = Cfg.AxiUserDefault; //usb_ctrl_req.w.user = Cfg.AxiUserDefault; //usb_ctrl_req.ar.user = Cfg.AxiUserDefault; - usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; - usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; + //usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; + //usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; // DMA connections - usb_dma_req.aw.id = 0; - usb_dma_req.aw.burst = 0; - usb_dma_req.aw.lock = 0; - usb_dma_req.aw.qos = 0; - usb_dma_req.aw.region = 0; - usb_dma_req.aw.user = Cfg.AxiUserDefault; - usb_dma_req.w.user = Cfg.AxiUserDefault; - usb_dma_req.ar.id = 0; - usb_dma_req.ar.burst = 0; - usb_dma_req.ar.qos = 0; - usb_dma_req.ar.region = 0; - usb_dma_req.ar.user = Cfg.AxiUserDefault; + //usb_dma_req.aw.id = 0; + //usb_dma_req.aw.burst = 0; + //usb_dma_req.aw.lock = 0; + //usb_dma_req.aw.qos = 0; + //usb_dma_req.aw.region = 0; + //usb_dma_req.aw.user = Cfg.AxiUserDefault; + //usb_dma_req.w.user = Cfg.AxiUserDefault; + //usb_dma_req.ar.id = 0; + //usb_dma_req.ar.burst = 0; + //usb_dma_req.ar.qos = 0; + //usb_dma_req.ar.region = 0; + //usb_dma_req.ar.user = Cfg.AxiUserDefault; //usb_dma_rsp.r.id = 0; //usb_dma_rsp.r.user = Cfg.AxiUserDefault; //usb_dma_rsp.b.id = 0; @@ -1649,10 +1649,6 @@ module cheshire_soc import cheshire_pkg::*; #( end - if (!(Cfg.Usb && Cfg.BusErr)) begin : gen_usb_bus_err_tie - assign intr.intn.bus_err.usb = '0; - end - /////////// // DMA // /////////// From 9dba42b1cfea23b59e7b448cc9ba23f6dafb74d2 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 8 Nov 2023 17:03:17 +0100 Subject: [PATCH 12/21] Remove interrupts from USB Host Fix port width inconsistencies --- hw/cheshire_pkg.sv | 2 +- hw/cheshire_soc.sv | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/hw/cheshire_pkg.sv b/hw/cheshire_pkg.sv index d4ab8b11..1c07803e 100644 --- a/hw/cheshire_pkg.sv +++ b/hw/cheshire_pkg.sv @@ -219,7 +219,7 @@ package cheshire_pkg; // Defined interrupts typedef struct packed { cheshire_bus_err_intr_t bus_err; - logic usb; + // logic usb; logic [31:0] gpio; logic spih_spi_event; logic spih_error; diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index be891e19..0ecd8f3d 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -1455,7 +1455,7 @@ module cheshire_soc import cheshire_pkg::*; #( .AxiSlvPortDataWidth ( Cfg.AxiDataWidth ), .AxiMstPortDataWidth ( 32 ), .AxiAddrWidth ( Cfg.AddrWidth ), - .AxiIdWidth ( AxiSlvIdWidth ), + .AxiIdWidth ( 8 ), .aw_chan_t ( axi_usb_ctrl_ser_aw_chan_t ), .ar_chan_t ( axi_usb_ctrl_ser_ar_chan_t ), .mst_w_chan_t ( axi_usb_ctrl_dw_w_chan_t ), @@ -1504,7 +1504,7 @@ module cheshire_soc import cheshire_pkg::*; #( .AxiSlvPortDataWidth ( 32 ), .AxiMstPortDataWidth ( Cfg.AxiDataWidth ), .AxiAddrWidth ( Cfg.AddrWidth ), - .AxiIdWidth ( AxiSlvIdWidth ), + .AxiIdWidth ( Cfg.AxiMstIdWidth ), .aw_chan_t ( axi_usb_dma_aw_chan_t ), .ar_chan_t ( axi_usb_dma_ar_chan_t ), .mst_w_chan_t ( axi_usb_dma_dw_w_chan_t ), @@ -1634,7 +1634,7 @@ module cheshire_soc import cheshire_pkg::*; #( .io_ctrl_r_payload_id ( usb_ctrl_rsp.r.id ), .io_ctrl_r_payload_resp ( usb_ctrl_rsp.r.resp ), .io_ctrl_r_payload_last ( usb_ctrl_rsp.r.last ), - .io_interrupt ( intr.intn.usb ), + .io_interrupt ( /*intr.intn.usb*/ ), .io_usb_0_dp_read ( usb_dp_i ), .io_usb_0_dp_write ( usb_dp_o ), .io_usb_0_dp_writeEnable ( usb_dp_en_o ), From 02d0ba671abf0a0a7d170d1ddb5ba11de092857f Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Fri, 10 Nov 2023 12:49:25 +0100 Subject: [PATCH 13/21] Replace i_usb_ctrl_id_serialize with i_usb_ctrl_iw_converter --- hw/cheshire_soc.sv | 51 +++++++++++++++++++++++----------------------- 1 file changed, 26 insertions(+), 25 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index 0ecd8f3d..7405fe72 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -1423,29 +1423,30 @@ module cheshire_soc import cheshire_pkg::*; #( axi_usb_ctrl_ser_req_t usb_ctrl_ser_req; axi_usb_ctrl_ser_rsp_t usb_ctrl_ser_rsp; - - axi_id_serialize #( - .AxiSlvPortMaxTxns ( 1 /* TODO */ ), - .AxiMstPortMaxUniqIds ( 1 /* TODO */ ), - .AxiMstPortMaxTxnsPerId ( 1 /* TODO */ ), - .AxiSlvPortIdWidth ( AxiSlvIdWidth ), - .AxiMstPortIdWidth ( 8 ), - .AxiAddrWidth ( Cfg.AddrWidth ), - .AxiDataWidth ( Cfg.AxiDataWidth ), - .AxiUserWidth ( Cfg.AxiUserWidth ), - .AtopSupport ( 0 /* filtered above */ ), - .slv_req_t ( axi_slv_req_t ), - .slv_resp_t ( axi_slv_rsp_t ), - .mst_req_t ( axi_usb_ctrl_ser_req_t ), - .mst_resp_t ( axi_usb_ctrl_ser_rsp_t ) - ) i_usb_ctrl_id_serialize ( - .clk_i, - .rst_ni, - .slv_req_i ( usb_cut_req ), - .slv_resp_o ( usb_cut_rsp ), - .mst_req_o ( usb_ctrl_ser_req ), - .mst_resp_i ( usb_ctrl_ser_rsp ) - ); + + axi_iw_converter #( + .AxiSlvPortIdWidth ( AxiSlvIdWidth ), + .AxiMstPortIdWidth ( 8 ), + .AxiSlvPortMaxUniqIds ( 1 /* TODO */ ), + .AxiSlvPortMaxTxnsPerId ( 1 /* TODO */ ), + .AxiSlvPortMaxTxns ( 1 /* TODO */ ), + .AxiMstPortMaxUniqIds ( 1 /* TODO */ ), + .AxiMstPortMaxTxnsPerId ( 1 /* TODO */ ), + .AxiAddrWidth ( Cfg.AddrWidth ), + .AxiDataWidth ( Cfg.AxiDataWidth ), + .AxiUserWidth ( Cfg.AxiUserWidth ), + .slv_req_t ( axi_slv_req_t ), + .slv_resp_t ( axi_slv_rsp_t ), + .mst_req_t ( axi_usb_ctrl_ser_req_t ), + .mst_resp_t ( axi_usb_ctrl_ser_rsp_t ) + ) i_usb_ctrl_iw_converter ( + .clk_i, + .rst_ni, + .slv_req_i ( usb_cut_req ), + .slv_resp_o ( usb_cut_rsp ), + .mst_req_o ( usb_ctrl_ser_req ), + .mst_resp_i ( usb_ctrl_ser_rsp ) + ); axi_usb_ctrl_dw_req_t usb_ctrl_dw_req; axi_usb_ctrl_dw_rsp_t usb_ctrl_dw_rsp; @@ -1642,9 +1643,9 @@ module cheshire_soc import cheshire_pkg::*; #( .io_usb_0_dm_write ( usb_dm_o ), .io_usb_0_dm_writeEnable ( usb_dm_en_o ), .phy_clk ( clk_i ), - .phy_reset ( rst_ni ), + .phy_reset ( rst_i ), .ctrl_clk ( clk_i ), - .ctrl_reset ( rst_ni ) + .ctrl_reset ( rst_i ) ); end From a2cd7a5331d208357129076634b7a8812bbcedec Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 13 Nov 2023 14:03:55 +0100 Subject: [PATCH 14/21] Fix reset signal on USB Host, Tie dangling signals, Code cleanup --- hw/cheshire_soc.sv | 66 +++++++++++++++++++++++----------------------- 1 file changed, 33 insertions(+), 33 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index 7405fe72..b584d218 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -98,12 +98,12 @@ module cheshire_soc import cheshire_pkg::*; #( output logic [Cfg.VgaGreenWidth-1:0] vga_green_o, output logic [Cfg.VgaBlueWidth -1:0] vga_blue_o, // USB interface - output logic usb_dm_o, - input logic usb_dm_i, - output logic usb_dm_en_o, - output logic usb_dp_o, - input logic usb_dp_i, - output logic usb_dp_en_o + (* dont_touch = "yes" *) (* mark_debug = "true" *) output logic usb_dm_o, + (* dont_touch = "yes" *) (* mark_debug = "true" *) input logic usb_dm_i, + (* dont_touch = "yes" *) (* mark_debug = "true" *) output logic usb_dm_en_o, + (* dont_touch = "yes" *) (* mark_debug = "true" *) output logic usb_dp_o, + (* dont_touch = "yes" *) (* mark_debug = "true" *) input logic usb_dp_i, + (* dont_touch = "yes" *) (* mark_debug = "true" *) output logic usb_dp_en_o ); `include "axi/typedef.svh" @@ -111,12 +111,18 @@ module cheshire_soc import cheshire_pkg::*; #( `include "common_cells/assertions.svh" `include "cheshire/typedef.svh" + `define ila(__name, __signal) \ + (* dont_touch = "yes" *) (* mark_debug = "true" *) logic [$bits(__signal)-1:0] __name; \ + assign __name = __signal; + + //`ila(ila_ready, axiin[cfg.Usb].aw_ready); + + // Declare interface types internally `CHESHIRE_TYPEDEF_ALL(, Cfg) ////////////////// - // Interrupts // - ////////////////// + // Interrupts .usb ////////////////// localparam int unsigned NumIntHarts = Cfg.NumCores; localparam int unsigned NumIrqHarts = NumIntHarts + Cfg.NumExtIrqHarts; @@ -1488,7 +1494,7 @@ module cheshire_soc import cheshire_pkg::*; #( ) i_usb_ctrl_modify_address ( .slv_req_i ( usb_ctrl_dw_req ), .slv_resp_o ( usb_ctrl_dw_rsp ), - .mst_aw_addr_i( usb_ctrl_dw_req.aw.addr[11:0] ), // Could not be correct, leave it for now + .mst_aw_addr_i( usb_ctrl_dw_req.aw.addr[11:0] ), .mst_ar_addr_i( usb_ctrl_dw_req.ar.addr[11:0] ), .mst_req_o ( usb_ctrl_req ), .mst_resp_i ( usb_ctrl_rsp ) @@ -1544,28 +1550,22 @@ module cheshire_soc import cheshire_pkg::*; #( // Tie unconnected AXI IO always_comb begin // Ctrl connections - //usb_ctrl_req.aw.user = Cfg.AxiUserDefault; - //usb_ctrl_req.w.user = Cfg.AxiUserDefault; - //usb_ctrl_req.ar.user = Cfg.AxiUserDefault; - //usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; - //usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; + usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; + usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; // DMA connections - //usb_dma_req.aw.id = 0; - //usb_dma_req.aw.burst = 0; - //usb_dma_req.aw.lock = 0; - //usb_dma_req.aw.qos = 0; - //usb_dma_req.aw.region = 0; - //usb_dma_req.aw.user = Cfg.AxiUserDefault; - //usb_dma_req.w.user = Cfg.AxiUserDefault; - //usb_dma_req.ar.id = 0; - //usb_dma_req.ar.burst = 0; - //usb_dma_req.ar.qos = 0; - //usb_dma_req.ar.region = 0; - //usb_dma_req.ar.user = Cfg.AxiUserDefault; - //usb_dma_rsp.r.id = 0; - //usb_dma_rsp.r.user = Cfg.AxiUserDefault; - //usb_dma_rsp.b.id = 0; - //usb_dma_rsp.b.user = Cfg.AxiUserDefault; + usb_dma_req.aw.id = '0; + usb_dma_req.aw.burst = axi_pkg::BURST_INCR; + usb_dma_req.aw.lock = 0; + usb_dma_req.aw.qos = '0; + usb_dma_req.aw.region = '0; + usb_dma_req.aw.atop = '0; + usb_dma_req.aw.user = Cfg.AxiUserDefault; + usb_dma_req.w.user = Cfg.AxiUserDefault; + usb_dma_req.ar.id = '0; + usb_dma_req.ar.burst = axi_pkg::BURST_INCR; + usb_dma_req.ar.qos = '0; + usb_dma_req.ar.region = '0; + usb_dma_req.ar.user = Cfg.AxiUserDefault; end UsbOhciAxi4 i_usb ( @@ -1635,7 +1635,7 @@ module cheshire_soc import cheshire_pkg::*; #( .io_ctrl_r_payload_id ( usb_ctrl_rsp.r.id ), .io_ctrl_r_payload_resp ( usb_ctrl_rsp.r.resp ), .io_ctrl_r_payload_last ( usb_ctrl_rsp.r.last ), - .io_interrupt ( /*intr.intn.usb*/ ), + .io_interrupt ( /*intr.intn.usb*/ ), .io_usb_0_dp_read ( usb_dp_i ), .io_usb_0_dp_write ( usb_dp_o ), .io_usb_0_dp_writeEnable ( usb_dp_en_o ), @@ -1643,9 +1643,9 @@ module cheshire_soc import cheshire_pkg::*; #( .io_usb_0_dm_write ( usb_dm_o ), .io_usb_0_dm_writeEnable ( usb_dm_en_o ), .phy_clk ( clk_i ), - .phy_reset ( rst_i ), + .phy_reset ( !rst_ni ), .ctrl_clk ( clk_i ), - .ctrl_reset ( rst_i ) + .ctrl_reset ( !rst_ni ) ); end From c95530a57c0d71e353870f122d87a552a6004926 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Thu, 16 Nov 2023 11:27:40 +0100 Subject: [PATCH 15/21] Add address w/r tests for USB Host --- sw/tests/helloworld.c | 61 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) diff --git a/sw/tests/helloworld.c b/sw/tests/helloworld.c index df250626..8dade335 100644 --- a/sw/tests/helloworld.c +++ b/sw/tests/helloworld.c @@ -19,6 +19,67 @@ int main(void) { uint64_t reset_freq = clint_get_core_freq(rtc_freq, 2500); uart_init(&__base_uart, reset_freq, 115200); uart_write_str(&__base_uart, str, sizeof(str)); + + + char rtn[] = "\r\n"; + + // Read USB Host Version (offset 11'h000) + uint32_t* ver_reg = (uint32_t*)0x01001000; + uint32_t ver = *ver_reg; + for (int32_t i = 31; i >= 0; --i) { + uart_write(&__base_uart, (uint8_t)(48 + ((ver >> i) % 2))); + } + uart_write_str(&__base_uart, rtn, sizeof(rtn)); + + // Read USB Host Vendor ID (offset 11'h040) + uint32_t* VID_reg = (uint32_t*)0x01001040; + uint32_t VID = *VID_reg; + for (int32_t i = 31; i >= 0; --i) { + uart_write(&__base_uart, (uint8_t)(48 + ((VID >> i) % 2))); + } + uart_write_str(&__base_uart, rtn, sizeof(rtn)); + + // Read Bus ID (offset 11'h01c) + uint32_t* BID_reg = (uint32_t*)0x0100101c; + uint32_t BID = *BID_reg; + for (int32_t i = 31; i >= 0; --i) { + uart_write(&__base_uart, (uint8_t)(48 + ((BID >> i) % 2))); + } + uart_write_str(&__base_uart, rtn, sizeof(rtn)); + + + // Test HCControl registers (set and clear) OHCI Spec 5.7 + + // Set bits 31, 29, 23, 18, 17 to one + uint32_t set = 0xA0860620; // 10100000 10000110 00000000 00000000 + + uint32_t* HCCset = 0x01001050; // Set register offset 11'h050 + + *HCCset = set; + + // Print HCControl + uint32_t HCC = *HCCset; + for (int32_t i = 31; i >= 0; --i) { + uart_write(&__base_uart, (uint8_t)(48 + ((HCC >> i) % 2))); + } + uart_write_str(&__base_uart, rtn, sizeof(rtn)); + + + // Reset bit 29 to zero + uint32_t clear = 0x80000000; // 10000000 00000000 00000000 00000000 + + uint32_t* HCCclear = 0x01001054; // Clear register offset 11'h054 + + *HCCclear = clear; + + // Print HCControl + HCC = *HCCset; + for (int32_t i = 31; i >= 0; --i) { + uart_write(&__base_uart, (uint8_t)(48 + ((HCC >> i) % 2))); + } + uart_write_str(&__base_uart, rtn, sizeof(rtn)); + + uart_write_flush(&__base_uart); return 0; } From 986e98de9c97c590dba2782c3b05ccb277221d77 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Thu, 16 Nov 2023 11:41:25 +0100 Subject: [PATCH 16/21] Add USB I/O to FPGA top --- target/xilinx/src/cheshire_top_xilinx.sv | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/target/xilinx/src/cheshire_top_xilinx.sv b/target/xilinx/src/cheshire_top_xilinx.sv index a624d6cc..f7719771 100644 --- a/target/xilinx/src/cheshire_top_xilinx.sv +++ b/target/xilinx/src/cheshire_top_xilinx.sv @@ -66,9 +66,21 @@ module cheshire_top_xilinx output logic vga_vs // USB output wires - +// output logic usb_dm_o, +// input logic usb_dm_i, +// output logic usb_dm_en_o, +// output logic usb_dp_o, +// input logic usb_dp_i, +// output logic usb_dp_en_o ); + logic usb_dm_o, + logic usb_dm_i, + logic usb_dm_en_o, + logic usb_dp_o, + logic usb_dp_i, + logic usb_dp_en_o + // Configure cheshire for FPGA mapping localparam cheshire_cfg_t FPGACfg = '{ // CVA6 parameters @@ -550,7 +562,13 @@ module cheshire_top_xilinx .vga_vsync_o ( vga_vs ), .vga_red_o ( vga_r ), .vga_green_o ( vga_g ), - .vga_blue_o ( vga_b ) + .vga_blue_o ( vga_b ), + .usb_dm_o, + .usb_dm_i, + .usb_dm_en_o, + .usb_dp_o, + .usb_dp_i, + .usb_dp_en_o ); endmodule From 60cbc5841f22617f0f66f68af4d1c748e3859a7d Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 20 Nov 2023 12:43:30 +0100 Subject: [PATCH 17/21] Add correct compile command to questa instructions --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 2cf18f38..97c42928 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ If you are impatient and have all needed [dependencies](https://pulp-platform.gi ``` set BINARY ../../../sw/tests/helloworld.spm.elf -source compile.tcl +source compile.cheshire_soc.tcl source start.cheshire_soc.tcl run -all ``` From 1c30a44e5f2c2f3778b8d7e61bccd14c5c9f79bb Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Tue, 21 Nov 2023 17:01:57 +0100 Subject: [PATCH 18/21] Fix combinatorial loop using axi_cut at USB CTRL port --- hw/cheshire_soc.sv | 168 +++++++++++++++++++++++++++++++-------------- 1 file changed, 118 insertions(+), 50 deletions(-) diff --git a/hw/cheshire_soc.sv b/hw/cheshire_soc.sv index b584d218..93fc7f70 100644 --- a/hw/cheshire_soc.sv +++ b/hw/cheshire_soc.sv @@ -111,18 +111,13 @@ module cheshire_soc import cheshire_pkg::*; #( `include "common_cells/assertions.svh" `include "cheshire/typedef.svh" - `define ila(__name, __signal) \ - (* dont_touch = "yes" *) (* mark_debug = "true" *) logic [$bits(__signal)-1:0] __name; \ - assign __name = __signal; - - //`ila(ila_ready, axiin[cfg.Usb].aw_ready); - // Declare interface types internally `CHESHIRE_TYPEDEF_ALL(, Cfg) ////////////////// - // Interrupts .usb ////////////////// + // Interrupts // + ////////////////// localparam int unsigned NumIntHarts = Cfg.NumCores; localparam int unsigned NumIrqHarts = NumIntHarts + Cfg.NumExtIrqHarts; @@ -1483,8 +1478,8 @@ module cheshire_soc import cheshire_pkg::*; #( .mst_resp_i ( usb_ctrl_dw_rsp ) ); - axi_usb_ctrl_req_t usb_ctrl_req; - axi_usb_ctrl_rsp_t usb_ctrl_rsp; + axi_usb_ctrl_req_t usb_ctrl_req, usb_ctrl_cut_req; + axi_usb_ctrl_rsp_t usb_ctrl_rsp, usb_ctrl_cut_rsp; axi_modify_address #( .slv_req_t ( axi_usb_ctrl_dw_req_t ), @@ -1500,6 +1495,25 @@ module cheshire_soc import cheshire_pkg::*; #( .mst_resp_i ( usb_ctrl_rsp ) ); + axi_cut #( + .Bypass ( ~Cfg.UsbConfAmoPostCut ), + .aw_chan_t ( axi_usb_ctrl_aw_chan_t ), + .w_chan_t ( axi_usb_ctrl_w_chan_t ), + .b_chan_t ( axi_usb_ctrl_b_chan_t ), + .ar_chan_t ( axi_usb_ctrl_ar_chan_t ), + .r_chan_t ( axi_usb_ctrl_r_chan_t ), + .axi_req_t ( axi_usb_ctrl_req_t ), + .axi_resp_t ( axi_usb_ctrl_rsp_t ) + ) i_usb_ctrl_cut ( + .clk_i, + .rst_ni, + .slv_req_i ( usb_ctrl_req ), + .slv_resp_o ( usb_ctrl_rsp ), + .mst_req_o ( usb_ctrl_cut_req ), + .mst_resp_i ( usb_ctrl_cut_rsp ) + ); + + axi_usb_dma_req_t usb_dma_req; axi_usb_dma_rsp_t usb_dma_rsp; @@ -1550,8 +1564,8 @@ module cheshire_soc import cheshire_pkg::*; #( // Tie unconnected AXI IO always_comb begin // Ctrl connections - usb_ctrl_rsp.r.user = Cfg.AxiUserDefault; - usb_ctrl_rsp.b.user = Cfg.AxiUserDefault; + usb_ctrl_cut_rsp.r.user = Cfg.AxiUserDefault; + usb_ctrl_cut_rsp.b.user = Cfg.AxiUserDefault; // DMA connections usb_dma_req.aw.id = '0; usb_dma_req.aw.burst = axi_pkg::BURST_INCR; @@ -1596,45 +1610,45 @@ module cheshire_soc import cheshire_pkg::*; #( .io_dma_r_payload_data ( usb_dma_rsp.r.data ), .io_dma_r_payload_resp ( usb_dma_rsp.r.resp ), .io_dma_r_payload_last ( usb_dma_rsp.r.last ), - .io_ctrl_aw_valid ( usb_ctrl_req.aw_valid ), - .io_ctrl_aw_ready ( usb_ctrl_rsp.aw_ready ), - .io_ctrl_aw_payload_addr ( usb_ctrl_req.aw.addr ), - .io_ctrl_aw_payload_id ( usb_ctrl_req.aw.id ), - .io_ctrl_aw_payload_region( usb_ctrl_req.aw.region ), - .io_ctrl_aw_payload_len ( usb_ctrl_req.aw.len ), - .io_ctrl_aw_payload_size ( usb_ctrl_req.aw.size ), - .io_ctrl_aw_payload_burst ( usb_ctrl_req.aw.burst ), - .io_ctrl_aw_payload_lock ( usb_ctrl_req.aw.lock ), - .io_ctrl_aw_payload_cache ( usb_ctrl_req.aw.cache ), - .io_ctrl_aw_payload_qos ( usb_ctrl_req.aw.qos ), - .io_ctrl_aw_payload_prot ( usb_ctrl_req.aw.prot ), - .io_ctrl_w_valid ( usb_ctrl_req.w_valid ), - .io_ctrl_w_ready ( usb_ctrl_rsp.w_ready ), - .io_ctrl_w_payload_data ( usb_ctrl_req.w.data ), - .io_ctrl_w_payload_strb ( usb_ctrl_req.w.strb ), - .io_ctrl_w_payload_last ( usb_ctrl_req.w.last ), - .io_ctrl_b_valid ( usb_ctrl_rsp.b_valid ), - .io_ctrl_b_ready ( usb_ctrl_req.b_ready ), - .io_ctrl_b_payload_id ( usb_ctrl_rsp.b.id ), - .io_ctrl_b_payload_resp ( usb_ctrl_rsp.b.resp ), - .io_ctrl_ar_valid ( usb_ctrl_req.ar_valid ), - .io_ctrl_ar_ready ( usb_ctrl_rsp.ar_ready ), - .io_ctrl_ar_payload_addr ( usb_ctrl_req.ar.addr ), - .io_ctrl_ar_payload_id ( usb_ctrl_req.ar.id ), - .io_ctrl_ar_payload_region( usb_ctrl_req.ar.region ), - .io_ctrl_ar_payload_len ( usb_ctrl_req.ar.len ), - .io_ctrl_ar_payload_size ( usb_ctrl_req.ar.size ), - .io_ctrl_ar_payload_burst ( usb_ctrl_req.ar.burst ), - .io_ctrl_ar_payload_lock ( usb_ctrl_req.ar.lock ), - .io_ctrl_ar_payload_cache ( usb_ctrl_req.ar.cache ), - .io_ctrl_ar_payload_qos ( usb_ctrl_req.ar.qos ), - .io_ctrl_ar_payload_prot ( usb_ctrl_req.ar.prot ), - .io_ctrl_r_valid ( usb_ctrl_rsp.r_valid ), - .io_ctrl_r_ready ( usb_ctrl_req.r_ready ), - .io_ctrl_r_payload_data ( usb_ctrl_rsp.r.data ), - .io_ctrl_r_payload_id ( usb_ctrl_rsp.r.id ), - .io_ctrl_r_payload_resp ( usb_ctrl_rsp.r.resp ), - .io_ctrl_r_payload_last ( usb_ctrl_rsp.r.last ), + .io_ctrl_aw_valid ( usb_ctrl_cut_req.aw_valid ), + .io_ctrl_aw_ready ( usb_ctrl_cut_rsp.aw_ready ), + .io_ctrl_aw_payload_addr ( usb_ctrl_cut_req.aw.addr ), + .io_ctrl_aw_payload_id ( usb_ctrl_cut_req.aw.id ), + .io_ctrl_aw_payload_region( usb_ctrl_cut_req.aw.region ), + .io_ctrl_aw_payload_len ( usb_ctrl_cut_req.aw.len ), + .io_ctrl_aw_payload_size ( usb_ctrl_cut_req.aw.size ), + .io_ctrl_aw_payload_burst ( usb_ctrl_cut_req.aw.burst ), + .io_ctrl_aw_payload_lock ( usb_ctrl_cut_req.aw.lock ), + .io_ctrl_aw_payload_cache ( usb_ctrl_cut_req.aw.cache ), + .io_ctrl_aw_payload_qos ( usb_ctrl_cut_req.aw.qos ), + .io_ctrl_aw_payload_prot ( usb_ctrl_cut_req.aw.prot ), + .io_ctrl_w_valid ( usb_ctrl_cut_req.w_valid ), + .io_ctrl_w_ready ( usb_ctrl_cut_rsp.w_ready ), + .io_ctrl_w_payload_data ( usb_ctrl_cut_req.w.data ), + .io_ctrl_w_payload_strb ( usb_ctrl_cut_req.w.strb ), + .io_ctrl_w_payload_last ( usb_ctrl_cut_req.w.last ), + .io_ctrl_b_valid ( usb_ctrl_cut_rsp.b_valid ), + .io_ctrl_b_ready ( usb_ctrl_cut_req.b_ready ), + .io_ctrl_b_payload_id ( usb_ctrl_cut_rsp.b.id ), + .io_ctrl_b_payload_resp ( usb_ctrl_cut_rsp.b.resp ), + .io_ctrl_ar_valid ( usb_ctrl_cut_req.ar_valid ), + .io_ctrl_ar_ready ( usb_ctrl_cut_rsp.ar_ready ), + .io_ctrl_ar_payload_addr ( usb_ctrl_cut_req.ar.addr ), + .io_ctrl_ar_payload_id ( usb_ctrl_cut_req.ar.id ), + .io_ctrl_ar_payload_region( usb_ctrl_cut_req.ar.region ), + .io_ctrl_ar_payload_len ( usb_ctrl_cut_req.ar.len ), + .io_ctrl_ar_payload_size ( usb_ctrl_cut_req.ar.size ), + .io_ctrl_ar_payload_burst ( usb_ctrl_cut_req.ar.burst ), + .io_ctrl_ar_payload_lock ( usb_ctrl_cut_req.ar.lock ), + .io_ctrl_ar_payload_cache ( usb_ctrl_cut_req.ar.cache ), + .io_ctrl_ar_payload_qos ( usb_ctrl_cut_req.ar.qos ), + .io_ctrl_ar_payload_prot ( usb_ctrl_cut_req.ar.prot ), + .io_ctrl_r_valid ( usb_ctrl_cut_rsp.r_valid ), + .io_ctrl_r_ready ( usb_ctrl_cut_req.r_ready ), + .io_ctrl_r_payload_data ( usb_ctrl_cut_rsp.r.data ), + .io_ctrl_r_payload_id ( usb_ctrl_cut_rsp.r.id ), + .io_ctrl_r_payload_resp ( usb_ctrl_cut_rsp.r.resp ), + .io_ctrl_r_payload_last ( usb_ctrl_cut_rsp.r.last ), .io_interrupt ( /*intr.intn.usb*/ ), .io_usb_0_dp_read ( usb_dp_i ), .io_usb_0_dp_write ( usb_dp_o ), @@ -1648,6 +1662,60 @@ module cheshire_soc import cheshire_pkg::*; #( .ctrl_reset ( !rst_ni ) ); + + // USB Valid/Ready signals added to ILA + `define ila(__name, __signal) \ + (* dont_touch = "yes" *) (* mark_debug = "true" *) logic [$bits(__signal)-1:0] __name; \ + assign __name = __signal; + + // USB DMA ILA crossbar side + `ila(ila_xbar_dma_aw_ready, axi_in_rsp[AxiIn.usb].aw_ready); + `ila(ila_xbar_dma_aw_valid, axi_in_req[AxiIn.usb].aw_valid); + `ila(ila_xbar_dma_w_ready, axi_in_rsp[AxiIn.usb].w_ready); + `ila(ila_xbar_dma_w_valid, axi_in_req[AxiIn.usb].w_valid); + `ila(ila_xbar_dma_b_ready, axi_in_req[AxiIn.usb].b_ready); + `ila(ila_xbar_dma_b_valid, axi_in_rsp[AxiIn.usb].b_valid); + `ila(ila_xbar_dma_ar_ready, axi_in_rsp[AxiIn.usb].ar_ready); + `ila(ila_xbar_dma_ar_valid, axi_in_req[AxiIn.usb].ar_valid); + `ila(ila_xbar_dma_r_ready, axi_in_req[AxiIn.usb].r_ready); + `ila(ila_xbar_dma_r_valid, axi_in_rsp[AxiIn.usb].r_valid); + + // USB DMA ILA host side + `ila(ila_host_dma_aw_ready, usb_dma_rsp.aw_ready); + `ila(ila_host_dma_aw_valid, usb_dma_req.aw_valid); + `ila(ila_host_dma_w_ready, usb_dma_rsp.w_ready); + `ila(ila_host_dma_w_valid, usb_dma_req.w_valid); + `ila(ila_host_dma_b_ready, usb_dma_req.b_ready); + `ila(ila_host_dma_b_valid, usb_dma_rsp.b_valid); + `ila(ila_host_dma_ar_ready, usb_dma_rsp.ar_ready); + `ila(ila_host_dma_ar_valid, usb_dma_req.ar_valid); + `ila(ila_host_dma_r_ready, usb_dma_req.r_ready); + `ila(ila_host_dma_r_valid, usb_dma_rsp.r_valid); + + // USB CTRL ILA crossbar side + `ila(ila_xbar_ctrl_aw_ready, axi_out_rsp[AxiOut.usb].aw_ready); + `ila(ila_xbar_ctrl_aw_valid, axi_out_req[AxiOut.usb].aw_valid); + `ila(ila_xbar_ctrl_w_ready, axi_out_rsp[AxiOut.usb].w_ready); + `ila(ila_xbar_ctrl_w_valid, axi_out_req[AxiOut.usb].w_valid); + `ila(ila_xbar_ctrl_b_ready, axi_out_req[AxiOut.usb].b_ready); + `ila(ila_xbar_ctrl_b_valid, axi_out_rsp[AxiOut.usb].b_valid); + `ila(ila_xbar_ctrl_ar_ready, axi_out_rsp[AxiOut.usb].ar_ready); + `ila(ila_xbar_ctrl_ar_valid, axi_out_req[AxiOut.usb].ar_valid); + `ila(ila_xbar_ctrl_r_ready, axi_out_req[AxiOut.usb].r_ready); + `ila(ila_xbar_ctrl_r_valid, axi_out_rsp[AxiOut.usb].r_valid); + + // USB CTRL ILA crossbar side + `ila(ila_host_ctrl_aw_ready, usb_ctrl_cut_rsp.aw_ready); + `ila(ila_host_ctrl_aw_valid, usb_ctrl_cut_req.aw_valid); + `ila(ila_host_ctrl_w_ready, usb_ctrl_cut_rsp.w_ready); + `ila(ila_host_ctrl_w_valid, usb_ctrl_cut_req.w_valid); + `ila(ila_host_ctrl_b_ready, usb_ctrl_cut_req.b_ready); + `ila(ila_host_ctrl_b_valid, usb_ctrl_cut_rsp.b_valid); + `ila(ila_host_ctrl_ar_ready, usb_ctrl_cut_rsp.ar_ready); + `ila(ila_host_ctrl_ar_valid, usb_ctrl_cut_req.ar_valid); + `ila(ila_host_ctrl_r_ready, usb_ctrl_cut_req.r_ready); + `ila(ila_host_ctrl_r_valid, usb_ctrl_cut_rsp.r_valid); + end /////////// From 221f0f93d10b0ad73b362d5d72ca629e5a1cd22f Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Tue, 21 Nov 2023 17:04:22 +0100 Subject: [PATCH 19/21] Modify Xilinx Top to accomodate USB I/O --- target/xilinx/src/cheshire_top_xilinx.sv | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/target/xilinx/src/cheshire_top_xilinx.sv b/target/xilinx/src/cheshire_top_xilinx.sv index f7719771..1a455f4d 100644 --- a/target/xilinx/src/cheshire_top_xilinx.sv +++ b/target/xilinx/src/cheshire_top_xilinx.sv @@ -74,12 +74,12 @@ module cheshire_top_xilinx // output logic usb_dp_en_o ); - logic usb_dm_o, - logic usb_dm_i, - logic usb_dm_en_o, - logic usb_dp_o, - logic usb_dp_i, - logic usb_dp_en_o + logic usb_dm_o; + logic usb_dm_i; + logic usb_dm_en_o; + logic usb_dp_o; + logic usb_dp_i; + logic usb_dp_en_o; // Configure cheshire for FPGA mapping localparam cheshire_cfg_t FPGACfg = '{ From 17741dd38239360c3e61c32f1425fca18cfa2b79 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Wed, 22 Nov 2023 15:28:33 +0100 Subject: [PATCH 20/21] Switch cva6-sdk call from git to https --- .gitmodules | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.gitmodules b/.gitmodules index 788785c5..620a456a 100644 --- a/.gitmodules +++ b/.gitmodules @@ -4,4 +4,5 @@ ignore = dirty [submodule "sw/deps/cva6-sdk"] path = sw/deps/cva6-sdk - url = git@github.com:pulp-platform/cva6-sdk.git + url = https://github.com/pulp-platform/cva6-sdk.git + ignore = dirty From 0fc739ed00025fb23b2ec23c6f6cca54d88a3a31 Mon Sep 17 00:00:00 2001 From: "sem23h24 Luka Guzenko (lguzenko)" Date: Mon, 27 Nov 2023 14:56:18 +0100 Subject: [PATCH 21/21] Fix Genesys 2 constraints and toplevel --- .gitmodules | 2 +- target/xilinx/constraints/genesys2.xdc | 4 ++-- target/xilinx/src/cheshire_top_xilinx.sv | 16 +++++++++++++++- 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/.gitmodules b/.gitmodules index 620a456a..ac8e86f8 100644 --- a/.gitmodules +++ b/.gitmodules @@ -4,5 +4,5 @@ ignore = dirty [submodule "sw/deps/cva6-sdk"] path = sw/deps/cva6-sdk - url = https://github.com/pulp-platform/cva6-sdk.git + url = https://github.com/pulp-platform/cva6-sdk ignore = dirty diff --git a/target/xilinx/constraints/genesys2.xdc b/target/xilinx/constraints/genesys2.xdc index 7142b159..69296b5e 100644 --- a/target/xilinx/constraints/genesys2.xdc +++ b/target/xilinx/constraints/genesys2.xdc @@ -143,8 +143,8 @@ set_property -dict { PACKAGE_PIN AG23 IOSTANDARD LVCMOS33 } [get_ports { vga_vs #set_property -dict { PACKAGE_PIN AG17 IOSTANDARD LVCMOS18 } [get_ports { oled_vdd }]; #IO_L12N_T1_MRCC_32 Sch=oled_vdd ## PMOD Header JA -#set_property -dict { PACKAGE_PIN U27 IOSTANDARD LVCMOS33 } [get_ports { ja[0] }]; #IO_L13P_T2_MRCC_14 Sch=ja_p[1] -#set_property -dict { PACKAGE_PIN U28 IOSTANDARD LVCMOS33 } [get_ports { ja[1] }]; #IO_L13N_T2_MRCC_14 Sch=ja_n[1] +set_property -dict { PACKAGE_PIN U27 IOSTANDARD LVCMOS33 } [get_ports { usb_dp }]; #IO_L13P_T2_MRCC_14 Sch=ja_p[1] +set_property -dict { PACKAGE_PIN U28 IOSTANDARD LVCMOS33 } [get_ports { usb_dm }]; #IO_L13N_T2_MRCC_14 Sch=ja_n[1] #set_property -dict { PACKAGE_PIN T26 IOSTANDARD LVCMOS33 } [get_ports { ja[2] }]; #IO_L12P_T1_MRCC_14 Sch=ja_p[2] #set_property -dict { PACKAGE_PIN T27 IOSTANDARD LVCMOS33 } [get_ports { ja[3] }]; #IO_L12N_T1_MRCC_14 Sch=ja_n[2] #set_property -dict { PACKAGE_PIN T22 IOSTANDARD LVCMOS33 } [get_ports { ja[4] }]; #IO_L5P_T0_D06_14 Sch=ja_p[3] diff --git a/target/xilinx/src/cheshire_top_xilinx.sv b/target/xilinx/src/cheshire_top_xilinx.sv index 1a455f4d..f2a9f140 100644 --- a/target/xilinx/src/cheshire_top_xilinx.sv +++ b/target/xilinx/src/cheshire_top_xilinx.sv @@ -63,7 +63,7 @@ module cheshire_top_xilinx // VGA Sync signals output logic vga_hs, - output logic vga_vs + output logic vga_vs, // USB output wires // output logic usb_dm_o, @@ -72,6 +72,8 @@ module cheshire_top_xilinx // output logic usb_dp_o, // input logic usb_dp_i, // output logic usb_dp_en_o + inout wire usb_dp, + inout wire usb_dm ); logic usb_dm_o; @@ -428,6 +430,18 @@ module cheshire_top_xilinx assign spi_sd_soc_in[3] = 1'b0; + ///////////////////////// + // USB I/O Connections // + ///////////////////////// + + assign usb_dp = usb_dp_en_o ? usb_dp_o : 'z; + assign usb_dp_i = usb_dp; + + assign usb_dm = usb_dm_en_o ? usb_dm_o : 'z; + assign usb_dm_i = usb_dm; + + + ///////////////////////// // "RTC" Clock Divider // /////////////////////////