mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-03 11:11:14 +00:00
kern: simplify random bitmap selection to match latest Nintendo logic
This commit is contained in:
parent
273f4a87ae
commit
ebca23305e
1 changed files with 9 additions and 28 deletions
|
@ -50,37 +50,18 @@ namespace ams::kern {
|
||||||
size_t SelectRandomBit(u64 bitmap) {
|
size_t SelectRandomBit(u64 bitmap) {
|
||||||
u64 selected = 0;
|
u64 selected = 0;
|
||||||
|
|
||||||
u64 cur_num_bits = BITSIZEOF(bitmap) / 2;
|
for (size_t cur_num_bits = BITSIZEOF(bitmap) / 2; cur_num_bits != 0; cur_num_bits /= 2) {
|
||||||
u64 cur_mask = (1ull << cur_num_bits) - 1;
|
const u64 high = (bitmap >> cur_num_bits);
|
||||||
|
const u64 low = (bitmap & (~(UINT64_C(0xFFFFFFFFFFFFFFFF) << cur_num_bits)));
|
||||||
|
|
||||||
while (cur_num_bits) {
|
/* Choose high if we have high and (don't have low or select high randomly). */
|
||||||
const u64 low = (bitmap >> 0) & cur_mask;
|
if (high && (low == 0 || this->GenerateRandomBit())) {
|
||||||
const u64 high = (bitmap >> cur_num_bits) & cur_mask;
|
|
||||||
|
|
||||||
bool choose_low;
|
|
||||||
if (high == 0) {
|
|
||||||
/* If only low val is set, choose low. */
|
|
||||||
choose_low = true;
|
|
||||||
} else if (low == 0) {
|
|
||||||
/* If only high val is set, choose high. */
|
|
||||||
choose_low = false;
|
|
||||||
} else {
|
|
||||||
/* If both are set, choose random. */
|
|
||||||
choose_low = this->GenerateRandomBit();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If we chose low, proceed with low. */
|
|
||||||
if (choose_low) {
|
|
||||||
bitmap = low;
|
|
||||||
selected += 0;
|
|
||||||
} else {
|
|
||||||
bitmap = high;
|
bitmap = high;
|
||||||
selected += cur_num_bits;
|
selected += cur_num_bits;
|
||||||
|
} else {
|
||||||
|
bitmap = low;
|
||||||
|
selected += 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Proceed. */
|
|
||||||
cur_num_bits /= 2;
|
|
||||||
cur_mask >>= cur_num_bits;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return selected;
|
return selected;
|
||||||
|
|
Loading…
Reference in a new issue