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}