From dca3105df5b86269eb2d4570e13e96555e6d8fee Mon Sep 17 00:00:00 2001 From: etkmao Date: Mon, 30 Dec 2024 20:23:21 +0800 Subject: [PATCH 1/3] fix(v8): v8 code cache file broken protect --- driver/js/src/js_driver_utils.cc | 50 +++++++++++++++++++++++++++ modules/vfs/native/include/vfs/file.h | 1 + modules/vfs/native/src/file.cc | 9 +++++ 3 files changed, 60 insertions(+) diff --git a/driver/js/src/js_driver_utils.cc b/driver/js/src/js_driver_utils.cc index e3b91d4d746..ae43abaaad8 100644 --- a/driver/js/src/js_driver_utils.cc +++ b/driver/js/src/js_driver_utils.cc @@ -80,6 +80,8 @@ constexpr char kGlobalKey[] = "global"; constexpr char kHippyKey[] = "Hippy"; constexpr char kNativeGlobalKey[] = "__HIPPYNATIVEGLOBAL__"; constexpr char kCallHostKey[] = "hippyCallNatives"; +constexpr char kCodeCacheFailCountFilePostfix[] = "_fail_count"; +const uint8_t kCodeCacheMaxFailCount = 3; #if defined(JS_V8) && defined(ENABLE_INSPECTOR) && !defined(V8_WITHOUT_INSPECTOR) using V8InspectorClientImpl = hippy::inspector::V8InspectorClientImpl; @@ -91,6 +93,7 @@ using DevtoolsDataSource = hippy::devtools::DevtoolsDataSource; static std::unordered_map, uint32_t>> reuse_engine_map; static std::mutex engine_mutex; +static std::mutex code_cache_file_mutex; void AsyncInitializeEngine(const std::shared_ptr& engine, const std::shared_ptr& task_runner, @@ -269,6 +272,39 @@ void JsDriverUtils::InitInstance( }); } +// Code cache file corruption prevention strategy: +// Record count before RunScript, clean count after RunScript, and if only start recording three times in a row, clean the code cache file. +bool CheckUseCodeCacheBeforeRunScript(const string_view& code_cache_path) { + string_view fail_count_path = code_cache_path + string_view(kCodeCacheFailCountFilePostfix); + u8string content; + HippyFile::ReadFile(fail_count_path, content, false); + if (content.length() == 1) { + uint8_t count = content[0]; + if (count >= kCodeCacheMaxFailCount) { + FOOTSTONE_LOG(INFO) << "Check code cache, count >= 3"; + // need to remove code cache file + return false; + } else { + FOOTSTONE_LOG(INFO) << "Check code cache, count = " << static_cast(count); + ++count; + std::string saveContent; + saveContent.push_back(count); + HippyFile::SaveFile(fail_count_path, saveContent); + } + } else { + FOOTSTONE_LOG(INFO) << "Check code cache, no count"; + std::string saveContent; + saveContent.push_back(1); + HippyFile::SaveFile(fail_count_path, saveContent); + } + return true; +} + +void CheckUseCodeCacheAfterRunScript(const string_view& code_cache_path) { + string_view fail_count_path = code_cache_path + string_view(kCodeCacheFailCountFilePostfix); + HippyFile::RmFile(fail_count_path); +} + bool JsDriverUtils::RunScript(const std::shared_ptr& scope, const string_view& file_name, bool is_use_code_cache, @@ -298,6 +334,7 @@ bool JsDriverUtils::RunScript(const std::shared_ptr& scope, auto engine = scope->GetEngine().lock(); FOOTSTONE_CHECK(engine); auto func = hippy::base::MakeCopyable([p = std::move(read_file_promise), code_cache_path, code_cache_dir]() mutable { + std::lock_guard lock(code_cache_file_mutex); u8string content; HippyFile::ReadFile(code_cache_path, content, true); if (content.empty()) { @@ -307,6 +344,12 @@ bool JsDriverUtils::RunScript(const std::shared_ptr& scope, FOOTSTONE_USE(ret); } else { FOOTSTONE_DLOG(INFO) << "Read code cache succ"; + if (!CheckUseCodeCacheBeforeRunScript(code_cache_path)) { + int ret = HippyFile::RmFullPath(code_cache_dir); + FOOTSTONE_DLOG(INFO) << "RmFullPath on check, ret = " << ret; + FOOTSTONE_USE(ret); + content.clear(); + } } p.set_value(std::move(content)); }); @@ -332,6 +375,10 @@ bool JsDriverUtils::RunScript(const std::shared_ptr& scope, if (!read_script_flag || StringViewUtils::IsEmpty(script_content)) { FOOTSTONE_LOG(WARNING) << "read_script_flag = " << read_script_flag << ", script content empty, uri = " << uri; + if (is_use_code_cache) { + std::lock_guard lock(code_cache_file_mutex); + CheckUseCodeCacheAfterRunScript(code_cache_path); + } return false; } @@ -345,6 +392,7 @@ bool JsDriverUtils::RunScript(const std::shared_ptr& scope, if (is_use_code_cache) { if (!StringViewUtils::IsEmpty(code_cache_content)) { auto func = [code_cache_path, code_cache_dir, code_cache_content] { + std::lock_guard lock(code_cache_file_mutex); int check_dir_ret = HippyFile::CheckDir(code_cache_dir, F_OK); FOOTSTONE_DLOG(INFO) << "check_parent_dir_ret = " << check_dir_ret; if (check_dir_ret) { @@ -364,6 +412,8 @@ bool JsDriverUtils::RunScript(const std::shared_ptr& scope, bool save_file_ret = HippyFile::SaveFile(code_cache_path, u8_code_cache_content); FOOTSTONE_LOG(INFO) << "code cache save_file_ret = " << save_file_ret; FOOTSTONE_USE(save_file_ret); + + CheckUseCodeCacheAfterRunScript(code_cache_path); }; auto engine = scope->GetEngine().lock(); FOOTSTONE_CHECK(engine); diff --git a/modules/vfs/native/include/vfs/file.h b/modules/vfs/native/include/vfs/file.h index 98ab2941910..fd3088a31df 100644 --- a/modules/vfs/native/include/vfs/file.h +++ b/modules/vfs/native/include/vfs/file.h @@ -46,6 +46,7 @@ class HippyFile { std::ios::openmode mode = std::ios::out | std::ios::binary | std::ios::trunc); + static int RmFile(const string_view& file_path); static int RmFullPath(const string_view& dir_full_path); static int CreateDir(const string_view& dir_path, mode_t mode); static int CheckDir(const string_view& dir_path, int mode); diff --git a/modules/vfs/native/src/file.cc b/modules/vfs/native/src/file.cc index 7f51040f271..b2b99ab3c36 100644 --- a/modules/vfs/native/src/file.cc +++ b/modules/vfs/native/src/file.cc @@ -51,6 +51,15 @@ bool HippyFile::SaveFile(const string_view& file_path, } } +int HippyFile::RmFile(const string_view& file_path) { + FOOTSTONE_DLOG(INFO) << "RmFile file_path = " << file_path; + auto path_str = StringViewUtils::ConvertEncoding(file_path, + string_view::Encoding::Utf8).utf8_value(); + auto path = reinterpret_cast(path_str.c_str()); + unlink(path); + return 0; +} + int HippyFile::RmFullPath(const string_view& dir_full_path) { FOOTSTONE_DLOG(INFO) << "RmFullPath dir_full_path = " << dir_full_path; auto path_str = StringViewUtils::ConvertEncoding(dir_full_path, From 68ba15e8239f19b8e572f6a3592a8048dfd3e36e Mon Sep 17 00:00:00 2001 From: etkmao Date: Thu, 2 Jan 2025 14:29:33 +0800 Subject: [PATCH 2/3] fix(jsc): fix ios c autorelease (#4162) --- modules/footstone/src/platform/ios/looper_driver.cc | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/modules/footstone/src/platform/ios/looper_driver.cc b/modules/footstone/src/platform/ios/looper_driver.cc index eac5e0d0bcb..0d0a502d18c 100644 --- a/modules/footstone/src/platform/ios/looper_driver.cc +++ b/modules/footstone/src/platform/ios/looper_driver.cc @@ -31,6 +31,9 @@ static constexpr CFTimeInterval kInterval = IOS_WORKER_TIME_INTERVAL; static constexpr CFTimeInterval kInterval = 1.0e10; #endif +extern "C" void * objc_autoreleasePoolPush(void); +extern "C" void objc_autoreleasePoolPop(void *); + static void OnTimerCb(CFRunLoopTimerRef timer, LooperDriver* driver) { FOOTSTONE_DCHECK(driver); driver->OnTimerFire(timer); @@ -88,7 +91,9 @@ void LooperDriver::OnTimerFire(CFRunLoopTimerRef timer) { if (IsExitImmediately()) { return; } + auto obj = objc_autoreleasePoolPush(); unit_(); + objc_autoreleasePoolPop(obj); } } From 3b59a7d921127a97ec9f15dd5db065c63a9d375b Mon Sep 17 00:00:00 2001 From: etkmao Date: Thu, 2 Jan 2025 14:36:48 +0800 Subject: [PATCH 3/3] fix(core): fix code owner file (#4163) --- .github/CODEOWNERS | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index fa181119ca9..c8c211c9e97 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -9,14 +9,14 @@ # # universal files -* @ilikethese @etkmao +* @etkmao # cmake related -*.cmake @ilikethese @etkmao -CMakeLists.txt @ilikethese @etkmao +*.cmake @etkmao +CMakeLists.txt @etkmao # driver: js -/driver/js/ @etkmao @ilikethese +/driver/js/ @etkmao /driver/js/*.js @zealotchen0 /driver/js/.eslintignore @zealotchen0 /driver/js/.eslintrc.js @zealotchen0 @@ -31,11 +31,11 @@ CMakeLists.txt @ilikethese @etkmao /driver/js/packages/ @zealotchen0 # driver: vl: -/driver/vl/ @ilikethese @etkmao +/driver/vl/ @etkmao # framework: android /framework/android/ @siguangli @iPel -/framework/android/**/src/main/cpp/ @etkmao @ilikethese +/framework/android/**/src/main/cpp/ @etkmao # framework: ios /framework/ios/ @wwwcg @ruifanyuan @@ -44,7 +44,7 @@ CMakeLists.txt @ilikethese @etkmao /framework/voltron/ @lvfen @henryjin0511 # dom: others -/dom/ @etkmao @ilikethese +/dom/ @etkmao # renderer: native /renderer/native/android/ @siguangli @iPel @@ -53,16 +53,16 @@ CMakeLists.txt @ilikethese @etkmao # renderer: tdf /renderer/tdf/ @vimerzhao /renderer/tdf/android/ @siguangli @iPel -/renderer/tdf/android/**/src/main/cpp/ @ilikethese @etkmao +/renderer/tdf/android/**/src/main/cpp/ @etkmao /renderer/tdf/ios/ @wwwcg @ruifanyuan # renderer: voltron /renderer/voltron/ @lvfen @henryjin0511 # module: vfs -/modules/vfs/ @etkmao @ilikethese +/modules/vfs/ @etkmao /modules/vfs/android/ @siguangli @iPel -/modules/vfs/android/**/src/main/cpp/ @etkmao @ilikethese +/modules/vfs/android/**/src/main/cpp/ @etkmao /modules/vfs/ios/ @wwwcg @ruifanyuan /modules/vfs/voltron/ @lvfen @henryjin0511 @@ -71,13 +71,13 @@ CMakeLists.txt @ilikethese @etkmao # module: android /modules/android/ @siguangli @iPel -/modules/android/jni/ @etkmao @ilikethese +/modules/android/jni/ @etkmao # module: ios /modules/ios/ @wwwcg @ruifanyuan # module: footstone -/modules/footstone/ @etkmao @ilikethese +/modules/footstone/ @etkmao # devtools: backend /devtools/ @lavnFan @@ -110,7 +110,7 @@ CMakeLists.txt @ilikethese @etkmao /xcodeinitscript.sh @wwwcg @ruifanyuan # build: config -/buildconfig/ @ilikethese @etkmao +/buildconfig/ @etkmao # build: ci /package.json @zealotchen0