mirror of https://github.com/auygun/kaliber.git
Add log verbosity level
This commit is contained in:
parent
1148e48085
commit
c6546b43b5
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
#define HERE std::make_tuple(__func__, __FILE__, __LINE__)
|
#define HERE std::make_tuple(__func__, __FILE__, __LINE__)
|
||||||
|
|
||||||
// Helper for logging location info, e.g. LOG << LOCATION(from)
|
// Helper for logging location info, e.g. LOG(0) << LOCATION(from)
|
||||||
#define LOCATION(from) \
|
#define LOCATION(from) \
|
||||||
std::get<0>(from) << "() [" << [](std::string path) -> std::string { \
|
std::get<0>(from) << "() [" << [](std::string path) -> std::string { \
|
||||||
size_t last_slash_pos = path.find_last_of("\\/"); \
|
size_t last_slash_pos = path.find_last_of("\\/"); \
|
||||||
|
|
|
@ -6,15 +6,27 @@
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#endif
|
#endif
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
int g_max_log_verbosity_level = 0;
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
// This is never instantiated, it's just used for EAT_STREAM_PARAMETERS to have
|
// This is never instantiated, it's just used for EAT_STREAM_PARAMETERS to have
|
||||||
// an object of the correct type on the LHS of the unused part of the ternary
|
// an object of the correct type on the LHS of the unused part of the ternary
|
||||||
// operator.
|
// operator.
|
||||||
std::ostream* LogMessage::swallow_stream;
|
std::ostream* LogMessage::swallow_stream;
|
||||||
|
|
||||||
LogMessage::LogMessage(const char* file, int line) : file_(file), line_(line) {}
|
int GlobalMaxLogVerbosityLevel() {
|
||||||
|
return g_max_log_verbosity_level;
|
||||||
|
}
|
||||||
|
|
||||||
|
LogMessage::LogMessage(const char* file, int line, int verbosity_level)
|
||||||
|
: file_(file), line_(line), verbosity_level_(verbosity_level) {}
|
||||||
|
|
||||||
LogMessage::~LogMessage() {
|
LogMessage::~LogMessage() {
|
||||||
stream_ << std::endl;
|
stream_ << std::endl;
|
||||||
|
@ -24,30 +36,32 @@ LogMessage::~LogMessage() {
|
||||||
if (last_slash_pos != std::string::npos)
|
if (last_slash_pos != std::string::npos)
|
||||||
filename = filename.substr(last_slash_pos + 1);
|
filename = filename.substr(last_slash_pos + 1);
|
||||||
#if defined(__ANDROID__)
|
#if defined(__ANDROID__)
|
||||||
__android_log_print(ANDROID_LOG_ERROR, "kaliber", "[%s:%d] %s",
|
__android_log_print(ANDROID_LOG_ERROR, "kaliber", "%d [%s:%d] %s",
|
||||||
filename.c_str(), line_, text.c_str());
|
verbosity_level_, filename.c_str(), line_, text.c_str());
|
||||||
#else
|
#else
|
||||||
printf("[%s:%d] %s", filename.c_str(), line_, text.c_str());
|
printf("%d [%s:%d] %s", verbosity_level_, filename.c_str(), line_,
|
||||||
|
text.c_str());
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
LogAbort LogAbort::Check(const char* file, int line, const char* expr) {
|
LogAbort LogAbort::Check(const char* file, int line, const char* expr) {
|
||||||
LogAbort instance(new LogMessage(file, line));
|
LogAbort instance(new LogMessage(file, line, 0));
|
||||||
instance.GetLog().stream() << "CHECK: "
|
instance.GetLog().stream() << "CHECK(" << expr << ") ";
|
||||||
<< "(" << expr << ") ";
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
LogAbort LogAbort::DCheck(const char* file, int line, const char* expr) {
|
LogAbort LogAbort::DCheck(const char* file, int line, const char* expr) {
|
||||||
LogAbort instance(new LogMessage(file, line));
|
LogAbort instance(new LogMessage(file, line, 0));
|
||||||
instance.GetLog().stream() << "DCHECK: "
|
instance.GetLog().stream() << "DCHECK(" << expr << ") ";
|
||||||
<< "(" << expr << ") ";
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
LogAbort LogAbort::NotReached(const char* file, int line) {
|
LogAbort LogAbort::NotReached(const char* file, int line) {
|
||||||
LogAbort instance(new LogMessage(file, line));
|
LogAbort instance(new LogMessage(file, line, 0));
|
||||||
instance.GetLog().stream() << "NOTREACHED ";
|
instance.GetLog().stream() << "NOTREACHED() ";
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,45 +11,66 @@
|
||||||
// CHECK(condition) terminates the process if the condition is false.
|
// CHECK(condition) terminates the process if the condition is false.
|
||||||
// NOTREACHED annotates unreachable codepaths and terminates the process if
|
// NOTREACHED annotates unreachable codepaths and terminates the process if
|
||||||
// reached.
|
// reached.
|
||||||
#define LOG base::LogMessage(__FILE__, __LINE__).stream()
|
#define LOG(verbosity_level) \
|
||||||
#define LOG_IF(condition) \
|
|
||||||
LAZY_STREAM(condition, base::LogMessage(__FILE__, __LINE__).stream())
|
|
||||||
#define CHECK(condition) \
|
|
||||||
LAZY_STREAM( \
|
LAZY_STREAM( \
|
||||||
!(condition), \
|
LOG_IS_ON(verbosity_level), \
|
||||||
base::LogAbort::Check(__FILE__, __LINE__, #condition).GetLog().stream())
|
::base::LogMessage(__FILE__, __LINE__, verbosity_level).stream())
|
||||||
|
#define LOG_IF(verbosity_level, condition) \
|
||||||
|
LAZY_STREAM( \
|
||||||
|
LOG_IS_ON(verbosity_level) && (condition), \
|
||||||
|
::base::LogMessage(__FILE__, __LINE__, verbosity_level).stream())
|
||||||
|
#define CHECK(condition) \
|
||||||
|
LAZY_STREAM(!(condition), \
|
||||||
|
::base::LogAbort::Check(__FILE__, __LINE__, #condition) \
|
||||||
|
.GetLog() \
|
||||||
|
.stream())
|
||||||
|
|
||||||
#define NOTREACHED \
|
#define NOTREACHED() \
|
||||||
base::LogAbort::NotReached(__FILE__, __LINE__).GetLog().stream()
|
::base::LogAbort::NotReached(__FILE__, __LINE__).GetLog().stream()
|
||||||
|
|
||||||
// Macros for logging which are active only in debug builds.
|
// Macros for logging which are active only in debug builds.
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define DLOG base::LogMessage(__FILE__, __LINE__).stream()
|
#define DLOG(verbosity_level) \
|
||||||
#define DLOG_IF(condition) \
|
LAZY_STREAM( \
|
||||||
LAZY_STREAM(condition, base::LogMessage(__FILE__, __LINE__).stream())
|
LOG_IS_ON(verbosity_level), \
|
||||||
|
::base::LogMessage(__FILE__, __LINE__, verbosity_level).stream())
|
||||||
|
#define DLOG_IF(verbosity_level, condition) \
|
||||||
|
LAZY_STREAM( \
|
||||||
|
LOG_IS_ON(verbosity_level) && (condition), \
|
||||||
|
::base::LogMessage(__FILE__, __LINE__, verbosity_level).stream())
|
||||||
#define DCHECK(condition) \
|
#define DCHECK(condition) \
|
||||||
LAZY_STREAM(!(condition), \
|
LAZY_STREAM(!(condition), \
|
||||||
base::LogAbort::DCheck(__FILE__, __LINE__, #condition) \
|
::base::LogAbort::DCheck(__FILE__, __LINE__, #condition) \
|
||||||
.GetLog() \
|
.GetLog() \
|
||||||
.stream())
|
.stream())
|
||||||
#else
|
#else
|
||||||
// "debug mode" logging is compiled away to nothing for release builds.
|
// "debug mode" logging is compiled away to nothing for release builds.
|
||||||
#define DLOG EAT_STREAM_PARAMETERS
|
#define DLOG(verbosity_level) EAT_STREAM_PARAMETERS
|
||||||
#define DLOG_IF(condition) EAT_STREAM_PARAMETERS
|
#define DLOG_IF(verbosity_level, condition) EAT_STREAM_PARAMETERS
|
||||||
#define DCHECK(condition) EAT_STREAM_PARAMETERS
|
#define DCHECK(condition) EAT_STREAM_PARAMETERS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Helper macro which avoids evaluating the arguments to a stream if
|
// Helper macro which avoids evaluating the arguments to a stream if
|
||||||
// the condition doesn't hold.
|
// the condition doesn't hold.
|
||||||
#define LAZY_STREAM(condition, stream) \
|
#define LAZY_STREAM(condition, stream) \
|
||||||
!(condition) ? (void)0 : base::LogMessage::Voidify() & (stream)
|
!(condition) ? (void)0 : ::base::LogMessage::Voidify() & (stream)
|
||||||
|
|
||||||
// Avoid any pointless instructions to be emitted by the compiler.
|
// Avoid any pointless instructions to be emitted by the compiler.
|
||||||
#define EAT_STREAM_PARAMETERS \
|
#define EAT_STREAM_PARAMETERS \
|
||||||
LAZY_STREAM(false, *base::LogMessage::swallow_stream)
|
LAZY_STREAM(false, *::base::LogMessage::swallow_stream)
|
||||||
|
|
||||||
|
#if defined(MAX_LOG_VERBOSITY_LEVEL)
|
||||||
|
#define LOG_IS_ON(verbosity_level) \
|
||||||
|
((verbosity_level) <= MAX_LOG_VERBOSITY_LEVEL)
|
||||||
|
#else
|
||||||
|
#define LOG_IS_ON(verbosity_level) \
|
||||||
|
((verbosity_level) <= ::base::GlobalMaxLogVerbosityLevel())
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
|
|
||||||
|
int GlobalMaxLogVerbosityLevel();
|
||||||
|
|
||||||
class LogMessage {
|
class LogMessage {
|
||||||
public:
|
public:
|
||||||
class Voidify {
|
class Voidify {
|
||||||
|
@ -61,18 +82,17 @@ class LogMessage {
|
||||||
void operator&(std::ostream&) {}
|
void operator&(std::ostream&) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
LogMessage(const char* file, int line);
|
LogMessage(const char* file, int line, int verbosity_level);
|
||||||
~LogMessage();
|
~LogMessage();
|
||||||
|
|
||||||
LogMessage& base() { return *this; }
|
|
||||||
|
|
||||||
std::ostream& stream() { return stream_; }
|
std::ostream& stream() { return stream_; }
|
||||||
|
|
||||||
static std::ostream* swallow_stream;
|
static std::ostream* swallow_stream;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
const char* file_;
|
const char* file_;
|
||||||
const int line_;
|
int line_;
|
||||||
|
int verbosity_level_;
|
||||||
std::ostringstream stream_;
|
std::ostringstream stream_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -86,7 +86,7 @@ void TaskRunner::RunTasks() {
|
||||||
auto [from, task_cb] = task;
|
auto [from, task_cb] = task;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
LOG << __func__ << " from: " << LOCATION(from);
|
LOG(0) << __func__ << " from: " << LOCATION(from);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
task_cb();
|
task_cb();
|
||||||
|
|
|
@ -1343,7 +1343,7 @@ class Matrix4 {
|
||||||
M_x_RotZ(angles[2]);
|
M_x_RotZ(angles[2]);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
NOTREACHED;
|
NOTREACHED();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1534,7 +1534,7 @@ class Matrix4 {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
NOTREACHED;
|
NOTREACHED();
|
||||||
}
|
}
|
||||||
return -angles;
|
return -angles;
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,17 +58,17 @@ bool Demo::PreInitialize() {
|
||||||
Engine::Get().AsyncLoadSound("boss_music", "Game_2_Boss.mp3", true);
|
Engine::Get().AsyncLoadSound("boss_music", "Game_2_Boss.mp3", true);
|
||||||
|
|
||||||
if (!enemy_.PreInitialize()) {
|
if (!enemy_.PreInitialize()) {
|
||||||
LOG << "Failed to create the enemy.";
|
LOG(0) << "Failed to create the enemy.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!player_.PreInitialize()) {
|
if (!player_.PreInitialize()) {
|
||||||
LOG << "Failed to create the enemy.";
|
LOG(0) << "Failed to create the enemy.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!menu_.PreInitialize()) {
|
if (!menu_.PreInitialize()) {
|
||||||
LOG << "Failed to create the menu.";
|
LOG(0) << "Failed to create the menu.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,32 +79,32 @@ bool Demo::Initialize() {
|
||||||
saved_data_.Load(kSaveFileName);
|
saved_data_.Load(kSaveFileName);
|
||||||
|
|
||||||
if (!sky_.Create(false)) {
|
if (!sky_.Create(false)) {
|
||||||
LOG << "Could not create the sky.";
|
LOG(0) << "Could not create the sky.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!enemy_.Initialize()) {
|
if (!enemy_.Initialize()) {
|
||||||
LOG << "Failed to create the enemy.";
|
LOG(0) << "Failed to create the enemy.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!player_.Initialize()) {
|
if (!player_.Initialize()) {
|
||||||
LOG << "Failed to create the enemy.";
|
LOG(0) << "Failed to create the enemy.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!hud_.Initialize()) {
|
if (!hud_.Initialize()) {
|
||||||
LOG << "Failed to create the hud.";
|
LOG(0) << "Failed to create the hud.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!menu_.Initialize()) {
|
if (!menu_.Initialize()) {
|
||||||
LOG << "Failed to create the menu.";
|
LOG(0) << "Failed to create the menu.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!credits_.Initialize()) {
|
if (!credits_.Initialize()) {
|
||||||
LOG << "Failed to create the credits.";
|
LOG(0) << "Failed to create the credits.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,7 +191,7 @@ void Demo::ContextLost() {
|
||||||
void Demo::LostFocus() {}
|
void Demo::LostFocus() {}
|
||||||
|
|
||||||
void Demo::GainedFocus(bool from_interstitial_ad) {
|
void Demo::GainedFocus(bool from_interstitial_ad) {
|
||||||
DLOG << __func__ << " from_interstitial_ad: " << from_interstitial_ad;
|
DLOG(0) << __func__ << " from_interstitial_ad: " << from_interstitial_ad;
|
||||||
if (!from_interstitial_ad) {
|
if (!from_interstitial_ad) {
|
||||||
// if (saved_data_.root().get(kLaunchCount, Json::Value(0)).asInt() >
|
// if (saved_data_.root().get(kLaunchCount, Json::Value(0)).asInt() >
|
||||||
// kLaunchCountBeforeAd)
|
// kLaunchCountBeforeAd)
|
||||||
|
@ -327,7 +327,7 @@ void Demo::UpdateMenuState(float delta_time) {
|
||||||
Engine::Get().Exit();
|
Engine::Get().Exit();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
NOTREACHED << "- Unknown menu option: " << menu_.selected_option();
|
NOTREACHED() << "- Unknown menu option: " << menu_.selected_option();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -411,7 +411,7 @@ void Demo::StartNextStage(bool boss) {
|
||||||
waiting_for_next_wave_ = true;
|
waiting_for_next_wave_ = true;
|
||||||
hud_.SetProgress(wave_ > 0 ? 0 : 1);
|
hud_.SetProgress(wave_ > 0 ? 0 : 1);
|
||||||
|
|
||||||
DLOG_IF(wave_ > 0 && stage_time_ > 0)
|
DLOG_IF(0, wave_ > 0 && stage_time_ > 0)
|
||||||
<< "wave: " << wave_ << " time: " << stage_time_ / 60.0f;
|
<< "wave: " << wave_ << " time: " << stage_time_ / 60.0f;
|
||||||
stage_time_ = 0;
|
stage_time_ = 0;
|
||||||
|
|
||||||
|
@ -432,7 +432,7 @@ void Demo::StartNextStage(bool boss) {
|
||||||
music_.Stop(10);
|
music_.Stop(10);
|
||||||
}
|
}
|
||||||
boss_fight_ = true;
|
boss_fight_ = true;
|
||||||
DLOG << "Boss fight.";
|
DLOG(0) << "Boss fight.";
|
||||||
} else {
|
} else {
|
||||||
size_t bonus_factor = [&]() -> size_t {
|
size_t bonus_factor = [&]() -> size_t {
|
||||||
if (wave_ <= 3)
|
if (wave_ <= 3)
|
||||||
|
@ -444,7 +444,7 @@ void Demo::StartNextStage(bool boss) {
|
||||||
return 100;
|
return 100;
|
||||||
}();
|
}();
|
||||||
size_t bonus_score = wave_score_ * (bonus_factor - 1);
|
size_t bonus_score = wave_score_ * (bonus_factor - 1);
|
||||||
DLOG << "total_score_" << total_score_ << " wave " << wave_
|
DLOG(0) << "total_score_" << total_score_ << " wave " << wave_
|
||||||
<< " score: " << wave_score_ << " bonus: " << bonus_score;
|
<< " score: " << wave_score_ << " bonus: " << bonus_score;
|
||||||
|
|
||||||
if (bonus_score > 0) {
|
if (bonus_score > 0) {
|
||||||
|
@ -484,7 +484,7 @@ void Demo::StartNextStage(bool boss) {
|
||||||
total_enemies_ = 23.0897f * log((float)wave_ + 1.0f) - 10.0f;
|
total_enemies_ = 23.0897f * log((float)wave_ + 1.0f) - 10.0f;
|
||||||
last_num_enemies_killed_ = 0;
|
last_num_enemies_killed_ = 0;
|
||||||
boss_fight_ = false;
|
boss_fight_ = false;
|
||||||
DLOG << "wave: " << wave_ << " total_enemies_: " << total_enemies_;
|
DLOG(0) << "wave: " << wave_ << " total_enemies_: " << total_enemies_;
|
||||||
}
|
}
|
||||||
|
|
||||||
hud_.SetScore(total_score_, true);
|
hud_.SetScore(total_score_, true);
|
||||||
|
@ -535,7 +535,7 @@ void Demo::SetDelayedWork(float seconds, base::Closure cb) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Demo::BenchmarkResult(int avarage_fps) {
|
void Demo::BenchmarkResult(int avarage_fps) {
|
||||||
LOG << __func__ << " avarage_fps: " << avarage_fps;
|
LOG(0) << __func__ << " avarage_fps: " << avarage_fps;
|
||||||
if (avarage_fps < 30)
|
if (avarage_fps < 30)
|
||||||
sky_.Create(true);
|
sky_.Create(true);
|
||||||
}
|
}
|
||||||
|
|
|
@ -510,7 +510,7 @@ void Enemy::OnWaveStarted(int wave, bool boss_fight) {
|
||||||
return 1.0f;
|
return 1.0f;
|
||||||
return 1.6f;
|
return 1.6f;
|
||||||
}();
|
}();
|
||||||
DLOG << "boss_spawn_time_factor_: " << boss_spawn_time_factor_;
|
DLOG(0) << "boss_spawn_time_factor_: " << boss_spawn_time_factor_;
|
||||||
SpawnBoss();
|
SpawnBoss();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -601,7 +601,7 @@ void Enemy::SpawnUnit(EnemyType enemy_type,
|
||||||
e.sprite.Create("crate_tex", {8, 3});
|
e.sprite.Create("crate_tex", {8, 3});
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
NOTREACHED << "- Unkown enemy type: " << enemy_type;
|
NOTREACHED() << "- Unkown enemy type: " << enemy_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
e.sprite.SetZOrder(11);
|
e.sprite.SetZOrder(11);
|
||||||
|
@ -778,7 +778,7 @@ void Enemy::SpawnBoss() {
|
||||||
e.enemy_type = kEnemyType_Boss;
|
e.enemy_type = kEnemyType_Boss;
|
||||||
e.damage_type = kDamageType_Any;
|
e.damage_type = kDamageType_Any;
|
||||||
e.total_health = e.hit_points = 41.1283f * log((float)game->wave()) - 20.0f;
|
e.total_health = e.hit_points = 41.1283f * log((float)game->wave()) - 20.0f;
|
||||||
DLOG << " Boss health: " << e.total_health;
|
DLOG(0) << " Boss health: " << e.total_health;
|
||||||
|
|
||||||
Vector2f hit_box_pos =
|
Vector2f hit_box_pos =
|
||||||
boss_.GetPosition() - boss_.GetSize() * Vector2f(0, 0.2f);
|
boss_.GetPosition() - boss_.GetSize() * Vector2f(0, 0.2f);
|
||||||
|
|
|
@ -19,7 +19,7 @@ bool Font::Load(const std::string& file_name) {
|
||||||
auto buffer = AssetFile::ReadWholeFile(
|
auto buffer = AssetFile::ReadWholeFile(
|
||||||
file_name.c_str(), Engine::Get().GetRootPath().c_str(), &buffer_size);
|
file_name.c_str(), Engine::Get().GetRootPath().c_str(), &buffer_size);
|
||||||
if (!buffer) {
|
if (!buffer) {
|
||||||
LOG << "Failed to read font file.";
|
LOG(0) << "Failed to read font file.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ bool Font::Load(const std::string& file_name) {
|
||||||
// It's tighly packed.
|
// It's tighly packed.
|
||||||
glyph_cache_ = std::make_unique<uint8_t[]>(kGlyphSize * kGlyphSize);
|
glyph_cache_ = std::make_unique<uint8_t[]>(kGlyphSize * kGlyphSize);
|
||||||
if (!glyph_cache_) {
|
if (!glyph_cache_) {
|
||||||
LOG << "Failed to allocate glyph cache.";
|
LOG(0) << "Failed to allocate glyph cache.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ bool Font::Load(const std::string& file_name) {
|
||||||
if (stbtt_BakeFontBitmap((unsigned char*)buffer.get(), 0, kFontHeight,
|
if (stbtt_BakeFontBitmap((unsigned char*)buffer.get(), 0, kFontHeight,
|
||||||
glyph_cache_.get(), kGlyphSize, kGlyphSize,
|
glyph_cache_.get(), kGlyphSize, kGlyphSize,
|
||||||
kFirstChar, kNumChars, glyph_info_) <= 0) {
|
kFirstChar, kNumChars, glyph_info_) <= 0) {
|
||||||
LOG << "Failed to bake the glyph cache: ";
|
LOG(0) << "Failed to bake the glyph cache: ";
|
||||||
glyph_cache_.reset();
|
glyph_cache_.reset();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -68,10 +68,10 @@ static void StretchBlit_I8_to_RGBA32(int dst_x0,
|
||||||
int dst_pitch,
|
int dst_pitch,
|
||||||
const uint8_t* src_i,
|
const uint8_t* src_i,
|
||||||
int src_pitch) {
|
int src_pitch) {
|
||||||
// LOG << "-- StretchBlit: --";
|
// LOG(0) << "-- StretchBlit: --";
|
||||||
// LOG << "dst: rect(" << dst_x0 << ", " << dst_y0 << ")..("
|
// LOG(0) << "dst: rect(" << dst_x0 << ", " << dst_y0 << ")..("
|
||||||
// << dst_x1 << ".." << dst_y1 << "), pitch(" << dst_pitch << ")";
|
// << dst_x1 << ".." << dst_y1 << "), pitch(" << dst_pitch << ")";
|
||||||
// LOG << "src: rect(" << src_x0 << ", " << src_y0 << ")..("
|
// LOG(0) << "src: rect(" << src_x0 << ", " << src_y0 << ")..("
|
||||||
// << src_x1 << ".." << src_y1 << "), pitch(" << src_pitch << ")";
|
// << src_x1 << ".." << src_y1 << "), pitch(" << src_pitch << ")";
|
||||||
|
|
||||||
int dst_width = dst_x1 - dst_x0, dst_height = dst_y1 - dst_y0,
|
int dst_width = dst_x1 - dst_x0, dst_height = dst_y1 - dst_y0,
|
||||||
|
@ -80,8 +80,8 @@ static void StretchBlit_I8_to_RGBA32(int dst_x0,
|
||||||
// int dst_dx = dst_width > 0 ? 1 : -1,
|
// int dst_dx = dst_width > 0 ? 1 : -1,
|
||||||
// dst_dy = dst_height > 0 ? 1 : -1;
|
// dst_dy = dst_height > 0 ? 1 : -1;
|
||||||
|
|
||||||
// LOG << "dst_width = " << dst_width << ", dst_height = " << dst_height;
|
// LOG(0) << "dst_width = " << dst_width << ", dst_height = " << dst_height;
|
||||||
// LOG << "src_width = " << src_width << ", src_height = " << src_height;
|
// LOG(0) << "src_width = " << src_width << ", src_height = " << src_height;
|
||||||
|
|
||||||
uint8_t* dst = dst_rgba + (dst_x0 + dst_y0 * dst_pitch) * 4;
|
uint8_t* dst = dst_rgba + (dst_x0 + dst_y0 * dst_pitch) * 4;
|
||||||
const uint8_t* src = src_i + (src_x0 + src_y0 * src_pitch) * 1;
|
const uint8_t* src = src_i + (src_x0 + src_y0 * src_pitch) * 1;
|
||||||
|
@ -159,7 +159,7 @@ void Font::CalculateBoundingBox(const std::string& text,
|
||||||
CalculateBoundingBox(text, x0, y0, x1, y1);
|
CalculateBoundingBox(text, x0, y0, x1, y1);
|
||||||
width = x1 - x0;
|
width = x1 - x0;
|
||||||
height = y1 - y0;
|
height = y1 - y0;
|
||||||
// LOG << "width = " << width << ", height = " << height;
|
// LOG(0) << "width = " << width << ", height = " << height;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Font::Print(int x,
|
void Font::Print(int x,
|
||||||
|
@ -167,7 +167,7 @@ void Font::Print(int x,
|
||||||
const std::string& text,
|
const std::string& text,
|
||||||
uint8_t* buffer,
|
uint8_t* buffer,
|
||||||
int width) const {
|
int width) const {
|
||||||
// LOG("Font::Print() = %s\n", text);
|
// LOG(0)("Font::Print() = %s\n", text);
|
||||||
|
|
||||||
if (!glyph_cache_)
|
if (!glyph_cache_)
|
||||||
return;
|
return;
|
||||||
|
@ -184,7 +184,7 @@ void Font::Print(int x,
|
||||||
stbtt_GetBakedQuad(glyph_info_, kGlyphSize, kGlyphSize, *ptr - kFirstChar,
|
stbtt_GetBakedQuad(glyph_info_, kGlyphSize, kGlyphSize, *ptr - kFirstChar,
|
||||||
&fx, &fy, &q, 1);
|
&fx, &fy, &q, 1);
|
||||||
|
|
||||||
// LOG("-- glyph --\nxy = (%f %f) .. (%f %f)\nuv = (%f %f) .. (%f %f)\n",
|
// LOG(0)("-- glyph --\nxy = (%f %f) .. (%f %f)\nuv = (%f %f) .. (%f %f)\n",
|
||||||
// q.x0, q.y0, q.x1, q.y1, q.s0, q.t0, q.s1, q.t1);
|
// q.x0, q.y0, q.x1, q.y1, q.s0, q.t0, q.s1, q.t1);
|
||||||
|
|
||||||
int ix0 = (int)q.x0, iy0 = (int)q.y0, ix1 = (int)q.x1, iy1 = (int)q.y1,
|
int ix0 = (int)q.x0, iy0 = (int)q.y0, ix1 = (int)q.x1, iy1 = (int)q.y1,
|
||||||
|
|
|
@ -138,7 +138,7 @@ bool Image::Load(const std::string& file_name) {
|
||||||
auto file_buffer = AssetFile::ReadWholeFile(
|
auto file_buffer = AssetFile::ReadWholeFile(
|
||||||
file_name.c_str(), Engine::Get().GetRootPath().c_str(), &buffer_size);
|
file_name.c_str(), Engine::Get().GetRootPath().c_str(), &buffer_size);
|
||||||
if (!file_buffer) {
|
if (!file_buffer) {
|
||||||
LOG << "Failed to read file: " << file_name;
|
LOG(0) << "Failed to read file: " << file_name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,16 +146,16 @@ bool Image::Load(const std::string& file_name) {
|
||||||
buffer_.reset((uint8_t*)stbi_load_from_memory(
|
buffer_.reset((uint8_t*)stbi_load_from_memory(
|
||||||
(const stbi_uc*)file_buffer.get(), buffer_size, &w, &h, &c, 0));
|
(const stbi_uc*)file_buffer.get(), buffer_size, &w, &h, &c, 0));
|
||||||
if (!buffer_) {
|
if (!buffer_) {
|
||||||
LOG << "Failed to load image file: " << file_name;
|
LOG(0) << "Failed to load image file: " << file_name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG << "Loaded " << file_name << ". number of color components: " << c;
|
LOG(0) << "Loaded " << file_name << ". number of color components: " << c;
|
||||||
|
|
||||||
uint8_t* converted_buffer = NULL;
|
uint8_t* converted_buffer = NULL;
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 1:
|
case 1:
|
||||||
// LOG("Converting image from 1 to 4 channels.\n");
|
// LOG(0)("Converting image from 1 to 4 channels.\n");
|
||||||
// Assume it's an intensity, duplicate it to RGB and fill A with opaque.
|
// Assume it's an intensity, duplicate it to RGB and fill A with opaque.
|
||||||
converted_buffer =
|
converted_buffer =
|
||||||
(uint8_t*)AlignedAlloc<16>(w * h * 4 * sizeof(uint8_t));
|
(uint8_t*)AlignedAlloc<16>(w * h * 4 * sizeof(uint8_t));
|
||||||
|
@ -168,7 +168,7 @@ bool Image::Load(const std::string& file_name) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
// LOG("Converting image from 3 to 4 channels.\n");
|
// LOG(0)("Converting image from 3 to 4 channels.\n");
|
||||||
// Add an opaque channel.
|
// Add an opaque channel.
|
||||||
converted_buffer =
|
converted_buffer =
|
||||||
(uint8_t*)AlignedAlloc<16>(w * h * 4 * sizeof(uint8_t));
|
(uint8_t*)AlignedAlloc<16>(w * h * 4 * sizeof(uint8_t));
|
||||||
|
@ -185,7 +185,7 @@ bool Image::Load(const std::string& file_name) {
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
default:
|
default:
|
||||||
LOG << "Image had unsuitable number of color components: " << c << " "
|
LOG(0) << "Image had unsuitable number of color components: " << c << " "
|
||||||
<< file_name;
|
<< file_name;
|
||||||
buffer_.reset();
|
buffer_.reset();
|
||||||
return false;
|
return false;
|
||||||
|
@ -234,7 +234,7 @@ void Image::ConvertToPow2() {
|
||||||
int new_width = RoundUpToPow2(width_);
|
int new_width = RoundUpToPow2(width_);
|
||||||
int new_height = RoundUpToPow2(height_);
|
int new_height = RoundUpToPow2(height_);
|
||||||
if ((new_width != width_) || (new_height != height_)) {
|
if ((new_width != width_) || (new_height != height_)) {
|
||||||
LOG << "Converting image from (" << width_ << ", " << height_ << ") to ("
|
LOG(0) << "Converting image from (" << width_ << ", " << height_ << ") to ("
|
||||||
<< new_width << ", " << new_height << ")";
|
<< new_width << ", " << new_height << ")";
|
||||||
|
|
||||||
int bigger_size = new_width * new_height * 4 * sizeof(uint8_t);
|
int bigger_size = new_width * new_height * 4 * sizeof(uint8_t);
|
||||||
|
@ -292,7 +292,7 @@ bool Image::Compress() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG << "Compressing image. Format: " << format_;
|
LOG(0) << "Compressing image. Format: " << format_;
|
||||||
|
|
||||||
unsigned compressedSize = GetSize();
|
unsigned compressedSize = GetSize();
|
||||||
uint8_t* compressedBuffer =
|
uint8_t* compressedBuffer =
|
||||||
|
|
|
@ -22,7 +22,7 @@ bool Mesh::Create(Primitive primitive,
|
||||||
num_indices_ = num_indices;
|
num_indices_ = num_indices;
|
||||||
|
|
||||||
if (!ParseVertexDescription(vertex_description, vertex_description_)) {
|
if (!ParseVertexDescription(vertex_description, vertex_description_)) {
|
||||||
LOG << "Failed to parse vertex description.";
|
LOG(0) << "Failed to parse vertex description.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
Engine::Get().GetRootPath().c_str(),
|
Engine::Get().GetRootPath().c_str(),
|
||||||
&buffer_size, true);
|
&buffer_size, true);
|
||||||
if (!json_mesh) {
|
if (!json_mesh) {
|
||||||
LOG << "Failed to read file: " << file_name;
|
LOG(0) << "Failed to read file: " << file_name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
const std::unique_ptr<Json::CharReader> reader(builder.newCharReader());
|
const std::unique_ptr<Json::CharReader> reader(builder.newCharReader());
|
||||||
if (!reader->parse(json_mesh.get(), json_mesh.get() + buffer_size, &root,
|
if (!reader->parse(json_mesh.get(), json_mesh.get() + buffer_size, &root,
|
||||||
&err)) {
|
&err)) {
|
||||||
LOG << "Failed to load mesh. Json parser error: " << err;
|
LOG(0) << "Failed to load mesh. Json parser error: " << err;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
} else if (primitive_str == "TriangleStrip") {
|
} else if (primitive_str == "TriangleStrip") {
|
||||||
primitive_ = kPrimitive_TriangleStrip;
|
primitive_ = kPrimitive_TriangleStrip;
|
||||||
} else {
|
} else {
|
||||||
LOG << "Failed to load mesh. Invalid primitive: " << primitive_str;
|
LOG(0) << "Failed to load mesh. Invalid primitive: " << primitive_str;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
|
|
||||||
if (!ParseVertexDescription(root["vertex_description"].asString(),
|
if (!ParseVertexDescription(root["vertex_description"].asString(),
|
||||||
vertex_description_)) {
|
vertex_description_)) {
|
||||||
LOG << "Failed to parse vertex description.";
|
LOG(0) << "Failed to parse vertex description.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,18 +90,19 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
|
|
||||||
const Json::Value vertices = root["vertices"];
|
const Json::Value vertices = root["vertices"];
|
||||||
if (vertices.size() != array_size) {
|
if (vertices.size() != array_size) {
|
||||||
LOG << "Failed to load mesh. Vertex array size: " << vertices.size()
|
LOG(0) << "Failed to load mesh. Vertex array size: " << vertices.size()
|
||||||
<< ", expected " << array_size;
|
<< ", expected " << array_size;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int vertex_buffer_size = GetVertexSize() * num_vertices_;
|
int vertex_buffer_size = GetVertexSize() * num_vertices_;
|
||||||
if (vertex_buffer_size <= 0) {
|
if (vertex_buffer_size <= 0) {
|
||||||
LOG << "Failed to load mesh. Invalid vertex size.";
|
LOG(0) << "Failed to load mesh. Invalid vertex size.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG << "Loaded " << file_name << ". Vertex array size: " << vertices.size();
|
LOG(0) << "Loaded " << file_name
|
||||||
|
<< ". Vertex array size: " << vertices.size();
|
||||||
|
|
||||||
vertices_ = std::make_unique<char[]>(vertex_buffer_size);
|
vertices_ = std::make_unique<char[]>(vertex_buffer_size);
|
||||||
|
|
||||||
|
@ -131,7 +132,7 @@ bool Mesh::Load(const std::string& file_name) {
|
||||||
*((unsigned short*)dst) = (unsigned short)vertices[i].asUInt();
|
*((unsigned short*)dst) = (unsigned short)vertices[i].asUInt();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
NOTREACHED << "- Unknown data type: " << data_type;
|
NOTREACHED() << "- Unknown data type: " << data_type;
|
||||||
}
|
}
|
||||||
dst += type_size;
|
dst += type_size;
|
||||||
++i;
|
++i;
|
||||||
|
|
|
@ -86,7 +86,7 @@ bool ShaderSource::Load(const std::string& name) {
|
||||||
if (!fragment_source_)
|
if (!fragment_source_)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
LOG << "Loaded " << name;
|
LOG(0) << "Loaded " << name;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,7 @@ size_t ShaderSource::LoadInternal(const std::string& name,
|
||||||
auto source = AssetFile::ReadWholeFile(
|
auto source = AssetFile::ReadWholeFile(
|
||||||
name.c_str(), Engine::Get().GetRootPath().c_str(), &size, true);
|
name.c_str(), Engine::Get().GetRootPath().c_str(), &size, true);
|
||||||
if (!source) {
|
if (!source) {
|
||||||
LOG << "Failed to read file: " << name;
|
LOG(0) << "Failed to read file: " << name;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ bool Sound::Load(const std::string& file_name, bool stream) {
|
||||||
Engine::Get().GetRootPath().c_str(),
|
Engine::Get().GetRootPath().c_str(),
|
||||||
&buffer_size, false);
|
&buffer_size, false);
|
||||||
if (!encoded_data_) {
|
if (!encoded_data_) {
|
||||||
LOG << "Failed to read file: " << file_name;
|
LOG(0) << "Failed to read file: " << file_name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,11 +44,11 @@ bool Sound::Load(const std::string& file_name, bool stream) {
|
||||||
reinterpret_cast<uint8_t*>(encoded_data_.get()),
|
reinterpret_cast<uint8_t*>(encoded_data_.get()),
|
||||||
buffer_size, MP3D_SEEK_TO_BYTE);
|
buffer_size, MP3D_SEEK_TO_BYTE);
|
||||||
if (err) {
|
if (err) {
|
||||||
LOG << "Failed to decode file: " << file_name << " error: " << err;
|
LOG(0) << "Failed to decode file: " << file_name << " error: " << err;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG << (stream ? "Streaming " : "Loaded ") << file_name << ". "
|
LOG(0) << (stream ? "Streaming " : "Loaded ") << file_name << ". "
|
||||||
<< mp3_dec_->samples << " samples, " << mp3_dec_->info.channels
|
<< mp3_dec_->samples << " samples, " << mp3_dec_->info.channels
|
||||||
<< " channels, " << mp3_dec_->info.hz << " hz, "
|
<< " channels, " << mp3_dec_->info.hz << " hz, "
|
||||||
<< "layer " << mp3_dec_->info.layer << ", "
|
<< "layer " << mp3_dec_->info.layer << ", "
|
||||||
|
@ -120,7 +120,7 @@ void Sound::StreamInternal(size_t num_samples, bool loop) {
|
||||||
size_t samples_read =
|
size_t samples_read =
|
||||||
mp3dec_ex_read(mp3_dec_.get(), buffer.get(), num_samples);
|
mp3dec_ex_read(mp3_dec_.get(), buffer.get(), num_samples);
|
||||||
if (samples_read != num_samples && mp3_dec_->last_error) {
|
if (samples_read != num_samples && mp3_dec_->last_error) {
|
||||||
LOG << "mp3 decode error: " << mp3_dec_->last_error;
|
LOG(0) << "mp3 decode error: " << mp3_dec_->last_error;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -256,7 +256,7 @@ void AudioMixer::RenderAudio(float* output_buffer, size_t num_frames) {
|
||||||
std::bind(&AudioMixer::DoStream, this, *it, flags & kLoop),
|
std::bind(&AudioMixer::DoStream, this, *it, flags & kLoop),
|
||||||
true);
|
true);
|
||||||
} else {
|
} else {
|
||||||
DLOG << "Mixer buffer underrun!";
|
DLOG(0) << "Mixer buffer underrun!";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ AudioSinkAlsa::AudioSinkAlsa(AudioSink::Delegate* delegate)
|
||||||
: delegate_(delegate) {}
|
: delegate_(delegate) {}
|
||||||
|
|
||||||
AudioSinkAlsa::~AudioSinkAlsa() {
|
AudioSinkAlsa::~AudioSinkAlsa() {
|
||||||
LOG << "Shutting down audio.";
|
LOG(0) << "Shutting down audio.";
|
||||||
|
|
||||||
TerminateAudioThread();
|
TerminateAudioThread();
|
||||||
snd_pcm_drop(device_);
|
snd_pcm_drop(device_);
|
||||||
|
@ -22,7 +22,7 @@ AudioSinkAlsa::~AudioSinkAlsa() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AudioSinkAlsa::Initialize() {
|
bool AudioSinkAlsa::Initialize() {
|
||||||
LOG << "Initializing audio.";
|
LOG(0) << "Initializing audio.";
|
||||||
|
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ bool AudioSinkAlsa::Initialize() {
|
||||||
// direct hardware device with software format conversion.
|
// direct hardware device with software format conversion.
|
||||||
if ((err = snd_pcm_open(&device_, "default", SND_PCM_STREAM_PLAYBACK, 0)) <
|
if ((err = snd_pcm_open(&device_, "default", SND_PCM_STREAM_PLAYBACK, 0)) <
|
||||||
0) {
|
0) {
|
||||||
LOG << "Cannot open audio device. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot open audio device. Error: " << snd_strerror(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,39 +43,40 @@ bool AudioSinkAlsa::Initialize() {
|
||||||
|
|
||||||
// Init hw_params with full configuration space.
|
// Init hw_params with full configuration space.
|
||||||
if ((err = snd_pcm_hw_params_any(device_, hw_params)) < 0) {
|
if ((err = snd_pcm_hw_params_any(device_, hw_params)) < 0) {
|
||||||
LOG << "Cannot initialize hardware parameter structure. Error: "
|
LOG(0) << "Cannot initialize hardware parameter structure. Error: "
|
||||||
<< snd_strerror(err);
|
<< snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err = snd_pcm_hw_params_set_access(
|
if ((err = snd_pcm_hw_params_set_access(
|
||||||
device_, hw_params, SND_PCM_ACCESS_RW_INTERLEAVED)) < 0) {
|
device_, hw_params, SND_PCM_ACCESS_RW_INTERLEAVED)) < 0) {
|
||||||
LOG << "Cannot set access type. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set access type. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err = snd_pcm_hw_params_set_format(device_, hw_params,
|
if ((err = snd_pcm_hw_params_set_format(device_, hw_params,
|
||||||
SND_PCM_FORMAT_FLOAT)) < 0) {
|
SND_PCM_FORMAT_FLOAT)) < 0) {
|
||||||
LOG << "Cannot set sample format. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set sample format. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disable software resampler.
|
// Disable software resampler.
|
||||||
if ((err = snd_pcm_hw_params_set_rate_resample(device_, hw_params, 0)) <
|
if ((err = snd_pcm_hw_params_set_rate_resample(device_, hw_params, 0)) <
|
||||||
0) {
|
0) {
|
||||||
LOG << "Cannot disbale software resampler. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot disbale software resampler. Error: "
|
||||||
|
<< snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned sample_rate = 48000;
|
unsigned sample_rate = 48000;
|
||||||
if ((err = snd_pcm_hw_params_set_rate_near(device_, hw_params, &sample_rate,
|
if ((err = snd_pcm_hw_params_set_rate_near(device_, hw_params, &sample_rate,
|
||||||
0)) < 0) {
|
0)) < 0) {
|
||||||
LOG << "Cannot set sample rate. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set sample rate. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err = snd_pcm_hw_params_set_channels(device_, hw_params, 2)) < 0) {
|
if ((err = snd_pcm_hw_params_set_channels(device_, hw_params, 2)) < 0) {
|
||||||
LOG << "Cannot set channel count. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set channel count. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,25 +84,25 @@ bool AudioSinkAlsa::Initialize() {
|
||||||
unsigned period_time = 4000;
|
unsigned period_time = 4000;
|
||||||
if ((err = snd_pcm_hw_params_set_period_time_near(device_, hw_params,
|
if ((err = snd_pcm_hw_params_set_period_time_near(device_, hw_params,
|
||||||
&period_time, 0)) < 0) {
|
&period_time, 0)) < 0) {
|
||||||
LOG << "Cannot set periods. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set periods. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned periods = 3;
|
unsigned periods = 3;
|
||||||
if ((err = snd_pcm_hw_params_set_periods_near(device_, hw_params, &periods,
|
if ((err = snd_pcm_hw_params_set_periods_near(device_, hw_params, &periods,
|
||||||
0)) < 0) {
|
0)) < 0) {
|
||||||
LOG << "Cannot set periods. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set periods. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Apply HW parameter settings to PCM device and prepare device.
|
// Apply HW parameter settings to PCM device and prepare device.
|
||||||
if ((err = snd_pcm_hw_params(device_, hw_params)) < 0) {
|
if ((err = snd_pcm_hw_params(device_, hw_params)) < 0) {
|
||||||
LOG << "Cannot set parameters. Error: " << snd_strerror(err);
|
LOG(0) << "Cannot set parameters. Error: " << snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err = snd_pcm_prepare(device_)) < 0) {
|
if ((err = snd_pcm_prepare(device_)) < 0) {
|
||||||
LOG << "Cannot prepare audio interface for use. Error: "
|
LOG(0) << "Cannot prepare audio interface for use. Error: "
|
||||||
<< snd_strerror(err);
|
<< snd_strerror(err);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -120,15 +121,15 @@ bool AudioSinkAlsa::Initialize() {
|
||||||
snd_pcm_hw_params_get_periods(hw_params, &periods, nullptr);
|
snd_pcm_hw_params_get_periods(hw_params, &periods, nullptr);
|
||||||
snd_pcm_hw_params_get_buffer_size(hw_params, &buffer_size);
|
snd_pcm_hw_params_get_buffer_size(hw_params, &buffer_size);
|
||||||
|
|
||||||
LOG << "Alsa Audio:";
|
LOG(0) << "Alsa Audio:";
|
||||||
LOG << " access: " << snd_pcm_access_name(access);
|
LOG(0) << " access: " << snd_pcm_access_name(access);
|
||||||
LOG << " format: " << snd_pcm_format_name(format);
|
LOG(0) << " format: " << snd_pcm_format_name(format);
|
||||||
LOG << " channel count: " << num_channels;
|
LOG(0) << " channel count: " << num_channels;
|
||||||
LOG << " sample rate: " << sample_rate;
|
LOG(0) << " sample rate: " << sample_rate;
|
||||||
LOG << " period size: " << period_size;
|
LOG(0) << " period size: " << period_size;
|
||||||
LOG << " period time: " << period_time;
|
LOG(0) << " period time: " << period_time;
|
||||||
LOG << " periods: " << periods;
|
LOG(0) << " periods: " << periods;
|
||||||
LOG << " buffer_size: " << buffer_size;
|
LOG(0) << " buffer_size: " << buffer_size;
|
||||||
|
|
||||||
num_channels_ = num_channels;
|
num_channels_ = num_channels;
|
||||||
sample_rate_ = sample_rate;
|
sample_rate_ = sample_rate;
|
||||||
|
@ -158,7 +159,7 @@ size_t AudioSinkAlsa::GetHardwareSampleRate() {
|
||||||
void AudioSinkAlsa::StartAudioThread() {
|
void AudioSinkAlsa::StartAudioThread() {
|
||||||
DCHECK(!audio_thread_.joinable());
|
DCHECK(!audio_thread_.joinable());
|
||||||
|
|
||||||
LOG << "Starting audio thread.";
|
LOG(0) << "Starting audio thread.";
|
||||||
terminate_audio_thread_.store(false, std::memory_order_relaxed);
|
terminate_audio_thread_.store(false, std::memory_order_relaxed);
|
||||||
suspend_audio_thread_.store(false, std::memory_order_relaxed);
|
suspend_audio_thread_.store(false, std::memory_order_relaxed);
|
||||||
audio_thread_ = std::thread(&AudioSinkAlsa::AudioThreadMain, this);
|
audio_thread_ = std::thread(&AudioSinkAlsa::AudioThreadMain, this);
|
||||||
|
@ -168,7 +169,7 @@ void AudioSinkAlsa::TerminateAudioThread() {
|
||||||
if (!audio_thread_.joinable())
|
if (!audio_thread_.joinable())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
LOG << "Terminating audio thread";
|
LOG(0) << "Terminating audio thread";
|
||||||
terminate_audio_thread_.store(true, std::memory_order_relaxed);
|
terminate_audio_thread_.store(true, std::memory_order_relaxed);
|
||||||
suspend_audio_thread_.store(true, std::memory_order_relaxed);
|
suspend_audio_thread_.store(true, std::memory_order_relaxed);
|
||||||
audio_thread_.join();
|
audio_thread_.join();
|
||||||
|
@ -192,7 +193,7 @@ void AudioSinkAlsa::AudioThreadMain() {
|
||||||
|
|
||||||
while (snd_pcm_writei(device_, buffer.get(), num_frames) < 0) {
|
while (snd_pcm_writei(device_, buffer.get(), num_frames) < 0) {
|
||||||
snd_pcm_prepare(device_);
|
snd_pcm_prepare(device_);
|
||||||
DLOG << "Alsa buffer underrun!";
|
DLOG(0) << "Alsa buffer underrun!";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,12 +11,12 @@ AudioSinkOboe::AudioSinkOboe(AudioSink::Delegate* delegate)
|
||||||
: callback_(std::make_unique<StreamCallback>(this)), delegate_(delegate) {}
|
: callback_(std::make_unique<StreamCallback>(this)), delegate_(delegate) {}
|
||||||
|
|
||||||
AudioSinkOboe::~AudioSinkOboe() {
|
AudioSinkOboe::~AudioSinkOboe() {
|
||||||
LOG << "Shutting down audio.";
|
LOG(0) << "Shutting down audio.";
|
||||||
stream_->stop();
|
stream_->stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AudioSinkOboe::Initialize() {
|
bool AudioSinkOboe::Initialize() {
|
||||||
LOG << "Initializing audio.";
|
LOG(0) << "Initializing audio.";
|
||||||
return RestartStream();
|
return RestartStream();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ oboe::DataCallbackResult AudioSinkOboe::StreamCallback::onAudioReady(
|
||||||
void AudioSinkOboe::StreamCallback::onErrorAfterClose(
|
void AudioSinkOboe::StreamCallback::onErrorAfterClose(
|
||||||
oboe::AudioStream* oboe_stream,
|
oboe::AudioStream* oboe_stream,
|
||||||
oboe::Result error) {
|
oboe::Result error) {
|
||||||
LOG << "Error after close. Error: " << oboe::convertToText(error);
|
LOG(0) << "Error after close. Error: " << oboe::convertToText(error);
|
||||||
|
|
||||||
audio_sink_->RestartStream();
|
audio_sink_->RestartStream();
|
||||||
}
|
}
|
||||||
|
@ -66,14 +66,14 @@ bool AudioSinkOboe::RestartStream() {
|
||||||
->setCallback(callback_.get())
|
->setCallback(callback_.get())
|
||||||
->openManagedStream(stream_);
|
->openManagedStream(stream_);
|
||||||
|
|
||||||
LOG << "Oboe Audio Stream:";
|
LOG(0) << "Oboe Audio Stream:";
|
||||||
LOG << " performance mode: " << (int)stream_->getPerformanceMode();
|
LOG(0) << " performance mode: " << (int)stream_->getPerformanceMode();
|
||||||
LOG << " format: " << (int)stream_->getFormat();
|
LOG(0) << " format: " << (int)stream_->getFormat();
|
||||||
LOG << " channel count: " << stream_->getChannelCount();
|
LOG(0) << " channel count: " << stream_->getChannelCount();
|
||||||
LOG << " sample rate: " << stream_->getSampleRate();
|
LOG(0) << " sample rate: " << stream_->getSampleRate();
|
||||||
|
|
||||||
if (result != oboe::Result::OK) {
|
if (result != oboe::Result::OK) {
|
||||||
LOG << "Failed to create the playback stream. Error: "
|
LOG(0) << "Failed to create the playback stream. Error: "
|
||||||
<< oboe::convertToText(result);
|
<< oboe::convertToText(result);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,7 @@ Engine::Engine(Platform* platform)
|
||||||
}
|
}
|
||||||
|
|
||||||
Engine::~Engine() {
|
Engine::~Engine() {
|
||||||
LOG << "Shutting down engine.";
|
LOG(0) << "Shutting down engine.";
|
||||||
|
|
||||||
thread_pool_.CancelTasks();
|
thread_pool_.CancelTasks();
|
||||||
thread_pool_.Shutdown();
|
thread_pool_.Shutdown();
|
||||||
|
@ -107,7 +107,7 @@ void Engine::Run() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Engine::Initialize() {
|
void Engine::Initialize() {
|
||||||
LOG << "Initializing engine.";
|
LOG(0) << "Initializing engine.";
|
||||||
|
|
||||||
thread_pool_.Initialize();
|
thread_pool_.Initialize();
|
||||||
|
|
||||||
|
@ -116,17 +116,17 @@ void Engine::Initialize() {
|
||||||
// Normalize viewport.
|
// Normalize viewport.
|
||||||
if (GetScreenWidth() > GetScreenHeight()) {
|
if (GetScreenWidth() > GetScreenHeight()) {
|
||||||
float aspect_ratio = (float)GetScreenWidth() / (float)GetScreenHeight();
|
float aspect_ratio = (float)GetScreenWidth() / (float)GetScreenHeight();
|
||||||
LOG << "aspect ratio: " << aspect_ratio;
|
LOG(0) << "aspect ratio: " << aspect_ratio;
|
||||||
screen_size_ = {aspect_ratio * 2.0f, 2.0f};
|
screen_size_ = {aspect_ratio * 2.0f, 2.0f};
|
||||||
projection_.CreateOrthoProjection(-aspect_ratio, aspect_ratio, -1.0f, 1.0f);
|
projection_.CreateOrthoProjection(-aspect_ratio, aspect_ratio, -1.0f, 1.0f);
|
||||||
} else {
|
} else {
|
||||||
float aspect_ratio = (float)GetScreenHeight() / (float)GetScreenWidth();
|
float aspect_ratio = (float)GetScreenHeight() / (float)GetScreenWidth();
|
||||||
LOG << "aspect_ratio: " << aspect_ratio;
|
LOG(0) << "aspect_ratio: " << aspect_ratio;
|
||||||
screen_size_ = {2.0f, aspect_ratio * 2.0f};
|
screen_size_ = {2.0f, aspect_ratio * 2.0f};
|
||||||
projection_.CreateOrthoProjection(-1.0, 1.0, -aspect_ratio, aspect_ratio);
|
projection_.CreateOrthoProjection(-1.0, 1.0, -aspect_ratio, aspect_ratio);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG << "image scale factor: " << GetImageScaleFactor();
|
LOG(0) << "image scale factor: " << GetImageScaleFactor();
|
||||||
|
|
||||||
system_font_ = std::make_unique<Font>();
|
system_font_ = std::make_unique<Font>();
|
||||||
system_font_->Load("engine/RobotoMono-Regular.ttf");
|
system_font_->Load("engine/RobotoMono-Regular.ttf");
|
||||||
|
@ -257,7 +257,7 @@ void Engine::SetImageSource(const std::string& asset_name,
|
||||||
CreateImageCB create_image,
|
CreateImageCB create_image,
|
||||||
bool persistent) {
|
bool persistent) {
|
||||||
if (textures_.contains(asset_name) && textures_[asset_name].use_count > 0) {
|
if (textures_.contains(asset_name) && textures_[asset_name].use_count > 0) {
|
||||||
DLOG << "Texture in use: " << asset_name;
|
DLOG(0) << "Texture in use: " << asset_name;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -268,7 +268,7 @@ void Engine::SetImageSource(const std::string& asset_name,
|
||||||
void Engine::RefreshImage(const std::string& asset_name) {
|
void Engine::RefreshImage(const std::string& asset_name) {
|
||||||
auto it = textures_.find(asset_name);
|
auto it = textures_.find(asset_name);
|
||||||
if (it == textures_.end()) {
|
if (it == textures_.end()) {
|
||||||
DLOG << "Texture not found: " << asset_name;
|
DLOG(0) << "Texture not found: " << asset_name;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -282,7 +282,7 @@ void Engine::RefreshImage(const std::string& asset_name) {
|
||||||
Texture* Engine::AcquireTexture(const std::string& asset_name) {
|
Texture* Engine::AcquireTexture(const std::string& asset_name) {
|
||||||
auto it = textures_.find(asset_name);
|
auto it = textures_.find(asset_name);
|
||||||
if (it == textures_.end()) {
|
if (it == textures_.end()) {
|
||||||
DLOG << "Texture not found: " << asset_name;
|
DLOG(0) << "Texture not found: " << asset_name;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -298,7 +298,7 @@ Texture* Engine::AcquireTexture(const std::string& asset_name) {
|
||||||
void Engine::ReleaseTexture(const std::string& asset_name) {
|
void Engine::ReleaseTexture(const std::string& asset_name) {
|
||||||
auto it = textures_.find(asset_name);
|
auto it = textures_.find(asset_name);
|
||||||
if (it == textures_.end()) {
|
if (it == textures_.end()) {
|
||||||
DLOG << "Texture not found: " << asset_name;
|
DLOG(0) << "Texture not found: " << asset_name;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,7 +311,7 @@ void Engine::ReleaseTexture(const std::string& asset_name) {
|
||||||
void Engine::SetShaderSource(const std::string& asset_name,
|
void Engine::SetShaderSource(const std::string& asset_name,
|
||||||
const std::string& file_name) {
|
const std::string& file_name) {
|
||||||
if (shaders_.contains(asset_name)) {
|
if (shaders_.contains(asset_name)) {
|
||||||
DLOG << "Shader already exists: " << asset_name;
|
DLOG(0) << "Shader already exists: " << asset_name;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -321,7 +321,7 @@ void Engine::SetShaderSource(const std::string& asset_name,
|
||||||
Shader* Engine::GetShader(const std::string& asset_name) {
|
Shader* Engine::GetShader(const std::string& asset_name) {
|
||||||
auto it = shaders_.find(asset_name);
|
auto it = shaders_.find(asset_name);
|
||||||
if (it == shaders_.end()) {
|
if (it == shaders_.end()) {
|
||||||
DLOG << "Shader not found: " << asset_name;
|
DLOG(0) << "Shader not found: " << asset_name;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -339,7 +339,7 @@ void Engine::AsyncLoadSound(const std::string& asset_name,
|
||||||
const std::string& file_name,
|
const std::string& file_name,
|
||||||
bool stream) {
|
bool stream) {
|
||||||
if (audio_buses_.contains(asset_name)) {
|
if (audio_buses_.contains(asset_name)) {
|
||||||
DLOG << "AudioBus already exists: " << asset_name;
|
DLOG(0) << "AudioBus already exists: " << asset_name;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -355,7 +355,7 @@ void Engine::AsyncLoadSound(const std::string& asset_name,
|
||||||
std::shared_ptr<AudioBus> Engine::GetAudioBus(const std::string& asset_name) {
|
std::shared_ptr<AudioBus> Engine::GetAudioBus(const std::string& asset_name) {
|
||||||
auto it = audio_buses_.find(asset_name);
|
auto it = audio_buses_.find(asset_name);
|
||||||
if (it == audio_buses_.end()) {
|
if (it == audio_buses_.end()) {
|
||||||
DLOG << "AudioBus not found: " << asset_name;
|
DLOG(0) << "AudioBus not found: " << asset_name;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -569,19 +569,21 @@ void Engine::CreateRendererInternal(RendererType type) {
|
||||||
type == RendererType::kOpenGL))
|
type == RendererType::kOpenGL))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (type == RendererType::kVulkan)
|
if (type == RendererType::kVulkan) {
|
||||||
renderer_ =
|
renderer_ =
|
||||||
std::make_unique<RendererVulkan>(std::bind(&Engine::ContextLost, this));
|
std::make_unique<RendererVulkan>(std::bind(&Engine::ContextLost, this));
|
||||||
else if (type == RendererType::kOpenGL)
|
} else if (type == RendererType::kOpenGL) {
|
||||||
renderer_ =
|
renderer_ =
|
||||||
std::make_unique<RendererOpenGL>(std::bind(&Engine::ContextLost, this));
|
std::make_unique<RendererOpenGL>(std::bind(&Engine::ContextLost, this));
|
||||||
else
|
} else {
|
||||||
NOTREACHED;
|
NOTREACHED();
|
||||||
|
}
|
||||||
|
|
||||||
bool result = renderer_->Initialize(platform_);
|
bool result = renderer_->Initialize(platform_);
|
||||||
if (!result && type == RendererType::kVulkan) {
|
if (!result && type == RendererType::kVulkan) {
|
||||||
LOG << "Failed to initialize " << renderer_->GetDebugName() << " renderer.";
|
LOG(0) << "Failed to initialize " << renderer_->GetDebugName()
|
||||||
LOG << "Fallback to OpenGL renderer.";
|
<< " renderer.";
|
||||||
|
LOG(0) << "Fallback to OpenGL renderer.";
|
||||||
CreateRendererInternal(RendererType::kOpenGL);
|
CreateRendererInternal(RendererType::kOpenGL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -645,7 +647,7 @@ void Engine::CreateRenderResources() {
|
||||||
pass_through_shader_->Create(std::move(source), quad_->vertex_description(),
|
pass_through_shader_->Create(std::move(source), quad_->vertex_description(),
|
||||||
quad_->primitive(), false);
|
quad_->primitive(), false);
|
||||||
} else {
|
} else {
|
||||||
LOG << "Could not create pass through shader.";
|
LOG(0) << "Could not create pass through shader.";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the shader we can reuse for solid rendering.
|
// Create the shader we can reuse for solid rendering.
|
||||||
|
@ -654,7 +656,7 @@ void Engine::CreateRenderResources() {
|
||||||
solid_shader_->Create(std::move(source), quad_->vertex_description(),
|
solid_shader_->Create(std::move(source), quad_->vertex_description(),
|
||||||
quad_->primitive(), false);
|
quad_->primitive(), false);
|
||||||
} else {
|
} else {
|
||||||
LOG << "Could not create solid shader.";
|
LOG(0) << "Could not create solid shader.";
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& t : textures_) {
|
for (auto& t : textures_) {
|
||||||
|
|
|
@ -27,7 +27,7 @@ bool PersistentData::Load(const std::string& file_name, StorageType type) {
|
||||||
ScopedFILE file;
|
ScopedFILE file;
|
||||||
file.reset(fopen(file_path.c_str(), "r"));
|
file.reset(fopen(file_path.c_str(), "r"));
|
||||||
if (!file) {
|
if (!file) {
|
||||||
LOG << "Failed to open file " << file_path;
|
LOG(0) << "Failed to open file " << file_path;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ bool PersistentData::Load(const std::string& file_name, StorageType type) {
|
||||||
buffer = std::make_unique<char[]>(size + 1);
|
buffer = std::make_unique<char[]>(size + 1);
|
||||||
size_t bytes_read = fread(buffer.get(), 1, size, file.get());
|
size_t bytes_read = fread(buffer.get(), 1, size, file.get());
|
||||||
if (!bytes_read) {
|
if (!bytes_read) {
|
||||||
LOG << "Failed to read a buffer of size: " << size << " from file "
|
LOG(0) << "Failed to read a buffer of size: " << size << " from file "
|
||||||
<< file_path;
|
<< file_path;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ bool PersistentData::Load(const std::string& file_name, StorageType type) {
|
||||||
Json::CharReaderBuilder builder;
|
Json::CharReaderBuilder builder;
|
||||||
const std::unique_ptr<Json::CharReader> reader(builder.newCharReader());
|
const std::unique_ptr<Json::CharReader> reader(builder.newCharReader());
|
||||||
if (!reader->parse(buffer.get(), buffer.get() + size, &root_, &err)) {
|
if (!reader->parse(buffer.get(), buffer.get() + size, &root_, &err)) {
|
||||||
LOG << "Failed to parse save file. Json parser error: " << err;
|
LOG(0) << "Failed to parse save file. Json parser error: " << err;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -86,13 +86,13 @@ bool PersistentData::SaveAs(const std::string& file_name, StorageType type) {
|
||||||
ScopedFILE file;
|
ScopedFILE file;
|
||||||
file.reset(fopen(file_path.c_str(), "w"));
|
file.reset(fopen(file_path.c_str(), "w"));
|
||||||
if (!file) {
|
if (!file) {
|
||||||
LOG << "Failed to create file " << file_path;
|
LOG(0) << "Failed to create file " << file_path;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string data = stream.str();
|
std::string data = stream.str();
|
||||||
if (fwrite(data.c_str(), data.size(), 1, file.get()) != 1) {
|
if (fwrite(data.c_str(), data.size(), 1, file.get()) != 1) {
|
||||||
LOG << "Failed to write to file " << file_path;
|
LOG(0) << "Failed to write to file " << file_path;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ std::unique_ptr<char[]> AssetFile::ReadWholeFile(const std::string& file_name,
|
||||||
// Read all of it.
|
// Read all of it.
|
||||||
size_t bytes_read = file.Read(buffer.get(), size);
|
size_t bytes_read = file.Read(buffer.get(), size);
|
||||||
if (!bytes_read) {
|
if (!bytes_read) {
|
||||||
LOG << "Failed to read a buffer of size: " << size << " from file "
|
LOG(0) << "Failed to read a buffer of size: " << size << " from file "
|
||||||
<< file_name;
|
<< file_name;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,14 +16,14 @@ bool AssetFile::Open(const std::string& file_name,
|
||||||
// Try to open the zip archive.
|
// Try to open the zip archive.
|
||||||
archive_ = unzOpen(root_path.c_str());
|
archive_ = unzOpen(root_path.c_str());
|
||||||
if (!archive_) {
|
if (!archive_) {
|
||||||
LOG << "Failed to open zip file: " << root_path;
|
LOG(0) << "Failed to open zip file: " << root_path;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try to find the file.
|
// Try to find the file.
|
||||||
std::string full_name = "assets/" + file_name;
|
std::string full_name = "assets/" + file_name;
|
||||||
if (UNZ_OK != unzLocateFile(archive_, full_name.c_str(), 1)) {
|
if (UNZ_OK != unzLocateFile(archive_, full_name.c_str(), 1)) {
|
||||||
LOG << "Failed to locate file in zip archive: " << file_name;
|
LOG(0) << "Failed to locate file in zip archive: " << file_name;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,14 +31,14 @@ bool AssetFile::Open(const std::string& file_name,
|
||||||
unz_file_info info;
|
unz_file_info info;
|
||||||
if (UNZ_OK !=
|
if (UNZ_OK !=
|
||||||
unzGetCurrentFileInfo(archive_, &info, NULL, 0, NULL, 0, NULL, 0)) {
|
unzGetCurrentFileInfo(archive_, &info, NULL, 0, NULL, 0, NULL, 0)) {
|
||||||
LOG << "Failed to get file info: " << file_name;
|
LOG(0) << "Failed to get file info: " << file_name;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
uncompressed_size_ = info.uncompressed_size;
|
uncompressed_size_ = info.uncompressed_size;
|
||||||
|
|
||||||
// Open the current file.
|
// Open the current file.
|
||||||
if (UNZ_OK != unzOpenCurrentFile(archive_)) {
|
if (UNZ_OK != unzOpenCurrentFile(archive_)) {
|
||||||
LOG << "Failed to open file: " << file_name;
|
LOG(0) << "Failed to open file: " << file_name;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -289,7 +289,7 @@ void Platform::HandleCmd(android_app* app, int32_t cmd) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_INIT_WINDOW:
|
case APP_CMD_INIT_WINDOW:
|
||||||
DLOG << "APP_CMD_INIT_WINDOW";
|
DLOG(0) << "APP_CMD_INIT_WINDOW";
|
||||||
if (app->window != NULL) {
|
if (app->window != NULL) {
|
||||||
platform->SetFrameRate(60);
|
platform->SetFrameRate(60);
|
||||||
if (platform->observer_)
|
if (platform->observer_)
|
||||||
|
@ -298,13 +298,13 @@ void Platform::HandleCmd(android_app* app, int32_t cmd) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_TERM_WINDOW:
|
case APP_CMD_TERM_WINDOW:
|
||||||
DLOG << "APP_CMD_TERM_WINDOW";
|
DLOG(0) << "APP_CMD_TERM_WINDOW";
|
||||||
if (platform->observer_)
|
if (platform->observer_)
|
||||||
platform->observer_->OnWindowDestroyed();
|
platform->observer_->OnWindowDestroyed();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_CONFIG_CHANGED:
|
case APP_CMD_CONFIG_CHANGED:
|
||||||
DLOG << "APP_CMD_CONFIG_CHANGED";
|
DLOG(0) << "APP_CMD_CONFIG_CHANGED";
|
||||||
if (platform->app_->window != NULL && platform->observer_)
|
if (platform->app_->window != NULL && platform->observer_)
|
||||||
platform->observer_->OnWindowResized(
|
platform->observer_->OnWindowResized(
|
||||||
ANativeWindow_getWidth(app->window),
|
ANativeWindow_getWidth(app->window),
|
||||||
|
@ -312,11 +312,11 @@ void Platform::HandleCmd(android_app* app, int32_t cmd) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_STOP:
|
case APP_CMD_STOP:
|
||||||
DLOG << "APP_CMD_STOP";
|
DLOG(0) << "APP_CMD_STOP";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_GAINED_FOCUS:
|
case APP_CMD_GAINED_FOCUS:
|
||||||
DLOG << "APP_CMD_GAINED_FOCUS";
|
DLOG(0) << "APP_CMD_GAINED_FOCUS";
|
||||||
// platform->timer_.Reset();
|
// platform->timer_.Reset();
|
||||||
platform->has_focus_ = true;
|
platform->has_focus_ = true;
|
||||||
if (platform->observer_)
|
if (platform->observer_)
|
||||||
|
@ -325,35 +325,35 @@ void Platform::HandleCmd(android_app* app, int32_t cmd) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_LOST_FOCUS:
|
case APP_CMD_LOST_FOCUS:
|
||||||
DLOG << "APP_CMD_LOST_FOCUS";
|
DLOG(0) << "APP_CMD_LOST_FOCUS";
|
||||||
platform->has_focus_ = false;
|
platform->has_focus_ = false;
|
||||||
if (platform->observer_)
|
if (platform->observer_)
|
||||||
platform->observer_->LostFocus();
|
platform->observer_->LostFocus();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APP_CMD_LOW_MEMORY:
|
case APP_CMD_LOW_MEMORY:
|
||||||
DLOG << "APP_CMD_LOW_MEMORY";
|
DLOG(0) << "APP_CMD_LOW_MEMORY";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Platform::Platform(android_app* app) {
|
Platform::Platform(android_app* app) {
|
||||||
LOG << "Initializing platform.";
|
LOG(0) << "Initializing platform.";
|
||||||
|
|
||||||
app_ = app;
|
app_ = app;
|
||||||
mobile_device_ = true;
|
mobile_device_ = true;
|
||||||
|
|
||||||
root_path_ = ::GetApkPath(app->activity);
|
root_path_ = ::GetApkPath(app->activity);
|
||||||
LOG << "Root path: " << root_path_.c_str();
|
LOG(0) << "Root path: " << root_path_.c_str();
|
||||||
|
|
||||||
data_path_ = ::GetDataPath(app->activity);
|
data_path_ = ::GetDataPath(app->activity);
|
||||||
LOG << "Data path: " << data_path_.c_str();
|
LOG(0) << "Data path: " << data_path_.c_str();
|
||||||
|
|
||||||
shared_data_path_ = ::GetSharedDataPath(app->activity);
|
shared_data_path_ = ::GetSharedDataPath(app->activity);
|
||||||
LOG << "Shared data path: " << shared_data_path_.c_str();
|
LOG(0) << "Shared data path: " << shared_data_path_.c_str();
|
||||||
|
|
||||||
device_dpi_ = ::GetDensityDpi(app);
|
device_dpi_ = ::GetDensityDpi(app);
|
||||||
LOG << "Device DPI: " << device_dpi_;
|
LOG(0) << "Device DPI: " << device_dpi_;
|
||||||
|
|
||||||
app->userData = reinterpret_cast<void*>(this);
|
app->userData = reinterpret_cast<void*>(this);
|
||||||
app->onAppCmd = Platform::HandleCmd;
|
app->onAppCmd = Platform::HandleCmd;
|
||||||
|
@ -375,7 +375,7 @@ Platform::Platform(android_app* app) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Platform::~Platform() {
|
Platform::~Platform() {
|
||||||
LOG << "Shutting down platform.";
|
LOG(0) << "Shutting down platform.";
|
||||||
}
|
}
|
||||||
|
|
||||||
void Platform::Update() {
|
void Platform::Update() {
|
||||||
|
@ -388,7 +388,7 @@ void Platform::Update() {
|
||||||
if (source != NULL)
|
if (source != NULL)
|
||||||
source->process(app_, source);
|
source->process(app_, source);
|
||||||
if (app_->destroyRequested != 0) {
|
if (app_->destroyRequested != 0) {
|
||||||
LOG << "App destroy requested.";
|
LOG(0) << "App destroy requested.";
|
||||||
should_exit_ = true;
|
should_exit_ = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,16 +14,16 @@ namespace eng {
|
||||||
void KaliberMain(Platform* platform);
|
void KaliberMain(Platform* platform);
|
||||||
|
|
||||||
Platform::Platform() {
|
Platform::Platform() {
|
||||||
LOG << "Initializing platform.";
|
LOG(0) << "Initializing platform.";
|
||||||
|
|
||||||
root_path_ = "../../";
|
root_path_ = "../../";
|
||||||
LOG << "Root path: " << root_path_.c_str();
|
LOG(0) << "Root path: " << root_path_.c_str();
|
||||||
|
|
||||||
data_path_ = "./";
|
data_path_ = "./";
|
||||||
LOG << "Data path: " << data_path_.c_str();
|
LOG(0) << "Data path: " << data_path_.c_str();
|
||||||
|
|
||||||
shared_data_path_ = "./";
|
shared_data_path_ = "./";
|
||||||
LOG << "Shared data path: " << shared_data_path_.c_str();
|
LOG(0) << "Shared data path: " << shared_data_path_.c_str();
|
||||||
|
|
||||||
bool res = CreateWindow(800, 1205);
|
bool res = CreateWindow(800, 1205);
|
||||||
CHECK(res) << "Failed to create window.";
|
CHECK(res) << "Failed to create window.";
|
||||||
|
@ -36,7 +36,7 @@ Platform::Platform() {
|
||||||
}
|
}
|
||||||
|
|
||||||
Platform::~Platform() {
|
Platform::~Platform() {
|
||||||
LOG << "Shutting down platform.";
|
LOG(0) << "Shutting down platform.";
|
||||||
DestroyWindow();
|
DestroyWindow();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@ bool Platform::CreateWindow(int width, int height) {
|
||||||
// Try to open the local display.
|
// Try to open the local display.
|
||||||
display_ = XOpenDisplay(NULL);
|
display_ = XOpenDisplay(NULL);
|
||||||
if (!display_) {
|
if (!display_) {
|
||||||
LOG << "Can't connect to X server. Try to set the DISPLAY environment "
|
LOG(0) << "Can't connect to X server. Try to set the DISPLAY environment "
|
||||||
"variable (hostname:number.screen_number).";
|
"variable (hostname:number.screen_number).";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -120,10 +120,10 @@ bool Platform::CreateWindow(int width, int height) {
|
||||||
|
|
||||||
XVisualInfo* visual_info = GetXVisualInfo(display_);
|
XVisualInfo* visual_info = GetXVisualInfo(display_);
|
||||||
if (!visual_info) {
|
if (!visual_info) {
|
||||||
LOG << "No appropriate visual found.";
|
LOG(0) << "No appropriate visual found.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
LOG << "Visual " << (void*)visual_info->visualid << " selected";
|
LOG(0) << "Visual " << (void*)visual_info->visualid << " selected";
|
||||||
|
|
||||||
// Create the main window.
|
// Create the main window.
|
||||||
XSetWindowAttributes window_attributes;
|
XSetWindowAttributes window_attributes;
|
||||||
|
|
|
@ -41,7 +41,7 @@ RendererOpenGL::~RendererOpenGL() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RendererOpenGL::Shutdown() {
|
void RendererOpenGL::Shutdown() {
|
||||||
LOG << "Shutting down renderer.";
|
LOG(0) << "Shutting down renderer.";
|
||||||
is_initialized_ = false;
|
is_initialized_ = false;
|
||||||
ShutdownInternal();
|
ShutdownInternal();
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ uint64_t RendererOpenGL::CreateGeometry(std::unique_ptr<Mesh> mesh) {
|
||||||
// Verify that we have a valid layout and get the total byte size per vertex.
|
// Verify that we have a valid layout and get the total byte size per vertex.
|
||||||
GLuint vertex_size = mesh->GetVertexSize();
|
GLuint vertex_size = mesh->GetVertexSize();
|
||||||
if (!vertex_size) {
|
if (!vertex_size) {
|
||||||
LOG << "Invalid vertex layout";
|
LOG(0) << "Invalid vertex layout";
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ uint64_t RendererOpenGL::CreateGeometry(std::unique_ptr<Mesh> mesh) {
|
||||||
std::vector<GeometryOpenGL::Element> vertex_layout;
|
std::vector<GeometryOpenGL::Element> vertex_layout;
|
||||||
if (!SetupVertexLayout(mesh->vertex_description(), vertex_size,
|
if (!SetupVertexLayout(mesh->vertex_description(), vertex_size,
|
||||||
vertex_array_objects_, vertex_layout)) {
|
vertex_array_objects_, vertex_layout)) {
|
||||||
LOG << "Invalid vertex layout";
|
LOG(0) << "Invalid vertex layout";
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,7 +212,7 @@ void RendererOpenGL::UpdateTexture(uint64_t resource_id,
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
NOTREACHED << "- Unhandled texure format: " << image->GetFormat();
|
NOTREACHED() << "- Unhandled texure format: " << image->GetFormat();
|
||||||
}
|
}
|
||||||
|
|
||||||
glCompressedTexImage2D(GL_TEXTURE_2D, 0, format, image->GetWidth(),
|
glCompressedTexImage2D(GL_TEXTURE_2D, 0, format, image->GetWidth(),
|
||||||
|
@ -230,7 +230,7 @@ void RendererOpenGL::UpdateTexture(uint64_t resource_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (err != GL_NO_ERROR)
|
if (err != GL_NO_ERROR)
|
||||||
LOG << "GL ERROR after glCompressedTexImage2D: " << (int)err;
|
LOG(0) << "GL ERROR after glCompressedTexImage2D: " << (int)err;
|
||||||
} else {
|
} else {
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, image->GetWidth(),
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, image->GetWidth(),
|
||||||
image->GetHeight(), 0, GL_RGBA, GL_UNSIGNED_BYTE,
|
image->GetHeight(), 0, GL_RGBA, GL_UNSIGNED_BYTE,
|
||||||
|
@ -290,7 +290,7 @@ uint64_t RendererOpenGL::CreateShader(
|
||||||
char* buffer = (char*)malloc(length);
|
char* buffer = (char*)malloc(length);
|
||||||
if (buffer) {
|
if (buffer) {
|
||||||
glGetProgramInfoLog(id, length, NULL, buffer);
|
glGetProgramInfoLog(id, length, NULL, buffer);
|
||||||
LOG << "Could not link program:\n" << buffer;
|
LOG(0) << "Could not link program:\n" << buffer;
|
||||||
free(buffer);
|
free(buffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -401,7 +401,7 @@ void RendererOpenGL::SetUniform(uint64_t resource_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
void RendererOpenGL::ContextLost() {
|
void RendererOpenGL::ContextLost() {
|
||||||
LOG << "Context lost.";
|
LOG(0) << "Context lost.";
|
||||||
|
|
||||||
DestroyAllResources();
|
DestroyAllResources();
|
||||||
context_lost_cb_();
|
context_lost_cb_();
|
||||||
|
@ -419,13 +419,13 @@ bool RendererOpenGL::InitCommon() {
|
||||||
reinterpret_cast<const char*>(glGetString(GL_RENDERER));
|
reinterpret_cast<const char*>(glGetString(GL_RENDERER));
|
||||||
const char* version = reinterpret_cast<const char*>(glGetString(GL_VERSION));
|
const char* version = reinterpret_cast<const char*>(glGetString(GL_VERSION));
|
||||||
|
|
||||||
LOG << "OpenGL:";
|
LOG(0) << "OpenGL:";
|
||||||
LOG << " vendor: " << (const char*)glGetString(GL_VENDOR);
|
LOG(0) << " vendor: " << (const char*)glGetString(GL_VENDOR);
|
||||||
LOG << " renderer: " << renderer;
|
LOG(0) << " renderer: " << renderer;
|
||||||
LOG << " version: " << version;
|
LOG(0) << " version: " << version;
|
||||||
LOG << " shader version: "
|
LOG(0) << " shader version: "
|
||||||
<< (const char*)glGetString(GL_SHADING_LANGUAGE_VERSION);
|
<< (const char*)glGetString(GL_SHADING_LANGUAGE_VERSION);
|
||||||
LOG << "Screen size: " << screen_width_ << ", " << screen_height_;
|
LOG(0) << "Screen size: " << screen_width_ << ", " << screen_height_;
|
||||||
|
|
||||||
// Setup extensions.
|
// Setup extensions.
|
||||||
std::stringstream stream((const char*)glGetString(GL_EXTENSIONS));
|
std::stringstream stream((const char*)glGetString(GL_EXTENSIONS));
|
||||||
|
@ -435,9 +435,9 @@ bool RendererOpenGL::InitCommon() {
|
||||||
extensions.insert(token);
|
extensions.insert(token);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
LOG << " extensions:";
|
LOG(0) << " extensions:";
|
||||||
for (auto& ext : extensions)
|
for (auto& ext : extensions)
|
||||||
LOG << " " << ext.c_str());
|
LOG(0) << " " << ext.c_str());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Check for supported texture compression extensions.
|
// Check for supported texture compression extensions.
|
||||||
|
@ -472,16 +472,16 @@ bool RendererOpenGL::InitCommon() {
|
||||||
|
|
||||||
// Ancient hardware is not supported.
|
// Ancient hardware is not supported.
|
||||||
if (!npot_)
|
if (!npot_)
|
||||||
LOG << "NPOT not supported.";
|
LOG(0) << "NPOT not supported.";
|
||||||
|
|
||||||
if (vertex_array_objects_)
|
if (vertex_array_objects_)
|
||||||
LOG << "Supports Vertex Array Objects.";
|
LOG(0) << "Supports Vertex Array Objects.";
|
||||||
|
|
||||||
LOG << "TextureCompression:";
|
LOG(0) << "TextureCompression:";
|
||||||
LOG << " atc: " << texture_compression_.atc;
|
LOG(0) << " atc: " << texture_compression_.atc;
|
||||||
LOG << " dxt1: " << texture_compression_.dxt1;
|
LOG(0) << " dxt1: " << texture_compression_.dxt1;
|
||||||
LOG << " etc1: " << texture_compression_.etc1;
|
LOG(0) << " etc1: " << texture_compression_.etc1;
|
||||||
LOG << " s3tc: " << texture_compression_.s3tc;
|
LOG(0) << " s3tc: " << texture_compression_.s3tc;
|
||||||
|
|
||||||
glViewport(0, 0, screen_width_, screen_height_);
|
glViewport(0, 0, screen_width_, screen_height_);
|
||||||
|
|
||||||
|
@ -580,7 +580,7 @@ GLuint RendererOpenGL::CreateShader(const char* source, GLenum type) {
|
||||||
char* buffer = (char*)malloc(length);
|
char* buffer = (char*)malloc(length);
|
||||||
if (buffer) {
|
if (buffer) {
|
||||||
glGetShaderInfoLog(shader, length, NULL, buffer);
|
glGetShaderInfoLog(shader, length, NULL, buffer);
|
||||||
LOG << "Could not compile shader " << type << ":\n" << buffer;
|
LOG(0) << "Could not compile shader " << type << ":\n" << buffer;
|
||||||
free(buffer);
|
free(buffer);
|
||||||
}
|
}
|
||||||
glDeleteShader(shader);
|
glDeleteShader(shader);
|
||||||
|
@ -622,7 +622,7 @@ GLint RendererOpenGL::GetUniformLocation(
|
||||||
if (index >= 0)
|
if (index >= 0)
|
||||||
uniforms[name] = index;
|
uniforms[name] = index;
|
||||||
else
|
else
|
||||||
LOG << "Cannot find uniform " << name.c_str() << " (shader: " << id
|
LOG(0) << "Cannot find uniform " << name.c_str() << " (shader: " << id
|
||||||
<< ")";
|
<< ")";
|
||||||
}
|
}
|
||||||
return index;
|
return index;
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
namespace eng {
|
namespace eng {
|
||||||
|
|
||||||
bool RendererOpenGL::Initialize(Platform* platform) {
|
bool RendererOpenGL::Initialize(Platform* platform) {
|
||||||
LOG << "Initializing renderer.";
|
LOG(0) << "Initializing renderer.";
|
||||||
|
|
||||||
window_ = platform->GetWindow();
|
window_ = platform->GetWindow();
|
||||||
ndk_helper::GLContext* gl_context = ndk_helper::GLContext::GetInstance();
|
ndk_helper::GLContext* gl_context = ndk_helper::GLContext::GetInstance();
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
namespace eng {
|
namespace eng {
|
||||||
|
|
||||||
bool RendererOpenGL::Initialize(Platform* platform) {
|
bool RendererOpenGL::Initialize(Platform* platform) {
|
||||||
LOG << "Initializing renderer.";
|
LOG(0) << "Initializing renderer.";
|
||||||
|
|
||||||
display_ = platform->GetDisplay();
|
display_ = platform->GetDisplay();
|
||||||
window_ = platform->GetWindow();
|
window_ = platform->GetWindow();
|
||||||
|
@ -21,14 +21,14 @@ bool RendererOpenGL::Initialize(Platform* platform) {
|
||||||
XVisualInfo* visual_info = glXChooseVisual(display_, 0, glx_attributes);
|
XVisualInfo* visual_info = glXChooseVisual(display_, 0, glx_attributes);
|
||||||
glx_context_ = glXCreateContext(display_, visual_info, NULL, GL_TRUE);
|
glx_context_ = glXCreateContext(display_, visual_info, NULL, GL_TRUE);
|
||||||
if (!glx_context_) {
|
if (!glx_context_) {
|
||||||
LOG << "Couldn't create the glx context.";
|
LOG(0) << "Couldn't create the glx context.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
glXMakeCurrent(display_, window_, glx_context_);
|
glXMakeCurrent(display_, window_, glx_context_);
|
||||||
|
|
||||||
if (GLEW_OK != glewInit()) {
|
if (GLEW_OK != glewInit()) {
|
||||||
LOG << "Couldn't initialize OpenGL extension wrangler.";
|
LOG(0) << "Couldn't initialize OpenGL extension wrangler.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ bool ParseVertexDescription(const std::string& vd_str, VertexDescription& out) {
|
||||||
while (token) {
|
while (token) {
|
||||||
// Check for invalid format.
|
// Check for invalid format.
|
||||||
if (strlen(token) != 3) {
|
if (strlen(token) != 3) {
|
||||||
LOG << "Invalid format: " << token;
|
LOG(0) << "Invalid format: " << token;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,14 +44,14 @@ bool ParseVertexDescription(const std::string& vd_str, VertexDescription& out) {
|
||||||
attrib_type = kAttribType_TexCoord;
|
attrib_type = kAttribType_TexCoord;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG << "Unknown attribute: " << token;
|
LOG(0) << "Unknown attribute: " << token;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// There can be between 1 and 4 elements in an attribute.
|
// There can be between 1 and 4 elements in an attribute.
|
||||||
ElementCount num_elements = token[1] - '1' + 1;
|
ElementCount num_elements = token[1] - '1' + 1;
|
||||||
if (num_elements < 1 || num_elements > 4) {
|
if (num_elements < 1 || num_elements > 4) {
|
||||||
LOG << "Invalid number of elements: " << token;
|
LOG(0) << "Invalid number of elements: " << token;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ bool ParseVertexDescription(const std::string& vd_str, VertexDescription& out) {
|
||||||
type_size = sizeof(unsigned short);
|
type_size = sizeof(unsigned short);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG << "Unknown data type: " << token;
|
LOG(0) << "Unknown data type: " << token;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ void Texture::Update(std::unique_ptr<Image> image) {
|
||||||
|
|
||||||
void Texture::Destroy() {
|
void Texture::Destroy() {
|
||||||
if (IsValid()) {
|
if (IsValid()) {
|
||||||
DLOG << "Texture destroyed. resource_id: " << resource_id_;
|
DLOG(0) << "Texture destroyed. resource_id: " << resource_id_;
|
||||||
renderer_->DestroyTexture(resource_id_);
|
renderer_->DestroyTexture(resource_id_);
|
||||||
resource_id_ = 0;
|
resource_id_ = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -313,7 +313,7 @@ VkIndexType GetIndexType(eng::DataType data_type) {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
NOTREACHED << "Invalid index type: " << data_type;
|
NOTREACHED() << "Invalid index type: " << data_type;
|
||||||
return VK_INDEX_TYPE_UINT16;
|
return VK_INDEX_TYPE_UINT16;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -331,7 +331,7 @@ VkFormat GetImageFormat(eng::Image::Format format) {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
NOTREACHED << "Invalid format: " << format;
|
NOTREACHED() << "Invalid format: " << format;
|
||||||
return VK_FORMAT_R8G8B8A8_UNORM;
|
return VK_FORMAT_R8G8B8A8_UNORM;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -346,7 +346,7 @@ std::pair<int, int> GetBlockSizeForImageFormat(VkFormat format) {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
NOTREACHED << "Invalid format: " << string_VkFormat(format);
|
NOTREACHED() << "Invalid format: " << string_VkFormat(format);
|
||||||
return {0, 0};
|
return {0, 0};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -362,7 +362,7 @@ std::pair<int, int> GetNumBlocksForImageFormat(VkFormat format,
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
NOTREACHED << "Invalid format: " << string_VkFormat(format);
|
NOTREACHED() << "Invalid format: " << string_VkFormat(format);
|
||||||
return {width, height};
|
return {width, height};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -537,11 +537,11 @@ uint64_t RendererVulkan::CreateShader(
|
||||||
std::string error;
|
std::string error;
|
||||||
spirv[0] = CompileGlsl(EShLangVertex, source->GetVertexSource(), &error);
|
spirv[0] = CompileGlsl(EShLangVertex, source->GetVertexSource(), &error);
|
||||||
if (!error.empty())
|
if (!error.empty())
|
||||||
DLOG << source->name() << " vertex shader compile error: " << error;
|
DLOG(0) << source->name() << " vertex shader compile error: " << error;
|
||||||
spirv[1] =
|
spirv[1] =
|
||||||
CompileGlsl(EShLangFragment, source->GetFragmentSource(), &error);
|
CompileGlsl(EShLangFragment, source->GetFragmentSource(), &error);
|
||||||
if (!error.empty())
|
if (!error.empty())
|
||||||
DLOG << source->name() << " fragment shader compile error: " << error;
|
DLOG(0) << source->name() << " fragment shader compile error: " << error;
|
||||||
it = spirv_cache_.insert({source->name(), spirv}).first;
|
it = spirv_cache_.insert({source->name(), spirv}).first;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -558,7 +558,7 @@ uint64_t RendererVulkan::CreateShader(
|
||||||
|
|
||||||
if (vkCreateShaderModule(device_, &shader_module_info, nullptr,
|
if (vkCreateShaderModule(device_, &shader_module_info, nullptr,
|
||||||
&vert_shader_module) != VK_SUCCESS) {
|
&vert_shader_module) != VK_SUCCESS) {
|
||||||
DLOG << "vkCreateShaderModule failed!";
|
DLOG(0) << "vkCreateShaderModule failed!";
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -573,7 +573,7 @@ uint64_t RendererVulkan::CreateShader(
|
||||||
|
|
||||||
if (vkCreateShaderModule(device_, &shader_module_info, nullptr,
|
if (vkCreateShaderModule(device_, &shader_module_info, nullptr,
|
||||||
&frag_shader_module) != VK_SUCCESS) {
|
&frag_shader_module) != VK_SUCCESS) {
|
||||||
DLOG << "vkCreateShaderModule failed!";
|
DLOG(0) << "vkCreateShaderModule failed!";
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -581,7 +581,7 @@ uint64_t RendererVulkan::CreateShader(
|
||||||
auto& shader = shaders_[++last_resource_id_] = {};
|
auto& shader = shaders_[++last_resource_id_] = {};
|
||||||
|
|
||||||
if (!CreatePipelineLayout(shader, spirv_vertex, spirv_fragment))
|
if (!CreatePipelineLayout(shader, spirv_vertex, spirv_fragment))
|
||||||
DLOG << "Failed to create pipeline layout!";
|
DLOG(0) << "Failed to create pipeline layout!";
|
||||||
|
|
||||||
VkPipelineShaderStageCreateInfo vert_shader_stage_info{};
|
VkPipelineShaderStageCreateInfo vert_shader_stage_info{};
|
||||||
vert_shader_stage_info.sType =
|
vert_shader_stage_info.sType =
|
||||||
|
@ -709,7 +709,7 @@ uint64_t RendererVulkan::CreateShader(
|
||||||
|
|
||||||
if (vkCreateGraphicsPipelines(device_, VK_NULL_HANDLE, 1, &pipeline_info,
|
if (vkCreateGraphicsPipelines(device_, VK_NULL_HANDLE, 1, &pipeline_info,
|
||||||
nullptr, &shader.pipeline) != VK_SUCCESS)
|
nullptr, &shader.pipeline) != VK_SUCCESS)
|
||||||
DLOG << "failed to create graphics pipeline.";
|
DLOG(0) << "failed to create graphics pipeline.";
|
||||||
|
|
||||||
vkDestroyShaderModule(device_, frag_shader_module, nullptr);
|
vkDestroyShaderModule(device_, frag_shader_module, nullptr);
|
||||||
vkDestroyShaderModule(device_, vert_shader_module, nullptr);
|
vkDestroyShaderModule(device_, vert_shader_module, nullptr);
|
||||||
|
@ -863,14 +863,16 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
VkResult err = vkCreateCommandPool(device_, &cmd_pool_info, nullptr,
|
VkResult err = vkCreateCommandPool(device_, &cmd_pool_info, nullptr,
|
||||||
&frames_[i].setup_command_pool);
|
&frames_[i].setup_command_pool);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateCommandPool failed with error " << string_VkResult(err);
|
DLOG(0) << "vkCreateCommandPool failed with error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = vkCreateCommandPool(device_, &cmd_pool_info, nullptr,
|
err = vkCreateCommandPool(device_, &cmd_pool_info, nullptr,
|
||||||
&frames_[i].draw_command_pool);
|
&frames_[i].draw_command_pool);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateCommandPool failed with error " << string_VkResult(err);
|
DLOG(0) << "vkCreateCommandPool failed with error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -885,7 +887,7 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
err = vkAllocateCommandBuffers(device_, &cmdbuf_info,
|
err = vkAllocateCommandBuffers(device_, &cmdbuf_info,
|
||||||
&frames_[i].setup_command_buffer);
|
&frames_[i].setup_command_buffer);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkAllocateCommandBuffers failed with error "
|
DLOG(0) << "vkAllocateCommandBuffers failed with error "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -894,7 +896,7 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
err = vkAllocateCommandBuffers(device_, &cmdbuf_info,
|
err = vkAllocateCommandBuffers(device_, &cmdbuf_info,
|
||||||
&frames_[i].draw_command_buffer);
|
&frames_[i].draw_command_buffer);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkAllocateCommandBuffers failed with error "
|
DLOG(0) << "vkAllocateCommandBuffers failed with error "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -919,7 +921,7 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
VkResult err = vkCreateDescriptorSetLayout(device_, &ds_layout_info, nullptr,
|
VkResult err = vkCreateDescriptorSetLayout(device_, &ds_layout_info, nullptr,
|
||||||
&descriptor_set_layout_);
|
&descriptor_set_layout_);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "Error (" << string_VkResult(err)
|
DLOG(0) << "Error (" << string_VkResult(err)
|
||||||
<< ") creating descriptor set layout for set";
|
<< ") creating descriptor set layout for set";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -947,18 +949,18 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
|
|
||||||
err = vkCreateSampler(device_, &sampler_info, nullptr, &sampler_);
|
err = vkCreateSampler(device_, &sampler_info, nullptr, &sampler_);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateSampler failed with error " << string_VkResult(err);
|
DLOG(0) << "vkCreateSampler failed with error " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
texture_compression_.dxt1 = IsFormatSupported(VK_FORMAT_BC1_RGB_UNORM_BLOCK);
|
texture_compression_.dxt1 = IsFormatSupported(VK_FORMAT_BC1_RGB_UNORM_BLOCK);
|
||||||
texture_compression_.s3tc = IsFormatSupported(VK_FORMAT_BC3_UNORM_BLOCK);
|
texture_compression_.s3tc = IsFormatSupported(VK_FORMAT_BC3_UNORM_BLOCK);
|
||||||
|
|
||||||
LOG << "TextureCompression:";
|
LOG(0) << "TextureCompression:";
|
||||||
LOG << " atc: " << texture_compression_.atc;
|
LOG(0) << " atc: " << texture_compression_.atc;
|
||||||
LOG << " dxt1: " << texture_compression_.dxt1;
|
LOG(0) << " dxt1: " << texture_compression_.dxt1;
|
||||||
LOG << " etc1: " << texture_compression_.etc1;
|
LOG(0) << " etc1: " << texture_compression_.etc1;
|
||||||
LOG << " s3tc: " << texture_compression_.s3tc;
|
LOG(0) << " s3tc: " << texture_compression_.s3tc;
|
||||||
|
|
||||||
// Use a background thread for filling up staging buffers and recording setup
|
// Use a background thread for filling up staging buffers and recording setup
|
||||||
// commands.
|
// commands.
|
||||||
|
@ -970,7 +972,7 @@ bool RendererVulkan::InitializeInternal() {
|
||||||
BeginFrame();
|
BeginFrame();
|
||||||
|
|
||||||
if (context_lost_ && context_lost_cb_) {
|
if (context_lost_ && context_lost_cb_) {
|
||||||
LOG << "Context lost.";
|
LOG(0) << "Context lost.";
|
||||||
context_lost_cb_();
|
context_lost_cb_();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -980,7 +982,7 @@ void RendererVulkan::Shutdown() {
|
||||||
if (device_ == VK_NULL_HANDLE)
|
if (device_ == VK_NULL_HANDLE)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
LOG << "Shutting down renderer.";
|
LOG(0) << "Shutting down renderer.";
|
||||||
task_runner_.CancelTasks();
|
task_runner_.CancelTasks();
|
||||||
quit_.store(true, std::memory_order_relaxed);
|
quit_.store(true, std::memory_order_relaxed);
|
||||||
semaphore_.release();
|
semaphore_.release();
|
||||||
|
@ -1035,14 +1037,16 @@ void RendererVulkan::BeginFrame() {
|
||||||
VkResult err = vkBeginCommandBuffer(
|
VkResult err = vkBeginCommandBuffer(
|
||||||
frames_[current_frame_].setup_command_buffer, &cmdbuf_begin);
|
frames_[current_frame_].setup_command_buffer, &cmdbuf_begin);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkBeginCommandBuffer failed with error " << string_VkResult(err);
|
DLOG(0) << "vkBeginCommandBuffer failed with error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = vkBeginCommandBuffer(frames_[current_frame_].draw_command_buffer,
|
err = vkBeginCommandBuffer(frames_[current_frame_].draw_command_buffer,
|
||||||
&cmdbuf_begin);
|
&cmdbuf_begin);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkBeginCommandBuffer failed with error " << string_VkResult(err);
|
DLOG(0) << "vkBeginCommandBuffer failed with error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1073,7 +1077,8 @@ void RendererVulkan::FlushSetupBuffer() {
|
||||||
VkResult err = vkBeginCommandBuffer(
|
VkResult err = vkBeginCommandBuffer(
|
||||||
frames_[current_frame_].setup_command_buffer, &cmdbuf_begin);
|
frames_[current_frame_].setup_command_buffer, &cmdbuf_begin);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkBeginCommandBuffer failed with error " << string_VkResult(err);
|
DLOG(0) << "vkBeginCommandBuffer failed with error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
context_.AppendCommandBuffer(frames_[current_frame_].setup_command_buffer,
|
context_.AppendCommandBuffer(frames_[current_frame_].setup_command_buffer,
|
||||||
|
@ -1286,7 +1291,7 @@ bool RendererVulkan::InsertStagingBuffer() {
|
||||||
&std::get<0>(block.buffer),
|
&std::get<0>(block.buffer),
|
||||||
&std::get<1>(block.buffer), &block.alloc_info);
|
&std::get<1>(block.buffer), &block.alloc_info);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vmaCreateBuffer failed with error " << string_VkResult(err);
|
DLOG(0) << "vmaCreateBuffer failed with error " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1327,7 +1332,7 @@ RendererVulkan::DescPool* RendererVulkan::AllocateDescriptorPool() {
|
||||||
VkResult err = vkCreateDescriptorPool(device_, &descriptor_pool_create_info,
|
VkResult err = vkCreateDescriptorPool(device_, &descriptor_pool_create_info,
|
||||||
nullptr, &desc_pool);
|
nullptr, &desc_pool);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateDescriptorPool failed with error "
|
DLOG(0) << "vkCreateDescriptorPool failed with error "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return VK_NULL_HANDLE;
|
return VK_NULL_HANDLE;
|
||||||
}
|
}
|
||||||
|
@ -1350,7 +1355,7 @@ void RendererVulkan::FreeDescriptorPool(DescPool* desc_pool) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
NOTREACHED;
|
NOTREACHED();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1383,7 +1388,7 @@ bool RendererVulkan::AllocateBuffer(Buffer<VkBuffer>& buffer,
|
||||||
VkResult err = vmaCreateBuffer(allocator_, &buffer_info, &allocation_info,
|
VkResult err = vmaCreateBuffer(allocator_, &buffer_info, &allocation_info,
|
||||||
&vk_buffer, &allocation, nullptr);
|
&vk_buffer, &allocation, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "Can't create buffer of size: " << std::to_string(size)
|
DLOG(0) << "Can't create buffer of size: " << std::to_string(size)
|
||||||
<< ", error " << string_VkResult(err);
|
<< ", error " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1500,7 +1505,7 @@ bool RendererVulkan::AllocateImage(Buffer<VkImage>& image,
|
||||||
VkResult err = vmaCreateImage(allocator_, &image_create_info, &allocInfo,
|
VkResult err = vmaCreateImage(allocator_, &image_create_info, &allocInfo,
|
||||||
&vk_image, &allocation, nullptr);
|
&vk_image, &allocation, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vmaCreateImage failed with error " << string_VkResult(err);
|
DLOG(0) << "vmaCreateImage failed with error " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1526,7 +1531,7 @@ bool RendererVulkan::AllocateImage(Buffer<VkImage>& image,
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
vmaDestroyImage(allocator_, vk_image, allocation);
|
vmaDestroyImage(allocator_, vk_image, allocation);
|
||||||
DLOG << "vkCreateImageView failed with error " << string_VkResult(err);
|
DLOG(0) << "vkCreateImageView failed with error " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1547,7 +1552,8 @@ bool RendererVulkan::AllocateImage(Buffer<VkImage>& image,
|
||||||
&descriptor_set);
|
&descriptor_set);
|
||||||
if (err) {
|
if (err) {
|
||||||
--std::get<1>(*desc_pool);
|
--std::get<1>(*desc_pool);
|
||||||
DLOG << "Cannot allocate descriptor sets, error " << string_VkResult(err);
|
DLOG(0) << "Cannot allocate descriptor sets, error "
|
||||||
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1682,7 +1688,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
SpvReflectResult result = spvReflectCreateShaderModule(
|
SpvReflectResult result = spvReflectCreateShaderModule(
|
||||||
spirv_vertex.size(), spirv_vertex.data(), &module_vertex);
|
spirv_vertex.size(), spirv_vertex.data(), &module_vertex);
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to parse vertex shader.";
|
DLOG(0) << "SPIR-V reflection failed to parse vertex shader.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1690,7 +1696,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
result = spvReflectCreateShaderModule(
|
result = spvReflectCreateShaderModule(
|
||||||
spirv_fragment.size(), spirv_fragment.data(), &module_fragment);
|
spirv_fragment.size(), spirv_fragment.data(), &module_fragment);
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to parse fragment shader.";
|
DLOG(0) << "SPIR-V reflection failed to parse fragment shader.";
|
||||||
spvReflectDestroyShaderModule(&module_vertex);
|
spvReflectDestroyShaderModule(&module_vertex);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1705,12 +1711,12 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
result = spvReflectEnumerateDescriptorBindings(&module_vertex,
|
result = spvReflectEnumerateDescriptorBindings(&module_vertex,
|
||||||
&binding_count, nullptr);
|
&binding_count, nullptr);
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to enumerate fragment shader "
|
DLOG(0) << "SPIR-V reflection failed to enumerate fragment shader "
|
||||||
"descriptor bindings.";
|
"descriptor bindings.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (binding_count > 0) {
|
if (binding_count > 0) {
|
||||||
DLOG << "SPIR-V reflection found " << binding_count
|
DLOG(0) << "SPIR-V reflection found " << binding_count
|
||||||
<< " descriptor bindings in vertex shader.";
|
<< " descriptor bindings in vertex shader.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1719,12 +1725,12 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
result = spvReflectEnumerateDescriptorBindings(&module_fragment,
|
result = spvReflectEnumerateDescriptorBindings(&module_fragment,
|
||||||
&binding_count, nullptr);
|
&binding_count, nullptr);
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to enumerate fragment shader "
|
DLOG(0) << "SPIR-V reflection failed to enumerate fragment shader "
|
||||||
"descriptor bindings.";
|
"descriptor bindings.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DLOG << __func__ << " binding_count: " << binding_count;
|
DLOG(0) << __func__ << " binding_count: " << binding_count;
|
||||||
|
|
||||||
if (binding_count > 0) {
|
if (binding_count > 0) {
|
||||||
// Collect binding names and validate that only COMBINED_IMAGE_SAMPLER
|
// Collect binding names and validate that only COMBINED_IMAGE_SAMPLER
|
||||||
|
@ -1735,7 +1741,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
&module_fragment, &binding_count, bindings.data());
|
&module_fragment, &binding_count, bindings.data());
|
||||||
|
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to get descriptor bindings for "
|
DLOG(0) << "SPIR-V reflection failed to get descriptor bindings for "
|
||||||
"fragment shader.";
|
"fragment shader.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1743,12 +1749,12 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
for (size_t i = 0; i < binding_count; ++i) {
|
for (size_t i = 0; i < binding_count; ++i) {
|
||||||
const SpvReflectDescriptorBinding& binding = *bindings[i];
|
const SpvReflectDescriptorBinding& binding = *bindings[i];
|
||||||
|
|
||||||
DLOG << __func__ << " name: " << binding.name
|
DLOG(0) << __func__ << " name: " << binding.name
|
||||||
<< " descriptor_type: " << binding.descriptor_type
|
<< " descriptor_type: " << binding.descriptor_type
|
||||||
<< " set: " << binding.set << " binding: " << binding.binding;
|
<< " set: " << binding.set << " binding: " << binding.binding;
|
||||||
|
|
||||||
if (binding.binding > 0) {
|
if (binding.binding > 0) {
|
||||||
DLOG << "SPIR-V reflection found " << binding_count
|
DLOG(0) << "SPIR-V reflection found " << binding_count
|
||||||
<< " bindings in vertex shader. Only one binding per set is "
|
<< " bindings in vertex shader. Only one binding per set is "
|
||||||
"supported";
|
"supported";
|
||||||
break;
|
break;
|
||||||
|
@ -1756,7 +1762,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
|
|
||||||
if (binding.descriptor_type !=
|
if (binding.descriptor_type !=
|
||||||
SPV_REFLECT_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER) {
|
SPV_REFLECT_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER) {
|
||||||
DLOG << "SPIR-V reflection found descriptor type "
|
DLOG(0) << "SPIR-V reflection found descriptor type "
|
||||||
<< binding.descriptor_type
|
<< binding.descriptor_type
|
||||||
<< " in fragment shader. Only COMBINED_IMAGE_SAMPLER type is "
|
<< " in fragment shader. Only COMBINED_IMAGE_SAMPLER type is "
|
||||||
"supported.";
|
"supported.";
|
||||||
|
@ -1780,15 +1786,15 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
result =
|
result =
|
||||||
spvReflectEnumeratePushConstantBlocks(&module, &pc_count, nullptr);
|
spvReflectEnumeratePushConstantBlocks(&module, &pc_count, nullptr);
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to enumerate push constats in shader "
|
DLOG(0) << "SPIR-V reflection failed to enumerate push constats in "
|
||||||
"stage "
|
"shader stage "
|
||||||
<< stage;
|
<< stage;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pc_count) {
|
if (pc_count) {
|
||||||
if (pc_count > 1) {
|
if (pc_count > 1) {
|
||||||
DLOG << "SPIR-V reflection found " << pc_count
|
DLOG(0) << "SPIR-V reflection found " << pc_count
|
||||||
<< " push constats blocks in shader stage " << stage
|
<< " push constats blocks in shader stage " << stage
|
||||||
<< ". Only one push constant block is supported.";
|
<< ". Only one push constant block is supported.";
|
||||||
return false;
|
return false;
|
||||||
|
@ -1798,7 +1804,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
result = spvReflectEnumeratePushConstantBlocks(&module, &pc_count,
|
result = spvReflectEnumeratePushConstantBlocks(&module, &pc_count,
|
||||||
pconstants.data());
|
pconstants.data());
|
||||||
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
if (result != SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
DLOG << "SPIR-V reflection failed to obtaining push constants.";
|
DLOG(0) << "SPIR-V reflection failed to obtaining push constants.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1819,18 +1825,19 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (pc_count_vertex != pc_count_fragment) {
|
if (pc_count_vertex != pc_count_fragment) {
|
||||||
DLOG << "SPIR-V reflection found different push constant blocks across "
|
DLOG(0) << "SPIR-V reflection found different push constant blocks "
|
||||||
"shader stages.";
|
"across shader stages.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pc_count_vertex) {
|
if (pc_count_vertex) {
|
||||||
DLOG << __func__ << " PushConstants size: " << pconstants_vertex[0]->size
|
DLOG(0) << __func__
|
||||||
|
<< " PushConstants size: " << pconstants_vertex[0]->size
|
||||||
<< " count: " << pconstants_vertex[0]->member_count;
|
<< " count: " << pconstants_vertex[0]->member_count;
|
||||||
|
|
||||||
if (pconstants_vertex[0]->size != pconstants_fragment[0]->size) {
|
if (pconstants_vertex[0]->size != pconstants_fragment[0]->size) {
|
||||||
DLOG << "SPIR-V reflection found different push constant blocks across "
|
DLOG(0) << "SPIR-V reflection found different push constant blocks "
|
||||||
"shader stages.";
|
"across shader stages.";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1841,7 +1848,8 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
|
|
||||||
size_t offset = 0;
|
size_t offset = 0;
|
||||||
for (uint32_t j = 0; j < pconstants_vertex[0]->member_count; j++) {
|
for (uint32_t j = 0; j < pconstants_vertex[0]->member_count; j++) {
|
||||||
DLOG << __func__ << " name: " << pconstants_vertex[0]->members[j].name
|
DLOG(0) << __func__
|
||||||
|
<< " name: " << pconstants_vertex[0]->members[j].name
|
||||||
<< " size: " << pconstants_vertex[0]->members[j].size
|
<< " size: " << pconstants_vertex[0]->members[j].size
|
||||||
<< " padded_size: "
|
<< " padded_size: "
|
||||||
<< pconstants_vertex[0]->members[j].padded_size;
|
<< pconstants_vertex[0]->members[j].padded_size;
|
||||||
|
@ -1886,7 +1894,7 @@ bool RendererVulkan::CreatePipelineLayout(
|
||||||
|
|
||||||
if (vkCreatePipelineLayout(device_, &pipeline_layout_create_info, nullptr,
|
if (vkCreatePipelineLayout(device_, &pipeline_layout_create_info, nullptr,
|
||||||
&shader.pipeline_layout) != VK_SUCCESS) {
|
&shader.pipeline_layout) != VK_SUCCESS) {
|
||||||
DLOG << "Failed to create pipeline layout!";
|
DLOG(0) << "Failed to create pipeline layout!";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1992,7 +2000,7 @@ void RendererVulkan::SetupThreadMain(int preallocate) {
|
||||||
|
|
||||||
for (int i = 0; i < preallocate; i++) {
|
for (int i = 0; i < preallocate; i++) {
|
||||||
bool err = InsertStagingBuffer();
|
bool err = InsertStagingBuffer();
|
||||||
LOG_IF(!err) << "Failed to create staging buffer.";
|
LOG_IF(0, !err) << "Failed to create staging buffer.";
|
||||||
}
|
}
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
@ -2015,11 +2023,11 @@ bool RendererVulkan::SetUniformInternal(ShaderVulkan& shader,
|
||||||
T val) {
|
T val) {
|
||||||
auto it = shader.variables.find(name);
|
auto it = shader.variables.find(name);
|
||||||
if (it == shader.variables.end()) {
|
if (it == shader.variables.end()) {
|
||||||
DLOG << "No variable found with name " << name;
|
DLOG(0) << "No variable found with name " << name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (it->second[0] != sizeof(val)) {
|
if (it->second[0] != sizeof(val)) {
|
||||||
DLOG << "Size mismatch for variable " << name;
|
DLOG(0) << "Size mismatch for variable " << name;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,18 +8,18 @@
|
||||||
namespace eng {
|
namespace eng {
|
||||||
|
|
||||||
bool RendererVulkan::Initialize(Platform* platform) {
|
bool RendererVulkan::Initialize(Platform* platform) {
|
||||||
LOG << "Initializing renderer.";
|
LOG(0) << "Initializing renderer.";
|
||||||
|
|
||||||
screen_width_ = ANativeWindow_getWidth(platform->GetWindow());
|
screen_width_ = ANativeWindow_getWidth(platform->GetWindow());
|
||||||
screen_height_ = ANativeWindow_getHeight(platform->GetWindow());
|
screen_height_ = ANativeWindow_getHeight(platform->GetWindow());
|
||||||
|
|
||||||
if (!context_.Initialize()) {
|
if (!context_.Initialize()) {
|
||||||
LOG << "Failed to initialize Vulkan context.";
|
LOG(0) << "Failed to initialize Vulkan context.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!context_.CreateWindow(platform->GetWindow(), screen_width_,
|
if (!context_.CreateWindow(platform->GetWindow(), screen_width_,
|
||||||
screen_height_)) {
|
screen_height_)) {
|
||||||
LOG << "Vulkan context failed to create window.";
|
LOG(0) << "Vulkan context failed to create window.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
namespace eng {
|
namespace eng {
|
||||||
|
|
||||||
bool RendererVulkan::Initialize(Platform* platform) {
|
bool RendererVulkan::Initialize(Platform* platform) {
|
||||||
LOG << "Initializing renderer.";
|
LOG(0) << "Initializing renderer.";
|
||||||
|
|
||||||
XWindowAttributes xwa;
|
XWindowAttributes xwa;
|
||||||
XGetWindowAttributes(platform->GetDisplay(), platform->GetWindow(), &xwa);
|
XGetWindowAttributes(platform->GetDisplay(), platform->GetWindow(), &xwa);
|
||||||
|
@ -14,12 +14,12 @@ bool RendererVulkan::Initialize(Platform* platform) {
|
||||||
screen_height_ = xwa.height;
|
screen_height_ = xwa.height;
|
||||||
|
|
||||||
if (!context_.Initialize()) {
|
if (!context_.Initialize()) {
|
||||||
LOG << "Failed to initialize Vulkan context.";
|
LOG(0) << "Failed to initialize Vulkan context.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!context_.CreateWindow(platform->GetDisplay(), platform->GetWindow(),
|
if (!context_.CreateWindow(platform->GetDisplay(), platform->GetWindow(),
|
||||||
screen_width_, screen_height_)) {
|
screen_width_, screen_height_)) {
|
||||||
LOG << "Vulkan context failed to create window.";
|
LOG(0) << "Vulkan context failed to create window.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
{ \
|
{ \
|
||||||
entrypoint = (PFN_vk##entrypoint)func(obj, "vk" #entrypoint); \
|
entrypoint = (PFN_vk##entrypoint)func(obj, "vk" #entrypoint); \
|
||||||
if (entrypoint == nullptr) { \
|
if (entrypoint == nullptr) { \
|
||||||
DLOG << #func << " failed to find vk"; \
|
DLOG(0) << #func << " failed to find vk"; \
|
||||||
return false; \
|
return false; \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
@ -164,16 +164,16 @@ VKAPI_ATTR VkBool32 VKAPI_CALL VulkanContext::DebugMessengerCallback(
|
||||||
|
|
||||||
switch (message_severity) {
|
switch (message_severity) {
|
||||||
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT:
|
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT:
|
||||||
LOG << error_message;
|
LOG(0) << error_message;
|
||||||
break;
|
break;
|
||||||
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT:
|
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT:
|
||||||
LOG << error_message;
|
LOG(0) << error_message;
|
||||||
break;
|
break;
|
||||||
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT:
|
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT:
|
||||||
LOG << error_message;
|
LOG(0) << error_message;
|
||||||
break;
|
break;
|
||||||
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT:
|
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT:
|
||||||
LOG << error_message;
|
LOG(0) << error_message;
|
||||||
break;
|
break;
|
||||||
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_FLAG_BITS_MAX_ENUM_EXT:
|
case VK_DEBUG_UTILS_MESSAGE_SEVERITY_FLAG_BITS_MAX_ENUM_EXT:
|
||||||
break;
|
break;
|
||||||
|
@ -195,7 +195,7 @@ VkBool32 VulkanContext::CheckLayers(uint32_t check_count,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!found) {
|
if (!found) {
|
||||||
DLOG << "Can't find layer: " << check_names[i];
|
DLOG(0) << "Can't find layer: " << check_names[i];
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -216,7 +216,7 @@ bool VulkanContext::CreateValidationLayers() {
|
||||||
uint32_t instance_layer_count = 0;
|
uint32_t instance_layer_count = 0;
|
||||||
err = vkEnumerateInstanceLayerProperties(&instance_layer_count, nullptr);
|
err = vkEnumerateInstanceLayerProperties(&instance_layer_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateInstanceLayerProperties failed. Error: "
|
DLOG(0) << "vkEnumerateInstanceLayerProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -230,7 +230,7 @@ bool VulkanContext::CreateValidationLayers() {
|
||||||
err = vkEnumerateInstanceLayerProperties(&instance_layer_count,
|
err = vkEnumerateInstanceLayerProperties(&instance_layer_count,
|
||||||
instance_layers.get());
|
instance_layers.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateInstanceLayerProperties failed. Error: "
|
DLOG(0) << "vkEnumerateInstanceLayerProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -287,7 +287,7 @@ bool VulkanContext::InitializeExtensions() {
|
||||||
err = vkEnumerateInstanceExtensionProperties(
|
err = vkEnumerateInstanceExtensionProperties(
|
||||||
nullptr, &instance_extension_count, nullptr);
|
nullptr, &instance_extension_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateInstanceExtensionProperties failed. Error: "
|
DLOG(0) << "vkEnumerateInstanceExtensionProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -298,7 +298,7 @@ bool VulkanContext::InitializeExtensions() {
|
||||||
err = vkEnumerateInstanceExtensionProperties(
|
err = vkEnumerateInstanceExtensionProperties(
|
||||||
nullptr, &instance_extension_count, instance_extensions.get());
|
nullptr, &instance_extension_count, instance_extensions.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateInstanceExtensionProperties failed. Error: "
|
DLOG(0) << "vkEnumerateInstanceExtensionProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -331,18 +331,18 @@ bool VulkanContext::InitializeExtensions() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (enabled_extension_count_ >= kMaxExtensions) {
|
if (enabled_extension_count_ >= kMaxExtensions) {
|
||||||
DLOG << "Enabled extension count reaches kMaxExtensions";
|
DLOG(0) << "Enabled extension count reaches kMaxExtensions";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!surfaceExtFound) {
|
if (!surfaceExtFound) {
|
||||||
DLOG << "No surface extension found.";
|
DLOG(0) << "No surface extension found.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!platformSurfaceExtFound) {
|
if (!platformSurfaceExtFound) {
|
||||||
DLOG << "No platform surface extension found.";
|
DLOG(0) << "No platform surface extension found.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -403,18 +403,18 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
if (instance_ == VK_NULL_HANDLE) {
|
if (instance_ == VK_NULL_HANDLE) {
|
||||||
VkResult err = vkCreateInstance(&inst_info, nullptr, &instance_);
|
VkResult err = vkCreateInstance(&inst_info, nullptr, &instance_);
|
||||||
if (err == VK_ERROR_INCOMPATIBLE_DRIVER) {
|
if (err == VK_ERROR_INCOMPATIBLE_DRIVER) {
|
||||||
DLOG
|
DLOG(0)
|
||||||
<< "Cannot find a compatible Vulkan installable client driver (ICD).";
|
<< "Cannot find a compatible Vulkan installable client driver (ICD).";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (err == VK_ERROR_EXTENSION_NOT_PRESENT) {
|
if (err == VK_ERROR_EXTENSION_NOT_PRESENT) {
|
||||||
DLOG
|
DLOG(0)
|
||||||
<< "Cannot find a specified extension library. Make sure your layers "
|
<< "Cannot find a specified extension library. Make sure your layers "
|
||||||
"path is set appropriately. ";
|
"path is set appropriately. ";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateInstance failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateInstance failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -424,13 +424,13 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
// Make initial call to query gpu_count.
|
// Make initial call to query gpu_count.
|
||||||
VkResult err = vkEnumeratePhysicalDevices(instance_, &gpu_count, nullptr);
|
VkResult err = vkEnumeratePhysicalDevices(instance_, &gpu_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumeratePhysicalDevices failed. Error: "
|
DLOG(0) << "vkEnumeratePhysicalDevices failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gpu_count == 0) {
|
if (gpu_count == 0) {
|
||||||
DLOG << "vkEnumeratePhysicalDevices reported zero accessible devices.";
|
DLOG(0) << "vkEnumeratePhysicalDevices reported zero accessible devices.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -438,7 +438,7 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
err =
|
err =
|
||||||
vkEnumeratePhysicalDevices(instance_, &gpu_count, physical_devices.get());
|
vkEnumeratePhysicalDevices(instance_, &gpu_count, physical_devices.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumeratePhysicalDevices failed. Error: "
|
DLOG(0) << "vkEnumeratePhysicalDevices failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -454,7 +454,7 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
err = vkEnumerateDeviceExtensionProperties(gpu_, nullptr,
|
err = vkEnumerateDeviceExtensionProperties(gpu_, nullptr,
|
||||||
&device_extension_count, nullptr);
|
&device_extension_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateDeviceExtensionProperties failed. Error: "
|
DLOG(0) << "vkEnumerateDeviceExtensionProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -465,7 +465,7 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
err = vkEnumerateDeviceExtensionProperties(
|
err = vkEnumerateDeviceExtensionProperties(
|
||||||
gpu_, nullptr, &device_extension_count, device_extensions.get());
|
gpu_, nullptr, &device_extension_count, device_extensions.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEnumerateDeviceExtensionProperties failed. Error: "
|
DLOG(0) << "vkEnumerateDeviceExtensionProperties failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -478,7 +478,7 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
VK_KHR_SWAPCHAIN_EXTENSION_NAME;
|
VK_KHR_SWAPCHAIN_EXTENSION_NAME;
|
||||||
}
|
}
|
||||||
if (enabled_extension_count_ >= kMaxExtensions) {
|
if (enabled_extension_count_ >= kMaxExtensions) {
|
||||||
DLOG << "Enabled extension count reaches kMaxExtensions";
|
DLOG(0) << "Enabled extension count reaches kMaxExtensions";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -491,14 +491,14 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
VK_KHR_MAINTENANCE1_EXTENSION_NAME;
|
VK_KHR_MAINTENANCE1_EXTENSION_NAME;
|
||||||
}
|
}
|
||||||
if (enabled_extension_count_ >= kMaxExtensions) {
|
if (enabled_extension_count_ >= kMaxExtensions) {
|
||||||
DLOG << "Enabled extension count reaches kMaxExtensions";
|
DLOG(0) << "Enabled extension count reaches kMaxExtensions";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!swapchain_ext_found) {
|
if (!swapchain_ext_found) {
|
||||||
DLOG << "vkEnumerateDeviceExtensionProperties failed to find "
|
DLOG(0) << "vkEnumerateDeviceExtensionProperties failed to find "
|
||||||
"the " VK_KHR_SWAPCHAIN_EXTENSION_NAME " extension.";
|
"the " VK_KHR_SWAPCHAIN_EXTENSION_NAME " extension.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -512,7 +512,7 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
instance_, "vkDestroyDebugUtilsMessengerEXT");
|
instance_, "vkDestroyDebugUtilsMessengerEXT");
|
||||||
if (nullptr == CreateDebugUtilsMessengerEXT ||
|
if (nullptr == CreateDebugUtilsMessengerEXT ||
|
||||||
nullptr == DestroyDebugUtilsMessengerEXT) {
|
nullptr == DestroyDebugUtilsMessengerEXT) {
|
||||||
DLOG << "GetProcAddr: Failed to init VK_EXT_debug_utils";
|
DLOG(0) << "GetProcAddr: Failed to init VK_EXT_debug_utils";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -522,31 +522,31 @@ bool VulkanContext::CreatePhysicalDevice() {
|
||||||
case VK_SUCCESS:
|
case VK_SUCCESS:
|
||||||
break;
|
break;
|
||||||
case VK_ERROR_OUT_OF_HOST_MEMORY:
|
case VK_ERROR_OUT_OF_HOST_MEMORY:
|
||||||
DLOG << "CreateDebugUtilsMessengerEXT: out of host memory";
|
DLOG(0) << "CreateDebugUtilsMessengerEXT: out of host memory";
|
||||||
return false;
|
return false;
|
||||||
default:
|
default:
|
||||||
DLOG << "CreateDebugUtilsMessengerEXT: unknown failure";
|
DLOG(0) << "CreateDebugUtilsMessengerEXT: unknown failure";
|
||||||
return false;
|
return false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
vkGetPhysicalDeviceProperties(gpu_, &gpu_props_);
|
vkGetPhysicalDeviceProperties(gpu_, &gpu_props_);
|
||||||
|
|
||||||
LOG << "Vulkan:";
|
LOG(0) << "Vulkan:";
|
||||||
LOG << " Name: " << gpu_props_.deviceName;
|
LOG(0) << " Name: " << gpu_props_.deviceName;
|
||||||
LOG << " Tame: " << string_VkPhysicalDeviceType(gpu_props_.deviceType);
|
LOG(0) << " Tame: " << string_VkPhysicalDeviceType(gpu_props_.deviceType);
|
||||||
LOG << " Vendor ID: " << gpu_props_.vendorID;
|
LOG(0) << " Vendor ID: " << gpu_props_.vendorID;
|
||||||
LOG << " API version: " << VK_VERSION_MAJOR(gpu_props_.apiVersion) << "."
|
LOG(0) << " API version: " << VK_VERSION_MAJOR(gpu_props_.apiVersion) << "."
|
||||||
<< VK_VERSION_MINOR(gpu_props_.apiVersion) << "."
|
<< VK_VERSION_MINOR(gpu_props_.apiVersion) << "."
|
||||||
<< VK_VERSION_PATCH(gpu_props_.apiVersion);
|
<< VK_VERSION_PATCH(gpu_props_.apiVersion);
|
||||||
LOG << " Driver version: " << VK_VERSION_MAJOR(gpu_props_.driverVersion)
|
LOG(0) << " Driver version: " << VK_VERSION_MAJOR(gpu_props_.driverVersion)
|
||||||
<< "." << VK_VERSION_MINOR(gpu_props_.driverVersion) << "."
|
<< "." << VK_VERSION_MINOR(gpu_props_.driverVersion) << "."
|
||||||
<< VK_VERSION_PATCH(gpu_props_.driverVersion);
|
<< VK_VERSION_PATCH(gpu_props_.driverVersion);
|
||||||
|
|
||||||
// Call with NULL data to get count,
|
// Call with NULL data to get count,
|
||||||
vkGetPhysicalDeviceQueueFamilyProperties(gpu_, &queue_family_count_, nullptr);
|
vkGetPhysicalDeviceQueueFamilyProperties(gpu_, &queue_family_count_, nullptr);
|
||||||
if (queue_family_count_ == 0) {
|
if (queue_family_count_ == 0) {
|
||||||
DLOG << "Failed to query queue family count.";
|
DLOG(0) << "Failed to query queue family count.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -610,7 +610,7 @@ bool VulkanContext::CreateDevice() {
|
||||||
}
|
}
|
||||||
err = vkCreateDevice(gpu_, &sdevice, nullptr, &device_);
|
err = vkCreateDevice(gpu_, &sdevice, nullptr, &device_);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateDevice failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateDevice failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -655,7 +655,7 @@ bool VulkanContext::InitializeQueues(VkSurfaceKHR surface) {
|
||||||
// Generate error if could not find both a graphics and a present queue
|
// Generate error if could not find both a graphics and a present queue
|
||||||
if (graphics_queue_family_index == std::numeric_limits<uint32_t>::max() ||
|
if (graphics_queue_family_index == std::numeric_limits<uint32_t>::max() ||
|
||||||
present_queue_family_index == std::numeric_limits<uint32_t>::max()) {
|
present_queue_family_index == std::numeric_limits<uint32_t>::max()) {
|
||||||
DLOG << "Could not find both graphics and present queues.";
|
DLOG(0) << "Could not find both graphics and present queues.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -688,7 +688,7 @@ bool VulkanContext::InitializeQueues(VkSurfaceKHR surface) {
|
||||||
VkResult err =
|
VkResult err =
|
||||||
GetPhysicalDeviceSurfaceFormatsKHR(gpu_, surface, &format_count, nullptr);
|
GetPhysicalDeviceSurfaceFormatsKHR(gpu_, surface, &format_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetPhysicalDeviceSurfaceFormatsKHR failed. Error: "
|
DLOG(0) << "GetPhysicalDeviceSurfaceFormatsKHR failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -696,7 +696,7 @@ bool VulkanContext::InitializeQueues(VkSurfaceKHR surface) {
|
||||||
err = GetPhysicalDeviceSurfaceFormatsKHR(gpu_, surface, &format_count,
|
err = GetPhysicalDeviceSurfaceFormatsKHR(gpu_, surface, &format_count,
|
||||||
surf_formats.get());
|
surf_formats.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetPhysicalDeviceSurfaceFormatsKHR failed. Error: "
|
DLOG(0) << "GetPhysicalDeviceSurfaceFormatsKHR failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -714,7 +714,7 @@ bool VulkanContext::InitializeQueues(VkSurfaceKHR surface) {
|
||||||
format_ = desired_format;
|
format_ = desired_format;
|
||||||
color_space_ = surf_formats[0].colorSpace;
|
color_space_ = surf_formats[0].colorSpace;
|
||||||
} else if (format_count < 1) {
|
} else if (format_count < 1) {
|
||||||
DLOG << "Format count less than 1.";
|
DLOG(0) << "Format count less than 1.";
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
// Find the first format that we support.
|
// Find the first format that we support.
|
||||||
|
@ -733,7 +733,7 @@ bool VulkanContext::InitializeQueues(VkSurfaceKHR surface) {
|
||||||
|
|
||||||
end_of_find_format:
|
end_of_find_format:
|
||||||
if (format_ == VK_FORMAT_UNDEFINED) {
|
if (format_ == VK_FORMAT_UNDEFINED) {
|
||||||
DLOG << "No usable surface format found.";
|
DLOG(0) << "No usable surface format found.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -765,26 +765,26 @@ bool VulkanContext::CreateSemaphores() {
|
||||||
for (uint32_t i = 0; i < kFrameLag; i++) {
|
for (uint32_t i = 0; i < kFrameLag; i++) {
|
||||||
err = vkCreateFence(device_, &fence_ci, nullptr, &fences_[i]);
|
err = vkCreateFence(device_, &fence_ci, nullptr, &fences_[i]);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateFence failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateFence failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
||||||
&image_acquired_semaphores_[i]);
|
&image_acquired_semaphores_[i]);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
||||||
&draw_complete_semaphores_[i]);
|
&draw_complete_semaphores_[i]);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (separate_present_queue_) {
|
if (separate_present_queue_) {
|
||||||
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
err = vkCreateSemaphore(device_, &semaphoreCreateInfo, nullptr,
|
||||||
&image_ownership_semaphores_[i]);
|
&image_ownership_semaphores_[i]);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateSemaphore failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -856,7 +856,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = GetPhysicalDeviceSurfaceCapabilitiesKHR(gpu_, window->surface,
|
err = GetPhysicalDeviceSurfaceCapabilitiesKHR(gpu_, window->surface,
|
||||||
&surf_capabilities);
|
&surf_capabilities);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetPhysicalDeviceSurfaceCapabilitiesKHR failed. Error: "
|
DLOG(0) << "GetPhysicalDeviceSurfaceCapabilitiesKHR failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -865,7 +865,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = GetPhysicalDeviceSurfacePresentModesKHR(gpu_, window->surface,
|
err = GetPhysicalDeviceSurfacePresentModesKHR(gpu_, window->surface,
|
||||||
&present_mode_count, nullptr);
|
&present_mode_count, nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetPhysicalDeviceSurfacePresentModesKHR failed. Error: "
|
DLOG(0) << "GetPhysicalDeviceSurfacePresentModesKHR failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -875,7 +875,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = GetPhysicalDeviceSurfacePresentModesKHR(
|
err = GetPhysicalDeviceSurfacePresentModesKHR(
|
||||||
gpu_, window->surface, &present_mode_count, present_modes.get());
|
gpu_, window->surface, &present_mode_count, present_modes.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetPhysicalDeviceSurfacePresentModesKHR failed. Error: "
|
DLOG(0) << "GetPhysicalDeviceSurfacePresentModesKHR failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -947,7 +947,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (swapchain_present_mode != fallback_present_mode) {
|
if (swapchain_present_mode != fallback_present_mode) {
|
||||||
LOG << "Present mode " << swapchain_present_mode << " is not supported";
|
LOG(0) << "Present mode " << swapchain_present_mode << " is not supported";
|
||||||
swapchain_present_mode = fallback_present_mode;
|
swapchain_present_mode = fallback_present_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1023,7 +1023,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
|
|
||||||
err = CreateSwapchainKHR(device_, &swapchain_ci, nullptr, &window->swapchain);
|
err = CreateSwapchainKHR(device_, &swapchain_ci, nullptr, &window->swapchain);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "CreateSwapchainKHR failed. Error: " << string_VkResult(err);
|
DLOG(0) << "CreateSwapchainKHR failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1031,7 +1031,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = GetSwapchainImagesKHR(device_, window->swapchain, &sp_image_count,
|
err = GetSwapchainImagesKHR(device_, window->swapchain, &sp_image_count,
|
||||||
nullptr);
|
nullptr);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetSwapchainImagesKHR failed. Error: " << string_VkResult(err);
|
DLOG(0) << "GetSwapchainImagesKHR failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1039,7 +1039,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
// Assign for the first time.
|
// Assign for the first time.
|
||||||
swapchain_image_count_ = sp_image_count;
|
swapchain_image_count_ = sp_image_count;
|
||||||
} else if (swapchain_image_count_ != sp_image_count) {
|
} else if (swapchain_image_count_ != sp_image_count) {
|
||||||
DLOG << "Swapchain image count mismatch";
|
DLOG(0) << "Swapchain image count mismatch";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1048,7 +1048,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = GetSwapchainImagesKHR(device_, window->swapchain,
|
err = GetSwapchainImagesKHR(device_, window->swapchain,
|
||||||
&swapchain_image_count_, swapchain_images.get());
|
&swapchain_image_count_, swapchain_images.get());
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "GetSwapchainImagesKHR failed. Error: " << string_VkResult(err);
|
DLOG(0) << "GetSwapchainImagesKHR failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1085,7 +1085,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = vkCreateImageView(device_, &color_image_view, nullptr,
|
err = vkCreateImageView(device_, &color_image_view, nullptr,
|
||||||
&window->swapchain_image_resources[i].view);
|
&window->swapchain_image_resources[i].view);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateImageView failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateImageView failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1169,7 +1169,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
|
|
||||||
err = vkCreateRenderPass(device_, &rp_info, nullptr, &window->render_pass);
|
err = vkCreateRenderPass(device_, &rp_info, nullptr, &window->render_pass);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateRenderPass failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateRenderPass failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1194,7 +1194,8 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
device_, &fb_info, nullptr,
|
device_, &fb_info, nullptr,
|
||||||
&window->swapchain_image_resources[i].frame_buffer);
|
&window->swapchain_image_resources[i].frame_buffer);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateFramebuffer failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateFramebuffer failed. Error: "
|
||||||
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1212,7 +1213,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = vkCreateCommandPool(device_, &present_cmd_pool_info, nullptr,
|
err = vkCreateCommandPool(device_, &present_cmd_pool_info, nullptr,
|
||||||
&window->present_cmd_pool);
|
&window->present_cmd_pool);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateCommandPool failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateCommandPool failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1228,7 +1229,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
device_, &present_cmd_info,
|
device_, &present_cmd_info,
|
||||||
&window->swapchain_image_resources[i].graphics_to_present_cmd);
|
&window->swapchain_image_resources[i].graphics_to_present_cmd);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkAllocateCommandBuffers failed. Error: "
|
DLOG(0) << "vkAllocateCommandBuffers failed. Error: "
|
||||||
<< string_VkResult(err);
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1243,7 +1244,8 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
window->swapchain_image_resources[i].graphics_to_present_cmd,
|
window->swapchain_image_resources[i].graphics_to_present_cmd,
|
||||||
&cmd_buf_info);
|
&cmd_buf_info);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkBeginCommandBuffer failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkBeginCommandBuffer failed. Error: "
|
||||||
|
<< string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1267,7 +1269,7 @@ bool VulkanContext::UpdateSwapChain(Window* window) {
|
||||||
err = vkEndCommandBuffer(
|
err = vkEndCommandBuffer(
|
||||||
window->swapchain_image_resources[i].graphics_to_present_cmd);
|
window->swapchain_image_resources[i].graphics_to_present_cmd);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkEndCommandBuffer failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkEndCommandBuffer failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1306,7 +1308,7 @@ bool VulkanContext::CreateDepthImage(Window* window) {
|
||||||
VkResult err =
|
VkResult err =
|
||||||
vkCreateImage(device_, &depth_image_ci, nullptr, &window->depth_image);
|
vkCreateImage(device_, &depth_image_ci, nullptr, &window->depth_image);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkCreateImage failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkCreateImage failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1325,7 +1327,7 @@ bool VulkanContext::CreateDepthImage(Window* window) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mti == memProperties.memoryTypeCount) {
|
if (mti == memProperties.memoryTypeCount) {
|
||||||
DLOG << "Memort type index not found.";
|
DLOG(0) << "Memort type index not found.";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1338,7 +1340,7 @@ bool VulkanContext::CreateDepthImage(Window* window) {
|
||||||
err = vkAllocateMemory(device_, &alloc_info, nullptr,
|
err = vkAllocateMemory(device_, &alloc_info, nullptr,
|
||||||
&window->depth_image_memory);
|
&window->depth_image_memory);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkAllocateMemory failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkAllocateMemory failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1375,7 +1377,7 @@ bool VulkanContext::CreateDepthImage(Window* window) {
|
||||||
if (err) {
|
if (err) {
|
||||||
vkDestroyImage(device_, window->depth_image, nullptr);
|
vkDestroyImage(device_, window->depth_image, nullptr);
|
||||||
vkFreeMemory(device_, window->depth_image_memory, nullptr);
|
vkFreeMemory(device_, window->depth_image_memory, nullptr);
|
||||||
DLOG << "vkCreateImageView failed with error " << std::to_string(err);
|
DLOG(0) << "vkCreateImageView failed with error " << std::to_string(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1408,7 +1410,7 @@ void VulkanContext::Flush(bool all) {
|
||||||
vkQueueSubmit(graphics_queue_, 1, &submit_info, VK_NULL_HANDLE);
|
vkQueueSubmit(graphics_queue_, 1, &submit_info, VK_NULL_HANDLE);
|
||||||
command_buffers_[0] = nullptr;
|
command_buffers_[0] = nullptr;
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1443,16 +1445,16 @@ bool VulkanContext::PrepareBuffers() {
|
||||||
if (err == VK_ERROR_OUT_OF_DATE_KHR) {
|
if (err == VK_ERROR_OUT_OF_DATE_KHR) {
|
||||||
// swapchain is out of date (e.g. the window was resized) and must be
|
// swapchain is out of date (e.g. the window was resized) and must be
|
||||||
// recreated:
|
// recreated:
|
||||||
DLOG << "Swapchain is out of date, recreating.";
|
DLOG(0) << "Swapchain is out of date, recreating.";
|
||||||
UpdateSwapChain(&window_);
|
UpdateSwapChain(&window_);
|
||||||
} else if (err == VK_SUBOPTIMAL_KHR) {
|
} else if (err == VK_SUBOPTIMAL_KHR) {
|
||||||
// swapchain is not as optimal as it could be, but the platform's
|
// swapchain is not as optimal as it could be, but the platform's
|
||||||
// presentation engine will still present the image correctly.
|
// presentation engine will still present the image correctly.
|
||||||
DLOG << "Swapchain is suboptimal, recreating.";
|
DLOG(0) << "Swapchain is suboptimal, recreating.";
|
||||||
UpdateSwapChain(&window_);
|
UpdateSwapChain(&window_);
|
||||||
break;
|
break;
|
||||||
} else if (err != VK_SUCCESS) {
|
} else if (err != VK_SUCCESS) {
|
||||||
DLOG << "AcquireNextImageKHR failed. Error: " << string_VkResult(err);
|
DLOG(0) << "AcquireNextImageKHR failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} while (err != VK_SUCCESS);
|
} while (err != VK_SUCCESS);
|
||||||
|
@ -1489,7 +1491,7 @@ bool VulkanContext::SwapBuffers() {
|
||||||
submit_info.pSignalSemaphores = &draw_complete_semaphores_[frame_index_];
|
submit_info.pSignalSemaphores = &draw_complete_semaphores_[frame_index_];
|
||||||
err = vkQueueSubmit(graphics_queue_, 1, &submit_info, fences_[frame_index_]);
|
err = vkQueueSubmit(graphics_queue_, 1, &submit_info, fences_[frame_index_]);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1520,7 +1522,7 @@ bool VulkanContext::SwapBuffers() {
|
||||||
submit_info.pSignalSemaphores = &image_ownership_semaphores_[frame_index_];
|
submit_info.pSignalSemaphores = &image_ownership_semaphores_[frame_index_];
|
||||||
err = vkQueueSubmit(present_queue_, 1, &submit_info, null_fence);
|
err = vkQueueSubmit(present_queue_, 1, &submit_info, null_fence);
|
||||||
if (err) {
|
if (err) {
|
||||||
DLOG << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
DLOG(0) << "vkQueueSubmit failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1561,13 +1563,13 @@ bool VulkanContext::SwapBuffers() {
|
||||||
if (err == VK_ERROR_OUT_OF_DATE_KHR) {
|
if (err == VK_ERROR_OUT_OF_DATE_KHR) {
|
||||||
// Swapchain is out of date (e.g. the window was resized) and must be
|
// Swapchain is out of date (e.g. the window was resized) and must be
|
||||||
// recreated.
|
// recreated.
|
||||||
DLOG << "Swapchain is out of date.";
|
DLOG(0) << "Swapchain is out of date.";
|
||||||
} else if (err == VK_SUBOPTIMAL_KHR) {
|
} else if (err == VK_SUBOPTIMAL_KHR) {
|
||||||
// Swapchain is not as optimal as it could be, but the platform's
|
// Swapchain is not as optimal as it could be, but the platform's
|
||||||
// presentation engine will still present the image correctly.
|
// presentation engine will still present the image correctly.
|
||||||
DLOG << "Swapchain is Suboptimal.";
|
DLOG(0) << "Swapchain is Suboptimal.";
|
||||||
} else if (err) {
|
} else if (err) {
|
||||||
DLOG << "QueuePresentKHR failed. Error: " << string_VkResult(err);
|
DLOG(0) << "QueuePresentKHR failed. Error: " << string_VkResult(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@ bool VulkanContext::CreateWindow(ANativeWindow* window, int width, int height) {
|
||||||
VkResult err =
|
VkResult err =
|
||||||
vkCreateAndroidSurfaceKHR(instance_, &surface_info, nullptr, &surface);
|
vkCreateAndroidSurfaceKHR(instance_, &surface_info, nullptr, &surface);
|
||||||
if (err != VK_SUCCESS) {
|
if (err != VK_SUCCESS) {
|
||||||
LOG << "vkCreateAndroidSurfaceKHR failed with error "
|
LOG(0) << "vkCreateAndroidSurfaceKHR failed with error "
|
||||||
<< std::to_string(err);
|
<< std::to_string(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ bool VulkanContext::CreateWindow(Display* display,
|
||||||
VkResult err =
|
VkResult err =
|
||||||
vkCreateXlibSurfaceKHR(instance_, &surface_info, nullptr, &surface);
|
vkCreateXlibSurfaceKHR(instance_, &surface_info, nullptr, &surface);
|
||||||
if (err != VK_SUCCESS) {
|
if (err != VK_SUCCESS) {
|
||||||
LOG << "vkCreateAndroidSurfaceKHR failed with error "
|
LOG(0) << "vkCreateAndroidSurfaceKHR failed with error "
|
||||||
<< std::to_string(err);
|
<< std::to_string(err);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue