| /* Plx9030.c - system configuration module for PLX9030 PCI to Local Bus Bridge */ |
| /* |
| * (C) Copyright 2002-2003 |
| * Josef Wagner, MicroSys GmbH, wagner@microsys.de. |
| * |
| * See file CREDITS for list of people who contributed to this |
| * project. |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License as |
| * published by the Free Software Foundation; either version 2 of |
| * the License, or (at your option) any later version. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
| * MA 02111-1307 USA |
| * |
| * Date Modification by |
| * ------- ---------------------------------------------- --- |
| * 30sep02 converted from VxWorks to LINUX wa |
| */ |
| |
| |
| /* |
| DESCRIPTION |
| |
| This is the configuration module for the PLX9030 PCI to Local Bus Bridge. |
| It configures the Chip select lines for SRAM (CS0), ST16C552 (CS1,CS2), Display and local |
| registers (CS3) on CPC45. |
| */ |
| |
| /* includes */ |
| |
| #include <common.h> |
| #include <malloc.h> |
| #include <net.h> |
| #include <asm/io.h> |
| #include <pci.h> |
| |
| /* imports */ |
| |
| |
| /* defines */ |
| #define PLX9030_VENDOR_ID 0x10B5 |
| #define PLX9030_DEVICE_ID 0x9030 |
| |
| #undef PLX_DEBUG |
| |
| /* PLX9030 register offsets */ |
| #define P9030_LAS0RR 0x00 |
| #define P9030_LAS1RR 0x04 |
| #define P9030_LAS2RR 0x08 |
| #define P9030_LAS3RR 0x0c |
| #define P9030_EROMRR 0x10 |
| #define P9030_LAS0BA 0x14 |
| #define P9030_LAS1BA 0x18 |
| #define P9030_LAS2BA 0x1c |
| #define P9030_LAS3BA 0x20 |
| #define P9030_EROMBA 0x24 |
| #define P9030_LAS0BRD 0x28 |
| #define P9030_LAS1BRD 0x2c |
| #define P9030_LAS2BRD 0x30 |
| #define P9030_LAS3BRD 0x34 |
| #define P9030_EROMBRD 0x38 |
| #define P9030_CS0BASE 0x3C |
| #define P9030_CS1BASE 0x40 |
| #define P9030_CS2BASE 0x44 |
| #define P9030_CS3BASE 0x48 |
| #define P9030_INTCSR 0x4c |
| #define P9030_CNTRL 0x50 |
| #define P9030_GPIOC 0x54 |
| |
| /* typedefs */ |
| |
| |
| /* locals */ |
| |
| static struct pci_device_id supported[] = { |
| { PLX9030_VENDOR_ID, PLX9030_DEVICE_ID }, |
| { } |
| }; |
| |
| /* forward declarations */ |
| void sysOutLong(ulong address, ulong value); |
| |
| |
| /*************************************************************************** |
| * |
| * Plx9030Init - init CS0..CS3 for CPC45 |
| * |
| * |
| * RETURNS: N/A |
| */ |
| |
| void Plx9030Init (void) |
| { |
| pci_dev_t devno; |
| ulong membaseCsr; /* base address of device memory space */ |
| int idx = 0; /* general index */ |
| |
| |
| /* find plx9030 device */ |
| |
| if ((devno = pci_find_devices(supported, idx++)) < 0) |
| { |
| printf("No PLX9030 device found !!\n"); |
| return; |
| } |
| |
| |
| #ifdef PLX_DEBUG |
| printf("PLX 9030 device found ! devno = 0x%x\n",devno); |
| #endif |
| |
| membaseCsr = PCI_PLX9030_MEMADDR; |
| |
| /* set base address */ |
| pci_write_config_dword(devno, PCI_BASE_ADDRESS_0, membaseCsr); |
| |
| /* enable mapped memory and IO addresses */ |
| pci_write_config_dword(devno, |
| PCI_COMMAND, |
| PCI_COMMAND_MEMORY | |
| PCI_COMMAND_MASTER); |
| |
| |
| /* configure GBIOC */ |
| sysOutLong((membaseCsr + P9030_GPIOC), 0x00000FC0); /* CS2/CS3 enable */ |
| |
| /* configure CS0 (SRAM) */ |
| sysOutLong((membaseCsr + P9030_LAS0BA), 0x00000001); /* enable space base */ |
| sysOutLong((membaseCsr + P9030_LAS0RR), 0x0FE00000); /* 2 MByte */ |
| sysOutLong((membaseCsr + P9030_LAS0BRD), 0x51928900); /* 4 wait states */ |
| sysOutLong((membaseCsr + P9030_CS0BASE), 0x00100001); /* enable 2 MByte */ |
| /* remap CS0 (SRAM) */ |
| pci_write_config_dword(devno, PCI_BASE_ADDRESS_2, SRAM_BASE); |
| |
| /* configure CS1 (ST16552 / CHAN A) */ |
| sysOutLong((membaseCsr + P9030_LAS1BA), 0x00400001); /* enable space base */ |
| sysOutLong((membaseCsr + P9030_LAS1RR), 0x0FFFFF00); /* 256 byte */ |
| sysOutLong((membaseCsr + P9030_LAS1BRD), 0x55122900); /* 4 wait states */ |
| sysOutLong((membaseCsr + P9030_CS1BASE), 0x00400081); /* enable 256 Byte */ |
| /* remap CS1 (ST16552 / CHAN A) */ |
| /* remap CS1 (ST16552 / CHAN A) */ |
| pci_write_config_dword(devno, PCI_BASE_ADDRESS_3, ST16552_A_BASE); |
| |
| /* configure CS2 (ST16552 / CHAN B) */ |
| sysOutLong((membaseCsr + P9030_LAS2BA), 0x00800001); /* enable space base */ |
| sysOutLong((membaseCsr + P9030_LAS2RR), 0x0FFFFF00); /* 256 byte */ |
| sysOutLong((membaseCsr + P9030_LAS2BRD), 0x55122900); /* 4 wait states */ |
| sysOutLong((membaseCsr + P9030_CS2BASE), 0x00800081); /* enable 256 Byte */ |
| /* remap CS2 (ST16552 / CHAN B) */ |
| pci_write_config_dword(devno, PCI_BASE_ADDRESS_4, ST16552_B_BASE); |
| |
| /* configure CS3 (BCSR) */ |
| sysOutLong((membaseCsr + P9030_LAS3BA), 0x00C00001); /* enable space base */ |
| sysOutLong((membaseCsr + P9030_LAS3RR), 0x0FFFFF00); /* 256 byte */ |
| sysOutLong((membaseCsr + P9030_LAS3BRD), 0x55357A80); /* 9 wait states */ |
| sysOutLong((membaseCsr + P9030_CS3BASE), 0x00C00081); /* enable 256 Byte */ |
| /* remap CS3 (DISPLAY and BCSR) */ |
| pci_write_config_dword(devno, PCI_BASE_ADDRESS_5, BCSR_BASE); |
| } |
| |
| void sysOutLong(ulong address, ulong value) |
| { |
| *(ulong*)address = cpu_to_le32(value); |
| } |
| |