|  | // Copyright lowRISC contributors. | 
|  | // Licensed under the Apache License, Version 2.0, see LICENSE for details. | 
|  | // SPDX-License-Identifier: Apache-2.0 | 
|  | // | 
|  | // Flash phy module package | 
|  | // | 
|  |  | 
|  | package flash_phy_pkg; | 
|  |  | 
|  | // flash phy parameters | 
|  | parameter int NumBanks      = flash_ctrl_pkg::NumBanks; | 
|  | parameter int InfosPerBank  = flash_ctrl_pkg::InfosPerBank; | 
|  | parameter int PagesPerBank  = flash_ctrl_pkg::PagesPerBank; | 
|  | parameter int WordsPerPage  = flash_ctrl_pkg::WordsPerPage; | 
|  | parameter int BankW         = flash_ctrl_pkg::BankW; | 
|  | parameter int PageW         = flash_ctrl_pkg::PageW; | 
|  | parameter int WordW         = flash_ctrl_pkg::WordW; | 
|  | parameter int BankAddrW     = flash_ctrl_pkg::BankAddrW; | 
|  | parameter int DataWidth     = flash_ctrl_pkg::DataWidth; | 
|  | parameter int EccWidth      = 8; | 
|  | parameter int MetaDataWidth = top_pkg::FLASH_METADATA_WIDTH; | 
|  | parameter int WidthMultiple = flash_ctrl_pkg::WidthMultiple; | 
|  | parameter int NumBuf        = 4; // number of flash read buffers | 
|  | parameter int RspOrderDepth = 2; // this should be DataWidth / BusWidth | 
|  | // will switch to this after bus widening | 
|  | parameter int ScrDataWidth  = DataWidth + EccWidth; | 
|  | parameter int FullDataWidth = DataWidth + MetaDataWidth; | 
|  |  | 
|  | // flash ctrl / bus parameters | 
|  | parameter int BusWidth       = flash_ctrl_pkg::BusWidth; | 
|  | parameter int BusBankAddrW   = flash_ctrl_pkg::BusBankAddrW; | 
|  | parameter int BusWordW       = flash_ctrl_pkg::BusWordW; | 
|  | parameter int ProgTypes      = flash_ctrl_pkg::ProgTypes; | 
|  |  | 
|  | // address bits remain must be 0 | 
|  | parameter int AddrBitsRemain = DataWidth % BusWidth; | 
|  |  | 
|  | // base index | 
|  | // This is the lsb position of the prim flash address when looking at the bus address | 
|  | parameter int LsbAddrBit    = $clog2(WidthMultiple); | 
|  | parameter int WordSelW      = WidthMultiple == 1 ? 1 : LsbAddrBit; | 
|  |  | 
|  | // scramble / de-scramble parameters | 
|  | // Number of cycles the gf_mult is given to complete | 
|  | parameter int KeySize       = 128; | 
|  | parameter int GfMultCycles  = 2; | 
|  | // If this value is greater than 1, constraints must be updated for multicycle paths | 
|  | parameter int CipherCycles  = 2; | 
|  |  | 
|  | // Read buffer metadata | 
|  | typedef enum logic [1:0] { | 
|  | Invalid     = 2'h0, | 
|  | Wip         = 2'h1, | 
|  | Valid       = 2'h2, | 
|  | Undef       = 2'h3 | 
|  | } rd_buf_attr_e; | 
|  |  | 
|  | typedef struct packed { | 
|  | logic [DataWidth-1:0] data; | 
|  | logic [BankAddrW-1:0] addr; // all address bits preserved to pick return portion | 
|  | logic part; | 
|  | rd_buf_attr_e attr; | 
|  | } rd_buf_t; | 
|  |  | 
|  | typedef struct packed { | 
|  | logic [NumBuf-1:0] buf_sel; | 
|  | logic [WordSelW-1:0] word_sel; | 
|  | } rsp_fifo_entry_t; | 
|  |  | 
|  | parameter int RspOrderFifoWidth = $bits(rsp_fifo_entry_t); | 
|  |  | 
|  | typedef struct packed { | 
|  | logic [BankAddrW-1:0] addr; | 
|  | logic descramble; | 
|  | } rd_attr_t; | 
|  |  | 
|  | // Flash Operations Supported | 
|  | typedef enum logic [2:0] { | 
|  | PhyRead      = 3'h0, | 
|  | PhyProg      = 3'h1, | 
|  | PhyPgErase   = 3'h2, | 
|  | PhyBkErase   = 3'h3, | 
|  | PhyOps       = 3'h4 | 
|  | } flash_phy_op_e; | 
|  |  | 
|  | // Flash Operations Selected | 
|  | typedef enum logic [1:0] { | 
|  | None         = 2'h0, | 
|  | Host         = 2'h1, | 
|  | Ctrl         = 2'h2 | 
|  | } flash_phy_op_sel_e; | 
|  |  | 
|  | typedef enum logic { | 
|  | ScrambleOp   = 1'b0, | 
|  | DeScrambleOp = 1'b1 | 
|  | } cipher_ops_e; | 
|  |  | 
|  | endpackage // flash_phy_pkg |