uint64_t addr;
        /* Maximum region size in bytes. */
        uint64_t region_size;
+       /* Usable region size in bytes. */
+       uint64_t usable_region_size;
 
        /* The parent resource for all memory added via this device. */
        struct resource *parent_resource;
 static void virtio_mem_refresh_config(struct virtio_mem *vm)
 {
        const struct range pluggable_range = mhp_get_pluggable_range(true);
-       uint64_t new_plugged_size, usable_region_size, end_addr;
+       uint64_t new_plugged_size, end_addr;
 
        /* the plugged_size is just a reflection of what _we_ did previously */
        virtio_cread_le(vm->vdev, struct virtio_mem_config, plugged_size,
 
        /* calculate the last usable memory block id */
        virtio_cread_le(vm->vdev, struct virtio_mem_config,
-                       usable_region_size, &usable_region_size);
-       end_addr = min(vm->addr + usable_region_size - 1,
+                       usable_region_size, &vm->usable_region_size);
+       end_addr = min(vm->addr + vm->usable_region_size - 1,
                       pluggable_range.end);
 
        if (vm->in_sbm) {
        virtio_cread_le(vm->vdev, struct virtio_mem_config, addr, &vm->addr);
        virtio_cread_le(vm->vdev, struct virtio_mem_config, region_size,
                        &vm->region_size);
+       virtio_cread_le(vm->vdev, struct virtio_mem_config, usable_region_size,
+                       &vm->usable_region_size);
 
        /* Determine the nid for the device based on the lowest address. */
        if (vm->nid == NUMA_NO_NODE)