2022.4.26:chrome100支持xp,堆栈大小问题

2022-05-10 12:49:53 浏览数 (2)

1,新版本v8确实恐怖,一上来就需要大堆栈,至少4M起步。

动态申请大堆栈的地方,是chromeappchrome_exe_main_win.cc的入口里。这里用到了技巧,就是用ConvertThreadToFiberEx可以申请大内存。

在v8的StackGuard::ThreadLocal::Initialize( ParseInfo::SetPerThreadState)里,会直接用当前堆栈地址GetCurrentStackPosition减去一个常量值,就成了堆栈溢出的检测值。

(题外话,触发堆栈溢出的话,会导致Genesis::InstallExtension里加载失败,从而v8启动失败。)

这时候,在xp上问题来了,xp的堆栈分配的比较小,如果不用ConvertThreadToFiberEx申请大内存堆栈(因为xp没有ConvertThreadToFiberEx),v8很容易就堆栈溢出了。

解决办法是用ConvertThreadToFiber来实现。

0 人点赞