using System.Collections.Generic;

namespace Ryujinx.HLE.HOS.Kernel.Memory
{
    class KSlabHeap
    {
        private readonly LinkedList<ulong> _items;

        public KSlabHeap(ulong pa, ulong itemSize, ulong size)
        {
            _items = new LinkedList<ulong>();

            int itemsCount = (int)(size / itemSize);

            for (int index = 0; index < itemsCount; index++)
            {
                _items.AddLast(pa);

                pa += itemSize;
            }
        }

        public bool TryGetItem(out ulong pa)
        {
            lock (_items)
            {
                if (_items.First != null)
                {
                    pa = _items.First.Value;

                    _items.RemoveFirst();

                    return true;
                }
            }

            pa = 0;

            return false;
        }

        public void Free(ulong pa)
        {
            lock (_items)
            {
                _items.AddFirst(pa);
            }
        }
    }
}