mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2025-10-24 14:01:56 +02:00
Move chromebook_link over to driver model for PCI. This involves: - adding a uclass for platform controller hub - removing most of the existing PCI driver - adjusting how CPU init works to use driver model instead - rename the lpc compatible string (it will be removed later) This does not really take advantage of driver model fully, but it does work. Furture work will improve the code structure to remove many of the explicit calls to init the board. Signed-off-by: Simon Glass <sjg@chromium.org>
68 lines
1.5 KiB
C
68 lines
1.5 KiB
C
/*
|
|
* 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>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <dm.h>
|
|
#include <pci.h>
|
|
#include <asm/pci.h>
|
|
#include <asm/post.h>
|
|
#include <asm/arch/bd82x6x.h>
|
|
#include <asm/arch/pch.h>
|
|
|
|
static int pci_ivybridge_probe(struct udevice *bus)
|
|
{
|
|
struct pci_controller *hose = dev_get_uclass_priv(bus);
|
|
pci_dev_t dev;
|
|
u16 reg16;
|
|
|
|
if (!(gd->flags & GD_FLG_RELOC))
|
|
return 0;
|
|
post_code(0x50);
|
|
bd82x6x_init();
|
|
post_code(0x51);
|
|
|
|
reg16 = 0xff;
|
|
dev = PCH_DEV;
|
|
reg16 = x86_pci_read_config16(dev, PCI_COMMAND);
|
|
reg16 |= PCI_COMMAND_SERR | PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY;
|
|
x86_pci_write_config16(dev, PCI_COMMAND, reg16);
|
|
|
|
/*
|
|
* Clear non-reserved bits in status register.
|
|
*/
|
|
pci_hose_write_config_word(hose, dev, PCI_STATUS, 0xffff);
|
|
pci_hose_write_config_byte(hose, dev, PCI_LATENCY_TIMER, 0x80);
|
|
pci_hose_write_config_byte(hose, dev, PCI_CACHE_LINE_SIZE, 0x08);
|
|
|
|
pci_write_bar32(hose, dev, 0, 0xf0000000);
|
|
post_code(0x52);
|
|
|
|
return 0;
|
|
}
|
|
|
|
static const struct dm_pci_ops pci_ivybridge_ops = {
|
|
.read_config = pci_x86_read_config,
|
|
.write_config = pci_x86_write_config,
|
|
};
|
|
|
|
static const struct udevice_id pci_ivybridge_ids[] = {
|
|
{ .compatible = "intel,pci-ivybridge" },
|
|
{ }
|
|
};
|
|
|
|
U_BOOT_DRIVER(pci_ivybridge_drv) = {
|
|
.name = "pci_ivybridge",
|
|
.id = UCLASS_PCI,
|
|
.of_match = pci_ivybridge_ids,
|
|
.ops = &pci_ivybridge_ops,
|
|
.probe = pci_ivybridge_probe,
|
|
};
|