xref: /rk3399_rockchip-uboot/arch/arm/mach-rmobile/include/mach/ehci-rmobile.h (revision c98b171e1098f94b2ff7720c45a25a602882f876)
1*7a7d246dSNobuhiro Iwamatsu /*
2*7a7d246dSNobuhiro Iwamatsu  *  Copyright (C) 2013,2014 Renesas Electronics Corporation
3*7a7d246dSNobuhiro Iwamatsu  *  Copyright (C) 2014 Nobuhiro Iwamatsu <nobuhiro.iwamatsu.yj@renesas.com>
4*7a7d246dSNobuhiro Iwamatsu  *
5*7a7d246dSNobuhiro Iwamatsu  *  SPDX-License-Identifier:     GPL-2.0
6*7a7d246dSNobuhiro Iwamatsu  */
7*7a7d246dSNobuhiro Iwamatsu 
8*7a7d246dSNobuhiro Iwamatsu #ifndef __EHCI_RMOBILE_H__
9*7a7d246dSNobuhiro Iwamatsu #define __EHCI_RMOBILE_H__
10*7a7d246dSNobuhiro Iwamatsu 
11*7a7d246dSNobuhiro Iwamatsu /* Register offset */
12*7a7d246dSNobuhiro Iwamatsu #define OHCI_OFFSET	0x00
13*7a7d246dSNobuhiro Iwamatsu #define OHCI_SIZE	0x1000
14*7a7d246dSNobuhiro Iwamatsu #define EHCI_OFFSET	0x1000
15*7a7d246dSNobuhiro Iwamatsu #define EHCI_SIZE	0x1000
16*7a7d246dSNobuhiro Iwamatsu 
17*7a7d246dSNobuhiro Iwamatsu #define EHCI_USBCMD	(EHCI_OFFSET + 0x0020)
18*7a7d246dSNobuhiro Iwamatsu 
19*7a7d246dSNobuhiro Iwamatsu /* USBCTR */
20*7a7d246dSNobuhiro Iwamatsu #define DIRPD		(1 << 8)
21*7a7d246dSNobuhiro Iwamatsu #define PLL_RST		(1 << 2)
22*7a7d246dSNobuhiro Iwamatsu #define PCICLK_MASK	(1 << 1)
23*7a7d246dSNobuhiro Iwamatsu #define USBH_RST	(1 << 0)
24*7a7d246dSNobuhiro Iwamatsu 
25*7a7d246dSNobuhiro Iwamatsu /* CMND_STS */
26*7a7d246dSNobuhiro Iwamatsu #define SERREN		(1 << 8)
27*7a7d246dSNobuhiro Iwamatsu #define PERREN		(1 << 6)
28*7a7d246dSNobuhiro Iwamatsu #define MASTEREN	(1 << 2)
29*7a7d246dSNobuhiro Iwamatsu #define MEMEN		(1 << 1)
30*7a7d246dSNobuhiro Iwamatsu 
31*7a7d246dSNobuhiro Iwamatsu /* PCIAHB_WIN1_CTR and PCIAHB_WIN2_CTR */
32*7a7d246dSNobuhiro Iwamatsu #define PCIAHB_WIN_PREFETCH	((1 << 1)|(1 << 0))
33*7a7d246dSNobuhiro Iwamatsu 
34*7a7d246dSNobuhiro Iwamatsu /* AHBPCI_WIN1_CTR */
35*7a7d246dSNobuhiro Iwamatsu #define PCIWIN1_PCICMD		((1 << 3)|(1 << 1))
36*7a7d246dSNobuhiro Iwamatsu #define AHB_CFG_AHBPCI		0x40000000
37*7a7d246dSNobuhiro Iwamatsu #define AHB_CFG_HOST		0x80000000
38*7a7d246dSNobuhiro Iwamatsu 
39*7a7d246dSNobuhiro Iwamatsu /* AHBPCI_WIN2_CTR */
40*7a7d246dSNobuhiro Iwamatsu #define PCIWIN2_PCICMD		((1 << 2)|(1 << 1))
41*7a7d246dSNobuhiro Iwamatsu 
42*7a7d246dSNobuhiro Iwamatsu /* PCI_INT_ENABLE */
43*7a7d246dSNobuhiro Iwamatsu #define USBH_PMEEN		(1 << 19)
44*7a7d246dSNobuhiro Iwamatsu #define USBH_INTBEN		(1 << 17)
45*7a7d246dSNobuhiro Iwamatsu #define USBH_INTAEN		(1 << 16)
46*7a7d246dSNobuhiro Iwamatsu 
47*7a7d246dSNobuhiro Iwamatsu /* AHB_BUS_CTR */
48*7a7d246dSNobuhiro Iwamatsu #define SMODE_READY_CTR		(1 << 17)
49*7a7d246dSNobuhiro Iwamatsu #define SMODE_READ_BURST	(1 << 16)
50*7a7d246dSNobuhiro Iwamatsu #define MMODE_HBUSREQ		(1 << 7)
51*7a7d246dSNobuhiro Iwamatsu #define MMODE_BOUNDARY		((1 << 6)|(1 << 5))
52*7a7d246dSNobuhiro Iwamatsu #define MMODE_BURST_WIDTH	((1 << 4)|(1 << 3))
53*7a7d246dSNobuhiro Iwamatsu #define MMODE_SINGLE_MODE	((1 << 4)|(1 << 3))
54*7a7d246dSNobuhiro Iwamatsu #define MMODE_WR_INCR		(1 << 2)
55*7a7d246dSNobuhiro Iwamatsu #define MMODE_BYTE_BURST	(1 << 1)
56*7a7d246dSNobuhiro Iwamatsu #define MMODE_HTRANS		(1 << 0)
57*7a7d246dSNobuhiro Iwamatsu 
58*7a7d246dSNobuhiro Iwamatsu /* PCI_ARBITER_CTR */
59*7a7d246dSNobuhiro Iwamatsu #define PCIBUS_PARK_TIMER       0x00FF0000
60*7a7d246dSNobuhiro Iwamatsu #define PCIBUS_PARK_TIMER_SET   0x00070000
61*7a7d246dSNobuhiro Iwamatsu #define PCIBP_MODE		(1 << 12)
62*7a7d246dSNobuhiro Iwamatsu #define PCIREQ7                 (1 << 7)
63*7a7d246dSNobuhiro Iwamatsu #define PCIREQ6                 (1 << 6)
64*7a7d246dSNobuhiro Iwamatsu #define PCIREQ5                 (1 << 5)
65*7a7d246dSNobuhiro Iwamatsu #define PCIREQ4                 (1 << 4)
66*7a7d246dSNobuhiro Iwamatsu #define PCIREQ3                 (1 << 3)
67*7a7d246dSNobuhiro Iwamatsu #define PCIREQ2                 (1 << 2)
68*7a7d246dSNobuhiro Iwamatsu #define PCIREQ1                 (1 << 1)
69*7a7d246dSNobuhiro Iwamatsu #define PCIREQ0                 (1 << 0)
70*7a7d246dSNobuhiro Iwamatsu 
71*7a7d246dSNobuhiro Iwamatsu #define SMSTPCR7        0xE615014C
72*7a7d246dSNobuhiro Iwamatsu #define SMSTPCR703      (1 << 3)
73*7a7d246dSNobuhiro Iwamatsu 
74*7a7d246dSNobuhiro Iwamatsu /* Init AHB master and slave functions of the host logic */
75*7a7d246dSNobuhiro Iwamatsu #define AHB_BUS_CTR_INIT \
76*7a7d246dSNobuhiro Iwamatsu 	(SMODE_READY_CTR | MMODE_HBUSREQ | MMODE_WR_INCR | \
77*7a7d246dSNobuhiro Iwamatsu 	 MMODE_BYTE_BURST | MMODE_HTRANS)
78*7a7d246dSNobuhiro Iwamatsu 
79*7a7d246dSNobuhiro Iwamatsu #define USBCTR_WIN_SIZE_1GB	0x800
80*7a7d246dSNobuhiro Iwamatsu 
81*7a7d246dSNobuhiro Iwamatsu /* PCI Configuration Registers */
82*7a7d246dSNobuhiro Iwamatsu #define PCI_CONF_OHCI_OFFSET	0x10000
83*7a7d246dSNobuhiro Iwamatsu #define PCI_CONF_EHCI_OFFSET	0x10100
84*7a7d246dSNobuhiro Iwamatsu struct ahb_pciconf {
85*7a7d246dSNobuhiro Iwamatsu 	u32 vid_did;
86*7a7d246dSNobuhiro Iwamatsu 	u32 cmnd_sts;
87*7a7d246dSNobuhiro Iwamatsu 	u32 rev;
88*7a7d246dSNobuhiro Iwamatsu 	u32 cache_line;
89*7a7d246dSNobuhiro Iwamatsu 	u32 basead;
90*7a7d246dSNobuhiro Iwamatsu };
91*7a7d246dSNobuhiro Iwamatsu 
92*7a7d246dSNobuhiro Iwamatsu /* PCI Configuration Registers for AHB-PCI Bridge Registers */
93*7a7d246dSNobuhiro Iwamatsu #define PCI_CONF_AHBPCI_OFFSET	0x10000
94*7a7d246dSNobuhiro Iwamatsu struct ahbconf_pci_bridge {
95*7a7d246dSNobuhiro Iwamatsu 	u32 vid_did;		/* 0x00 */
96*7a7d246dSNobuhiro Iwamatsu 	u32 cmnd_sts;
97*7a7d246dSNobuhiro Iwamatsu 	u32 revid_cc;
98*7a7d246dSNobuhiro Iwamatsu 	u32 cls_lt_ht_bist;
99*7a7d246dSNobuhiro Iwamatsu 	u32 basead;		/* 0x10 */
100*7a7d246dSNobuhiro Iwamatsu 	u32 win1_basead;
101*7a7d246dSNobuhiro Iwamatsu 	u32 win2_basead;
102*7a7d246dSNobuhiro Iwamatsu 	u32 dummy0[5];
103*7a7d246dSNobuhiro Iwamatsu 	u32 ssvdi_ssid;		/* 0x2C */
104*7a7d246dSNobuhiro Iwamatsu 	u32 dummy1[4];
105*7a7d246dSNobuhiro Iwamatsu 	u32 intr_line_pin;
106*7a7d246dSNobuhiro Iwamatsu };
107*7a7d246dSNobuhiro Iwamatsu 
108*7a7d246dSNobuhiro Iwamatsu /* AHB-PCI Bridge PCI Communication Registers */
109*7a7d246dSNobuhiro Iwamatsu #define AHBPCI_OFFSET	0x10800
110*7a7d246dSNobuhiro Iwamatsu struct ahbcom_pci_bridge {
111*7a7d246dSNobuhiro Iwamatsu 	u32 pciahb_win1_ctr;	/* 0x00 */
112*7a7d246dSNobuhiro Iwamatsu 	u32 pciahb_win2_ctr;
113*7a7d246dSNobuhiro Iwamatsu 	u32 pciahb_dct_ctr;
114*7a7d246dSNobuhiro Iwamatsu 	u32 dummy0;
115*7a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_win1_ctr;	/* 0x10 */
116*7a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_win2_ctr;
117*7a7d246dSNobuhiro Iwamatsu 	u32 dummy1;
118*7a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_dct_ctr;
119*7a7d246dSNobuhiro Iwamatsu 	u32 pci_int_enable;	/* 0x20 */
120*7a7d246dSNobuhiro Iwamatsu 	u32 pci_int_status;
121*7a7d246dSNobuhiro Iwamatsu 	u32 dummy2[2];
122*7a7d246dSNobuhiro Iwamatsu 	u32 ahb_bus_ctr;	/* 0x30 */
123*7a7d246dSNobuhiro Iwamatsu 	u32 usbctr;
124*7a7d246dSNobuhiro Iwamatsu 	u32 dummy3[2];
125*7a7d246dSNobuhiro Iwamatsu 	u32 pci_arbiter_ctr;	/* 0x40 */
126*7a7d246dSNobuhiro Iwamatsu 	u32 dummy4;
127*7a7d246dSNobuhiro Iwamatsu 	u32 pci_unit_rev;	/* 0x48 */
128*7a7d246dSNobuhiro Iwamatsu };
129*7a7d246dSNobuhiro Iwamatsu 
130*7a7d246dSNobuhiro Iwamatsu struct rmobile_ehci_reg {
131*7a7d246dSNobuhiro Iwamatsu 	u32 hciversion;		/* hciversion/caplength */
132*7a7d246dSNobuhiro Iwamatsu 	u32 hcsparams;		/* hcsparams */
133*7a7d246dSNobuhiro Iwamatsu 	u32 hccparams;		/* hccparams */
134*7a7d246dSNobuhiro Iwamatsu 	u32 hcsp_portroute;	/* hcsp_portroute */
135*7a7d246dSNobuhiro Iwamatsu 	u32 usbcmd;		/* usbcmd */
136*7a7d246dSNobuhiro Iwamatsu 	u32 usbsts;		/* usbsts */
137*7a7d246dSNobuhiro Iwamatsu 	u32 usbintr;		/* usbintr */
138*7a7d246dSNobuhiro Iwamatsu 	u32 frindex;		/* frindex */
139*7a7d246dSNobuhiro Iwamatsu 	u32 ctrldssegment;	/* ctrldssegment */
140*7a7d246dSNobuhiro Iwamatsu 	u32 periodiclistbase;	/* periodiclistbase */
141*7a7d246dSNobuhiro Iwamatsu 	u32 asynclistaddr;	/* asynclistaddr */
142*7a7d246dSNobuhiro Iwamatsu 	u32 dummy[9];
143*7a7d246dSNobuhiro Iwamatsu 	u32 configflag;		/* configflag */
144*7a7d246dSNobuhiro Iwamatsu 	u32 portsc;		/* portsc */
145*7a7d246dSNobuhiro Iwamatsu };
146*7a7d246dSNobuhiro Iwamatsu 
147*7a7d246dSNobuhiro Iwamatsu #endif /* __EHCI_RMOBILE_H__ */
148