return mlxsw_reg_write(mlxsw_sx->core, MLXSW_REG(sspr), sspr_pl);
 }
 
-static int mlxsw_sx_port_module_check(struct mlxsw_sx_port *mlxsw_sx_port,
-                                     bool *p_usable)
+static int mlxsw_sx_port_module_info_get(struct mlxsw_sx *mlxsw_sx,
+                                        u8 local_port, u8 *p_width)
 {
-       struct mlxsw_sx *mlxsw_sx = mlxsw_sx_port->mlxsw_sx;
        char pmlp_pl[MLXSW_REG_PMLP_LEN];
        int err;
 
-       mlxsw_reg_pmlp_pack(pmlp_pl, mlxsw_sx_port->local_port);
+       mlxsw_reg_pmlp_pack(pmlp_pl, local_port);
        err = mlxsw_reg_query(mlxsw_sx->core, MLXSW_REG(pmlp), pmlp_pl);
        if (err)
                return err;
-       *p_usable = mlxsw_reg_pmlp_width_get(pmlp_pl) ? true : false;
+       *p_width = mlxsw_reg_pmlp_width_get(pmlp_pl);
        return 0;
 }
 
 {
        struct mlxsw_sx_port *mlxsw_sx_port;
        struct net_device *dev;
-       bool usable;
        int err;
 
        dev = alloc_etherdev(sizeof(struct mlxsw_sx_port));
         */
        dev->needed_headroom = MLXSW_TXHDR_LEN;
 
-       err = mlxsw_sx_port_module_check(mlxsw_sx_port, &usable);
-       if (err) {
-               dev_err(mlxsw_sx->bus_info->dev, "Port %d: Failed to check module\n",
-                       mlxsw_sx_port->local_port);
-               goto err_port_module_check;
-       }
-
-       if (!usable) {
-               dev_dbg(mlxsw_sx->bus_info->dev, "Port %d: Not usable, skipping initialization\n",
-                       mlxsw_sx_port->local_port);
-               goto port_not_usable;
-       }
-
        err = mlxsw_sx_port_system_port_mapping_set(mlxsw_sx_port);
        if (err) {
                dev_err(mlxsw_sx->bus_info->dev, "Port %d: Failed to set system port mapping\n",
        mlxsw_sx_port_swid_set(mlxsw_sx_port, MLXSW_PORT_SWID_DISABLED_PORT);
 err_port_swid_set:
 err_port_system_port_mapping_set:
-port_not_usable:
-err_port_module_check:
 err_dev_addr_get:
        free_percpu(mlxsw_sx_port->pcpu_stats);
 err_alloc_stats:
 static int mlxsw_sx_ports_create(struct mlxsw_sx *mlxsw_sx)
 {
        size_t alloc_size;
+       u8 width;
        int i;
        int err;
 
                return -ENOMEM;
 
        for (i = 1; i < MLXSW_PORT_MAX_PORTS; i++) {
+               err = mlxsw_sx_port_module_info_get(mlxsw_sx, i, &width);
+               if (err)
+                       goto err_port_module_info_get;
+               if (!width)
+                       continue;
                err = mlxsw_sx_port_create(mlxsw_sx, i);
                if (err)
                        goto err_port_create;
        return 0;
 
 err_port_create:
+err_port_module_info_get:
        for (i--; i >= 1; i--)
                mlxsw_sx_port_remove(mlxsw_sx, i);
        kfree(mlxsw_sx->ports);