xref: /openbmc/u-boot/arch/arm/mach-rmobile/include/mach/ehci-rmobile.h (revision f739fcd831240dda10a92f4212f1854f8481aeee)
1*f739fcd8STom Rini /* SPDX-License-Identifier: GPL-2.0 */
27a7d246dSNobuhiro Iwamatsu /*
37a7d246dSNobuhiro Iwamatsu  *  Copyright (C) 2013,2014 Renesas Electronics Corporation
47a7d246dSNobuhiro Iwamatsu  *  Copyright (C) 2014 Nobuhiro Iwamatsu <nobuhiro.iwamatsu.yj@renesas.com>
57a7d246dSNobuhiro Iwamatsu  */
67a7d246dSNobuhiro Iwamatsu 
77a7d246dSNobuhiro Iwamatsu #ifndef __EHCI_RMOBILE_H__
87a7d246dSNobuhiro Iwamatsu #define __EHCI_RMOBILE_H__
97a7d246dSNobuhiro Iwamatsu 
107a7d246dSNobuhiro Iwamatsu /* Register offset */
117a7d246dSNobuhiro Iwamatsu #define OHCI_OFFSET	0x00
127a7d246dSNobuhiro Iwamatsu #define OHCI_SIZE	0x1000
137a7d246dSNobuhiro Iwamatsu #define EHCI_OFFSET	0x1000
147a7d246dSNobuhiro Iwamatsu #define EHCI_SIZE	0x1000
157a7d246dSNobuhiro Iwamatsu 
167a7d246dSNobuhiro Iwamatsu #define EHCI_USBCMD	(EHCI_OFFSET + 0x0020)
177a7d246dSNobuhiro Iwamatsu 
187a7d246dSNobuhiro Iwamatsu /* USBCTR */
197a7d246dSNobuhiro Iwamatsu #define DIRPD		(1 << 8)
207a7d246dSNobuhiro Iwamatsu #define PLL_RST		(1 << 2)
217a7d246dSNobuhiro Iwamatsu #define PCICLK_MASK	(1 << 1)
227a7d246dSNobuhiro Iwamatsu #define USBH_RST	(1 << 0)
237a7d246dSNobuhiro Iwamatsu 
247a7d246dSNobuhiro Iwamatsu /* CMND_STS */
257a7d246dSNobuhiro Iwamatsu #define SERREN		(1 << 8)
267a7d246dSNobuhiro Iwamatsu #define PERREN		(1 << 6)
277a7d246dSNobuhiro Iwamatsu #define MASTEREN	(1 << 2)
287a7d246dSNobuhiro Iwamatsu #define MEMEN		(1 << 1)
297a7d246dSNobuhiro Iwamatsu 
307a7d246dSNobuhiro Iwamatsu /* PCIAHB_WIN1_CTR and PCIAHB_WIN2_CTR */
317a7d246dSNobuhiro Iwamatsu #define PCIAHB_WIN_PREFETCH	((1 << 1)|(1 << 0))
327a7d246dSNobuhiro Iwamatsu 
337a7d246dSNobuhiro Iwamatsu /* AHBPCI_WIN1_CTR */
347a7d246dSNobuhiro Iwamatsu #define PCIWIN1_PCICMD		((1 << 3)|(1 << 1))
357a7d246dSNobuhiro Iwamatsu #define AHB_CFG_AHBPCI		0x40000000
367a7d246dSNobuhiro Iwamatsu #define AHB_CFG_HOST		0x80000000
377a7d246dSNobuhiro Iwamatsu 
387a7d246dSNobuhiro Iwamatsu /* AHBPCI_WIN2_CTR */
397a7d246dSNobuhiro Iwamatsu #define PCIWIN2_PCICMD		((1 << 2)|(1 << 1))
407a7d246dSNobuhiro Iwamatsu 
417a7d246dSNobuhiro Iwamatsu /* PCI_INT_ENABLE */
427a7d246dSNobuhiro Iwamatsu #define USBH_PMEEN		(1 << 19)
437a7d246dSNobuhiro Iwamatsu #define USBH_INTBEN		(1 << 17)
447a7d246dSNobuhiro Iwamatsu #define USBH_INTAEN		(1 << 16)
457a7d246dSNobuhiro Iwamatsu 
467a7d246dSNobuhiro Iwamatsu /* AHB_BUS_CTR */
477a7d246dSNobuhiro Iwamatsu #define SMODE_READY_CTR		(1 << 17)
487a7d246dSNobuhiro Iwamatsu #define SMODE_READ_BURST	(1 << 16)
497a7d246dSNobuhiro Iwamatsu #define MMODE_HBUSREQ		(1 << 7)
507a7d246dSNobuhiro Iwamatsu #define MMODE_BOUNDARY		((1 << 6)|(1 << 5))
517a7d246dSNobuhiro Iwamatsu #define MMODE_BURST_WIDTH	((1 << 4)|(1 << 3))
527a7d246dSNobuhiro Iwamatsu #define MMODE_SINGLE_MODE	((1 << 4)|(1 << 3))
537a7d246dSNobuhiro Iwamatsu #define MMODE_WR_INCR		(1 << 2)
547a7d246dSNobuhiro Iwamatsu #define MMODE_BYTE_BURST	(1 << 1)
557a7d246dSNobuhiro Iwamatsu #define MMODE_HTRANS		(1 << 0)
567a7d246dSNobuhiro Iwamatsu 
577a7d246dSNobuhiro Iwamatsu /* PCI_ARBITER_CTR */
587a7d246dSNobuhiro Iwamatsu #define PCIBUS_PARK_TIMER       0x00FF0000
597a7d246dSNobuhiro Iwamatsu #define PCIBUS_PARK_TIMER_SET   0x00070000
607a7d246dSNobuhiro Iwamatsu #define PCIBP_MODE		(1 << 12)
617a7d246dSNobuhiro Iwamatsu #define PCIREQ7                 (1 << 7)
627a7d246dSNobuhiro Iwamatsu #define PCIREQ6                 (1 << 6)
637a7d246dSNobuhiro Iwamatsu #define PCIREQ5                 (1 << 5)
647a7d246dSNobuhiro Iwamatsu #define PCIREQ4                 (1 << 4)
657a7d246dSNobuhiro Iwamatsu #define PCIREQ3                 (1 << 3)
667a7d246dSNobuhiro Iwamatsu #define PCIREQ2                 (1 << 2)
677a7d246dSNobuhiro Iwamatsu #define PCIREQ1                 (1 << 1)
687a7d246dSNobuhiro Iwamatsu #define PCIREQ0                 (1 << 0)
697a7d246dSNobuhiro Iwamatsu 
707a7d246dSNobuhiro Iwamatsu #define SMSTPCR7        0xE615014C
717a7d246dSNobuhiro Iwamatsu #define SMSTPCR703      (1 << 3)
727a7d246dSNobuhiro Iwamatsu 
737a7d246dSNobuhiro Iwamatsu /* Init AHB master and slave functions of the host logic */
747a7d246dSNobuhiro Iwamatsu #define AHB_BUS_CTR_INIT \
757a7d246dSNobuhiro Iwamatsu 	(SMODE_READY_CTR | MMODE_HBUSREQ | MMODE_WR_INCR | \
767a7d246dSNobuhiro Iwamatsu 	 MMODE_BYTE_BURST | MMODE_HTRANS)
777a7d246dSNobuhiro Iwamatsu 
787a7d246dSNobuhiro Iwamatsu #define USBCTR_WIN_SIZE_1GB	0x800
797a7d246dSNobuhiro Iwamatsu 
807a7d246dSNobuhiro Iwamatsu /* PCI Configuration Registers */
817a7d246dSNobuhiro Iwamatsu #define PCI_CONF_OHCI_OFFSET	0x10000
827a7d246dSNobuhiro Iwamatsu #define PCI_CONF_EHCI_OFFSET	0x10100
837a7d246dSNobuhiro Iwamatsu struct ahb_pciconf {
847a7d246dSNobuhiro Iwamatsu 	u32 vid_did;
857a7d246dSNobuhiro Iwamatsu 	u32 cmnd_sts;
867a7d246dSNobuhiro Iwamatsu 	u32 rev;
877a7d246dSNobuhiro Iwamatsu 	u32 cache_line;
887a7d246dSNobuhiro Iwamatsu 	u32 basead;
897a7d246dSNobuhiro Iwamatsu };
907a7d246dSNobuhiro Iwamatsu 
917a7d246dSNobuhiro Iwamatsu /* PCI Configuration Registers for AHB-PCI Bridge Registers */
927a7d246dSNobuhiro Iwamatsu #define PCI_CONF_AHBPCI_OFFSET	0x10000
937a7d246dSNobuhiro Iwamatsu struct ahbconf_pci_bridge {
947a7d246dSNobuhiro Iwamatsu 	u32 vid_did;		/* 0x00 */
957a7d246dSNobuhiro Iwamatsu 	u32 cmnd_sts;
967a7d246dSNobuhiro Iwamatsu 	u32 revid_cc;
977a7d246dSNobuhiro Iwamatsu 	u32 cls_lt_ht_bist;
987a7d246dSNobuhiro Iwamatsu 	u32 basead;		/* 0x10 */
997a7d246dSNobuhiro Iwamatsu 	u32 win1_basead;
1007a7d246dSNobuhiro Iwamatsu 	u32 win2_basead;
1017a7d246dSNobuhiro Iwamatsu 	u32 dummy0[5];
1027a7d246dSNobuhiro Iwamatsu 	u32 ssvdi_ssid;		/* 0x2C */
1037a7d246dSNobuhiro Iwamatsu 	u32 dummy1[4];
1047a7d246dSNobuhiro Iwamatsu 	u32 intr_line_pin;
1057a7d246dSNobuhiro Iwamatsu };
1067a7d246dSNobuhiro Iwamatsu 
1077a7d246dSNobuhiro Iwamatsu /* AHB-PCI Bridge PCI Communication Registers */
1087a7d246dSNobuhiro Iwamatsu #define AHBPCI_OFFSET	0x10800
1097a7d246dSNobuhiro Iwamatsu struct ahbcom_pci_bridge {
1107a7d246dSNobuhiro Iwamatsu 	u32 pciahb_win1_ctr;	/* 0x00 */
1117a7d246dSNobuhiro Iwamatsu 	u32 pciahb_win2_ctr;
1127a7d246dSNobuhiro Iwamatsu 	u32 pciahb_dct_ctr;
1137a7d246dSNobuhiro Iwamatsu 	u32 dummy0;
1147a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_win1_ctr;	/* 0x10 */
1157a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_win2_ctr;
1167a7d246dSNobuhiro Iwamatsu 	u32 dummy1;
1177a7d246dSNobuhiro Iwamatsu 	u32 ahbpci_dct_ctr;
1187a7d246dSNobuhiro Iwamatsu 	u32 pci_int_enable;	/* 0x20 */
1197a7d246dSNobuhiro Iwamatsu 	u32 pci_int_status;
1207a7d246dSNobuhiro Iwamatsu 	u32 dummy2[2];
1217a7d246dSNobuhiro Iwamatsu 	u32 ahb_bus_ctr;	/* 0x30 */
1227a7d246dSNobuhiro Iwamatsu 	u32 usbctr;
1237a7d246dSNobuhiro Iwamatsu 	u32 dummy3[2];
1247a7d246dSNobuhiro Iwamatsu 	u32 pci_arbiter_ctr;	/* 0x40 */
1257a7d246dSNobuhiro Iwamatsu 	u32 dummy4;
1267a7d246dSNobuhiro Iwamatsu 	u32 pci_unit_rev;	/* 0x48 */
1277a7d246dSNobuhiro Iwamatsu };
1287a7d246dSNobuhiro Iwamatsu 
1297a7d246dSNobuhiro Iwamatsu struct rmobile_ehci_reg {
1307a7d246dSNobuhiro Iwamatsu 	u32 hciversion;		/* hciversion/caplength */
1317a7d246dSNobuhiro Iwamatsu 	u32 hcsparams;		/* hcsparams */
1327a7d246dSNobuhiro Iwamatsu 	u32 hccparams;		/* hccparams */
1337a7d246dSNobuhiro Iwamatsu 	u32 hcsp_portroute;	/* hcsp_portroute */
1347a7d246dSNobuhiro Iwamatsu 	u32 usbcmd;		/* usbcmd */
1357a7d246dSNobuhiro Iwamatsu 	u32 usbsts;		/* usbsts */
1367a7d246dSNobuhiro Iwamatsu 	u32 usbintr;		/* usbintr */
1377a7d246dSNobuhiro Iwamatsu 	u32 frindex;		/* frindex */
1387a7d246dSNobuhiro Iwamatsu 	u32 ctrldssegment;	/* ctrldssegment */
1397a7d246dSNobuhiro Iwamatsu 	u32 periodiclistbase;	/* periodiclistbase */
1407a7d246dSNobuhiro Iwamatsu 	u32 asynclistaddr;	/* asynclistaddr */
1417a7d246dSNobuhiro Iwamatsu 	u32 dummy[9];
1427a7d246dSNobuhiro Iwamatsu 	u32 configflag;		/* configflag */
1437a7d246dSNobuhiro Iwamatsu 	u32 portsc;		/* portsc */
1447a7d246dSNobuhiro Iwamatsu };
1457a7d246dSNobuhiro Iwamatsu 
1467a7d246dSNobuhiro Iwamatsu #endif /* __EHCI_RMOBILE_H__ */
147