0001
0002
0003
0004
0005
0006 #ifndef __ASM_POWERPC_MPC5121_H__
0007 #define __ASM_POWERPC_MPC5121_H__
0008
0009
0010 struct mpc512x_reset_module {
0011 u32 rcwlr;
0012 u32 rcwhr;
0013 u32 reserved1;
0014 u32 reserved2;
0015 u32 rsr;
0016 u32 rmr;
0017 u32 rpr;
0018 u32 rcr;
0019 u32 rcer;
0020 };
0021
0022
0023
0024
0025 struct mpc512x_ccm {
0026 u32 spmr;
0027 u32 sccr1;
0028 u32 sccr2;
0029 u32 scfr1;
0030 u32 scfr2;
0031 u32 scfr2s;
0032 u32 bcr;
0033 u32 psc_ccr[12];
0034 u32 spccr;
0035 u32 cccr;
0036 u32 dccr;
0037 u32 mscan_ccr[4];
0038 u32 out_ccr[4];
0039 u32 rsv0[2];
0040 u32 scfr3;
0041 u32 rsv1[3];
0042 u32 spll_lock_cnt;
0043 u8 res[0x6c];
0044 };
0045
0046
0047
0048
0049 struct mpc512x_lpc {
0050 u32 cs_cfg[8];
0051 u32 cs_ctrl;
0052 u32 cs_status;
0053 u32 burst_ctrl;
0054 u32 deadcycle_ctrl;
0055 u32 holdcycle_ctrl;
0056 u32 alt;
0057 };
0058
0059 int mpc512x_cs_config(unsigned int cs, u32 val);
0060
0061
0062
0063
0064 struct mpc512x_lpbfifo {
0065 u32 pkt_size;
0066 u32 start_addr;
0067 u32 ctrl;
0068 u32 enable;
0069 u32 reserved1;
0070 u32 status;
0071 u32 bytes_done;
0072 u32 emb_sc;
0073 u32 emb_pc;
0074 u32 reserved2[7];
0075 u32 data_word;
0076 u32 fifo_status;
0077 u32 fifo_ctrl;
0078 u32 fifo_alarm;
0079 };
0080
0081 #define MPC512X_SCLPC_START (1 << 31)
0082 #define MPC512X_SCLPC_CS(x) (((x) & 0x7) << 24)
0083 #define MPC512X_SCLPC_FLUSH (1 << 17)
0084 #define MPC512X_SCLPC_READ (1 << 16)
0085 #define MPC512X_SCLPC_DAI (1 << 8)
0086 #define MPC512X_SCLPC_BPT(x) ((x) & 0x3f)
0087 #define MPC512X_SCLPC_RESET (1 << 24)
0088 #define MPC512X_SCLPC_FIFO_RESET (1 << 16)
0089 #define MPC512X_SCLPC_ABORT_INT_ENABLE (1 << 9)
0090 #define MPC512X_SCLPC_NORM_INT_ENABLE (1 << 8)
0091 #define MPC512X_SCLPC_ENABLE (1 << 0)
0092 #define MPC512X_SCLPC_SUCCESS (1 << 24)
0093 #define MPC512X_SCLPC_FIFO_CTRL(x) (((x) & 0x7) << 24)
0094 #define MPC512X_SCLPC_FIFO_ALARM(x) ((x) & 0x3ff)
0095
0096 enum lpb_dev_portsize {
0097 LPB_DEV_PORTSIZE_UNDEFINED = 0,
0098 LPB_DEV_PORTSIZE_1_BYTE = 1,
0099 LPB_DEV_PORTSIZE_2_BYTES = 2,
0100 LPB_DEV_PORTSIZE_4_BYTES = 4,
0101 LPB_DEV_PORTSIZE_8_BYTES = 8
0102 };
0103
0104 enum mpc512x_lpbfifo_req_dir {
0105 MPC512X_LPBFIFO_REQ_DIR_READ,
0106 MPC512X_LPBFIFO_REQ_DIR_WRITE
0107 };
0108
0109 struct mpc512x_lpbfifo_request {
0110 phys_addr_t dev_phys_addr;
0111 void *ram_virt_addr;
0112 u32 size;
0113 enum lpb_dev_portsize portsize;
0114 enum mpc512x_lpbfifo_req_dir dir;
0115 void (*callback)(struct mpc512x_lpbfifo_request *);
0116 };
0117
0118 int mpc512x_lpbfifo_submit(struct mpc512x_lpbfifo_request *req);
0119
0120 #endif