在 2017/9/20 5:18, Jason Gunthorpe 写道: > Use the new verbs infrastructure to match providers against modalias > files. This changes the parse of the compatible string to one > that is based on modalias instead of directly reading the compatible > string. > > Signed-off-by: Jason Gunthorpe <jgunthorpe@xxxxxxxxxxxxxxxxxxxx> > --- > providers/hns/hns_roce_u.c | 52 +++++++--------------------------------- > providers/hns/hns_roce_u.h | 1 + > providers/hns/hns_roce_u_hw_v1.c | 1 + > 3 files changed, 10 insertions(+), 44 deletions(-) > > diff --git a/providers/hns/hns_roce_u.c b/providers/hns/hns_roce_u.c > index 88389721811fce..c27212ac7fb603 100644 > --- a/providers/hns/hns_roce_u.c > +++ b/providers/hns/hns_roce_u.c > @@ -44,20 +44,11 @@ > #define HID_LEN 15 > #define DEV_MATCH_LEN 128 > > -struct hca_ent { > - const char *str; > - struct hns_roce_u_hw *data; > - int version; > -}; > - > -static const struct hca_ent acpi_table[] = { > - {"acpi:HISI00D1:", &hns_roce_u_hw_v1, HNS_ROCE_HW_VER1}, > - {}, > -}; > - > -static const struct hca_ent dt_table[] = { > - {"hisilicon,hns-roce-v1", &hns_roce_u_hw_v1, HNS_ROCE_HW_VER1}, > - {}, > +static const struct verbs_match_ent hca_table[] = { > + VERBS_MODALIAS_MATCH("acpi*:HISI00D1:*", &hns_roce_u_hw_v1), > + VERBS_MODALIAS_MATCH("of:N*T*Chisilicon,hns-roce-v1C*", &hns_roce_u_hw_v1), > + VERBS_MODALIAS_MATCH("of:N*T*Chisilicon,hns-roce-v1", &hns_roce_u_hw_v1), > + {} > }; > > static struct ibv_context *hns_roce_alloc_context(struct ibv_device *ibdev, > @@ -178,43 +169,16 @@ static void hns_uninit_device(struct verbs_device *verbs_device) > free(dev); > } > > -static bool hns_device_match(struct verbs_sysfs_dev *sysfs_dev) > -{ > - const char *uverbs_sys_path = sysfs_dev->sysfs_path; > - char value[128]; > - int i; > - > - if (ibv_read_sysfs_file(uverbs_sys_path, "device/modalias", > - value, sizeof(value)) > 0) > - for (i = 0; i < sizeof(acpi_table) / sizeof(acpi_table[0]); ++i) > - if (!strcmp(value, acpi_table[i].str)) { > - sysfs_dev->provider_data = > - (void *)&acpi_table[i]; > - return true; > - } > - > - if (ibv_read_sysfs_file(uverbs_sys_path, "device/of_node/compatible", > - value, sizeof(value)) > 0) > - for (i = 0; i < sizeof(dt_table) / sizeof(dt_table[0]); ++i) > - if (!strcmp(value, dt_table[i].str)) { > - sysfs_dev->provider_data = (void *)&dt_table[i]; > - return true; > - } > - > - return false; > -} > - > static struct verbs_device *hns_device_alloc(struct verbs_sysfs_dev *sysfs_dev) > { > struct hns_roce_device *dev; > - const struct hca_ent *hca_ent = sysfs_dev->provider_data; > > dev = calloc(1, sizeof(*dev)); > if (!dev) > return NULL; > > - dev->u_hw = hca_ent->data; > - dev->hw_version = hca_ent->version; > + dev->u_hw = sysfs_dev->match->driver_data; > + dev->hw_version = dev->u_hw->hw_version; > dev->page_size = sysconf(_SC_PAGESIZE); > return &dev->ibv_dev; > } > @@ -223,7 +187,7 @@ static const struct verbs_device_ops hns_roce_dev_ops = { > .name = "hns", > .match_min_abi_version = 0, > .match_max_abi_version = INT_MAX, > - .match_device = hns_device_match, > + .match_table = hca_table, > .alloc_device = hns_device_alloc, > .uninit_device = hns_uninit_device, > .alloc_context = hns_roce_alloc_context, > diff --git a/providers/hns/hns_roce_u.h b/providers/hns/hns_roce_u.h > index dc8956af4f8fae..d0e2351fc7fc4c 100644 > --- a/providers/hns/hns_roce_u.h > +++ b/providers/hns/hns_roce_u.h > @@ -170,6 +170,7 @@ struct hns_roce_qp { > }; > > struct hns_roce_u_hw { > + uint32_t hw_version; > int (*poll_cq)(struct ibv_cq *ibvcq, int ne, struct ibv_wc *wc); > int (*arm_cq)(struct ibv_cq *ibvcq, int solicited); > int (*post_send)(struct ibv_qp *ibvqp, struct ibv_send_wr *wr, > diff --git a/providers/hns/hns_roce_u_hw_v1.c b/providers/hns/hns_roce_u_hw_v1.c > index 0de94e1fabd3d9..482eac90df2183 100644 > --- a/providers/hns/hns_roce_u_hw_v1.c > +++ b/providers/hns/hns_roce_u_hw_v1.c > @@ -829,6 +829,7 @@ out: > } > > struct hns_roce_u_hw hns_roce_u_hw_v1 = { > + .hw_version = HNS_ROCE_HW_VER1, > .poll_cq = hns_roce_u_v1_poll_cq, > .arm_cq = hns_roce_u_v1_arm_cq, > .post_send = hns_roce_u_v1_post_send, > Acked-by: Lijun Ou <oulijun@xxxxxxxxxx> -- To unsubscribe from this list: send the line "unsubscribe linux-rdma" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html