This patch adds support for autogenerating the MPTABLE from devicetree.cb. This is done by a write_smp_table() declared weak in mpspec.c. If the mainboard doesn't provide it's own function, this generic implementation is called. Syntax in devicetree.cb: ioapic_irq <APICID> <INTA|INTB|INTC|INTD> <INTPIN> The ioapic_irq directive can be used in pci and pci_domain devices. If there's no directive, the autogen code traverses the tree back to the pci_domain and stops at the first device which such a directive, and use that information to generate the entry according to PCI IRQ routing rules. Change-Id: I4df5b198e8430f939d477c14c798414e398a2027 Signed-off-by: Sven Schnelle <svens@stackframe.org> Reviewed-on: http://review.coreboot.org/1138 Tested-by: build bot (Jenkins) Reviewed-by: Patrick Georgi <patrick@georgi-clan.de>
89 lines
1.3 KiB
C
89 lines
1.3 KiB
C
#ifndef DEVICE_PATH_H
|
|
#define DEVICE_PATH_H
|
|
|
|
enum device_path_type {
|
|
DEVICE_PATH_NONE = 0,
|
|
DEVICE_PATH_ROOT,
|
|
DEVICE_PATH_PCI,
|
|
DEVICE_PATH_PNP,
|
|
DEVICE_PATH_I2C,
|
|
DEVICE_PATH_APIC,
|
|
DEVICE_PATH_PCI_DOMAIN,
|
|
DEVICE_PATH_APIC_CLUSTER,
|
|
DEVICE_PATH_CPU,
|
|
DEVICE_PATH_CPU_BUS,
|
|
DEVICE_PATH_IOAPIC,
|
|
};
|
|
|
|
struct pci_domain_path
|
|
{
|
|
unsigned domain;
|
|
};
|
|
|
|
struct pci_path
|
|
{
|
|
unsigned devfn;
|
|
};
|
|
|
|
struct pnp_path
|
|
{
|
|
unsigned port;
|
|
unsigned device;
|
|
};
|
|
|
|
struct i2c_path
|
|
{
|
|
unsigned device;
|
|
};
|
|
|
|
struct apic_path
|
|
{
|
|
unsigned apic_id;
|
|
unsigned node_id;
|
|
unsigned core_id;
|
|
unsigned index;
|
|
};
|
|
|
|
struct ioapic_path
|
|
{
|
|
unsigned ioapic_id;
|
|
};
|
|
|
|
struct apic_cluster_path
|
|
{
|
|
unsigned cluster;
|
|
};
|
|
|
|
struct cpu_path
|
|
{
|
|
unsigned id;
|
|
};
|
|
|
|
struct cpu_bus_path
|
|
{
|
|
unsigned id;
|
|
};
|
|
|
|
|
|
struct device_path {
|
|
enum device_path_type type;
|
|
union {
|
|
struct pci_path pci;
|
|
struct pnp_path pnp;
|
|
struct i2c_path i2c;
|
|
struct apic_path apic;
|
|
struct ioapic_path ioapic;
|
|
struct pci_domain_path pci_domain;
|
|
struct apic_cluster_path apic_cluster;
|
|
struct cpu_path cpu;
|
|
struct cpu_bus_path cpu_bus;
|
|
};
|
|
};
|
|
|
|
|
|
#define DEVICE_PATH_MAX 30
|
|
#define BUS_PATH_MAX (DEVICE_PATH_MAX+10)
|
|
|
|
extern int path_eq(struct device_path *path1, struct device_path *path2);
|
|
|
|
#endif /* DEVICE_PATH_H */
|