OpenBMC的c++代码中的变量初始化问题(二)

2024-02-24 18:36

本文主要是介绍OpenBMC的c++代码中的变量初始化问题(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 开发平台

Win11、VS2022、Fedora39。

2 作业目的

通过VS2022跨平台Linux构建openbmc/intel-ipmi-oem的x64可执行模块。

3 问题描述

该模块启动后,出现以下异常:

上图中的调用堆栈消息是:

       std::__uniq_ptr_impl<sd_bus, sdbusplus::bus::details::BusDeleter>::_M_ptr(const std::__uniq_ptr_impl<sd_bus, sdbusplus::bus::details::BusDeleter> * const this) Line 199      C++

      std::unique_ptr<sd_bus, sdbusplus::bus::details::BusDeleter>::get(const std::unique_ptr<sd_bus, sdbusplus::bus::details::BusDeleter> * const this) Line 470      C++

      sdbusplus::bus::bus::get(sdbusplus::bus::bus * const this) Line 501 C++

      sdbusplus::bus::details::bus_friend::get_busp(sdbusplus::bus::bus & b) Line 616   C++

      libsdbusplus.so.1!sdbusplus::bus::match::match::match(sdbusplus::bus::bus&, char const*, std::function<void (sdbusplus::message::message&)>)(sdbusplus::bus::match::match * const this, sdbusplus::bus_t & bus, const char * _match, sdbusplus::bus::match::match::callback_t callback) Line 40 C++

      __static_initialization_and_destruction_0() Line 102   C++

      _GLOBAL__sub_I__ZN4ipmi10sensorTreeB5cxx11E() Line 1893       C++

      libc.so.6!__libc_start_main_impl  

      _start     

根据上述消息,异常发生在main函数执行之前的全局变量初始化,其中出现了变量名sensorTree。

sensorTree的定义在sensorcommands.cpp中:

SensorSubTree sensorTree;

类型名SensorSubTree的定义在sdrutils.hpp中:

using SensorSubTree = boost::container::flat_map<std::string,boost::container::flat_map<std::string, std::vector<std::string>>,CmpStrVersion>;

4 解决方法

调用堆栈消息中出现了大量的match,但是看不出SensorSubTree与match有何关联。

在sensorTree的定义下面有三个函数的定义中出现了match:

static sdbusplus::bus::match_t sensorAdded(

static sdbusplus::bus::match_t sensorRemoved(

static sdbusplus::bus::match_t thresholdChanged(

经搜索发现这三个函数都没有被调用,于是把它们注掉。

重新编译后运行时没有出现上述异常。

以上解决方法实属侥幸,请有识之士赐教。

这篇关于OpenBMC的c++代码中的变量初始化问题(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742991

相关文章

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一