1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * Copyright 2006 Freescale Semiconductor.
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0+
5*4882a593Smuzhiyun */
6*4882a593Smuzhiyun
7*4882a593Smuzhiyun #include <common.h>
8*4882a593Smuzhiyun #include <pci.h>
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun /* Config the VIA chip */
mpc85xx_config_via(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)11*4882a593Smuzhiyun void mpc85xx_config_via(struct pci_controller *hose,
12*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
13*4882a593Smuzhiyun {
14*4882a593Smuzhiyun pci_dev_t bridge;
15*4882a593Smuzhiyun unsigned int cmdstat;
16*4882a593Smuzhiyun
17*4882a593Smuzhiyun /* Enable USB and IDE functions */
18*4882a593Smuzhiyun pci_hose_write_config_byte(hose, dev, 0x48, 0x08);
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun pci_hose_read_config_dword(hose, dev, PCI_COMMAND, &cmdstat);
21*4882a593Smuzhiyun cmdstat |= PCI_COMMAND_IO | PCI_COMMAND_MEMORY| PCI_COMMAND_MASTER;
22*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_COMMAND, cmdstat);
23*4882a593Smuzhiyun pci_hose_write_config_byte(hose, dev, PCI_CACHE_LINE_SIZE, 0x08);
24*4882a593Smuzhiyun pci_hose_write_config_byte(hose, dev, PCI_LATENCY_TIMER, 0x80);
25*4882a593Smuzhiyun
26*4882a593Smuzhiyun /*
27*4882a593Smuzhiyun * Force the backplane P2P bridge to have a window
28*4882a593Smuzhiyun * open from 0x00000000-0x00001fff in PCI I/O space.
29*4882a593Smuzhiyun * This allows legacy I/O (i8259, etc) on the VIA
30*4882a593Smuzhiyun * southbridge to be accessed.
31*4882a593Smuzhiyun */
32*4882a593Smuzhiyun bridge = PCI_BDF(0,BRIDGE_ID,0);
33*4882a593Smuzhiyun pci_hose_write_config_byte(hose, bridge, PCI_IO_BASE, 0);
34*4882a593Smuzhiyun pci_hose_write_config_word(hose, bridge, PCI_IO_BASE_UPPER16, 0);
35*4882a593Smuzhiyun pci_hose_write_config_byte(hose, bridge, PCI_IO_LIMIT, 0x10);
36*4882a593Smuzhiyun pci_hose_write_config_word(hose, bridge, PCI_IO_LIMIT_UPPER16, 0);
37*4882a593Smuzhiyun }
38*4882a593Smuzhiyun
39*4882a593Smuzhiyun /* Function 1, IDE */
mpc85xx_config_via_usbide(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)40*4882a593Smuzhiyun void mpc85xx_config_via_usbide(struct pci_controller *hose,
41*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
42*4882a593Smuzhiyun {
43*4882a593Smuzhiyun pciauto_config_device(hose, dev);
44*4882a593Smuzhiyun /*
45*4882a593Smuzhiyun * Since the P2P window was forced to cover the fixed
46*4882a593Smuzhiyun * legacy I/O addresses, it is necessary to manually
47*4882a593Smuzhiyun * place the base addresses for the IDE and USB functions
48*4882a593Smuzhiyun * within this window.
49*4882a593Smuzhiyun */
50*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_0, 0x1ff8);
51*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_1, 0x1ff4);
52*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_2, 0x1fe8);
53*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_3, 0x1fe4);
54*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_4, 0x1fd0);
55*4882a593Smuzhiyun }
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun /* Function 2, USB ports 0-1 */
mpc85xx_config_via_usb(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)58*4882a593Smuzhiyun void mpc85xx_config_via_usb(struct pci_controller *hose,
59*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
60*4882a593Smuzhiyun {
61*4882a593Smuzhiyun pciauto_config_device(hose, dev);
62*4882a593Smuzhiyun
63*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_4, 0x1fa0);
64*4882a593Smuzhiyun }
65*4882a593Smuzhiyun
66*4882a593Smuzhiyun /* Function 3, USB ports 2-3 */
mpc85xx_config_via_usb2(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)67*4882a593Smuzhiyun void mpc85xx_config_via_usb2(struct pci_controller *hose,
68*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
69*4882a593Smuzhiyun {
70*4882a593Smuzhiyun pciauto_config_device(hose, dev);
71*4882a593Smuzhiyun
72*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_4, 0x1f80);
73*4882a593Smuzhiyun }
74*4882a593Smuzhiyun
75*4882a593Smuzhiyun /* Function 5, Power Management */
mpc85xx_config_via_power(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)76*4882a593Smuzhiyun void mpc85xx_config_via_power(struct pci_controller *hose,
77*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
78*4882a593Smuzhiyun {
79*4882a593Smuzhiyun pciauto_config_device(hose, dev);
80*4882a593Smuzhiyun
81*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_0, 0x1e00);
82*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_1, 0x1dfc);
83*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_2, 0x1df8);
84*4882a593Smuzhiyun }
85*4882a593Smuzhiyun
86*4882a593Smuzhiyun /* Function 6, AC97 Interface */
mpc85xx_config_via_ac97(struct pci_controller * hose,pci_dev_t dev,struct pci_config_table * tab)87*4882a593Smuzhiyun void mpc85xx_config_via_ac97(struct pci_controller *hose,
88*4882a593Smuzhiyun pci_dev_t dev, struct pci_config_table *tab)
89*4882a593Smuzhiyun {
90*4882a593Smuzhiyun pciauto_config_device(hose, dev);
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun pci_hose_write_config_dword(hose, dev, PCI_BASE_ADDRESS_0, 0x1c00);
93*4882a593Smuzhiyun }
94