buffer_cache: avoid overflow in usage tracker (#13166)
This commit is contained in:
parent
9bc85dda5f
commit
1de37306a5
|
@ -26,6 +26,9 @@ public:
|
||||||
void Track(u64 offset, u64 size) noexcept {
|
void Track(u64 offset, u64 size) noexcept {
|
||||||
const size_t page = offset >> PAGE_SHIFT;
|
const size_t page = offset >> PAGE_SHIFT;
|
||||||
const size_t page_end = (offset + size) >> PAGE_SHIFT;
|
const size_t page_end = (offset + size) >> PAGE_SHIFT;
|
||||||
|
if (page_end < page || page_end >= pages.size()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
TrackPage(page, offset, size);
|
TrackPage(page, offset, size);
|
||||||
if (page == page_end) {
|
if (page == page_end) {
|
||||||
return;
|
return;
|
||||||
|
@ -41,6 +44,9 @@ public:
|
||||||
[[nodiscard]] bool IsUsed(u64 offset, u64 size) const noexcept {
|
[[nodiscard]] bool IsUsed(u64 offset, u64 size) const noexcept {
|
||||||
const size_t page = offset >> PAGE_SHIFT;
|
const size_t page = offset >> PAGE_SHIFT;
|
||||||
const size_t page_end = (offset + size) >> PAGE_SHIFT;
|
const size_t page_end = (offset + size) >> PAGE_SHIFT;
|
||||||
|
if (page_end < page || page_end >= pages.size()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (IsPageUsed(page, offset, size)) {
|
if (IsPageUsed(page, offset, size)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
Reference in New Issue