mirror of
https://github.com/fail0verflow/switch-coreboot.git
synced 2025-05-04 01:39:18 -04:00
code boots and works on qemu and alix1c. It represents a huge change and a huge improvement. There are a few fixes left to do, which will come once this is in. This change started out easy: get the device IDs OUT of the the dts, and into one place. We decided the device IDs should be in the constructors ONLY. To make a long story short, that just did not work out, and it revealed a flaw in the design. The result? - no more ids in the various dts files. - the constructor struct is gone -- one less struct, nobody liked the name anyway - the device_operations struct now includes the device id. - constructor property no longer used; use device_operations instead. - lpc replaced with ioport All the changes below stem from this "simple" change. I am finding this new structure much easier to work with. I hope we're done on this for real, however! TODO: 1. Change limitation in dtc that makes it hard to use hex in pci@ notation. Now for the bad news. Sometime today, interrupts or io or something stopped working between r596 and r602 -- but I did no commits at that point. So something has gone wrong, but I don't think it's this stuff. I did try a build of HEAD, and it fails really, really badly. Much more badly than this fails, so I think this commit is only going to improve things. It does work fine on qemu, fails on alix1c, so I suspect one of today's "clean up commits" broke something. Signed-off-by: Ronald G. Minnich <rminnich@gmail.com> Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net> git-svn-id: svn://coreboot.org/repository/coreboot-v3@603 f3766cd6-281f-0410-b1cd-43a5c92072e9
112 lines
2 KiB
C
112 lines
2 KiB
C
/*
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
#ifndef DEVICE_PATH_H
|
|
#define DEVICE_PATH_H
|
|
|
|
enum device_path_type {
|
|
DEVICE_PATH_NONE = 0,
|
|
DEVICE_PATH_ROOT,
|
|
DEVICE_PATH_PCI_DOMAIN,
|
|
DEVICE_PATH_PCI_BUS,
|
|
DEVICE_PATH_PCI,
|
|
DEVICE_PATH_PNP,
|
|
DEVICE_PATH_I2C,
|
|
DEVICE_PATH_APIC,
|
|
DEVICE_PATH_APIC_CLUSTER,
|
|
DEVICE_PATH_CPU,
|
|
DEVICE_PATH_CPU_BUS,
|
|
DEVICE_PATH_IOPORT,
|
|
};
|
|
|
|
struct pci_domain_path
|
|
{
|
|
unsigned domain;
|
|
};
|
|
|
|
struct pci_bus_path
|
|
{
|
|
unsigned bus;
|
|
};
|
|
|
|
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;
|
|
};
|
|
|
|
struct apic_cluster_path
|
|
{
|
|
unsigned cluster;
|
|
};
|
|
|
|
struct cpu_path
|
|
{
|
|
unsigned id;
|
|
};
|
|
|
|
struct cpu_bus_path
|
|
{
|
|
unsigned id;
|
|
};
|
|
|
|
struct ioport_path
|
|
{
|
|
unsigned iobase;
|
|
};
|
|
|
|
|
|
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 pci_domain_path pci_domain;
|
|
struct pci_bus_path pci_bus;
|
|
struct apic_cluster_path apic_cluster;
|
|
struct cpu_path cpu;
|
|
struct cpu_bus_path cpu_bus;
|
|
struct ioport_path ioport;
|
|
} u;
|
|
};
|
|
|
|
|
|
#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 */
|