coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
ioe_p2sb.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 
3 #define __SIMPLE_DEVICE__
4 
5 #include <console/console.h>
6 #include <device/pci.h>
7 #include <device/pci_ids.h>
8 #include <intelblocks/p2sb.h>
9 #include <intelblocks/p2sblib.h>
10 #include <intelblocks/pcr.h>
11 #include <soc/iomap.h>
12 #include <soc/pci_devs.h>
13 
15 {
16  return p2sb_dev_sbi_read(PCI_DEV_IOE_P2SB, pid, reg);
17 }
18 
20 {
21  p2sb_dev_sbi_write(PCI_DEV_IOE_P2SB, pid, reg, val);
22 }
23 
25 {
26  p2sb_dev_enable_bar(PCI_DEV_IOE_P2SB, IOE_P2SB_BAR);
27 }
28 
29 static void read_resources(struct device *dev)
30 {
31  mmio_resource(dev, 0, IOE_P2SB_BAR / KiB, IOE_P2SB_SIZE / KiB);
32 }
33 
36  .set_resources = noop_set_resources,
37  .ops_pci = &pci_dev_ops_pci,
38 };
39 
40 static const unsigned short pci_device_ids[] = {
43  0,
44 };
45 
46 static const struct pci_driver ioe_p2sb __pci_driver = {
47  .ops = &device_ops,
48  .vendor = PCI_VID_INTEL,
49  .devices = pci_device_ids,
50 };
#define KiB
Definition: helpers.h:75
static void noop_set_resources(struct device *dev)
Definition: device.h:74
#define mmio_resource(dev, idx, basek, sizek)
Definition: device.h:334
void ioe_p2sb_sbi_write(uint8_t pid, uint16_t reg, uint32_t val)
Definition: ioe_p2sb.c:19
struct device_operations device_ops
Definition: ioe_p2sb.c:34
static const struct pci_driver ioe_p2sb __pci_driver
Definition: ioe_p2sb.c:46
static const unsigned short pci_device_ids[]
Definition: ioe_p2sb.c:40
static void read_resources(struct device *dev)
Definition: ioe_p2sb.c:29
uint32_t ioe_p2sb_sbi_read(uint8_t pid, uint16_t reg)
Definition: ioe_p2sb.c:14
void ioe_p2sb_enable_bar(void)
Definition: ioe_p2sb.c:24
uint32_t p2sb_dev_sbi_read(pci_devfn_t dev, uint8_t pid, uint16_t reg)
Definition: p2sblib.c:92
void p2sb_dev_enable_bar(pci_devfn_t dev, uint64_t bar)
Definition: p2sblib.c:13
void p2sb_dev_sbi_write(pci_devfn_t dev, uint8_t pid, uint16_t reg, uint32_t val)
Definition: p2sblib.c:99
struct pci_operations pci_dev_ops_pci
Default device operation for PCI devices.
Definition: pci_device.c:911
#define PCI_DID_INTEL_MTL_IOE_P_P2SB
Definition: pci_ids.h:4163
#define PCI_DID_INTEL_MTL_IOE_M_P2SB
Definition: pci_ids.h:4162
#define PCI_VID_INTEL
Definition: pci_ids.h:2157
unsigned short uint16_t
Definition: stdint.h:11
unsigned int uint32_t
Definition: stdint.h:14
unsigned char uint8_t
Definition: stdint.h:8
void(* read_resources)(struct device *dev)
Definition: device.h:39
Definition: device.h:107
u8 val
Definition: sys.c:300