blob: 8d036930e73b9e936285cf265f0ab834eb27e705 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Simon Glass4e037812015-03-05 12:25:31 -07002/*
3 * Copyright (c) 2015 Google, Inc
Simon Glass4e037812015-03-05 12:25:31 -07004 */
5
Tom Riniabb9a042024-05-18 20:20:43 -06006#include <common.h>
Simon Glass4e037812015-03-05 12:25:31 -07007#include <dm.h>
8#include <pci.h>
Simon Glassa1548b82015-07-03 18:28:25 -06009#include <asm/pci.h>
Simon Glass4e037812015-03-05 12:25:31 -070010
Simon Glass2a311e82020-01-27 08:49:37 -070011static int _pci_x86_read_config(const struct udevice *bus, pci_dev_t bdf,
12 uint offset, ulong *valuep,
13 enum pci_size_t size)
Simon Glassa5464582019-08-31 21:23:18 -060014{
15 return pci_x86_read_config(bdf, offset, valuep, size);
16}
17
18static int _pci_x86_write_config(struct udevice *bus, pci_dev_t bdf,
19 uint offset, ulong value, enum pci_size_t size)
20{
21 return pci_x86_write_config(bdf, offset, value, size);
22}
23
Simon Glassa1548b82015-07-03 18:28:25 -060024static const struct dm_pci_ops pci_x86_ops = {
Simon Glassa5464582019-08-31 21:23:18 -060025 .read_config = _pci_x86_read_config,
26 .write_config = _pci_x86_write_config,
Simon Glass4e037812015-03-05 12:25:31 -070027};
28
Simon Glassa1548b82015-07-03 18:28:25 -060029static const struct udevice_id pci_x86_ids[] = {
30 { .compatible = "pci-x86" },
Simon Glass4e037812015-03-05 12:25:31 -070031 { }
32};
33
34U_BOOT_DRIVER(pci_x86) = {
35 .name = "pci_x86",
36 .id = UCLASS_PCI,
Simon Glassa1548b82015-07-03 18:28:25 -060037 .of_match = pci_x86_ids,
38 .ops = &pci_x86_ops,
Simon Glass4e037812015-03-05 12:25:31 -070039};