aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/HOS/Kernel/Memory/KSlabHeap.cs
blob: 9051e84cc279dbfb4dcc6e4faf4cb8585f1caa16 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
using System.Collections.Generic;

namespace Ryujinx.HLE.HOS.Kernel.Memory
{
    class KSlabHeap
    {
        private 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);
            }
        }
    }
}