1 // Copyright 2023 The Android Open Source Project
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #include "host-common/GfxstreamFatalError.h"
16 
17 #include <cstdlib>
18 #include <ostream>
19 
20 #include "aemu/base/Metrics.h"
21 #include "host-common/logging.h"
22 
23 namespace {
24 
25 using android::base::CreateMetricsLogger;
26 using android::base::GfxstreamVkAbort;
27 
28 std::optional<std::function<void()>> customDieFunction = std::nullopt;
29 
die()30 [[noreturn]] void die() {
31     if (customDieFunction) {
32         (*customDieFunction)();
33     }
34     abort();
35 }
36 
37 }  // namespace
38 
39 namespace emugl {
40 
AbortMessage(const char * file,const char * function,int line,FatalError reason)41 AbortMessage::AbortMessage(const char *file, const char *function, int line, FatalError reason)
42     : mFile(file), mFunction(function), mLine(line), mReason(reason) {
43     mOss << "FATAL in " << function << ", err code: " << reason.getAbortCode() << ": ";
44 }
45 
~AbortMessage()46 AbortMessage::~AbortMessage() {
47     OutputLog(stderr, 'F', mFile, mLine, 0, mOss.str().c_str());
48     fflush(stderr);
49     CreateMetricsLogger()->logMetricEvent(GfxstreamVkAbort{.file = mFile,
50                                                            .function = mFunction,
51                                                            .msg = mOss.str().c_str(),
52                                                            .line = mLine,
53                                                            .abort_reason = mReason.getAbortCode()});
54 
55     die();
56 }
57 
setDieFunction(std::optional<std::function<void ()>> newDie)58 void setDieFunction(std::optional<std::function<void()>> newDie) { customDieFunction = newDie; }
59 }  // namespace emugl
60