17c804472Sopenharmony_ci/* 27c804472Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 37c804472Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 47c804472Sopenharmony_ci * you may not use this file except in compliance with the License. 57c804472Sopenharmony_ci * You may obtain a copy of the License at 67c804472Sopenharmony_ci * 77c804472Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 87c804472Sopenharmony_ci * 97c804472Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 107c804472Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 117c804472Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 127c804472Sopenharmony_ci * See the License for the specific language governing permissions and 137c804472Sopenharmony_ci * limitations under the License. 147c804472Sopenharmony_ci */ 157c804472Sopenharmony_ci 167c804472Sopenharmony_ci#include "CrashHandler.h" 177c804472Sopenharmony_ci 187c804472Sopenharmony_ci#include <csignal> 197c804472Sopenharmony_ci#include <cstdlib> 207c804472Sopenharmony_ci#include <execinfo.h> 217c804472Sopenharmony_ci#include <sstream> 227c804472Sopenharmony_ci#include <unistd.h> 237c804472Sopenharmony_ci 247c804472Sopenharmony_ci#include "PreviewerEngineLog.h" 257c804472Sopenharmony_ci#include "PublicMethods.h" 267c804472Sopenharmony_ci 277c804472Sopenharmony_civoid CrashHandler::InitExceptionHandler() 287c804472Sopenharmony_ci{ 297c804472Sopenharmony_ci if (signal(SIGSEGV, ApplicationCrashHandler) == SIG_ERR) { 307c804472Sopenharmony_ci ELOG("InitExceptionHandler failed"); 317c804472Sopenharmony_ci return; 327c804472Sopenharmony_ci } 337c804472Sopenharmony_ci} 347c804472Sopenharmony_ci 357c804472Sopenharmony_civoid CrashHandler::ApplicationCrashHandler(int signal) 367c804472Sopenharmony_ci{ 377c804472Sopenharmony_ci const uint32_t MAX_STACK_SIZE = 128; 387c804472Sopenharmony_ci int8_t crashBeginLog[] = "[JsEngine Crash]Engine Crash Info Begin.\n"; 397c804472Sopenharmony_ci write(STDERR_FILENO, crashBeginLog, sizeof(crashBeginLog) - 1); 407c804472Sopenharmony_ci int8_t stackIntLog[PublicMethods::MAX_ITOA_BIT] = {0}; 417c804472Sopenharmony_ci uint32_t itoaLength = PublicMethods::Ulltoa(signal, stackIntLog); 427c804472Sopenharmony_ci int8_t signalLog[] = "[JsEngine Crash]Error: signal : 0x"; 437c804472Sopenharmony_ci write(STDERR_FILENO, signalLog, sizeof(signalLog) - 1); 447c804472Sopenharmony_ci write(STDERR_FILENO, stackIntLog, itoaLength); 457c804472Sopenharmony_ci 467c804472Sopenharmony_ci // get void*'s for all entries on the stack 477c804472Sopenharmony_ci void *array[10]; 487c804472Sopenharmony_ci size_t size = backtrace(array, MAX_STACK_SIZE); 497c804472Sopenharmony_ci // print out all the frames to stdout 507c804472Sopenharmony_ci backtrace_symbols_fd(array, size, STDERR_FILENO); 517c804472Sopenharmony_ci 527c804472Sopenharmony_ci int8_t crashEndLog[] = "\n[JsEngine Crash]Engine Crash Info End.\n"; 537c804472Sopenharmony_ci write(STDERR_FILENO, crashEndLog, sizeof(crashEndLog) - 1); 547c804472Sopenharmony_ci}