mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-12 05:08:57 +00:00
83d290c56f
When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
96 lines
2.8 KiB
C
96 lines
2.8 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* (C) Copyright 2005
|
|
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
|
* Copyright (C) 2006-2009 Freescale Semiconductor, Inc.
|
|
*/
|
|
|
|
#include <asm/mmu.h>
|
|
#include <asm/io.h>
|
|
#include <common.h>
|
|
#include <mpc83xx.h>
|
|
#include <pci.h>
|
|
#include <i2c.h>
|
|
#include <asm/fsl_i2c.h>
|
|
|
|
static struct pci_region pci1_regions[] = {
|
|
{
|
|
bus_start: CONFIG_SYS_PCI1_MEM_BASE,
|
|
phys_start: CONFIG_SYS_PCI1_MEM_PHYS,
|
|
size: CONFIG_SYS_PCI1_MEM_SIZE,
|
|
flags: PCI_REGION_MEM | PCI_REGION_PREFETCH
|
|
},
|
|
{
|
|
bus_start: CONFIG_SYS_PCI1_IO_BASE,
|
|
phys_start: CONFIG_SYS_PCI1_IO_PHYS,
|
|
size: CONFIG_SYS_PCI1_IO_SIZE,
|
|
flags: PCI_REGION_IO
|
|
},
|
|
{
|
|
bus_start: CONFIG_SYS_PCI1_MMIO_BASE,
|
|
phys_start: CONFIG_SYS_PCI1_MMIO_PHYS,
|
|
size: CONFIG_SYS_PCI1_MMIO_SIZE,
|
|
flags: PCI_REGION_MEM
|
|
},
|
|
};
|
|
|
|
/*
|
|
* pci_init_board()
|
|
*
|
|
* NOTICE: MPC8349 internally has two PCI controllers (PCI1 and PCI2) but since
|
|
* per TQM834x design physical connections to external devices (PCI sockets)
|
|
* are routed only to the PCI1 we do not account for the second one - this code
|
|
* supports PCI1 module only. Should support for the PCI2 be required in the
|
|
* future it needs a separate pci_controller structure (above) and handling -
|
|
* please refer to other boards' implementation for dual PCI host controllers,
|
|
* for example board/Marvell/db64360/pci.c, pci_init_board()
|
|
*
|
|
*/
|
|
void
|
|
pci_init_board(void)
|
|
{
|
|
volatile immap_t *immr = (volatile immap_t *)CONFIG_SYS_IMMR;
|
|
volatile clk83xx_t *clk = (volatile clk83xx_t *)&immr->clk;
|
|
volatile law83xx_t *pci_law = immr->sysconf.pcilaw;
|
|
struct pci_region *reg[] = { pci1_regions };
|
|
u32 reg32;
|
|
|
|
/*
|
|
* Configure PCI controller and PCI_CLK_OUTPUT
|
|
*
|
|
* WARNING! only PCI_CLK_OUTPUT1 is enabled here as this is the one
|
|
* line actually used for clocking all external PCI devices in TQM83xx.
|
|
* Enabling other PCI_CLK_OUTPUT lines may lead to board's hang for
|
|
* unknown reasons - particularly PCI_CLK_OUTPUT6 and PCI_CLK_OUTPUT7
|
|
* are known to hang the board; this issue is under investigation
|
|
* (13 oct 05)
|
|
*/
|
|
reg32 = OCCR_PCICOE1;
|
|
#if 0
|
|
/* enabling all PCI_CLK_OUTPUT lines HANGS the board... */
|
|
reg32 = 0xff000000;
|
|
#endif
|
|
if (clk->spmr & SPMR_CKID) {
|
|
/* PCI Clock is half CONFIG_83XX_CLKIN so need to set up OCCR
|
|
* fields accordingly */
|
|
reg32 |= (OCCR_PCI1CR | OCCR_PCI2CR);
|
|
|
|
reg32 |= (OCCR_PCICD0 | OCCR_PCICD1 | OCCR_PCICD2 \
|
|
| OCCR_PCICD3 | OCCR_PCICD4 | OCCR_PCICD5 \
|
|
| OCCR_PCICD6 | OCCR_PCICD7);
|
|
}
|
|
|
|
clk->occr = reg32;
|
|
udelay(2000);
|
|
|
|
/* Configure PCI Local Access Windows */
|
|
pci_law[0].bar = CONFIG_SYS_PCI1_MEM_PHYS & LAWBAR_BAR;
|
|
pci_law[0].ar = LAWAR_EN | LAWAR_SIZE_512M;
|
|
|
|
pci_law[1].bar = CONFIG_SYS_PCI1_IO_PHYS & LAWBAR_BAR;
|
|
pci_law[1].ar = LAWAR_EN | LAWAR_SIZE_16M;
|
|
|
|
udelay(2000);
|
|
|
|
mpc83xx_pci_init(1, reg);
|
|
}
|