2011-11-29 18:05:07 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2011 The Chromium OS Authors.
|
|
|
|
* (C) Copyright 2008,2009
|
|
|
|
* Graeme Russ, <graeme.russ@gmail.com>
|
|
|
|
*
|
|
|
|
* (C) Copyright 2002
|
|
|
|
* Daniel Engström, Omicron Ceti AB, <daniel@omicron.se>
|
|
|
|
*
|
2013-10-07 11:07:26 +00:00
|
|
|
* SPDX-License-Identifier: GPL-2.0+
|
2011-11-29 18:05:07 +00:00
|
|
|
*/
|
|
|
|
|
2012-10-10 13:12:57 +00:00
|
|
|
#include <common.h>
|
|
|
|
#include <pci.h>
|
|
|
|
#include <asm/pci.h>
|
|
|
|
|
2012-10-10 13:12:59 +00:00
|
|
|
static void config_pci_bridge(struct pci_controller *hose, pci_dev_t dev,
|
|
|
|
struct pci_config_table *table)
|
|
|
|
{
|
|
|
|
u8 secondary;
|
|
|
|
hose->read_byte(hose, dev, PCI_SECONDARY_BUS, &secondary);
|
linux/kernel.h: sync min, max, min3, max3 macros with Linux
U-Boot has never cared about the type when we get max/min of two
values, but Linux Kernel does. This commit gets min, max, min3, max3
macros synced with the kernel introducing type checks.
Many of references of those macros must be fixed to suppress warnings.
We have two options:
- Use min, max, min3, max3 only when the arguments have the same type
(or add casts to the arguments)
- Use min_t/max_t instead with the appropriate type for the first
argument
Signed-off-by: Masahiro Yamada <yamada.m@jp.panasonic.com>
Acked-by: Pavel Machek <pavel@denx.de>
Acked-by: Lukasz Majewski <l.majewski@samsung.com>
Tested-by: Lukasz Majewski <l.majewski@samsung.com>
[trini: Fixup arch/blackfin/lib/string.c]
Signed-off-by: Tom Rini <trini@ti.com>
2014-11-06 18:03:31 +00:00
|
|
|
hose->last_busno = max(hose->last_busno, (int)secondary);
|
2012-10-10 13:12:59 +00:00
|
|
|
pci_hose_scan_bus(hose, secondary);
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct pci_config_table pci_coreboot_config_table[] = {
|
|
|
|
/* vendor, device, class, bus, dev, func */
|
|
|
|
{ PCI_ANY_ID, PCI_ANY_ID, PCI_CLASS_BRIDGE_PCI,
|
|
|
|
PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, &config_pci_bridge },
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
2014-11-13 05:42:11 +00:00
|
|
|
void board_pci_setup_hose(struct pci_controller *hose)
|
2011-11-29 18:05:07 +00:00
|
|
|
{
|
2014-11-13 05:42:11 +00:00
|
|
|
hose->config_table = pci_coreboot_config_table;
|
|
|
|
hose->first_busno = 0;
|
|
|
|
hose->last_busno = 0;
|
2012-10-10 13:12:57 +00:00
|
|
|
|
2014-11-13 05:42:11 +00:00
|
|
|
pci_set_region(hose->regions + 0, 0x0, 0x0, 0xffffffff,
|
|
|
|
PCI_REGION_MEM);
|
|
|
|
hose->region_count = 1;
|
2011-11-29 18:05:07 +00:00
|
|
|
}
|