Lines Matching +full:start +full:- +full:up
1 // SPDX-License-Identifier: GPL-2.0-only
8 * Copyright (C) 2004 by Ralf Baechle (ralf@linux-mips.org)
18 #include <asm/mips-cps.h>
19 #include <asm/mips-boards/generic.h>
20 #include <asm/mips-boards/bonito64.h>
21 #include <asm/mips-boards/msc01_pci.h>
30 .start = 0x00000000UL,
36 .name = "GT-64120 PCI MEM",
41 .name = "GT-64120 PCI I/O",
81 resource_size_t start, end, map, start1, end1, map1, map2, map3, mask; in mips_pcibios_init() local
102 /* Set up resource ranges from the controller's registers. */ in mips_pcibios_init()
103 start = GT_READ(GT_PCI0M0LD_OFS); in mips_pcibios_init()
106 end = (end & GT_PCI_HD_MSK) | (start & ~GT_PCI_HD_MSK); in mips_pcibios_init()
112 if (end1 - start1 > end - start) { in mips_pcibios_init()
113 start = start1; in mips_pcibios_init()
117 mask = ~(start ^ end); in mips_pcibios_init()
119 BUG_ON((start & GT_PCI_HD_MSK) != (map & GT_PCI_HD_MSK) && in mips_pcibios_init()
120 mask != ~((mask & -mask) - 1)); in mips_pcibios_init()
121 gt64120_mem_resource.start = start; in mips_pcibios_init()
123 gt64120_controller.mem_offset = (start & mask) - (map & mask); in mips_pcibios_init()
124 /* Addresses are 36-bit, so do shifts in the destinations. */ in mips_pcibios_init()
125 gt64120_mem_resource.start <<= GT_PCI_DCRM_SHF; in mips_pcibios_init()
127 gt64120_mem_resource.end |= (1 << GT_PCI_DCRM_SHF) - 1; in mips_pcibios_init()
130 start = GT_READ(GT_PCI0IOLD_OFS); in mips_pcibios_init()
133 end = (end & GT_PCI_HD_MSK) | (start & ~GT_PCI_HD_MSK); in mips_pcibios_init()
134 mask = ~(start ^ end); in mips_pcibios_init()
136 BUG_ON((start & GT_PCI_HD_MSK) != (map & GT_PCI_HD_MSK) && in mips_pcibios_init()
137 mask != ~((mask & -mask) - 1)); in mips_pcibios_init()
138 gt64120_io_resource.start = map & mask; in mips_pcibios_init()
141 /* Addresses are 36-bit, so do shifts in the destinations. */ in mips_pcibios_init()
142 gt64120_io_resource.start <<= GT_PCI_DCRM_SHF; in mips_pcibios_init()
144 gt64120_io_resource.end |= (1 << GT_PCI_DCRM_SHF) - 1; in mips_pcibios_init()
150 /* Set up resource ranges from the controller's registers. */ in mips_pcibios_init()
160 start = BONITO_PCILO0_BASE; in mips_pcibios_init()
164 start = BONITO_PCILO1_BASE; in mips_pcibios_init()
169 start = BONITO_PCILO0_BASE; in mips_pcibios_init()
172 bonito64_mem_resource.start = start; in mips_pcibios_init()
173 bonito64_mem_resource.end = start + in mips_pcibios_init()
174 BONITO_PCIMAP_WINBASE(end) - 1; in mips_pcibios_init()
175 bonito64_controller.mem_offset = start - in mips_pcibios_init()
185 /* Set up resource ranges from the controller's registers. */ in mips_pcibios_init()
186 MSC_READ(MSC01_PCI_SC2PMBASL, start); in mips_pcibios_init()
189 msc_mem_resource.start = start & mask; in mips_pcibios_init()
190 msc_mem_resource.end = (start & mask) | ~mask; in mips_pcibios_init()
191 msc_controller.mem_offset = (start & mask) - (map & mask); in mips_pcibios_init()
193 write_gcr_reg0_base(start); in mips_pcibios_init()
197 MSC_READ(MSC01_PCI_SC2PIOBASL, start); in mips_pcibios_init()
200 msc_io_resource.start = map & mask; in mips_pcibios_init()
205 write_gcr_reg1_base(start); in mips_pcibios_init()
210 start = start & mask; in mips_pcibios_init()
211 end = start | ~mask; in mips_pcibios_init()
212 if ((start >= msc_mem_resource.start && in mips_pcibios_init()
213 start <= msc_mem_resource.end) || in mips_pcibios_init()
214 (end >= msc_mem_resource.start && in mips_pcibios_init()
217 start = max(start, msc_mem_resource.start); in mips_pcibios_init()
219 if (start - msc_mem_resource.start >= in mips_pcibios_init()
220 msc_mem_resource.end - end) in mips_pcibios_init()
221 msc_mem_resource.end = start - 1; in mips_pcibios_init()
223 msc_mem_resource.start = end + 1; in mips_pcibios_init()
233 if (controller->io_resource->start < 0x00001000UL) in mips_pcibios_init()
234 controller->io_resource->start = 0x00001000UL; in mips_pcibios_init()
237 ioport_resource.end = controller->io_resource->end; in mips_pcibios_init()
239 controller->io_map_base = mips_io_port_base; in mips_pcibios_init()