ProfileViewer: Interpret addresses >= 0xc0000000 as kernel frames
This commit is contained in:
parent
32ec1e5aed
commit
efbdaaaa65
Notes:
sideshowbarker
2024-07-19 10:25:18 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/efbdaaaa655
2 changed files with 3 additions and 2 deletions
|
@ -35,7 +35,8 @@ Profile::Profile(const JsonArray& json)
|
|||
if (frames_array.size() < 2)
|
||||
continue;
|
||||
|
||||
sample.in_kernel = frames_array.at(1).as_object().get("address").to_number<u32>() < (8 * MB);
|
||||
u32 innermost_frame_address = frames_array.at(1).as_object().get("address").to_number<u32>();
|
||||
sample.in_kernel = innermost_frame_address >= 0xc0000000 || innermost_frame_address < (8 * MB);
|
||||
|
||||
for (int i = frames_array.size() - 1; i >= 1; --i) {
|
||||
auto& frame_value = frames_array.at(i);
|
||||
|
|
|
@ -92,7 +92,7 @@ GVariant ProfileModel::data(const GModelIndex& index, Role role) const
|
|||
auto* node = static_cast<ProfileNode*>(index.internal_data());
|
||||
if (role == Role::Icon) {
|
||||
if (index.column() == Column::StackFrame) {
|
||||
if (node->address() < (8 * MB))
|
||||
if (node->address() < (8 * MB) || node->address() >= 0xc0000000)
|
||||
return m_kernel_frame_icon;
|
||||
return m_user_frame_icon;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue