struct mlxsw_resources {
        u8      max_span_valid:1,
                max_lag_valid:1,
-               max_ports_in_lag_valid:1;
+               max_ports_in_lag_valid:1,
+               kvd_size_valid:1,
+               kvd_single_min_size_valid:1,
+               kvd_double_min_size_valid:1;
        u8      max_span;
        u8      max_lag;
        u8      max_ports_in_lag;
+       u32     kvd_size;
+       u32     kvd_single_min_size;
+       u32     kvd_double_min_size;
 };
 
 struct mlxsw_resources *mlxsw_core_resources_get(struct mlxsw_core *mlxsw_core);
 
 #define MLXSW_MAX_SPAN_ID 0x2420
 #define MLXSW_MAX_LAG_ID 0x2520
 #define MLXSW_MAX_PORTS_IN_LAG_ID 0x2521
+#define MLXSW_KVD_SIZE_ID 0x1001
+#define MLXSW_KVD_SINGLE_MIN_SIZE_ID 0x1002
+#define MLXSW_KVD_DOUBLE_MIN_SIZE_ID 0x1003
 #define MLXSW_RESOURCES_QUERY_MAX_QUERIES 100
 #define MLXSW_RESOURCES_PER_QUERY 32
 
                resources->max_ports_in_lag = val;
                resources->max_ports_in_lag_valid = 1;
                break;
+       case MLXSW_KVD_SIZE_ID:
+               resources->kvd_size = val;
+               resources->kvd_size_valid = 1;
+               break;
+       case MLXSW_KVD_SINGLE_MIN_SIZE_ID:
+               resources->kvd_single_min_size = val;
+               resources->kvd_single_min_size_valid = 1;
+               break;
+       case MLXSW_KVD_DOUBLE_MIN_SIZE_ID:
+               resources->kvd_double_min_size = val;
+               resources->kvd_double_min_size_valid = 1;
+               break;
        default:
                break;
        }