| // Copyright lowRISC contributors. | 
 | // Licensed under the Apache License, Version 2.0, see LICENSE for details. | 
 | // SPDX-License-Identifier: Apache-2.0 | 
 | // | 
 | // This module is the overall reset manager wrapper | 
 | // TODO: This module is only a draft implementation that covers most of the rstmgr | 
 | // functoinality but is incomplete | 
 |  | 
 | package rstmgr_pkg; | 
 |  | 
 |   // Power domain parameters | 
 |   parameter int PowerDomains = 2; | 
 |   parameter int DomainAonSel = 0; | 
 |   parameter int Domain0Sel = 1; | 
 |  | 
 |   // Number of non-always-on domains | 
 |   parameter int OffDomains = PowerDomains - 1; | 
 |  | 
 |   // positions of software controllable reset bits | 
 |   parameter int SPI_DEVICE = 0; | 
 |   parameter int USB = 1; | 
 |  | 
 |   // ast interface | 
 |   typedef struct packed { | 
 |     logic aon_pok; | 
 |   } rstmgr_ast_t; | 
 |  | 
 |   // default value for rstmgr_ast_rsp_t (for dangling ports) | 
 |   parameter rstmgr_ast_t RSTMGR_AST_DEFAULT = '{ | 
 |     aon_pok: 1'b1 | 
 |   }; | 
 |  | 
 |   // resets generated and broadcast | 
 |   // This should be templatized and generated | 
 |   typedef struct packed { | 
 |     logic [PowerDomains-1:0] rst_por_aon_n; | 
 |     logic [PowerDomains-1:0] rst_por_n; | 
 |     logic [PowerDomains-1:0] rst_por_io_n; | 
 |     logic [PowerDomains-1:0] rst_por_io_div2_n; | 
 |     logic [PowerDomains-1:0] rst_por_io_div4_n; | 
 |     logic [PowerDomains-1:0] rst_por_usb_n; | 
 |     logic [PowerDomains-1:0] rst_lc_n; | 
 |     logic [PowerDomains-1:0] rst_lc_io_div4_n; | 
 |     logic [PowerDomains-1:0] rst_sys_n; | 
 |     logic [PowerDomains-1:0] rst_sys_io_n; | 
 |     logic [PowerDomains-1:0] rst_sys_io_div4_n; | 
 |     logic [PowerDomains-1:0] rst_sys_aon_n; | 
 |     logic [PowerDomains-1:0] rst_spi_device_n; | 
 |     logic [PowerDomains-1:0] rst_usb_n; | 
 |   } rstmgr_out_t; | 
 |  | 
 |   // exported resets | 
 |   typedef struct packed { | 
 |     logic [PowerDomains-1:0] rst_ast_usbdev_sys_io_div4_n; | 
 |     logic [PowerDomains-1:0] rst_ast_usbdev_usb_n; | 
 |     logic [PowerDomains-1:0] rst_ast_sensor_ctrl_sys_io_div4_n; | 
 |   } rstmgr_ast_out_t; | 
 |  | 
 |   // cpu reset requests and status | 
 |   typedef struct packed { | 
 |     logic ndmreset_req; | 
 |   } rstmgr_cpu_t; | 
 |  | 
 |   // default value for rstmgr_ast_rsp_t (for dangling ports) | 
 |   parameter rstmgr_cpu_t RSTMGR_CPU_DEFAULT = '{ | 
 |     ndmreset_req: '0 | 
 |   }; | 
 |  | 
 | endpackage // rstmgr_pkg |