Lines Matching full:reserve
81 * @reserve: pool of memory from which devices reserve entitlement, incl. spare
94 struct vio_cmo_pool reserve; member
154 /* Determine the amount of free entitlement available in reserve */ in vio_cmo_alloc()
184 * the reserve pool is used to reduce device entitlement, the excess
185 * pool is used to increase the reserve pool toward the desired entitlement
211 /* Spare is a subset of the reserve pool, replenish it first. */ in vio_cmo_dealloc()
215 * Replenish the spare in the reserve pool from the excess pool. in vio_cmo_dealloc()
216 * This moves entitlement into the reserve pool. in vio_cmo_dealloc()
221 vio_cmo.reserve.size += tmp; in vio_cmo_dealloc()
229 * Replenish the spare in the reserve pool from the reserve pool. in vio_cmo_dealloc()
245 * Increase the reserve pool until the desired allocation is met. in vio_cmo_dealloc()
246 * Move an allocation freed from the excess pool into the reserve in vio_cmo_dealloc()
249 if (excess_freed && (vio_cmo.desired > vio_cmo.reserve.size)) { in vio_cmo_dealloc()
250 tmp = min(excess_freed, (vio_cmo.desired - vio_cmo.reserve.size)); in vio_cmo_dealloc()
253 vio_cmo.reserve.size += tmp; in vio_cmo_dealloc()
295 vio_cmo.reserve.size += tmp; in vio_cmo_entitlement_update()
378 * Upon completion sizes of the reserve and excess pools are calculated.
460 /* Calculate new reserve and excess pool sizes */ in vio_cmo_balance()
461 cmo->reserve.size = cmo->min; in vio_cmo_balance()
467 /* Calculated reserve size above the minimum entitlement */ in vio_cmo_balance()
469 cmo->reserve.size += (viodev->cmo.entitled - in vio_cmo_balance()
475 cmo->excess.size = cmo->entitled - cmo->reserve.size; in vio_cmo_balance()
667 * any reserve memory in the change region to the excess pool. in vio_cmo_set_dev_desired()
670 vio_cmo.reserve.size -= viodev->cmo.entitled - desired; in vio_cmo_set_dev_desired()
673 * If entitlement moving from the reserve pool to the in vio_cmo_set_dev_desired()
762 * the reserve pool. in vio_cmo_bus_probe()
787 vio_cmo.reserve.size += tmp; in vio_cmo_bus_probe()
849 * Save min allocation for device in reserve as long in vio_cmo_bus_remove()
855 /* Replenish spare from freed reserve pool */ in vio_cmo_bus_remove()
863 /* Remaining reserve goes to excess pool */ in vio_cmo_bus_remove()
866 vio_cmo.reserve.size -= viodev->cmo.entitled; in vio_cmo_bus_remove()
889 * Set up the reserve and excess entitlement pools based on available
891 * require entitlement in the reserve pool.
920 vio_cmo.reserve.size = vio_cmo.spare; in vio_cmo_bus_init()
921 vio_cmo.reserve.size += (vio_cmo_num_OF_devs() * in vio_cmo_bus_init()
923 if (vio_cmo.reserve.size > vio_cmo.entitled) { in vio_cmo_bus_init()
930 vio_cmo.excess.size = vio_cmo.entitled - vio_cmo.reserve.size; in vio_cmo_bus_init()
932 vio_cmo.min = vio_cmo.reserve.size; in vio_cmo_bus_init()
933 vio_cmo.desired = vio_cmo.reserve.size; in vio_cmo_bus_init()
1017 viobus_cmo_pool_rd_attr(reserve, size);