mlxsw: core_linecards: Expose device PSID over device info
authorJiri Pirko <jiri@nvidia.com>
Mon, 25 Jul 2022 08:29:22 +0000 (10:29 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 26 Jul 2022 20:56:36 +0000 (13:56 -0700)
Use tunneled MGIR to obtain PSID of line card device and extend
device_info_get() op to fill up the info with that.

Example:

$ devlink dev info auxiliary/mlxsw_core.lc.0
auxiliary/mlxsw_core.lc.0:
  versions:
      fixed:
        hw.revision 0
        fw.psid MT_0000000749
      running:
        ini.version 4
        fw 19.2010.1312

Signed-off-by: Jiri Pirko <jiri@nvidia.com>
Reviewed-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Documentation/networking/devlink/mlxsw.rst
drivers/net/ethernet/mellanox/mlxsw/core.h
drivers/net/ethernet/mellanox/mlxsw/core_linecards.c

index 65ceed98f94da18bcf2d5329deb7ef0b711b0f76..433962225bd4f71ef1805cde11bf1b3b60b1de42 100644 (file)
@@ -75,6 +75,9 @@ The ``mlxsw`` driver reports the following versions for line card auxiliary devi
    * - ``ini.version``
      - running
      - Version of line card INI loaded
+   * - ``fw.psid``
+     - fixed
+     - Line card device PSID
    * - ``fw.version``
      - running
      - Three digit firmware version of line card device
index e4c6f8a6e016c651d6a6346bcc60711a6ab2dff1..57849888139f6d421e3c1447c6c4f90c809a25b0 100644 (file)
@@ -570,6 +570,7 @@ struct mlxsw_linecard_device_info {
        u16 fw_major;
        u16 fw_minor;
        u16 fw_sub_minor;
+       char psid[MLXSW_REG_MGIR_FW_INFO_PSID_SIZE];
 };
 
 struct mlxsw_linecard {
index a9568d72ba1bff1cb00959395a33605619a531fd..771a3e43b8bb04341e5871fa3ee73e8242512c79 100644 (file)
@@ -87,6 +87,27 @@ static const char *mlxsw_linecard_type_name(struct mlxsw_linecard *linecard)
        return linecard->name;
 }
 
+static int mlxsw_linecard_device_psid_get(struct mlxsw_linecard *linecard,
+                                         u8 device_index, char *psid)
+{
+       struct mlxsw_core *mlxsw_core = linecard->linecards->mlxsw_core;
+       char mddt_pl[MLXSW_REG_MDDT_LEN];
+       char *mgir_pl;
+       int err;
+
+       mlxsw_reg_mddt_pack(mddt_pl, linecard->slot_index, device_index,
+                           MLXSW_REG_MDDT_METHOD_QUERY,
+                           MLXSW_REG(mgir), &mgir_pl);
+
+       mlxsw_reg_mgir_pack(mgir_pl);
+       err = mlxsw_reg_query(mlxsw_core, MLXSW_REG(mddt), mddt_pl);
+       if (err)
+               return err;
+
+       mlxsw_reg_mgir_fw_info_psid_memcpy_from(mgir_pl, psid);
+       return 0;
+}
+
 static int mlxsw_linecard_device_info_update(struct mlxsw_linecard *linecard)
 {
        struct mlxsw_core *mlxsw_core = linecard->linecards->mlxsw_core;
@@ -121,6 +142,12 @@ static int mlxsw_linecard_device_info_update(struct mlxsw_linecard *linecard)
                                      linecard->slot_index);
                        return 0;
                }
+
+               err = mlxsw_linecard_device_psid_get(linecard, device_index,
+                                                    info.psid);
+               if (err)
+                       return err;
+
                linecard->device.info = info;
                flashable_found = true;
        } while (msg_seq);
@@ -293,6 +320,10 @@ int mlxsw_linecard_devlink_info_get(struct mlxsw_linecard *linecard,
        if (linecard->active) {
                struct mlxsw_linecard_device_info *info = &linecard->device.info;
 
+               err = devlink_info_version_fixed_put(req,
+                                                    DEVLINK_INFO_VERSION_GENERIC_FW_PSID,
+                                                    info->psid);
+
                sprintf(buf, "%u.%u.%u", info->fw_major, info->fw_minor,
                        info->fw_sub_minor);
                err = devlink_info_version_running_put(req,