Commit 3037a7b6 authored by K. Y. Srinivasan's avatar K. Y. Srinivasan Committed by Greg Kroah-Hartman

Staging: hv: vmbus: Introduce a utility function to match hv_vmbus_device_id

Introduce a utility function to match hv_vmbus_device_id.
Signed-off-by: default avatarK. Y. Srinivasan <kys@microsoft.com>
Signed-off-by: default avatarHaiyang Zhang <haiyangz@microsoft.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 25bb6c0a
...@@ -272,6 +272,22 @@ static inline bool is_null_guid(const __u8 *guid) ...@@ -272,6 +272,22 @@ static inline bool is_null_guid(const __u8 *guid)
return true; return true;
} }
/*
* Return a matching hv_vmbus_device_id pointer.
* If there is no match, return NULL.
*/
static const struct hv_vmbus_device_id *hv_vmbus_get_id(
const struct hv_vmbus_device_id *id,
__u8 *guid)
{
for (; !is_null_guid(id->guid); id++)
if (!memcmp(&id->guid, guid, sizeof(uuid_le)))
return id;
return NULL;
}
/* /*
* vmbus_match - Attempt to match the specified device to the specified driver * vmbus_match - Attempt to match the specified device to the specified driver
...@@ -280,12 +296,9 @@ static int vmbus_match(struct device *device, struct device_driver *driver) ...@@ -280,12 +296,9 @@ static int vmbus_match(struct device *device, struct device_driver *driver)
{ {
struct hv_driver *drv = drv_to_hv_drv(driver); struct hv_driver *drv = drv_to_hv_drv(driver);
struct hv_device *hv_dev = device_to_hv_device(device); struct hv_device *hv_dev = device_to_hv_device(device);
const struct hv_vmbus_device_id *id_array = drv->id_table;
for (; !is_null_guid(id_array->guid); id_array++) if (hv_vmbus_get_id(drv->id_table, hv_dev->dev_type.b))
if (!memcmp(&id_array->guid, &hv_dev->dev_type.b, return 1;
sizeof(uuid_le)))
return 1;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment