mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-12-01 01:36:09 +03:00
40 lines
1.2 KiB
C++
40 lines
1.2 KiB
C++
|
// Copyright 2015 The Chromium Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
// found in the LICENSE file.
|
||
|
|
||
|
#include "base/threading/platform_thread_internal_posix.h"
|
||
|
|
||
|
#include "base/containers/adapters.h"
|
||
|
#include "base/logging.h"
|
||
|
|
||
|
namespace base {
|
||
|
|
||
|
namespace internal {
|
||
|
|
||
|
int ThreadPriorityToNiceValue(ThreadPriority priority) {
|
||
|
for (const auto& pair : kThreadPriorityToNiceValueMap) {
|
||
|
if (pair.priority == priority)
|
||
|
return pair.nice_value;
|
||
|
}
|
||
|
NOTREACHED() << "Unknown ThreadPriority";
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
ThreadPriority NiceValueToThreadPriority(int nice_value) {
|
||
|
// Try to find a priority that best describes |nice_value|. If there isn't
|
||
|
// an exact match, this method returns the closest priority whose nice value
|
||
|
// is higher (lower priority) than |nice_value|.
|
||
|
for (const auto& pair : Reversed(kThreadPriorityToNiceValueMap)) {
|
||
|
if (pair.nice_value >= nice_value)
|
||
|
return pair.priority;
|
||
|
}
|
||
|
|
||
|
// Reaching here means |nice_value| is more than any of the defined
|
||
|
// priorities. The lowest priority is suitable in this case.
|
||
|
return ThreadPriority::BACKGROUND;
|
||
|
}
|
||
|
|
||
|
} // namespace internal
|
||
|
|
||
|
} // namespace base
|