1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * MPC5121 Prototypes and definitions 4*4882a593Smuzhiyun */ 5*4882a593Smuzhiyun 6*4882a593Smuzhiyun #ifndef __ASM_POWERPC_MPC5121_H__ 7*4882a593Smuzhiyun #define __ASM_POWERPC_MPC5121_H__ 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun /* MPC512x Reset module registers */ 10*4882a593Smuzhiyun struct mpc512x_reset_module { 11*4882a593Smuzhiyun u32 rcwlr; /* Reset Configuration Word Low Register */ 12*4882a593Smuzhiyun u32 rcwhr; /* Reset Configuration Word High Register */ 13*4882a593Smuzhiyun u32 reserved1; 14*4882a593Smuzhiyun u32 reserved2; 15*4882a593Smuzhiyun u32 rsr; /* Reset Status Register */ 16*4882a593Smuzhiyun u32 rmr; /* Reset Mode Register */ 17*4882a593Smuzhiyun u32 rpr; /* Reset Protection Register */ 18*4882a593Smuzhiyun u32 rcr; /* Reset Control Register */ 19*4882a593Smuzhiyun u32 rcer; /* Reset Control Enable Register */ 20*4882a593Smuzhiyun }; 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun /* 23*4882a593Smuzhiyun * Clock Control Module 24*4882a593Smuzhiyun */ 25*4882a593Smuzhiyun struct mpc512x_ccm { 26*4882a593Smuzhiyun u32 spmr; /* System PLL Mode Register */ 27*4882a593Smuzhiyun u32 sccr1; /* System Clock Control Register 1 */ 28*4882a593Smuzhiyun u32 sccr2; /* System Clock Control Register 2 */ 29*4882a593Smuzhiyun u32 scfr1; /* System Clock Frequency Register 1 */ 30*4882a593Smuzhiyun u32 scfr2; /* System Clock Frequency Register 2 */ 31*4882a593Smuzhiyun u32 scfr2s; /* System Clock Frequency Shadow Register 2 */ 32*4882a593Smuzhiyun u32 bcr; /* Bread Crumb Register */ 33*4882a593Smuzhiyun u32 psc_ccr[12]; /* PSC Clock Control Registers */ 34*4882a593Smuzhiyun u32 spccr; /* SPDIF Clock Control Register */ 35*4882a593Smuzhiyun u32 cccr; /* CFM Clock Control Register */ 36*4882a593Smuzhiyun u32 dccr; /* DIU Clock Control Register */ 37*4882a593Smuzhiyun u32 mscan_ccr[4]; /* MSCAN Clock Control Registers */ 38*4882a593Smuzhiyun u32 out_ccr[4]; /* OUT CLK Configure Registers */ 39*4882a593Smuzhiyun u32 rsv0[2]; /* Reserved */ 40*4882a593Smuzhiyun u32 scfr3; /* System Clock Frequency Register 3 */ 41*4882a593Smuzhiyun u32 rsv1[3]; /* Reserved */ 42*4882a593Smuzhiyun u32 spll_lock_cnt; /* System PLL Lock Counter */ 43*4882a593Smuzhiyun u8 res[0x6c]; /* Reserved */ 44*4882a593Smuzhiyun }; 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun /* 47*4882a593Smuzhiyun * LPC Module 48*4882a593Smuzhiyun */ 49*4882a593Smuzhiyun struct mpc512x_lpc { 50*4882a593Smuzhiyun u32 cs_cfg[8]; /* CS config */ 51*4882a593Smuzhiyun u32 cs_ctrl; /* CS Control Register */ 52*4882a593Smuzhiyun u32 cs_status; /* CS Status Register */ 53*4882a593Smuzhiyun u32 burst_ctrl; /* CS Burst Control Register */ 54*4882a593Smuzhiyun u32 deadcycle_ctrl; /* CS Deadcycle Control Register */ 55*4882a593Smuzhiyun u32 holdcycle_ctrl; /* CS Holdcycle Control Register */ 56*4882a593Smuzhiyun u32 alt; /* Address Latch Timing Register */ 57*4882a593Smuzhiyun }; 58*4882a593Smuzhiyun 59*4882a593Smuzhiyun int mpc512x_cs_config(unsigned int cs, u32 val); 60*4882a593Smuzhiyun 61*4882a593Smuzhiyun /* 62*4882a593Smuzhiyun * SCLPC Module (LPB FIFO) 63*4882a593Smuzhiyun */ 64*4882a593Smuzhiyun struct mpc512x_lpbfifo { 65*4882a593Smuzhiyun u32 pkt_size; /* SCLPC Packet Size Register */ 66*4882a593Smuzhiyun u32 start_addr; /* SCLPC Start Address Register */ 67*4882a593Smuzhiyun u32 ctrl; /* SCLPC Control Register */ 68*4882a593Smuzhiyun u32 enable; /* SCLPC Enable Register */ 69*4882a593Smuzhiyun u32 reserved1; 70*4882a593Smuzhiyun u32 status; /* SCLPC Status Register */ 71*4882a593Smuzhiyun u32 bytes_done; /* SCLPC Bytes Done Register */ 72*4882a593Smuzhiyun u32 emb_sc; /* EMB Share Counter Register */ 73*4882a593Smuzhiyun u32 emb_pc; /* EMB Pause Control Register */ 74*4882a593Smuzhiyun u32 reserved2[7]; 75*4882a593Smuzhiyun u32 data_word; /* LPC RX/TX FIFO Data Word Register */ 76*4882a593Smuzhiyun u32 fifo_status; /* LPC RX/TX FIFO Status Register */ 77*4882a593Smuzhiyun u32 fifo_ctrl; /* LPC RX/TX FIFO Control Register */ 78*4882a593Smuzhiyun u32 fifo_alarm; /* LPC RX/TX FIFO Alarm Register */ 79*4882a593Smuzhiyun }; 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun #define MPC512X_SCLPC_START (1 << 31) 82*4882a593Smuzhiyun #define MPC512X_SCLPC_CS(x) (((x) & 0x7) << 24) 83*4882a593Smuzhiyun #define MPC512X_SCLPC_FLUSH (1 << 17) 84*4882a593Smuzhiyun #define MPC512X_SCLPC_READ (1 << 16) 85*4882a593Smuzhiyun #define MPC512X_SCLPC_DAI (1 << 8) 86*4882a593Smuzhiyun #define MPC512X_SCLPC_BPT(x) ((x) & 0x3f) 87*4882a593Smuzhiyun #define MPC512X_SCLPC_RESET (1 << 24) 88*4882a593Smuzhiyun #define MPC512X_SCLPC_FIFO_RESET (1 << 16) 89*4882a593Smuzhiyun #define MPC512X_SCLPC_ABORT_INT_ENABLE (1 << 9) 90*4882a593Smuzhiyun #define MPC512X_SCLPC_NORM_INT_ENABLE (1 << 8) 91*4882a593Smuzhiyun #define MPC512X_SCLPC_ENABLE (1 << 0) 92*4882a593Smuzhiyun #define MPC512X_SCLPC_SUCCESS (1 << 24) 93*4882a593Smuzhiyun #define MPC512X_SCLPC_FIFO_CTRL(x) (((x) & 0x7) << 24) 94*4882a593Smuzhiyun #define MPC512X_SCLPC_FIFO_ALARM(x) ((x) & 0x3ff) 95*4882a593Smuzhiyun 96*4882a593Smuzhiyun enum lpb_dev_portsize { 97*4882a593Smuzhiyun LPB_DEV_PORTSIZE_UNDEFINED = 0, 98*4882a593Smuzhiyun LPB_DEV_PORTSIZE_1_BYTE = 1, 99*4882a593Smuzhiyun LPB_DEV_PORTSIZE_2_BYTES = 2, 100*4882a593Smuzhiyun LPB_DEV_PORTSIZE_4_BYTES = 4, 101*4882a593Smuzhiyun LPB_DEV_PORTSIZE_8_BYTES = 8 102*4882a593Smuzhiyun }; 103*4882a593Smuzhiyun 104*4882a593Smuzhiyun enum mpc512x_lpbfifo_req_dir { 105*4882a593Smuzhiyun MPC512X_LPBFIFO_REQ_DIR_READ, 106*4882a593Smuzhiyun MPC512X_LPBFIFO_REQ_DIR_WRITE 107*4882a593Smuzhiyun }; 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun struct mpc512x_lpbfifo_request { 110*4882a593Smuzhiyun phys_addr_t dev_phys_addr; /* physical address of some device on LPB */ 111*4882a593Smuzhiyun void *ram_virt_addr; /* virtual address of some region in RAM */ 112*4882a593Smuzhiyun u32 size; 113*4882a593Smuzhiyun enum lpb_dev_portsize portsize; 114*4882a593Smuzhiyun enum mpc512x_lpbfifo_req_dir dir; 115*4882a593Smuzhiyun void (*callback)(struct mpc512x_lpbfifo_request *); 116*4882a593Smuzhiyun }; 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun int mpc512x_lpbfifo_submit(struct mpc512x_lpbfifo_request *req); 119*4882a593Smuzhiyun 120*4882a593Smuzhiyun #endif /* __ASM_POWERPC_MPC5121_H__ */ 121