MinGW编译平台的应用程序使用libcef.dll,当调用cef的capi接口时程序崩溃。调试单步到cef capi函数时,调试器报错“Cannot find bounds of current function”。

解决问题的思路在https://stackoverflow.com/questions/8741493/why-i-do-get-cannot-find-bound-of-current-function-when-i-overwrite-the-ret-ad

在windows平台需要使用嵌入浏览器cef,同时要使用c++11,又不想安装庞大的VS开发环境。选用了codeblocks-17.12mingw-nosetup作为开妇环境,压缩包不到100MB,MinGW gcc为2015年的5.1.0版本。支持同等c++11特性的vc编译器,应该是VS2015,即使是express版也有5G庞大。

http://opensource.spotify.com/cefbuilds/index.html#windows32_builds找到最低版本的libcef.3.2704.1414,体积约50M。笔者在其它软件找到体积更小,只有40M的libcef.dll.3.2171。如果不迷恋c++wrapper的话,下载后的cefbuild直接可以使用capi。如果已经习惯了<<inside c++ object model>>的思维和c面向对象的思维,就明白其实cef的capi已经经过面向对象思想设计。

有了开发环境codeblocks+MinGw,现成的库文件libcef.dll.3.2171,还有接口头文件libcef.3.2704.1414.zip。只要将win32的库文件转换成MinGw的链接库就可以使用。自然就是使用MinGw的工具导出def,然后导出.a库文件。

经过一番适配调整配置后,程序编译链接成功,但是运行失败了, 调试时gcc在运行cef capi处报错"Cannot find bounds of current function"。

这个错误并非没有加载到库文件,或者是没有加载到函数,而是函数边界问题。在stackoverflow有post讨论回答“It overwrites the current stack frame of your function with irrelevant data, and destroys the return address in the process, which is normally stored there among other things”。就是函数调用的栈帧被破坏。这事情在win平台开发比较常见, stdcall与cdecl,callee和caller谁负责平衡堆栈的问题,不一致时使得栈帧被破坏。WINAPI以及CALLBACK就是stdcall。而cef项目却有这么一个CEF_CALLBACK对win操作平台下的回调约定,自然就是stdcall。早期cef项目(这里指本文采用的3.27xx于2016年)不考虑对MinGW支持,预编译只有两大平台的分支COMPILER_MSVC与COMPLIER_GCC,诡异的就是MinGW是在WINOS上的GCC,所有十分尴尬。最新版的cef将CEF_CALLBACK的定义单独放置在一个预编译分支OS_WIN。

CEF_CALLBACK的定义在internal/cef_export.h。下面两个版本的文件对照:

3.2704.1414

#if defined(COMPILER_MSVC)

#ifdef BUILDING_CEF_SHARED
#define CEF_EXPORT __declspec(dllexport)
#elif USING_CEF_SHARED
#define CEF_EXPORT __declspec(dllimport)
#else
#define CEF_EXPORT
#endif
#define CEF_CALLBACK __stdcall #elif defined(COMPILER_GCC) #define CEF_EXPORT __attribute__ ((visibility("default")))
#define CEF_CALLBACK #endif // COMPILER_GCC #endif // CEF_INCLUDE_INTERNAL_CEF_EXPORT_H_

78.3.9

#if defined(COMPILER_MSVC)

#ifdef BUILDING_CEF_SHARED
#define CEF_EXPORT __declspec(dllexport)
#elif USING_CEF_SHARED
#define CEF_EXPORT __declspec(dllimport)
#else
#define CEF_EXPORT
#endif #elif defined(COMPILER_GCC) #define CEF_EXPORT __attribute__((visibility("default"))) #endif // COMPILER_GCC #if defined(OS_WIN)
#define CEF_CALLBACK __stdcall
#else
#define CEF_CALLBACK
#endif

问题迎刃而解。

Cannot find bounds of current function的更多相关文章

  1. GDB错误:Cannot find bounds of current function

    http://blog.csdn.net/zoomdy/article/details/17249165 mingdu.zheng <at> gmail <dot> com 使 ...

  2. Dynamics 365中计算字段与Now进行计算实体导入报错:You can't use Now(), which is of type DateTime, with the current function.

    微软动态CRM专家罗勇 ,回复338或者20190521可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me. 计算字段是从Dynamics CRM 2015 SP1版本开始推 ...

  3. linux网络编程学习笔记之五 -----并发机制与线程�

    进程线程分配方式 简述下常见的进程和线程分配方式:(好吧,我仅仅是举几个样例作为笔记...并发的水太深了,不敢妄谈...) 1.进程线程预分配 简言之,当I/O开销大于计算开销且并发量较大时,为了节省 ...

  4. 2018-2019-1 20189210 《LInux内核原理与分析》第六周作业

    系统调用实验(下): 将第四章的两个实验集成到MenuOS系统中,将其作为MenuOS系统的两个命令,新版本的menu中已经把两个系统调用添加进去了,只需重新克隆一个新版本的menu. 使用make ...

  5. 基于Linux-3.9.4内核的GDB跟踪系统调用实验

    382 + 原创作品转载请注明出处 + https://github.com/mengning/linuxkernel/ 一.实验环境 win10 -> VMware -> Ubuntu1 ...

  6. 2018-2019-1 20189221 《Linux内核原理与分析》第六周作业

    2018-2019-1 20189221 <Linux内核原理与分析>第六周作业 实验五 实验过程 将Fork函数移植到Linux的MenuOS fork()函数通过系统调用创建一个与原来 ...

  7. 2018-2019-1 20189218《Linux内核原理与分析》第六周作业

    向menuOS中增加命令 修改menu目录下的test.c文件,增加自己的函数定义,并在修改main()函数,按照前面的menuconfig的写法写好自己的menuconfig. 我选择的是acces ...

  8. GNU :6.47 Function Names as Strings

    链接:http://gcc.gnu.org/onlinedocs/gcc/Function-Names.html#Function-Names GCC provides three magic var ...

  9. Function Names as Strings

    [Function Names as Strings] GCC provides three magic variables that hold the name of the current fun ...

随机推荐

  1. modbus-poll和modbus-slave工具的学习使用——modbus协议功能码2的解析

    功能码2的功能是:读从机离散量输入信号的 ON/OFF 状态.可读取1-2000个连续的离散量输入状态,如果离散输入的数量个数不是8的整数倍,则用0填充最后数据字节的剩余位,功能码2的查询信息规定了要 ...

  2. 手写队列以及stl中队列的使用

    一,手写队列. struct queue { ; ,rear=,a[maxn]; void push(int x) { a[++rear]=x; } void pop() { first++; } i ...

  3. LeetCode 845. Longest Mountain in Array

    原题链接在这里:https://leetcode.com/problems/longest-mountain-in-array/ 题目: Let's call any (contiguous) sub ...

  4. BZOJ 5469: [FJOI2018]领导集团问题 dp+线段树合并

    在 dp 问题中,如果发现可以用后缀最大值来进行转移的话可以考虑去查分这个后缀最大值. 这样的话可以用差分的方式来方便地进行维护 ~ #include <bits/stdc++.h> #d ...

  5. 通过HttpServletRequest重写+filter 添加header

    问题说明 需要做的事情比较简单,就是通过filter 重写httpservletrequest ,同时给予request 添加header 主要是通过HttpServletRequestWrapper ...

  6. dinoql 使用graphql 语法查询javascript objects

    dinoql 是一个不错的基于graphql 语法查询javascript objects 的工具包,包含以下特性 graphql 语法(很灵活) 安全的访问(当keys 不存在的时候,不会抛出运行时 ...

  7. ubuntu编译PCRE时出现 line 81: aclocal-1.14: command not found错误

    WARNING: 'aclocal-1.14' is missing on your system. You should only need it if you modified 'acinclud ...

  8. P2340 奶牛会展 DP 背包

    P2340 奶牛会展 DP \(n\)头牛,每头牛有智商\(s[i]\)情商\(f[i]\),问如何从中选择几头牛使得智商情商之和最大 且 情商之和.智商之和非负 \(n\le 400,-10^3\l ...

  9. matrix67中适合程序员的例子

    交互式证明:http://www.matrix67.com/blog/archives/6572 捡石子游戏(移动皇后问题):http://www.matrix67.com/blog/archives ...

  10. 第03组 团队git现场编程实战

    1.组员职责分工 张逸杰:复制监督整个编程任务的进程以及协助组员编程 黄智锋.刘汪洋:负责UI设计 苏凯婷.鲍冰如:爬取数据并负责测评出福州最受欢迎的商圈 陈荣杰.杨锦镔:爬取数据并负责测评出福州人均 ...