In x-Buddy system, the random-interleaved page allocation
for multi-threaded workloads can be achieved by randomly
selecting pages in the order-0 free list. Moreover,
similar effect achieved by M3 [27] can be also supported in
x-Buddy by allocating physical pages with all 32 colors
(0000011111) in a round-robin fashion and interleaving
requested pages evenly across all banks to reduce the potential
bank conflicts. Based on the x-Buddy system, we develop
a hash-based searching algorithm (see Pseudocode 1) to
allocate a page in O(1) time (O(logn) time complexity in
extreme cases, where memory blocks are frequently merging
and splitting).