[PATCH] powerpc: use a common vio_match_device routine
This requires the compatible properties having vaules that are empty strings instead of just being empty properties. Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
parent
e10fa77368
commit
dd721ffd95
@ -47,7 +47,8 @@ static const struct vio_device_id *vio_match_device(
|
|||||||
const struct vio_device_id *ids, const struct vio_dev *dev)
|
const struct vio_device_id *ids, const struct vio_dev *dev)
|
||||||
{
|
{
|
||||||
while (ids->type[0] != '\0') {
|
while (ids->type[0] != '\0') {
|
||||||
if (vio_bus_ops.match(ids, dev))
|
if ((strncmp(dev->type, ids->type, strlen(ids->type)) == 0) &&
|
||||||
|
device_is_compatible(dev->dev.platform_data, ids->compat))
|
||||||
return ids;
|
return ids;
|
||||||
ids++;
|
ids++;
|
||||||
}
|
}
|
||||||
|
@ -927,7 +927,7 @@ void dt_vdevices(struct iseries_flat_dt *dt)
|
|||||||
snprintf(buf, sizeof(buf), "viocons@%08x", reg);
|
snprintf(buf, sizeof(buf), "viocons@%08x", reg);
|
||||||
dt_start_node(dt, buf);
|
dt_start_node(dt, buf);
|
||||||
dt_prop_str(dt, "device_type", "serial");
|
dt_prop_str(dt, "device_type", "serial");
|
||||||
dt_prop_empty(dt, "compatible");
|
dt_prop_str(dt, "compatible", "");
|
||||||
dt_prop_u32(dt, "reg", reg);
|
dt_prop_u32(dt, "reg", reg);
|
||||||
dt_end_node(dt);
|
dt_end_node(dt);
|
||||||
reg++;
|
reg++;
|
||||||
@ -949,7 +949,7 @@ void dt_vdevices(struct iseries_flat_dt *dt)
|
|||||||
snprintf(buf, 32, "vlan@%08x", reg + i);
|
snprintf(buf, 32, "vlan@%08x", reg + i);
|
||||||
dt_start_node(dt, buf);
|
dt_start_node(dt, buf);
|
||||||
dt_prop_str(dt, "device_type", "vlan");
|
dt_prop_str(dt, "device_type", "vlan");
|
||||||
dt_prop_empty(dt, "compatible");
|
dt_prop_str(dt, "compatible", "");
|
||||||
dt_prop_u32(dt, "reg", reg + i);
|
dt_prop_u32(dt, "reg", reg + i);
|
||||||
dt_prop_u32(dt, "linux,unit_address", i);
|
dt_prop_u32(dt, "linux,unit_address", i);
|
||||||
|
|
||||||
@ -970,7 +970,7 @@ void dt_vdevices(struct iseries_flat_dt *dt)
|
|||||||
snprintf(buf, 32, "viodasd@%08x", reg + i);
|
snprintf(buf, 32, "viodasd@%08x", reg + i);
|
||||||
dt_start_node(dt, buf);
|
dt_start_node(dt, buf);
|
||||||
dt_prop_str(dt, "device_type", "viodasd");
|
dt_prop_str(dt, "device_type", "viodasd");
|
||||||
dt_prop_empty(dt, "compatible");
|
dt_prop_str(dt, "compatible", "");
|
||||||
dt_prop_u32(dt, "reg", reg + i);
|
dt_prop_u32(dt, "reg", reg + i);
|
||||||
dt_prop_u32(dt, "linux,unit_address", i);
|
dt_prop_u32(dt, "linux,unit_address", i);
|
||||||
dt_end_node(dt);
|
dt_end_node(dt);
|
||||||
@ -980,7 +980,7 @@ void dt_vdevices(struct iseries_flat_dt *dt)
|
|||||||
snprintf(buf, 32, "viocd@%08x", reg + i);
|
snprintf(buf, 32, "viocd@%08x", reg + i);
|
||||||
dt_start_node(dt, buf);
|
dt_start_node(dt, buf);
|
||||||
dt_prop_str(dt, "device_type", "viocd");
|
dt_prop_str(dt, "device_type", "viocd");
|
||||||
dt_prop_empty(dt, "compatible");
|
dt_prop_str(dt, "compatible", "");
|
||||||
dt_prop_u32(dt, "reg", reg + i);
|
dt_prop_u32(dt, "reg", reg + i);
|
||||||
dt_prop_u32(dt, "linux,unit_address", i);
|
dt_prop_u32(dt, "linux,unit_address", i);
|
||||||
dt_end_node(dt);
|
dt_end_node(dt);
|
||||||
@ -990,7 +990,7 @@ void dt_vdevices(struct iseries_flat_dt *dt)
|
|||||||
snprintf(buf, 32, "viotape@%08x", reg + i);
|
snprintf(buf, 32, "viotape@%08x", reg + i);
|
||||||
dt_start_node(dt, buf);
|
dt_start_node(dt, buf);
|
||||||
dt_prop_str(dt, "device_type", "viotape");
|
dt_prop_str(dt, "device_type", "viotape");
|
||||||
dt_prop_empty(dt, "compatible");
|
dt_prop_str(dt, "compatible", "");
|
||||||
dt_prop_u32(dt, "reg", reg + i);
|
dt_prop_u32(dt, "reg", reg + i);
|
||||||
dt_prop_u32(dt, "linux,unit_address", i);
|
dt_prop_u32(dt, "linux,unit_address", i);
|
||||||
dt_end_node(dt);
|
dt_end_node(dt);
|
||||||
|
@ -50,18 +50,7 @@ static struct iommu_table *vio_build_iommu_table(struct vio_dev *dev)
|
|||||||
return &vio_iommu_table;
|
return &vio_iommu_table;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* vio_match_device_iseries: - Tell if a iSeries VIO device matches a
|
|
||||||
* vio_device_id
|
|
||||||
*/
|
|
||||||
static int vio_match_device_iseries(const struct vio_device_id *id,
|
|
||||||
const struct vio_dev *dev)
|
|
||||||
{
|
|
||||||
return strncmp(dev->type, id->type, strlen(id->type)) == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct vio_bus_ops vio_bus_ops_iseries = {
|
static struct vio_bus_ops vio_bus_ops_iseries = {
|
||||||
.match = vio_match_device_iseries,
|
|
||||||
.build_iommu_table = vio_build_iommu_table,
|
.build_iommu_table = vio_build_iommu_table,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -75,5 +64,4 @@ static int __init vio_bus_init_iseries(void)
|
|||||||
iSeries_vio_dev = &vio_bus_device.dev;
|
iSeries_vio_dev = &vio_bus_device.dev;
|
||||||
return vio_bus_init(&vio_bus_ops_iseries);
|
return vio_bus_init(&vio_bus_ops_iseries);
|
||||||
}
|
}
|
||||||
|
|
||||||
__initcall(vio_bus_init_iseries);
|
__initcall(vio_bus_init_iseries);
|
||||||
|
@ -26,17 +26,6 @@
|
|||||||
|
|
||||||
extern struct subsystem devices_subsys; /* needed for vio_find_name() */
|
extern struct subsystem devices_subsys; /* needed for vio_find_name() */
|
||||||
|
|
||||||
/**
|
|
||||||
* vio_match_device_pseries: - Tell if a pSeries VIO device matches a
|
|
||||||
* vio_device_id
|
|
||||||
*/
|
|
||||||
static int vio_match_device_pseries(const struct vio_device_id *id,
|
|
||||||
const struct vio_dev *dev)
|
|
||||||
{
|
|
||||||
return (strncmp(dev->type, id->type, strlen(id->type)) == 0) &&
|
|
||||||
device_is_compatible(dev->dev.platform_data, id->compat);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* vio_build_iommu_table: - gets the dma information from OF and
|
* vio_build_iommu_table: - gets the dma information from OF and
|
||||||
* builds the TCE tree.
|
* builds the TCE tree.
|
||||||
@ -76,7 +65,6 @@ static struct iommu_table *vio_build_iommu_table(struct vio_dev *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct vio_bus_ops vio_bus_ops_pseries = {
|
static struct vio_bus_ops vio_bus_ops_pseries = {
|
||||||
.match = vio_match_device_pseries,
|
|
||||||
.build_iommu_table = vio_build_iommu_table,
|
.build_iommu_table = vio_build_iommu_table,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -65,7 +65,6 @@ struct vio_driver {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct vio_bus_ops {
|
struct vio_bus_ops {
|
||||||
int (*match)(const struct vio_device_id *id, const struct vio_dev *dev);
|
|
||||||
struct iommu_table *(*build_iommu_table)(struct vio_dev *dev);
|
struct iommu_table *(*build_iommu_table)(struct vio_dev *dev);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user