xref: /OK3568_Linux_fs/kernel/arch/powerpc/include/asm/mpc5121.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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