|
@@ -40,10 +40,14 @@ static const struct nla_policy nldev_policy[RDMA_NLDEV_ATTR_MAX] = {
|
|
|
[RDMA_NLDEV_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING,
|
|
|
.len = IB_DEVICE_NAME_MAX - 1},
|
|
|
[RDMA_NLDEV_ATTR_PORT_INDEX] = { .type = NLA_U32 },
|
|
|
+ [RDMA_NLDEV_ATTR_FW_VERSION] = { .type = NLA_NUL_STRING,
|
|
|
+ .len = IB_FW_VERSION_NAME_MAX - 1},
|
|
|
};
|
|
|
|
|
|
static int fill_dev_info(struct sk_buff *msg, struct ib_device *device)
|
|
|
{
|
|
|
+ char fw[IB_FW_VERSION_NAME_MAX];
|
|
|
+
|
|
|
if (nla_put_u32(msg, RDMA_NLDEV_ATTR_DEV_INDEX, device->index))
|
|
|
return -EMSGSIZE;
|
|
|
if (nla_put_string(msg, RDMA_NLDEV_ATTR_DEV_NAME, device->name))
|
|
@@ -56,6 +60,11 @@ static int fill_dev_info(struct sk_buff *msg, struct ib_device *device)
|
|
|
device->attrs.device_cap_flags, 0))
|
|
|
return -EMSGSIZE;
|
|
|
|
|
|
+ ib_get_device_fw_str(device, fw);
|
|
|
+ /* Device without FW has strlen(fw) */
|
|
|
+ if (strlen(fw) && nla_put_string(msg, RDMA_NLDEV_ATTR_FW_VERSION, fw))
|
|
|
+ return -EMSGSIZE;
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|