/* * setup.c, Setup for the TANBAC TB0229 (VR4131DIMM) * * Copyright (C) 2002-2004 Yoichi Yuasa * * Modified for TANBAC TB0229: * Copyright (C) 2003 Megasolution Inc. * * 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 */ #include #include #include #include #include #include #include #include #ifdef CONFIG_PCI static struct resource vr41xx_pci_io_resource = { .name = "PCI I/O space", .start = VR41XX_PCI_IO_START, .end = VR41XX_PCI_IO_END, .flags = IORESOURCE_IO, }; static struct resource vr41xx_pci_mem_resource = { .name = "PCI memory space", .start = VR41XX_PCI_MEM_START, .end = VR41XX_PCI_MEM_END, .flags = IORESOURCE_MEM, }; struct pci_channel mips_pci_channels[] = { { .pci_ops = &vr41xx_pci_ops, .io_resource = &vr41xx_pci_io_resource, .mem_resource = &vr41xx_pci_mem_resource, .first_devfn = 0, .last_devfn = 256, }, { .pci_ops = NULL, .io_resource = NULL, .mem_resource = NULL, .first_devfn = 0, .last_devfn = 0, } }; struct vr41xx_pci_address_space vr41xx_pci_mem1 = { .internal_base = VR41XX_PCI_MEM1_BASE, .address_mask = VR41XX_PCI_MEM1_MASK, .pci_base = IO_MEM1_RESOURCE_START, }; struct vr41xx_pci_address_space vr41xx_pci_mem2 = { .internal_base = VR41XX_PCI_MEM2_BASE, .address_mask = VR41XX_PCI_MEM2_MASK, .pci_base = IO_MEM2_RESOURCE_START, }; struct vr41xx_pci_address_space vr41xx_pci_io = { .internal_base = VR41XX_PCI_IO_BASE, .address_mask = VR41XX_PCI_IO_MASK, .pci_base = IO_PORT_RESOURCE_START, }; static struct vr41xx_pci_address_map pci_address_map = { .mem1 = &vr41xx_pci_mem1, .mem2 = &vr41xx_pci_mem2, .io = &vr41xx_pci_io, }; #endif void __init tanbac_tb0229_setup(void) { set_io_port_base(IO_PORT_BASE); ioport_resource.start = IO_PORT_RESOURCE_START; ioport_resource.end = IO_PORT_RESOURCE_END; iomem_resource.start = IO_MEM1_RESOURCE_START; iomem_resource.end = IO_MEM2_RESOURCE_END; board_time_init = vr41xx_time_init; board_timer_setup = vr41xx_timer_setup; #ifdef CONFIG_FB conswitchp = &dummy_con; #endif vr41xx_bcu_init(); vr41xx_cmu_init(); vr41xx_pmu_init(); #ifdef CONFIG_SERIAL vr41xx_siu_init(SIU_RS232C, 0); vr41xx_dsiu_init(); #endif #ifdef CONFIG_PCI vr41xx_pciu_init(&pci_address_map); #endif #ifdef CONFIG_TANBAC_TB0219 _machine_restart = tanbac_tb0219_restart; #endif }